mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-08 14:13:53 +00:00
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6
* git://git.kernel.org/pub/scm/linux/kernel/git/davem/net-2.6: (56 commits) netns: Fix crash by making igmp per namespace bnx2x: Version update bnx2x: Checkpatch compliance bnx2x: Spelling mistakes bnx2x: Minor code improvements bnx2x: Driver info bnx2x: 1G LED does not turn off bnx2x: 8073 PHY changes bnx2x: Change GPIO for any port bnx2x: Pause settings bnx2x: Link order with external PHY bnx2x: No LRO without Rx checksum bnx2x: Wrong structure size bnx2x: WoL capability bnx2x: Clearing MAC addresses filters bnx2x: Delay in while loops bnx2x: PBA Table Page Alignment Workaround bnx2x: Self-test false positive bnx2x: Memory allocation bnx2x: HW attention lock ...
This commit is contained in:
commit
7a49efae71
@ -3076,6 +3076,7 @@ M: horms@verge.net.au
|
||||
P: Julian Anastasov
|
||||
M: ja@ssi.bg
|
||||
L: netdev@vger.kernel.org
|
||||
L: lvs-devel@vger.kernel.org
|
||||
S: Maintained
|
||||
|
||||
NFS, SUNRPC, AND LOCKD CLIENTS
|
||||
|
@ -40,20 +40,20 @@
|
||||
#define DP(__mask, __fmt, __args...) do { \
|
||||
if (bp->msglevel & (__mask)) \
|
||||
printk(DP_LEVEL "[%s:%d(%s)]" __fmt, __func__, __LINE__, \
|
||||
bp->dev?(bp->dev->name):"?", ##__args); \
|
||||
bp->dev ? (bp->dev->name) : "?", ##__args); \
|
||||
} while (0)
|
||||
|
||||
/* errors debug print */
|
||||
#define BNX2X_DBG_ERR(__fmt, __args...) do { \
|
||||
if (bp->msglevel & NETIF_MSG_PROBE) \
|
||||
printk(KERN_ERR "[%s:%d(%s)]" __fmt, __func__, __LINE__, \
|
||||
bp->dev?(bp->dev->name):"?", ##__args); \
|
||||
bp->dev ? (bp->dev->name) : "?", ##__args); \
|
||||
} while (0)
|
||||
|
||||
/* for errors (never masked) */
|
||||
#define BNX2X_ERR(__fmt, __args...) do { \
|
||||
printk(KERN_ERR "[%s:%d(%s)]" __fmt, __func__, __LINE__, \
|
||||
bp->dev?(bp->dev->name):"?", ##__args); \
|
||||
bp->dev ? (bp->dev->name) : "?", ##__args); \
|
||||
} while (0)
|
||||
|
||||
/* before we have a dev->name use dev_info() */
|
||||
@ -120,16 +120,8 @@
|
||||
#define SHMEM_RD(bp, field) REG_RD(bp, SHMEM_ADDR(bp, field))
|
||||
#define SHMEM_WR(bp, field, val) REG_WR(bp, SHMEM_ADDR(bp, field), val)
|
||||
|
||||
#define NIG_WR(reg, val) REG_WR(bp, reg, val)
|
||||
#define EMAC_WR(reg, val) REG_WR(bp, emac_base + reg, val)
|
||||
#define BMAC_WR(reg, val) REG_WR(bp, GRCBASE_NIG + bmac_addr + reg, val)
|
||||
|
||||
|
||||
#define for_each_queue(bp, var) for (var = 0; var < bp->num_queues; var++)
|
||||
|
||||
#define for_each_nondefault_queue(bp, var) \
|
||||
for (var = 1; var < bp->num_queues; var++)
|
||||
#define is_multi(bp) (bp->num_queues > 1)
|
||||
#define EMAC_RD(bp, reg) REG_RD(bp, emac_base + reg)
|
||||
#define EMAC_WR(bp, reg, val) REG_WR(bp, emac_base + reg, val)
|
||||
|
||||
|
||||
/* fast path */
|
||||
@ -163,7 +155,7 @@ struct sw_rx_page {
|
||||
#define NUM_RX_SGE_PAGES 2
|
||||
#define RX_SGE_CNT (BCM_PAGE_SIZE / sizeof(struct eth_rx_sge))
|
||||
#define MAX_RX_SGE_CNT (RX_SGE_CNT - 2)
|
||||
/* RX_SGE_CNT is promissed to be a power of 2 */
|
||||
/* RX_SGE_CNT is promised to be a power of 2 */
|
||||
#define RX_SGE_MASK (RX_SGE_CNT - 1)
|
||||
#define NUM_RX_SGE (RX_SGE_CNT * NUM_RX_SGE_PAGES)
|
||||
#define MAX_RX_SGE (NUM_RX_SGE - 1)
|
||||
@ -258,8 +250,7 @@ struct bnx2x_fastpath {
|
||||
|
||||
unsigned long tx_pkt,
|
||||
rx_pkt,
|
||||
rx_calls,
|
||||
rx_alloc_failed;
|
||||
rx_calls;
|
||||
/* TPA related */
|
||||
struct sw_rx_bd tpa_pool[ETH_MAX_AGGREGATION_QUEUES_E1H];
|
||||
u8 tpa_state[ETH_MAX_AGGREGATION_QUEUES_E1H];
|
||||
@ -275,6 +266,15 @@ struct bnx2x_fastpath {
|
||||
|
||||
#define bnx2x_fp(bp, nr, var) (bp->fp[nr].var)
|
||||
|
||||
#define BNX2X_HAS_TX_WORK(fp) \
|
||||
((fp->tx_pkt_prod != le16_to_cpu(*fp->tx_cons_sb)) || \
|
||||
(fp->tx_pkt_prod != fp->tx_pkt_cons))
|
||||
|
||||
#define BNX2X_HAS_RX_WORK(fp) \
|
||||
(fp->rx_comp_cons != le16_to_cpu(*fp->rx_cons_sb))
|
||||
|
||||
#define BNX2X_HAS_WORK(fp) (BNX2X_HAS_RX_WORK(fp) || BNX2X_HAS_TX_WORK(fp))
|
||||
|
||||
|
||||
/* MC hsi */
|
||||
#define MAX_FETCH_BD 13 /* HW max BDs per packet */
|
||||
@ -317,7 +317,7 @@ struct bnx2x_fastpath {
|
||||
#define RCQ_BD(x) ((x) & MAX_RCQ_BD)
|
||||
|
||||
|
||||
/* This is needed for determening of last_max */
|
||||
/* This is needed for determining of last_max */
|
||||
#define SUB_S16(a, b) (s16)((s16)(a) - (s16)(b))
|
||||
|
||||
#define __SGE_MASK_SET_BIT(el, bit) \
|
||||
@ -386,20 +386,28 @@ struct bnx2x_fastpath {
|
||||
#define TPA_TYPE(cqe_fp_flags) ((cqe_fp_flags) & \
|
||||
(TPA_TYPE_START | TPA_TYPE_END))
|
||||
|
||||
#define BNX2X_RX_SUM_OK(cqe) \
|
||||
(!(cqe->fast_path_cqe.status_flags & \
|
||||
(ETH_FAST_PATH_RX_CQE_IP_XSUM_NO_VALIDATION_FLG | \
|
||||
ETH_FAST_PATH_RX_CQE_L4_XSUM_NO_VALIDATION_FLG)))
|
||||
#define ETH_RX_ERROR_FALGS ETH_FAST_PATH_RX_CQE_PHY_DECODE_ERR_FLG
|
||||
|
||||
#define BNX2X_IP_CSUM_ERR(cqe) \
|
||||
(!((cqe)->fast_path_cqe.status_flags & \
|
||||
ETH_FAST_PATH_RX_CQE_IP_XSUM_NO_VALIDATION_FLG) && \
|
||||
((cqe)->fast_path_cqe.type_error_flags & \
|
||||
ETH_FAST_PATH_RX_CQE_IP_BAD_XSUM_FLG))
|
||||
|
||||
#define BNX2X_L4_CSUM_ERR(cqe) \
|
||||
(!((cqe)->fast_path_cqe.status_flags & \
|
||||
ETH_FAST_PATH_RX_CQE_L4_XSUM_NO_VALIDATION_FLG) && \
|
||||
((cqe)->fast_path_cqe.type_error_flags & \
|
||||
ETH_FAST_PATH_RX_CQE_L4_BAD_XSUM_FLG))
|
||||
|
||||
#define BNX2X_RX_CSUM_OK(cqe) \
|
||||
(!(BNX2X_L4_CSUM_ERR(cqe) || BNX2X_IP_CSUM_ERR(cqe)))
|
||||
|
||||
#define BNX2X_RX_SUM_FIX(cqe) \
|
||||
((le16_to_cpu(cqe->fast_path_cqe.pars_flags.flags) & \
|
||||
PARSING_FLAGS_OVER_ETHERNET_PROTOCOL) == \
|
||||
(1 << PARSING_FLAGS_OVER_ETHERNET_PROTOCOL_SHIFT))
|
||||
|
||||
#define ETH_RX_ERROR_FALGS (ETH_FAST_PATH_RX_CQE_PHY_DECODE_ERR_FLG | \
|
||||
ETH_FAST_PATH_RX_CQE_IP_BAD_XSUM_FLG | \
|
||||
ETH_FAST_PATH_RX_CQE_L4_BAD_XSUM_FLG)
|
||||
|
||||
|
||||
#define FP_USB_FUNC_OFF (2 + 2*HC_USTORM_SB_NUM_INDICES)
|
||||
#define FP_CSB_FUNC_OFF (2 + 2*HC_CSTORM_SB_NUM_INDICES)
|
||||
@ -647,6 +655,8 @@ struct bnx2x_eth_stats {
|
||||
|
||||
u32 brb_drop_hi;
|
||||
u32 brb_drop_lo;
|
||||
u32 brb_truncate_hi;
|
||||
u32 brb_truncate_lo;
|
||||
|
||||
u32 jabber_packets_received;
|
||||
|
||||
@ -663,6 +673,9 @@ struct bnx2x_eth_stats {
|
||||
u32 mac_discard;
|
||||
|
||||
u32 driver_xoff;
|
||||
u32 rx_err_discard_pkt;
|
||||
u32 rx_skb_alloc_failed;
|
||||
u32 hw_csum_err;
|
||||
};
|
||||
|
||||
#define STATS_OFFSET32(stat_name) \
|
||||
@ -753,7 +766,6 @@ struct bnx2x {
|
||||
u16 def_att_idx;
|
||||
u32 attn_state;
|
||||
struct attn_route attn_group[MAX_DYNAMIC_ATTN_GRPS];
|
||||
u32 aeu_mask;
|
||||
u32 nig_mask;
|
||||
|
||||
/* slow path ring */
|
||||
@ -772,7 +784,7 @@ struct bnx2x {
|
||||
u8 stats_pending;
|
||||
u8 set_mac_pending;
|
||||
|
||||
/* End of fileds used in the performance code paths */
|
||||
/* End of fields used in the performance code paths */
|
||||
|
||||
int panic;
|
||||
int msglevel;
|
||||
@ -794,9 +806,6 @@ struct bnx2x {
|
||||
#define BP_FUNC(bp) (bp->func)
|
||||
#define BP_E1HVN(bp) (bp->func >> 1)
|
||||
#define BP_L_ID(bp) (BP_E1HVN(bp) << 2)
|
||||
/* assorted E1HVN */
|
||||
#define IS_E1HMF(bp) (bp->e1hmf != 0)
|
||||
#define BP_MAX_QUEUES(bp) (IS_E1HMF(bp) ? 4 : 16)
|
||||
|
||||
int pm_cap;
|
||||
int pcie_cap;
|
||||
@ -821,6 +830,7 @@ struct bnx2x {
|
||||
u32 mf_config;
|
||||
u16 e1hov;
|
||||
u8 e1hmf;
|
||||
#define IS_E1HMF(bp) (bp->e1hmf != 0)
|
||||
|
||||
u8 wol;
|
||||
|
||||
@ -836,7 +846,6 @@ struct bnx2x {
|
||||
u16 rx_ticks_int;
|
||||
u16 rx_ticks;
|
||||
|
||||
u32 stats_ticks;
|
||||
u32 lin_cnt;
|
||||
|
||||
int state;
|
||||
@ -852,6 +861,7 @@ struct bnx2x {
|
||||
#define BNX2X_STATE_ERROR 0xf000
|
||||
|
||||
int num_queues;
|
||||
#define BP_MAX_QUEUES(bp) (IS_E1HMF(bp) ? 4 : 16)
|
||||
|
||||
u32 rx_mode;
|
||||
#define BNX2X_RX_MODE_NONE 0
|
||||
@ -902,10 +912,17 @@ struct bnx2x {
|
||||
};
|
||||
|
||||
|
||||
#define for_each_queue(bp, var) for (var = 0; var < bp->num_queues; var++)
|
||||
|
||||
#define for_each_nondefault_queue(bp, var) \
|
||||
for (var = 1; var < bp->num_queues; var++)
|
||||
#define is_multi(bp) (bp->num_queues > 1)
|
||||
|
||||
|
||||
void bnx2x_read_dmae(struct bnx2x *bp, u32 src_addr, u32 len32);
|
||||
void bnx2x_write_dmae(struct bnx2x *bp, dma_addr_t dma_addr, u32 dst_addr,
|
||||
u32 len32);
|
||||
int bnx2x_set_gpio(struct bnx2x *bp, int gpio_num, u32 mode);
|
||||
int bnx2x_set_gpio(struct bnx2x *bp, int gpio_num, u32 mode, u8 port);
|
||||
|
||||
static inline u32 reg_poll(struct bnx2x *bp, u32 reg, u32 expected, int ms,
|
||||
int wait)
|
||||
@ -976,7 +993,7 @@ static inline u32 reg_poll(struct bnx2x *bp, u32 reg, u32 expected, int ms,
|
||||
#define PCICFG_LINK_SPEED_SHIFT 16
|
||||
|
||||
|
||||
#define BNX2X_NUM_STATS 39
|
||||
#define BNX2X_NUM_STATS 42
|
||||
#define BNX2X_NUM_TESTS 8
|
||||
|
||||
#define BNX2X_MAC_LOOPBACK 0
|
||||
@ -1007,10 +1024,10 @@ static inline u32 reg_poll(struct bnx2x *bp, u32 reg, u32 expected, int ms,
|
||||
/* resolution of the rate shaping timer - 100 usec */
|
||||
#define RS_PERIODIC_TIMEOUT_USEC 100
|
||||
/* resolution of fairness algorithm in usecs -
|
||||
coefficient for clauclating the actuall t fair */
|
||||
coefficient for calculating the actual t fair */
|
||||
#define T_FAIR_COEF 10000000
|
||||
/* number of bytes in single QM arbitration cycle -
|
||||
coeffiecnt for calculating the fairness timer */
|
||||
coefficient for calculating the fairness timer */
|
||||
#define QM_ARB_BYTES 40000
|
||||
#define FAIR_MEM 2
|
||||
|
||||
|
@ -9,165 +9,171 @@
|
||||
|
||||
|
||||
#define CSTORM_ASSERT_LIST_INDEX_OFFSET \
|
||||
(IS_E1H_OFFSET? 0x7000 : 0x1000)
|
||||
(IS_E1H_OFFSET ? 0x7000 : 0x1000)
|
||||
#define CSTORM_ASSERT_LIST_OFFSET(idx) \
|
||||
(IS_E1H_OFFSET? (0x7020 + (idx * 0x10)) : (0x1020 + (idx * 0x10)))
|
||||
(IS_E1H_OFFSET ? (0x7020 + (idx * 0x10)) : (0x1020 + (idx * 0x10)))
|
||||
#define CSTORM_DEF_SB_HC_DISABLE_OFFSET(function, index) \
|
||||
(IS_E1H_OFFSET? (0x8522 + ((function>>1) * 0x40) + ((function&1) \
|
||||
* 0x100) + (index * 0x4)) : (0x1922 + (function * 0x40) + (index \
|
||||
* 0x4)))
|
||||
(IS_E1H_OFFSET ? (0x8522 + ((function>>1) * 0x40) + \
|
||||
((function&1) * 0x100) + (index * 0x4)) : (0x1922 + (function * \
|
||||
0x40) + (index * 0x4)))
|
||||
#define CSTORM_DEF_SB_HOST_SB_ADDR_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0x8500 + ((function>>1) * 0x40) + ((function&1) \
|
||||
* 0x100)) : (0x1900 + (function * 0x40)))
|
||||
(IS_E1H_OFFSET ? (0x8500 + ((function>>1) * 0x40) + \
|
||||
((function&1) * 0x100)) : (0x1900 + (function * 0x40)))
|
||||
#define CSTORM_DEF_SB_HOST_STATUS_BLOCK_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0x8508 + ((function>>1) * 0x40) + ((function&1) \
|
||||
* 0x100)) : (0x1908 + (function * 0x40)))
|
||||
(IS_E1H_OFFSET ? (0x8508 + ((function>>1) * 0x40) + \
|
||||
((function&1) * 0x100)) : (0x1908 + (function * 0x40)))
|
||||
#define CSTORM_FUNCTION_MODE_OFFSET \
|
||||
(IS_E1H_OFFSET? 0x11e8 : 0xffffffff)
|
||||
(IS_E1H_OFFSET ? 0x11e8 : 0xffffffff)
|
||||
#define CSTORM_HC_BTR_OFFSET(port) \
|
||||
(IS_E1H_OFFSET? (0x8704 + (port * 0xf0)) : (0x1984 + (port * 0xc0)))
|
||||
(IS_E1H_OFFSET ? (0x8704 + (port * 0xf0)) : (0x1984 + (port * 0xc0)))
|
||||
#define CSTORM_SB_HC_DISABLE_OFFSET(port, cpu_id, index) \
|
||||
(IS_E1H_OFFSET? (0x801a + (port * 0x280) + (cpu_id * 0x28) + \
|
||||
(IS_E1H_OFFSET ? (0x801a + (port * 0x280) + (cpu_id * 0x28) + \
|
||||
(index * 0x4)) : (0x141a + (port * 0x280) + (cpu_id * 0x28) + \
|
||||
(index * 0x4)))
|
||||
#define CSTORM_SB_HC_TIMEOUT_OFFSET(port, cpu_id, index) \
|
||||
(IS_E1H_OFFSET? (0x8018 + (port * 0x280) + (cpu_id * 0x28) + \
|
||||
(IS_E1H_OFFSET ? (0x8018 + (port * 0x280) + (cpu_id * 0x28) + \
|
||||
(index * 0x4)) : (0x1418 + (port * 0x280) + (cpu_id * 0x28) + \
|
||||
(index * 0x4)))
|
||||
#define CSTORM_SB_HOST_SB_ADDR_OFFSET(port, cpu_id) \
|
||||
(IS_E1H_OFFSET? (0x8000 + (port * 0x280) + (cpu_id * 0x28)) : \
|
||||
(IS_E1H_OFFSET ? (0x8000 + (port * 0x280) + (cpu_id * 0x28)) : \
|
||||
(0x1400 + (port * 0x280) + (cpu_id * 0x28)))
|
||||
#define CSTORM_SB_HOST_STATUS_BLOCK_OFFSET(port, cpu_id) \
|
||||
(IS_E1H_OFFSET? (0x8008 + (port * 0x280) + (cpu_id * 0x28)) : \
|
||||
(IS_E1H_OFFSET ? (0x8008 + (port * 0x280) + (cpu_id * 0x28)) : \
|
||||
(0x1408 + (port * 0x280) + (cpu_id * 0x28)))
|
||||
#define CSTORM_STATS_FLAGS_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0x1108 + (function * 0x8)) : (0x5108 + \
|
||||
(IS_E1H_OFFSET ? (0x1108 + (function * 0x8)) : (0x5108 + \
|
||||
(function * 0x8)))
|
||||
#define TSTORM_APPROXIMATE_MATCH_MULTICAST_FILTERING_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0x31c0 + (function * 0x20)) : 0xffffffff)
|
||||
(IS_E1H_OFFSET ? (0x31c0 + (function * 0x20)) : 0xffffffff)
|
||||
#define TSTORM_ASSERT_LIST_INDEX_OFFSET \
|
||||
(IS_E1H_OFFSET? 0xa000 : 0x1000)
|
||||
(IS_E1H_OFFSET ? 0xa000 : 0x1000)
|
||||
#define TSTORM_ASSERT_LIST_OFFSET(idx) \
|
||||
(IS_E1H_OFFSET? (0xa020 + (idx * 0x10)) : (0x1020 + (idx * 0x10)))
|
||||
(IS_E1H_OFFSET ? (0xa020 + (idx * 0x10)) : (0x1020 + (idx * 0x10)))
|
||||
#define TSTORM_CLIENT_CONFIG_OFFSET(port, client_id) \
|
||||
(IS_E1H_OFFSET? (0x3358 + (port * 0x3e8) + (client_id * 0x28)) : \
|
||||
(0x9c8 + (port * 0x2f8) + (client_id * 0x28)))
|
||||
(IS_E1H_OFFSET ? (0x3358 + (port * 0x3e8) + (client_id * 0x28)) \
|
||||
: (0x9c8 + (port * 0x2f8) + (client_id * 0x28)))
|
||||
#define TSTORM_DEF_SB_HC_DISABLE_OFFSET(function, index) \
|
||||
(IS_E1H_OFFSET? (0xb01a + ((function>>1) * 0x28) + ((function&1) \
|
||||
* 0xa0) + (index * 0x4)) : (0x141a + (function * 0x28) + (index * \
|
||||
0x4)))
|
||||
(IS_E1H_OFFSET ? (0xb01a + ((function>>1) * 0x28) + \
|
||||
((function&1) * 0xa0) + (index * 0x4)) : (0x141a + (function * \
|
||||
0x28) + (index * 0x4)))
|
||||
#define TSTORM_DEF_SB_HOST_SB_ADDR_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0xb000 + ((function>>1) * 0x28) + ((function&1) \
|
||||
* 0xa0)) : (0x1400 + (function * 0x28)))
|
||||
(IS_E1H_OFFSET ? (0xb000 + ((function>>1) * 0x28) + \
|
||||
((function&1) * 0xa0)) : (0x1400 + (function * 0x28)))
|
||||
#define TSTORM_DEF_SB_HOST_STATUS_BLOCK_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0xb008 + ((function>>1) * 0x28) + ((function&1) \
|
||||
* 0xa0)) : (0x1408 + (function * 0x28)))
|
||||
(IS_E1H_OFFSET ? (0xb008 + ((function>>1) * 0x28) + \
|
||||
((function&1) * 0xa0)) : (0x1408 + (function * 0x28)))
|
||||
#define TSTORM_ETH_STATS_QUERY_ADDR_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0x2b80 + (function * 0x8)) : (0x4b68 + \
|
||||
(IS_E1H_OFFSET ? (0x2b80 + (function * 0x8)) : (0x4b68 + \
|
||||
(function * 0x8)))
|
||||
#define TSTORM_FUNCTION_COMMON_CONFIG_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0x3000 + (function * 0x38)) : (0x1500 + \
|
||||
(IS_E1H_OFFSET ? (0x3000 + (function * 0x38)) : (0x1500 + \
|
||||
(function * 0x38)))
|
||||
#define TSTORM_FUNCTION_MODE_OFFSET \
|
||||
(IS_E1H_OFFSET? 0x1ad0 : 0xffffffff)
|
||||
(IS_E1H_OFFSET ? 0x1ad0 : 0xffffffff)
|
||||
#define TSTORM_HC_BTR_OFFSET(port) \
|
||||
(IS_E1H_OFFSET? (0xb144 + (port * 0x30)) : (0x1454 + (port * 0x18)))
|
||||
(IS_E1H_OFFSET ? (0xb144 + (port * 0x30)) : (0x1454 + (port * 0x18)))
|
||||
#define TSTORM_INDIRECTION_TABLE_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0x12c8 + (function * 0x80)) : (0x22c8 + \
|
||||
(IS_E1H_OFFSET ? (0x12c8 + (function * 0x80)) : (0x22c8 + \
|
||||
(function * 0x80)))
|
||||
#define TSTORM_INDIRECTION_TABLE_SIZE 0x80
|
||||
#define TSTORM_MAC_FILTER_CONFIG_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0x3008 + (function * 0x38)) : (0x1508 + \
|
||||
(IS_E1H_OFFSET ? (0x3008 + (function * 0x38)) : (0x1508 + \
|
||||
(function * 0x38)))
|
||||
#define TSTORM_PER_COUNTER_ID_STATS_OFFSET(port, stats_counter_id) \
|
||||
(IS_E1H_OFFSET ? (0x2010 + (port * 0x5b0) + (stats_counter_id * \
|
||||
0x50)) : (0x4000 + (port * 0x3f0) + (stats_counter_id * 0x38)))
|
||||
#define TSTORM_RX_PRODS_OFFSET(port, client_id) \
|
||||
(IS_E1H_OFFSET? (0x3350 + (port * 0x3e8) + (client_id * 0x28)) : \
|
||||
(0x9c0 + (port * 0x2f8) + (client_id * 0x28)))
|
||||
(IS_E1H_OFFSET ? (0x3350 + (port * 0x3e8) + (client_id * 0x28)) \
|
||||
: (0x9c0 + (port * 0x2f8) + (client_id * 0x28)))
|
||||
#define TSTORM_STATS_FLAGS_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0x2c00 + (function * 0x8)) : (0x4b88 + \
|
||||
(IS_E1H_OFFSET ? (0x2c00 + (function * 0x8)) : (0x4b88 + \
|
||||
(function * 0x8)))
|
||||
#define TSTORM_TPA_EXIST_OFFSET (IS_E1H_OFFSET? 0x3b30 : 0x1c20)
|
||||
#define USTORM_AGG_DATA_OFFSET (IS_E1H_OFFSET? 0xa040 : 0x2c10)
|
||||
#define USTORM_AGG_DATA_SIZE (IS_E1H_OFFSET? 0x2440 : 0x1200)
|
||||
#define TSTORM_TPA_EXIST_OFFSET (IS_E1H_OFFSET ? 0x3b30 : 0x1c20)
|
||||
#define USTORM_AGG_DATA_OFFSET (IS_E1H_OFFSET ? 0xa040 : 0x2c10)
|
||||
#define USTORM_AGG_DATA_SIZE (IS_E1H_OFFSET ? 0x2440 : 0x1200)
|
||||
#define USTORM_ASSERT_LIST_INDEX_OFFSET \
|
||||
(IS_E1H_OFFSET? 0x8000 : 0x1000)
|
||||
(IS_E1H_OFFSET ? 0x8000 : 0x1000)
|
||||
#define USTORM_ASSERT_LIST_OFFSET(idx) \
|
||||
(IS_E1H_OFFSET? (0x8020 + (idx * 0x10)) : (0x1020 + (idx * 0x10)))
|
||||
(IS_E1H_OFFSET ? (0x8020 + (idx * 0x10)) : (0x1020 + (idx * 0x10)))
|
||||
#define USTORM_CQE_PAGE_BASE_OFFSET(port, clientId) \
|
||||
(IS_E1H_OFFSET? (0x3298 + (port * 0x258) + (clientId * 0x18)) : \
|
||||
(IS_E1H_OFFSET ? (0x3298 + (port * 0x258) + (clientId * 0x18)) : \
|
||||
(0x5450 + (port * 0x1c8) + (clientId * 0x18)))
|
||||
#define USTORM_DEF_SB_HC_DISABLE_OFFSET(function, index) \
|
||||
(IS_E1H_OFFSET? (0x951a + ((function>>1) * 0x28) + ((function&1) \
|
||||
* 0xa0) + (index * 0x4)) : (0x191a + (function * 0x28) + (index * \
|
||||
0x4)))
|
||||
(IS_E1H_OFFSET ? (0x951a + ((function>>1) * 0x28) + \
|
||||
((function&1) * 0xa0) + (index * 0x4)) : (0x191a + (function * \
|
||||
0x28) + (index * 0x4)))
|
||||
#define USTORM_DEF_SB_HOST_SB_ADDR_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0x9500 + ((function>>1) * 0x28) + ((function&1) \
|
||||
* 0xa0)) : (0x1900 + (function * 0x28)))
|
||||
(IS_E1H_OFFSET ? (0x9500 + ((function>>1) * 0x28) + \
|
||||
((function&1) * 0xa0)) : (0x1900 + (function * 0x28)))
|
||||
#define USTORM_DEF_SB_HOST_STATUS_BLOCK_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0x9508 + ((function>>1) * 0x28) + ((function&1) \
|
||||
* 0xa0)) : (0x1908 + (function * 0x28)))
|
||||
(IS_E1H_OFFSET ? (0x9508 + ((function>>1) * 0x28) + \
|
||||
((function&1) * 0xa0)) : (0x1908 + (function * 0x28)))
|
||||
#define USTORM_FUNCTION_MODE_OFFSET \
|
||||
(IS_E1H_OFFSET? 0x2448 : 0xffffffff)
|
||||
(IS_E1H_OFFSET ? 0x2448 : 0xffffffff)
|
||||
#define USTORM_HC_BTR_OFFSET(port) \
|
||||
(IS_E1H_OFFSET? (0x9644 + (port * 0xd0)) : (0x1954 + (port * 0xb8)))
|
||||
(IS_E1H_OFFSET ? (0x9644 + (port * 0xd0)) : (0x1954 + (port * 0xb8)))
|
||||
#define USTORM_MAX_AGG_SIZE_OFFSET(port, clientId) \
|
||||
(IS_E1H_OFFSET? (0x3290 + (port * 0x258) + (clientId * 0x18)) : \
|
||||
(IS_E1H_OFFSET ? (0x3290 + (port * 0x258) + (clientId * 0x18)) : \
|
||||
(0x5448 + (port * 0x1c8) + (clientId * 0x18)))
|
||||
#define USTORM_MEM_WORKAROUND_ADDRESS_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0x2408 + (function * 0x8)) : (0x5408 + \
|
||||
(IS_E1H_OFFSET ? (0x2408 + (function * 0x8)) : (0x5408 + \
|
||||
(function * 0x8)))
|
||||
#define USTORM_SB_HC_DISABLE_OFFSET(port, cpu_id, index) \
|
||||
(IS_E1H_OFFSET? (0x901a + (port * 0x280) + (cpu_id * 0x28) + \
|
||||
(IS_E1H_OFFSET ? (0x901a + (port * 0x280) + (cpu_id * 0x28) + \
|
||||
(index * 0x4)) : (0x141a + (port * 0x280) + (cpu_id * 0x28) + \
|
||||
(index * 0x4)))
|
||||
#define USTORM_SB_HC_TIMEOUT_OFFSET(port, cpu_id, index) \
|
||||
(IS_E1H_OFFSET? (0x9018 + (port * 0x280) + (cpu_id * 0x28) + \
|
||||
(IS_E1H_OFFSET ? (0x9018 + (port * 0x280) + (cpu_id * 0x28) + \
|
||||
(index * 0x4)) : (0x1418 + (port * 0x280) + (cpu_id * 0x28) + \
|
||||
(index * 0x4)))
|
||||
#define USTORM_SB_HOST_SB_ADDR_OFFSET(port, cpu_id) \
|
||||
(IS_E1H_OFFSET? (0x9000 + (port * 0x280) + (cpu_id * 0x28)) : \
|
||||
(IS_E1H_OFFSET ? (0x9000 + (port * 0x280) + (cpu_id * 0x28)) : \
|
||||
(0x1400 + (port * 0x280) + (cpu_id * 0x28)))
|
||||
#define USTORM_SB_HOST_STATUS_BLOCK_OFFSET(port, cpu_id) \
|
||||
(IS_E1H_OFFSET? (0x9008 + (port * 0x280) + (cpu_id * 0x28)) : \
|
||||
(IS_E1H_OFFSET ? (0x9008 + (port * 0x280) + (cpu_id * 0x28)) : \
|
||||
(0x1408 + (port * 0x280) + (cpu_id * 0x28)))
|
||||
#define XSTORM_ASSERT_LIST_INDEX_OFFSET \
|
||||
(IS_E1H_OFFSET? 0x9000 : 0x1000)
|
||||
(IS_E1H_OFFSET ? 0x9000 : 0x1000)
|
||||
#define XSTORM_ASSERT_LIST_OFFSET(idx) \
|
||||
(IS_E1H_OFFSET? (0x9020 + (idx * 0x10)) : (0x1020 + (idx * 0x10)))
|
||||
(IS_E1H_OFFSET ? (0x9020 + (idx * 0x10)) : (0x1020 + (idx * 0x10)))
|
||||
#define XSTORM_CMNG_PER_PORT_VARS_OFFSET(port) \
|
||||
(IS_E1H_OFFSET? (0x24a8 + (port * 0x40)) : (0x3ba0 + (port * 0x40)))
|
||||
(IS_E1H_OFFSET ? (0x24a8 + (port * 0x40)) : (0x3ba0 + (port * 0x40)))
|
||||
#define XSTORM_DEF_SB_HC_DISABLE_OFFSET(function, index) \
|
||||
(IS_E1H_OFFSET? (0xa01a + ((function>>1) * 0x28) + ((function&1) \
|
||||
* 0xa0) + (index * 0x4)) : (0x141a + (function * 0x28) + (index * \
|
||||
0x4)))
|
||||
(IS_E1H_OFFSET ? (0xa01a + ((function>>1) * 0x28) + \
|
||||
((function&1) * 0xa0) + (index * 0x4)) : (0x141a + (function * \
|
||||
0x28) + (index * 0x4)))
|
||||
#define XSTORM_DEF_SB_HOST_SB_ADDR_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0xa000 + ((function>>1) * 0x28) + ((function&1) \
|
||||
* 0xa0)) : (0x1400 + (function * 0x28)))
|
||||
(IS_E1H_OFFSET ? (0xa000 + ((function>>1) * 0x28) + \
|
||||
((function&1) * 0xa0)) : (0x1400 + (function * 0x28)))
|
||||
#define XSTORM_DEF_SB_HOST_STATUS_BLOCK_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0xa008 + ((function>>1) * 0x28) + ((function&1) \
|
||||
* 0xa0)) : (0x1408 + (function * 0x28)))
|
||||
(IS_E1H_OFFSET ? (0xa008 + ((function>>1) * 0x28) + \
|
||||
((function&1) * 0xa0)) : (0x1408 + (function * 0x28)))
|
||||
#define XSTORM_E1HOV_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0x2ab8 + (function * 0x2)) : 0xffffffff)
|
||||
(IS_E1H_OFFSET ? (0x2ab8 + (function * 0x2)) : 0xffffffff)
|
||||
#define XSTORM_ETH_STATS_QUERY_ADDR_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0x2418 + (function * 0x8)) : (0x3b70 + \
|
||||
(IS_E1H_OFFSET ? (0x2418 + (function * 0x8)) : (0x3b70 + \
|
||||
(function * 0x8)))
|
||||
#define XSTORM_FAIRNESS_PER_VN_VARS_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0x2568 + (function * 0x70)) : (0x3c60 + \
|
||||
(IS_E1H_OFFSET ? (0x2568 + (function * 0x70)) : (0x3c60 + \
|
||||
(function * 0x70)))
|
||||
#define XSTORM_FUNCTION_MODE_OFFSET \
|
||||
(IS_E1H_OFFSET? 0x2ac8 : 0xffffffff)
|
||||
(IS_E1H_OFFSET ? 0x2ac8 : 0xffffffff)
|
||||
#define XSTORM_HC_BTR_OFFSET(port) \
|
||||
(IS_E1H_OFFSET? (0xa144 + (port * 0x30)) : (0x1454 + (port * 0x18)))
|
||||
(IS_E1H_OFFSET ? (0xa144 + (port * 0x30)) : (0x1454 + (port * 0x18)))
|
||||
#define XSTORM_PER_COUNTER_ID_STATS_OFFSET(port, stats_counter_id) \
|
||||
(IS_E1H_OFFSET ? (0xc000 + (port * 0x3f0) + (stats_counter_id * \
|
||||
0x38)) : (0x3378 + (port * 0x3f0) + (stats_counter_id * 0x38)))
|
||||
#define XSTORM_RATE_SHAPING_PER_VN_VARS_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0x2528 + (function * 0x70)) : (0x3c20 + \
|
||||
(IS_E1H_OFFSET ? (0x2528 + (function * 0x70)) : (0x3c20 + \
|
||||
(function * 0x70)))
|
||||
#define XSTORM_SPQ_PAGE_BASE_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0x2000 + (function * 0x10)) : (0x3328 + \
|
||||
(IS_E1H_OFFSET ? (0x2000 + (function * 0x10)) : (0x3328 + \
|
||||
(function * 0x10)))
|
||||
#define XSTORM_SPQ_PROD_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0x2008 + (function * 0x10)) : (0x3330 + \
|
||||
(IS_E1H_OFFSET ? (0x2008 + (function * 0x10)) : (0x3330 + \
|
||||
(function * 0x10)))
|
||||
#define XSTORM_STATS_FLAGS_OFFSET(function) \
|
||||
(IS_E1H_OFFSET? (0x23d8 + (function * 0x8)) : (0x3b60 + \
|
||||
(IS_E1H_OFFSET ? (0x23d8 + (function * 0x8)) : (0x3b60 + \
|
||||
(function * 0x8)))
|
||||
#define COMMON_ASM_INVALID_ASSERT_OPCODE 0x0
|
||||
|
||||
|
@ -1268,7 +1268,7 @@ struct doorbell {
|
||||
|
||||
|
||||
/*
|
||||
* IGU driver acknowlegement register
|
||||
* IGU driver acknowledgement register
|
||||
*/
|
||||
struct igu_ack_register {
|
||||
#if defined(__BIG_ENDIAN)
|
||||
@ -1882,7 +1882,7 @@ struct timers_block_context {
|
||||
};
|
||||
|
||||
/*
|
||||
* structure for easy accessability to assembler
|
||||
* structure for easy accessibility to assembler
|
||||
*/
|
||||
struct eth_tx_bd_flags {
|
||||
u8 as_bitfield;
|
||||
@ -2044,7 +2044,7 @@ struct eth_context {
|
||||
|
||||
|
||||
/*
|
||||
* ethernet doorbell
|
||||
* Ethernet doorbell
|
||||
*/
|
||||
struct eth_tx_doorbell {
|
||||
#if defined(__BIG_ENDIAN)
|
||||
@ -2256,7 +2256,7 @@ struct ramrod_data {
|
||||
};
|
||||
|
||||
/*
|
||||
* union for ramrod data for ethernet protocol (CQE) (force size of 16 bits)
|
||||
* union for ramrod data for Ethernet protocol (CQE) (force size of 16 bits)
|
||||
*/
|
||||
union eth_ramrod_data {
|
||||
struct ramrod_data general;
|
||||
@ -2330,7 +2330,7 @@ struct spe_hdr {
|
||||
};
|
||||
|
||||
/*
|
||||
* ethernet slow path element
|
||||
* Ethernet slow path element
|
||||
*/
|
||||
union eth_specific_data {
|
||||
u8 protocol_data[8];
|
||||
@ -2343,7 +2343,7 @@ union eth_specific_data {
|
||||
};
|
||||
|
||||
/*
|
||||
* ethernet slow path element
|
||||
* Ethernet slow path element
|
||||
*/
|
||||
struct eth_spe {
|
||||
struct spe_hdr hdr;
|
||||
@ -2615,7 +2615,7 @@ struct tstorm_eth_rx_producers {
|
||||
|
||||
|
||||
/*
|
||||
* common flag to indicate existance of TPA.
|
||||
* common flag to indicate existence of TPA.
|
||||
*/
|
||||
struct tstorm_eth_tpa_exist {
|
||||
#if defined(__BIG_ENDIAN)
|
||||
@ -2765,7 +2765,7 @@ struct tstorm_common_stats {
|
||||
};
|
||||
|
||||
/*
|
||||
* Eth statistics query sturcture for the eth_stats_quesry ramrod
|
||||
* Eth statistics query structure for the eth_stats_query ramrod
|
||||
*/
|
||||
struct eth_stats_query {
|
||||
struct xstorm_common_stats xstorm_common;
|
||||
|
@ -72,26 +72,26 @@
|
||||
|
||||
|
||||
struct raw_op {
|
||||
u32 op :8;
|
||||
u32 offset :24;
|
||||
u32 op:8;
|
||||
u32 offset:24;
|
||||
u32 raw_data;
|
||||
};
|
||||
|
||||
struct op_read {
|
||||
u32 op :8;
|
||||
u32 offset :24;
|
||||
u32 op:8;
|
||||
u32 offset:24;
|
||||
u32 pad;
|
||||
};
|
||||
|
||||
struct op_write {
|
||||
u32 op :8;
|
||||
u32 offset :24;
|
||||
u32 op:8;
|
||||
u32 offset:24;
|
||||
u32 val;
|
||||
};
|
||||
|
||||
struct op_string_write {
|
||||
u32 op :8;
|
||||
u32 offset :24;
|
||||
u32 op:8;
|
||||
u32 offset:24;
|
||||
#ifdef __LITTLE_ENDIAN
|
||||
u16 data_off;
|
||||
u16 data_len;
|
||||
@ -102,8 +102,8 @@ struct op_string_write {
|
||||
};
|
||||
|
||||
struct op_zero {
|
||||
u32 op :8;
|
||||
u32 offset :24;
|
||||
u32 op:8;
|
||||
u32 offset:24;
|
||||
u32 len;
|
||||
};
|
||||
|
||||
@ -208,7 +208,7 @@ static void bnx2x_init_wr_64(struct bnx2x *bp, u32 addr, const u32 *data,
|
||||
/*********************************************************
|
||||
There are different blobs for each PRAM section.
|
||||
In addition, each blob write operation is divided into a few operations
|
||||
in order to decrease the amount of phys. contigious buffer needed.
|
||||
in order to decrease the amount of phys. contiguous buffer needed.
|
||||
Thus, when we select a blob the address may be with some offset
|
||||
from the beginning of PRAM section.
|
||||
The same holds for the INT_TABLE sections.
|
||||
@ -336,7 +336,7 @@ static void bnx2x_init_block(struct bnx2x *bp, u32 op_start, u32 op_end)
|
||||
len = op->str_wr.data_len;
|
||||
data = data_base + op->str_wr.data_off;
|
||||
|
||||
/* carefull! it must be in order */
|
||||
/* careful! it must be in order */
|
||||
if (unlikely(op_type > OP_WB)) {
|
||||
|
||||
/* If E1 only */
|
||||
@ -740,7 +740,7 @@ static u8 calc_crc8(u32 data, u8 crc)
|
||||
return crc_res;
|
||||
}
|
||||
|
||||
/* regiesers addresses are not in order
|
||||
/* registers addresses are not in order
|
||||
so these arrays help simplify the code */
|
||||
static const int cm_start[E1H_FUNC_MAX][9] = {
|
||||
{MISC_FUNC0_START, TCM_FUNC0_START, UCM_FUNC0_START, CCM_FUNC0_START,
|
||||
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -55,14 +55,17 @@ struct link_params {
|
||||
#define LOOPBACK_BMAC 2
|
||||
#define LOOPBACK_XGXS_10 3
|
||||
#define LOOPBACK_EXT_PHY 4
|
||||
#define LOOPBACK_EXT 5
|
||||
|
||||
u16 req_duplex;
|
||||
u16 req_flow_ctrl;
|
||||
u16 req_fc_auto_adv; /* Should be set to TX / BOTH when
|
||||
req_flow_ctrl is set to AUTO */
|
||||
u16 req_line_speed; /* Also determine AutoNeg */
|
||||
|
||||
/* Device parameters */
|
||||
u8 mac_addr[6];
|
||||
u16 mtu;
|
||||
|
||||
|
||||
|
||||
/* shmem parameters */
|
||||
@ -140,7 +143,7 @@ u8 bnx2x_cl45_write(struct bnx2x *bp, u8 port, u32 ext_phy_type,
|
||||
u8 phy_addr, u8 devad, u16 reg, u16 val);
|
||||
|
||||
/* Reads the link_status from the shmem,
|
||||
and update the link vars accordinaly */
|
||||
and update the link vars accordingly */
|
||||
void bnx2x_link_status_update(struct link_params *input,
|
||||
struct link_vars *output);
|
||||
/* returns string representing the fw_version of the external phy */
|
||||
@ -149,7 +152,7 @@ u8 bnx2x_get_ext_phy_fw_version(struct link_params *params, u8 driver_loaded,
|
||||
|
||||
/* Set/Unset the led
|
||||
Basically, the CLC takes care of the led for the link, but in case one needs
|
||||
to set/unset the led unnatually, set the "mode" to LED_MODE_OPER to
|
||||
to set/unset the led unnaturally, set the "mode" to LED_MODE_OPER to
|
||||
blink the led, and LED_MODE_OFF to set the led off.*/
|
||||
u8 bnx2x_set_led(struct bnx2x *bp, u8 port, u8 mode, u32 speed,
|
||||
u16 hw_led_mode, u32 chip_id);
|
||||
@ -164,5 +167,7 @@ u8 bnx2x_flash_download(struct bnx2x *bp, u8 port, u32 ext_phy_config,
|
||||
otherwise link is down*/
|
||||
u8 bnx2x_test_link(struct link_params *input, struct link_vars *vars);
|
||||
|
||||
/* One-time initialization for external phy after power up */
|
||||
u8 bnx2x_common_init_phy(struct bnx2x *bp, u32 shmem_base);
|
||||
|
||||
#endif /* BNX2X_LINK_H */
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -6,7 +6,7 @@
|
||||
* it under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation.
|
||||
*
|
||||
* The registers description starts with the regsister Access type followed
|
||||
* The registers description starts with the register Access type followed
|
||||
* by size in bits. For example [RW 32]. The access types are:
|
||||
* R - Read only
|
||||
* RC - Clear on read
|
||||
@ -49,7 +49,7 @@
|
||||
/* [RW 10] Write client 0: Assert pause threshold. */
|
||||
#define BRB1_REG_PAUSE_LOW_THRESHOLD_0 0x60068
|
||||
#define BRB1_REG_PAUSE_LOW_THRESHOLD_1 0x6006c
|
||||
/* [R 24] The number of full blocks occpied by port. */
|
||||
/* [R 24] The number of full blocks occupied by port. */
|
||||
#define BRB1_REG_PORT_NUM_OCC_BLOCKS_0 0x60094
|
||||
/* [RW 1] Reset the design by software. */
|
||||
#define BRB1_REG_SOFT_RESET 0x600dc
|
||||
@ -740,6 +740,7 @@
|
||||
#define HC_REG_ATTN_MSG1_ADDR_L 0x108020
|
||||
#define HC_REG_ATTN_NUM_P0 0x108038
|
||||
#define HC_REG_ATTN_NUM_P1 0x10803c
|
||||
#define HC_REG_COMMAND_REG 0x108180
|
||||
#define HC_REG_CONFIG_0 0x108000
|
||||
#define HC_REG_CONFIG_1 0x108004
|
||||
#define HC_REG_FUNC_NUM_P0 0x1080ac
|
||||
@ -1372,6 +1373,23 @@
|
||||
be asserted). */
|
||||
#define MISC_REG_DRIVER_CONTROL_16 0xa5f0
|
||||
#define MISC_REG_DRIVER_CONTROL_16_SIZE 2
|
||||
/* [RW 32] The following driver registers(1...16) represent 16 drivers and
|
||||
32 clients. Each client can be controlled by one driver only. One in each
|
||||
bit represent that this driver control the appropriate client (Ex: bit 5
|
||||
is set means this driver control client number 5). addr1 = set; addr0 =
|
||||
clear; read from both addresses will give the same result = status. write
|
||||
to address 1 will set a request to control all the clients that their
|
||||
appropriate bit (in the write command) is set. if the client is free (the
|
||||
appropriate bit in all the other drivers is clear) one will be written to
|
||||
that driver register; if the client isn't free the bit will remain zero.
|
||||
if the appropriate bit is set (the driver request to gain control on a
|
||||
client it already controls the ~MISC_REGISTERS_INT_STS.GENERIC_SW
|
||||
interrupt will be asserted). write to address 0 will set a request to
|
||||
free all the clients that their appropriate bit (in the write command) is
|
||||
set. if the appropriate bit is clear (the driver request to free a client
|
||||
it doesn't controls the ~MISC_REGISTERS_INT_STS.GENERIC_SW interrupt will
|
||||
be asserted). */
|
||||
#define MISC_REG_DRIVER_CONTROL_7 0xa3c8
|
||||
/* [RW 1] e1hmf for WOL. If clr WOL signal o the PXP will be send on bit 0
|
||||
only. */
|
||||
#define MISC_REG_E1HMF_MODE 0xa5f8
|
||||
@ -1394,13 +1412,13 @@
|
||||
#define MISC_REG_GPIO 0xa490
|
||||
/* [R 28] this field hold the last information that caused reserved
|
||||
attention. bits [19:0] - address; [22:20] function; [23] reserved;
|
||||
[27:24] the master thatcaused the attention - according to the following
|
||||
[27:24] the master that caused the attention - according to the following
|
||||
encodeing:1 = pxp; 2 = mcp; 3 = usdm; 4 = tsdm; 5 = xsdm; 6 = csdm; 7 =
|
||||
dbu; 8 = dmae */
|
||||
#define MISC_REG_GRC_RSV_ATTN 0xa3c0
|
||||
/* [R 28] this field hold the last information that caused timeout
|
||||
attention. bits [19:0] - address; [22:20] function; [23] reserved;
|
||||
[27:24] the master thatcaused the attention - according to the following
|
||||
[27:24] the master that caused the attention - according to the following
|
||||
encodeing:1 = pxp; 2 = mcp; 3 = usdm; 4 = tsdm; 5 = xsdm; 6 = csdm; 7 =
|
||||
dbu; 8 = dmae */
|
||||
#define MISC_REG_GRC_TIMEOUT_ATTN 0xa3c4
|
||||
@ -1677,6 +1695,7 @@
|
||||
/* [RW 8] init credit counter for port0 in LLH */
|
||||
#define NIG_REG_LLH0_XCM_INIT_CREDIT 0x10554
|
||||
#define NIG_REG_LLH0_XCM_MASK 0x10130
|
||||
#define NIG_REG_LLH1_BRB1_DRV_MASK 0x10248
|
||||
/* [RW 1] send to BRB1 if no match on any of RMP rules. */
|
||||
#define NIG_REG_LLH1_BRB1_NOT_MCP 0x102dc
|
||||
/* [RW 2] Determine the classification participants. 0: no classification.1:
|
||||
@ -1727,6 +1746,9 @@
|
||||
/* [R 32] Rx statistics : In user packets discarded due to BRB backpressure
|
||||
for port0 */
|
||||
#define NIG_REG_STAT0_BRB_DISCARD 0x105f0
|
||||
/* [R 32] Rx statistics : In user packets truncated due to BRB backpressure
|
||||
for port0 */
|
||||
#define NIG_REG_STAT0_BRB_TRUNCATE 0x105f8
|
||||
/* [WB_R 36] Tx statistics : Number of packets from emac0 or bmac0 that
|
||||
between 1024 and 1522 bytes for port0 */
|
||||
#define NIG_REG_STAT0_EGRESS_MAC_PKT0 0x10750
|
||||
@ -2298,7 +2320,7 @@
|
||||
/* [RW 3] page size in L2P table for QM module; -4k; -8k; -16k; -32k; -64k;
|
||||
-128k */
|
||||
#define PXP2_REG_RQ_QM_P_SIZE 0x120050
|
||||
/* [RW 1] 1' indicates that the RBC has finished configurating the PSWRQ */
|
||||
/* [RW 1] 1' indicates that the RBC has finished configuring the PSWRQ */
|
||||
#define PXP2_REG_RQ_RBC_DONE 0x1201b0
|
||||
/* [RW 3] Max burst size filed for read requests port 0; 000 - 128B;
|
||||
001:256B; 010: 512B; 11:1K:100:2K; 01:4K */
|
||||
@ -2406,7 +2428,7 @@
|
||||
/* [RW 2] 0 - 128B; - 256B; - 512B; - 1024B; when the payload in the
|
||||
buffer reaches this number has_payload will be asserted */
|
||||
#define PXP2_REG_WR_DMAE_MPS 0x1205ec
|
||||
/* [RW 10] if Number of entries in dmae fifo will be higer than this
|
||||
/* [RW 10] if Number of entries in dmae fifo will be higher than this
|
||||
threshold then has_payload indication will be asserted; the default value
|
||||
should be equal to > write MBS size! */
|
||||
#define PXP2_REG_WR_DMAE_TH 0x120368
|
||||
@ -2427,7 +2449,7 @@
|
||||
/* [RW 2] 0 - 128B; - 256B; - 512B; - 1024B; when the payload in the
|
||||
buffer reaches this number has_payload will be asserted */
|
||||
#define PXP2_REG_WR_TSDM_MPS 0x1205d4
|
||||
/* [RW 10] if Number of entries in usdmdp fifo will be higer than this
|
||||
/* [RW 10] if Number of entries in usdmdp fifo will be higher than this
|
||||
threshold then has_payload indication will be asserted; the default value
|
||||
should be equal to > write MBS size! */
|
||||
#define PXP2_REG_WR_USDMDP_TH 0x120348
|
||||
@ -3294,12 +3316,12 @@
|
||||
#define XSEM_XSEM_INT_MASK_0_REG_ADDRESS_ERROR_SIZE 0
|
||||
#define CFC_DEBUG1_REG_WRITE_AC (0x1<<4)
|
||||
#define CFC_DEBUG1_REG_WRITE_AC_SIZE 4
|
||||
/* [R 1] debug only: This bit indicates wheter indicates that external
|
||||
/* [R 1] debug only: This bit indicates whether indicates that external
|
||||
buffer was wrapped (oldest data was thrown); Relevant only when
|
||||
~dbg_registers_debug_target=2 (PCI) & ~dbg_registers_full_mode=1 (wrap); */
|
||||
#define DBG_REG_WRAP_ON_EXT_BUFFER 0xc124
|
||||
#define DBG_REG_WRAP_ON_EXT_BUFFER_SIZE 1
|
||||
/* [R 1] debug only: This bit indicates wheter the internal buffer was
|
||||
/* [R 1] debug only: This bit indicates whether the internal buffer was
|
||||
wrapped (oldest data was thrown) Relevant only when
|
||||
~dbg_registers_debug_target=0 (internal buffer) */
|
||||
#define DBG_REG_WRAP_ON_INT_BUFFER 0xc128
|
||||
@ -4944,6 +4966,7 @@
|
||||
#define EMAC_RX_MODE_PROMISCUOUS (1L<<8)
|
||||
#define EMAC_RX_MTU_SIZE_JUMBO_ENA (1L<<31)
|
||||
#define EMAC_TX_MODE_EXT_PAUSE_EN (1L<<3)
|
||||
#define EMAC_TX_MODE_FLOW_EN (1L<<4)
|
||||
#define MISC_REGISTERS_GPIO_0 0
|
||||
#define MISC_REGISTERS_GPIO_1 1
|
||||
#define MISC_REGISTERS_GPIO_2 2
|
||||
@ -4959,6 +4982,7 @@
|
||||
#define MISC_REGISTERS_GPIO_PORT_SHIFT 4
|
||||
#define MISC_REGISTERS_GPIO_SET_POS 8
|
||||
#define MISC_REGISTERS_RESET_REG_1_CLEAR 0x588
|
||||
#define MISC_REGISTERS_RESET_REG_1_RST_NIG (0x1<<7)
|
||||
#define MISC_REGISTERS_RESET_REG_1_SET 0x584
|
||||
#define MISC_REGISTERS_RESET_REG_2_CLEAR 0x598
|
||||
#define MISC_REGISTERS_RESET_REG_2_RST_BMAC0 (0x1<<0)
|
||||
@ -4993,7 +5017,9 @@
|
||||
#define HW_LOCK_MAX_RESOURCE_VALUE 31
|
||||
#define HW_LOCK_RESOURCE_8072_MDIO 0
|
||||
#define HW_LOCK_RESOURCE_GPIO 1
|
||||
#define HW_LOCK_RESOURCE_PORT0_ATT_MASK 3
|
||||
#define HW_LOCK_RESOURCE_SPIO 2
|
||||
#define HW_LOCK_RESOURCE_UNDI 5
|
||||
#define AEU_INPUTS_ATTN_BITS_BRB_PARITY_ERROR (1<<18)
|
||||
#define AEU_INPUTS_ATTN_BITS_CCM_HW_INTERRUPT (1<<31)
|
||||
#define AEU_INPUTS_ATTN_BITS_CDU_HW_INTERRUPT (1<<9)
|
||||
@ -5144,59 +5170,73 @@
|
||||
#define GRCBASE_MISC_AEU GRCBASE_MISC
|
||||
|
||||
|
||||
/*the offset of the configuration space in the pci core register*/
|
||||
/* offset of configuration space in the pci core register */
|
||||
#define PCICFG_OFFSET 0x2000
|
||||
#define PCICFG_VENDOR_ID_OFFSET 0x00
|
||||
#define PCICFG_DEVICE_ID_OFFSET 0x02
|
||||
#define PCICFG_COMMAND_OFFSET 0x04
|
||||
#define PCICFG_COMMAND_IO_SPACE (1<<0)
|
||||
#define PCICFG_COMMAND_MEM_SPACE (1<<1)
|
||||
#define PCICFG_COMMAND_BUS_MASTER (1<<2)
|
||||
#define PCICFG_COMMAND_SPECIAL_CYCLES (1<<3)
|
||||
#define PCICFG_COMMAND_MWI_CYCLES (1<<4)
|
||||
#define PCICFG_COMMAND_VGA_SNOOP (1<<5)
|
||||
#define PCICFG_COMMAND_PERR_ENA (1<<6)
|
||||
#define PCICFG_COMMAND_STEPPING (1<<7)
|
||||
#define PCICFG_COMMAND_SERR_ENA (1<<8)
|
||||
#define PCICFG_COMMAND_FAST_B2B (1<<9)
|
||||
#define PCICFG_COMMAND_INT_DISABLE (1<<10)
|
||||
#define PCICFG_COMMAND_RESERVED (0x1f<<11)
|
||||
#define PCICFG_STATUS_OFFSET 0x06
|
||||
#define PCICFG_REVESION_ID 0x08
|
||||
#define PCICFG_REVESION_ID 0x08
|
||||
#define PCICFG_CACHE_LINE_SIZE 0x0c
|
||||
#define PCICFG_LATENCY_TIMER 0x0d
|
||||
#define PCICFG_BAR_1_LOW 0x10
|
||||
#define PCICFG_BAR_1_HIGH 0x14
|
||||
#define PCICFG_BAR_2_LOW 0x18
|
||||
#define PCICFG_BAR_2_HIGH 0x1c
|
||||
#define PCICFG_SUBSYSTEM_VENDOR_ID_OFFSET 0x2c
|
||||
#define PCICFG_BAR_1_LOW 0x10
|
||||
#define PCICFG_BAR_1_HIGH 0x14
|
||||
#define PCICFG_BAR_2_LOW 0x18
|
||||
#define PCICFG_BAR_2_HIGH 0x1c
|
||||
#define PCICFG_SUBSYSTEM_VENDOR_ID_OFFSET 0x2c
|
||||
#define PCICFG_SUBSYSTEM_ID_OFFSET 0x2e
|
||||
#define PCICFG_INT_LINE 0x3c
|
||||
#define PCICFG_INT_PIN 0x3d
|
||||
#define PCICFG_PM_CSR_OFFSET 0x4c
|
||||
#define PCICFG_GRC_ADDRESS 0x78
|
||||
#define PCICFG_GRC_DATA 0x80
|
||||
#define PCICFG_INT_LINE 0x3c
|
||||
#define PCICFG_INT_PIN 0x3d
|
||||
#define PCICFG_PM_CAPABILITY 0x48
|
||||
#define PCICFG_PM_CAPABILITY_VERSION (0x3<<16)
|
||||
#define PCICFG_PM_CAPABILITY_CLOCK (1<<19)
|
||||
#define PCICFG_PM_CAPABILITY_RESERVED (1<<20)
|
||||
#define PCICFG_PM_CAPABILITY_DSI (1<<21)
|
||||
#define PCICFG_PM_CAPABILITY_AUX_CURRENT (0x7<<22)
|
||||
#define PCICFG_PM_CAPABILITY_D1_SUPPORT (1<<25)
|
||||
#define PCICFG_PM_CAPABILITY_D2_SUPPORT (1<<26)
|
||||
#define PCICFG_PM_CAPABILITY_PME_IN_D0 (1<<27)
|
||||
#define PCICFG_PM_CAPABILITY_PME_IN_D1 (1<<28)
|
||||
#define PCICFG_PM_CAPABILITY_PME_IN_D2 (1<<29)
|
||||
#define PCICFG_PM_CAPABILITY_PME_IN_D3_HOT (1<<30)
|
||||
#define PCICFG_PM_CAPABILITY_PME_IN_D3_COLD (1<<31)
|
||||
#define PCICFG_PM_CSR_OFFSET 0x4c
|
||||
#define PCICFG_PM_CSR_STATE (0x3<<0)
|
||||
#define PCICFG_PM_CSR_PME_ENABLE (1<<8)
|
||||
#define PCICFG_PM_CSR_PME_STATUS (1<<15)
|
||||
#define PCICFG_GRC_ADDRESS 0x78
|
||||
#define PCICFG_GRC_DATA 0x80
|
||||
#define PCICFG_DEVICE_CONTROL 0xb4
|
||||
#define PCICFG_LINK_CONTROL 0xbc
|
||||
|
||||
#define PCICFG_COMMAND_IO_SPACE (1<<0)
|
||||
#define PCICFG_COMMAND_MEM_SPACE (1<<1)
|
||||
#define PCICFG_COMMAND_BUS_MASTER (1<<2)
|
||||
#define PCICFG_COMMAND_SPECIAL_CYCLES (1<<3)
|
||||
#define PCICFG_COMMAND_MWI_CYCLES (1<<4)
|
||||
#define PCICFG_COMMAND_VGA_SNOOP (1<<5)
|
||||
#define PCICFG_COMMAND_PERR_ENA (1<<6)
|
||||
#define PCICFG_COMMAND_STEPPING (1<<7)
|
||||
#define PCICFG_COMMAND_SERR_ENA (1<<8)
|
||||
#define PCICFG_COMMAND_FAST_B2B (1<<9)
|
||||
#define PCICFG_COMMAND_INT_DISABLE (1<<10)
|
||||
#define PCICFG_COMMAND_RESERVED (0x1f<<11)
|
||||
|
||||
#define PCICFG_PM_CSR_STATE (0x3<<0)
|
||||
#define PCICFG_PM_CSR_PME_STATUS (1<<15)
|
||||
|
||||
#define BAR_USTRORM_INTMEM 0x400000
|
||||
#define BAR_CSTRORM_INTMEM 0x410000
|
||||
#define BAR_XSTRORM_INTMEM 0x420000
|
||||
#define BAR_TSTRORM_INTMEM 0x430000
|
||||
|
||||
/* for accessing the IGU in case of status block ACK */
|
||||
#define BAR_IGU_INTMEM 0x440000
|
||||
|
||||
#define BAR_DOORBELL_OFFSET 0x800000
|
||||
|
||||
#define BAR_ME_REGISTER 0x450000
|
||||
|
||||
|
||||
#define GRC_CONFIG_2_SIZE_REG 0x408 /* config_2 offset */
|
||||
#define PCI_CONFIG_2_BAR1_SIZE (0xfL<<0)
|
||||
/* config_2 offset */
|
||||
#define GRC_CONFIG_2_SIZE_REG 0x408
|
||||
#define PCI_CONFIG_2_BAR1_SIZE (0xfL<<0)
|
||||
#define PCI_CONFIG_2_BAR1_SIZE_DISABLED (0L<<0)
|
||||
#define PCI_CONFIG_2_BAR1_SIZE_64K (1L<<0)
|
||||
#define PCI_CONFIG_2_BAR1_SIZE_128K (2L<<0)
|
||||
@ -5213,11 +5253,11 @@
|
||||
#define PCI_CONFIG_2_BAR1_SIZE_256M (13L<<0)
|
||||
#define PCI_CONFIG_2_BAR1_SIZE_512M (14L<<0)
|
||||
#define PCI_CONFIG_2_BAR1_SIZE_1G (15L<<0)
|
||||
#define PCI_CONFIG_2_BAR1_64ENA (1L<<4)
|
||||
#define PCI_CONFIG_2_EXP_ROM_RETRY (1L<<5)
|
||||
#define PCI_CONFIG_2_CFG_CYCLE_RETRY (1L<<6)
|
||||
#define PCI_CONFIG_2_FIRST_CFG_DONE (1L<<7)
|
||||
#define PCI_CONFIG_2_EXP_ROM_SIZE (0xffL<<8)
|
||||
#define PCI_CONFIG_2_BAR1_64ENA (1L<<4)
|
||||
#define PCI_CONFIG_2_EXP_ROM_RETRY (1L<<5)
|
||||
#define PCI_CONFIG_2_CFG_CYCLE_RETRY (1L<<6)
|
||||
#define PCI_CONFIG_2_FIRST_CFG_DONE (1L<<7)
|
||||
#define PCI_CONFIG_2_EXP_ROM_SIZE (0xffL<<8)
|
||||
#define PCI_CONFIG_2_EXP_ROM_SIZE_DISABLED (0L<<8)
|
||||
#define PCI_CONFIG_2_EXP_ROM_SIZE_2K (1L<<8)
|
||||
#define PCI_CONFIG_2_EXP_ROM_SIZE_4K (2L<<8)
|
||||
@ -5234,46 +5274,44 @@
|
||||
#define PCI_CONFIG_2_EXP_ROM_SIZE_8M (13L<<8)
|
||||
#define PCI_CONFIG_2_EXP_ROM_SIZE_16M (14L<<8)
|
||||
#define PCI_CONFIG_2_EXP_ROM_SIZE_32M (15L<<8)
|
||||
#define PCI_CONFIG_2_BAR_PREFETCH (1L<<16)
|
||||
#define PCI_CONFIG_2_RESERVED0 (0x7fffL<<17)
|
||||
#define PCI_CONFIG_2_BAR_PREFETCH (1L<<16)
|
||||
#define PCI_CONFIG_2_RESERVED0 (0x7fffL<<17)
|
||||
|
||||
/* config_3 offset */
|
||||
#define GRC_CONFIG_3_SIZE_REG (0x40c)
|
||||
#define PCI_CONFIG_3_STICKY_BYTE (0xffL<<0)
|
||||
#define PCI_CONFIG_3_FORCE_PME (1L<<24)
|
||||
#define PCI_CONFIG_3_PME_STATUS (1L<<25)
|
||||
#define PCI_CONFIG_3_PME_ENABLE (1L<<26)
|
||||
#define PCI_CONFIG_3_PM_STATE (0x3L<<27)
|
||||
#define PCI_CONFIG_3_VAUX_PRESET (1L<<30)
|
||||
#define PCI_CONFIG_3_PCI_POWER (1L<<31)
|
||||
|
||||
/* config_2 offset */
|
||||
#define GRC_CONFIG_2_SIZE_REG 0x408
|
||||
#define GRC_CONFIG_3_SIZE_REG 0x40c
|
||||
#define PCI_CONFIG_3_STICKY_BYTE (0xffL<<0)
|
||||
#define PCI_CONFIG_3_FORCE_PME (1L<<24)
|
||||
#define PCI_CONFIG_3_PME_STATUS (1L<<25)
|
||||
#define PCI_CONFIG_3_PME_ENABLE (1L<<26)
|
||||
#define PCI_CONFIG_3_PM_STATE (0x3L<<27)
|
||||
#define PCI_CONFIG_3_VAUX_PRESET (1L<<30)
|
||||
#define PCI_CONFIG_3_PCI_POWER (1L<<31)
|
||||
|
||||
#define GRC_BAR2_CONFIG 0x4e0
|
||||
#define PCI_CONFIG_2_BAR2_SIZE (0xfL<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_DISABLED (0L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_64K (1L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_128K (2L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_256K (3L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_512K (4L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_1M (5L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_2M (6L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_4M (7L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_8M (8L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_16M (9L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_32M (10L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_64M (11L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_128M (12L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_256M (13L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_512M (14L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_1G (15L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_64ENA (1L<<4)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE (0xfL<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_DISABLED (0L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_64K (1L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_128K (2L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_256K (3L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_512K (4L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_1M (5L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_2M (6L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_4M (7L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_8M (8L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_16M (9L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_32M (10L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_64M (11L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_128M (12L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_256M (13L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_512M (14L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_SIZE_1G (15L<<0)
|
||||
#define PCI_CONFIG_2_BAR2_64ENA (1L<<4)
|
||||
|
||||
#define PCI_PM_DATA_A 0x410
|
||||
#define PCI_PM_DATA_B 0x414
|
||||
#define PCI_ID_VAL1 0x434
|
||||
#define PCI_ID_VAL2 0x438
|
||||
|
||||
#define PCI_PM_DATA_A (0x410)
|
||||
#define PCI_PM_DATA_B (0x414)
|
||||
#define PCI_ID_VAL1 (0x434)
|
||||
#define PCI_ID_VAL2 (0x438)
|
||||
|
||||
#define MDIO_REG_BANK_CL73_IEEEB0 0x0
|
||||
#define MDIO_CL73_IEEEB0_CL73_AN_CONTROL 0x0
|
||||
@ -5522,6 +5560,8 @@ Theotherbitsarereservedandshouldbezero*/
|
||||
#define MDIO_PMA_REG_GEN_CTRL 0xca10
|
||||
#define MDIO_PMA_REG_GEN_CTRL_ROM_RESET_INTERNAL_MP 0x0188
|
||||
#define MDIO_PMA_REG_GEN_CTRL_ROM_MICRO_RESET 0x018a
|
||||
#define MDIO_PMA_REG_M8051_MSGIN_REG 0xca12
|
||||
#define MDIO_PMA_REG_M8051_MSGOUT_REG 0xca13
|
||||
#define MDIO_PMA_REG_ROM_VER1 0xca19
|
||||
#define MDIO_PMA_REG_ROM_VER2 0xca1a
|
||||
#define MDIO_PMA_REG_EDC_FFE_MAIN 0xca1b
|
||||
@ -5576,7 +5616,8 @@ Theotherbitsarereservedandshouldbezero*/
|
||||
#define MDIO_AN_REG_LINK_STATUS 0x8304
|
||||
#define MDIO_AN_REG_CL37_CL73 0x8370
|
||||
#define MDIO_AN_REG_CL37_AN 0xffe0
|
||||
#define MDIO_AN_REG_CL37_FD 0xffe4
|
||||
#define MDIO_AN_REG_CL37_FC_LD 0xffe4
|
||||
#define MDIO_AN_REG_CL37_FC_LP 0xffe5
|
||||
|
||||
|
||||
#define IGU_FUNC_BASE 0x0400
|
||||
@ -5600,4 +5641,13 @@ Theotherbitsarereservedandshouldbezero*/
|
||||
#define IGU_INT_NOP 2
|
||||
#define IGU_INT_NOP2 3
|
||||
|
||||
#define COMMAND_REG_INT_ACK 0x0
|
||||
#define COMMAND_REG_PROD_UPD 0x4
|
||||
#define COMMAND_REG_ATTN_BITS_UPD 0x8
|
||||
#define COMMAND_REG_ATTN_BITS_SET 0xc
|
||||
#define COMMAND_REG_ATTN_BITS_CLR 0x10
|
||||
#define COMMAND_REG_COALESCE_NOW 0x14
|
||||
#define COMMAND_REG_SIMD_MASK 0x18
|
||||
#define COMMAND_REG_SIMD_NOMASK 0x1c
|
||||
|
||||
|
||||
|
@ -901,7 +901,7 @@ extern unsigned char *__pskb_pull_tail(struct sk_buff *skb, int delta);
|
||||
static inline unsigned char *__pskb_pull(struct sk_buff *skb, unsigned int len)
|
||||
{
|
||||
if (len > skb_headlen(skb) &&
|
||||
!__pskb_pull_tail(skb, len-skb_headlen(skb)))
|
||||
!__pskb_pull_tail(skb, len - skb_headlen(skb)))
|
||||
return NULL;
|
||||
skb->len -= len;
|
||||
return skb->data += len;
|
||||
@ -918,7 +918,7 @@ static inline int pskb_may_pull(struct sk_buff *skb, unsigned int len)
|
||||
return 1;
|
||||
if (unlikely(len > skb->len))
|
||||
return 0;
|
||||
return __pskb_pull_tail(skb, len-skb_headlen(skb)) != NULL;
|
||||
return __pskb_pull_tail(skb, len - skb_headlen(skb)) != NULL;
|
||||
}
|
||||
|
||||
/**
|
||||
@ -1321,7 +1321,7 @@ static inline int skb_padto(struct sk_buff *skb, unsigned int len)
|
||||
unsigned int size = skb->len;
|
||||
if (likely(size >= len))
|
||||
return 0;
|
||||
return skb_pad(skb, len-size);
|
||||
return skb_pad(skb, len - size);
|
||||
}
|
||||
|
||||
static inline int skb_add_data(struct sk_buff *skb,
|
||||
|
@ -38,11 +38,6 @@ struct route_info {
|
||||
#define RT6_LOOKUP_F_SRCPREF_COA 0x00000020
|
||||
|
||||
|
||||
#ifdef CONFIG_IPV6_MULTIPLE_TABLES
|
||||
extern struct rt6_info *ip6_prohibit_entry;
|
||||
extern struct rt6_info *ip6_blk_hole_entry;
|
||||
#endif
|
||||
|
||||
extern void ip6_route_input(struct sk_buff *skb);
|
||||
|
||||
extern struct dst_entry * ip6_route_output(struct net *net,
|
||||
@ -118,7 +113,6 @@ extern int rt6_dump_route(struct rt6_info *rt, void *p_arg);
|
||||
extern void rt6_ifdown(struct net *net, struct net_device *dev);
|
||||
extern void rt6_mtu_change(struct net_device *dev, unsigned mtu);
|
||||
|
||||
extern rwlock_t rt6_lock;
|
||||
|
||||
/*
|
||||
* Store a destination cache entry in a socket
|
||||
|
@ -140,8 +140,24 @@ struct ip_vs_seq {
|
||||
|
||||
|
||||
/*
|
||||
* IPVS statistics object
|
||||
* IPVS statistics objects
|
||||
*/
|
||||
struct ip_vs_estimator {
|
||||
struct list_head list;
|
||||
|
||||
u64 last_inbytes;
|
||||
u64 last_outbytes;
|
||||
u32 last_conns;
|
||||
u32 last_inpkts;
|
||||
u32 last_outpkts;
|
||||
|
||||
u32 cps;
|
||||
u32 inpps;
|
||||
u32 outpps;
|
||||
u32 inbps;
|
||||
u32 outbps;
|
||||
};
|
||||
|
||||
struct ip_vs_stats
|
||||
{
|
||||
__u32 conns; /* connections scheduled */
|
||||
@ -156,7 +172,15 @@ struct ip_vs_stats
|
||||
__u32 inbps; /* current in byte rate */
|
||||
__u32 outbps; /* current out byte rate */
|
||||
|
||||
/*
|
||||
* Don't add anything before the lock, because we use memcpy() to copy
|
||||
* the members before the lock to struct ip_vs_stats_user in
|
||||
* ip_vs_ctl.c.
|
||||
*/
|
||||
|
||||
spinlock_t lock; /* spin lock */
|
||||
|
||||
struct ip_vs_estimator est; /* estimator */
|
||||
};
|
||||
|
||||
struct dst_entry;
|
||||
@ -440,7 +464,7 @@ struct ip_vs_app
|
||||
*/
|
||||
extern const char *ip_vs_proto_name(unsigned proto);
|
||||
extern void ip_vs_init_hash_table(struct list_head *table, int rows);
|
||||
#define IP_VS_INIT_HASH_TABLE(t) ip_vs_init_hash_table(t, sizeof(t)/sizeof(t[0]))
|
||||
#define IP_VS_INIT_HASH_TABLE(t) ip_vs_init_hash_table((t), ARRAY_SIZE((t)))
|
||||
|
||||
#define IP_VS_APP_TYPE_FTP 1
|
||||
|
||||
@ -620,7 +644,7 @@ extern int sysctl_ip_vs_expire_quiescent_template;
|
||||
extern int sysctl_ip_vs_sync_threshold[2];
|
||||
extern int sysctl_ip_vs_nat_icmp_send;
|
||||
extern struct ip_vs_stats ip_vs_stats;
|
||||
extern struct ctl_path net_vs_ctl_path[];
|
||||
extern const struct ctl_path net_vs_ctl_path[];
|
||||
|
||||
extern struct ip_vs_service *
|
||||
ip_vs_service_get(__u32 fwmark, __u16 protocol, __be32 vaddr, __be16 vport);
|
||||
@ -659,7 +683,7 @@ extern void ip_vs_sync_conn(struct ip_vs_conn *cp);
|
||||
/*
|
||||
* IPVS rate estimator prototypes (from ip_vs_est.c)
|
||||
*/
|
||||
extern int ip_vs_new_estimator(struct ip_vs_stats *stats);
|
||||
extern void ip_vs_new_estimator(struct ip_vs_stats *stats);
|
||||
extern void ip_vs_kill_estimator(struct ip_vs_stats *stats);
|
||||
extern void ip_vs_zero_estimator(struct ip_vs_stats *stats);
|
||||
|
||||
|
@ -89,7 +89,10 @@ extern void __qdisc_run(struct Qdisc *q);
|
||||
|
||||
static inline void qdisc_run(struct Qdisc *q)
|
||||
{
|
||||
if (!test_and_set_bit(__QDISC_STATE_RUNNING, &q->state))
|
||||
struct netdev_queue *txq = q->dev_queue;
|
||||
|
||||
if (!netif_tx_queue_stopped(txq) &&
|
||||
!test_and_set_bit(__QDISC_STATE_RUNNING, &q->state))
|
||||
__qdisc_run(q);
|
||||
}
|
||||
|
||||
|
@ -99,7 +99,7 @@ struct gen_estimator_head
|
||||
|
||||
static struct gen_estimator_head elist[EST_MAX_INTERVAL+1];
|
||||
|
||||
/* Protects against NULL dereference */
|
||||
/* Protects against NULL dereference and RCU write-side */
|
||||
static DEFINE_RWLOCK(est_lock);
|
||||
|
||||
static void est_timer(unsigned long arg)
|
||||
@ -185,6 +185,7 @@ int gen_new_estimator(struct gnet_stats_basic *bstats,
|
||||
est->last_packets = bstats->packets;
|
||||
est->avpps = rate_est->pps<<10;
|
||||
|
||||
write_lock_bh(&est_lock);
|
||||
if (!elist[idx].timer.function) {
|
||||
INIT_LIST_HEAD(&elist[idx].list);
|
||||
setup_timer(&elist[idx].timer, est_timer, idx);
|
||||
@ -194,6 +195,7 @@ int gen_new_estimator(struct gnet_stats_basic *bstats,
|
||||
mod_timer(&elist[idx].timer, jiffies + ((HZ/4) << idx));
|
||||
|
||||
list_add_rcu(&est->list, &elist[idx].list);
|
||||
write_unlock_bh(&est_lock);
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -212,7 +214,6 @@ static void __gen_kill_estimator(struct rcu_head *head)
|
||||
* Removes the rate estimator specified by &bstats and &rate_est
|
||||
* and deletes the timer.
|
||||
*
|
||||
* NOTE: Called under rtnl_mutex
|
||||
*/
|
||||
void gen_kill_estimator(struct gnet_stats_basic *bstats,
|
||||
struct gnet_stats_rate_est *rate_est)
|
||||
@ -226,17 +227,17 @@ void gen_kill_estimator(struct gnet_stats_basic *bstats,
|
||||
if (!elist[idx].timer.function)
|
||||
continue;
|
||||
|
||||
write_lock_bh(&est_lock);
|
||||
list_for_each_entry_safe(e, n, &elist[idx].list, list) {
|
||||
if (e->rate_est != rate_est || e->bstats != bstats)
|
||||
continue;
|
||||
|
||||
write_lock_bh(&est_lock);
|
||||
e->bstats = NULL;
|
||||
write_unlock_bh(&est_lock);
|
||||
|
||||
list_del_rcu(&e->list);
|
||||
call_rcu(&e->e_rcu, __gen_kill_estimator);
|
||||
}
|
||||
write_unlock_bh(&est_lock);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1961,6 +1961,8 @@ static int pktgen_setup_dev(struct pktgen_dev *pkt_dev, const char *ifname)
|
||||
*/
|
||||
static void pktgen_setup_inject(struct pktgen_dev *pkt_dev)
|
||||
{
|
||||
int ntxq;
|
||||
|
||||
if (!pkt_dev->odev) {
|
||||
printk(KERN_ERR "pktgen: ERROR: pkt_dev->odev == NULL in "
|
||||
"setup_inject.\n");
|
||||
@ -1969,6 +1971,33 @@ static void pktgen_setup_inject(struct pktgen_dev *pkt_dev)
|
||||
return;
|
||||
}
|
||||
|
||||
/* make sure that we don't pick a non-existing transmit queue */
|
||||
ntxq = pkt_dev->odev->real_num_tx_queues;
|
||||
if (ntxq <= num_online_cpus() && (pkt_dev->flags & F_QUEUE_MAP_CPU)) {
|
||||
printk(KERN_WARNING "pktgen: WARNING: QUEUE_MAP_CPU "
|
||||
"disabled because CPU count (%d) exceeds number ",
|
||||
num_online_cpus());
|
||||
printk(KERN_WARNING "pktgen: WARNING: of tx queues "
|
||||
"(%d) on %s \n", ntxq, pkt_dev->odev->name);
|
||||
pkt_dev->flags &= ~F_QUEUE_MAP_CPU;
|
||||
}
|
||||
if (ntxq <= pkt_dev->queue_map_min) {
|
||||
printk(KERN_WARNING "pktgen: WARNING: Requested "
|
||||
"queue_map_min (%d) exceeds number of tx\n",
|
||||
pkt_dev->queue_map_min);
|
||||
printk(KERN_WARNING "pktgen: WARNING: queues (%d) on "
|
||||
"%s, resetting\n", ntxq, pkt_dev->odev->name);
|
||||
pkt_dev->queue_map_min = ntxq - 1;
|
||||
}
|
||||
if (ntxq <= pkt_dev->queue_map_max) {
|
||||
printk(KERN_WARNING "pktgen: WARNING: Requested "
|
||||
"queue_map_max (%d) exceeds number of tx\n",
|
||||
pkt_dev->queue_map_max);
|
||||
printk(KERN_WARNING "pktgen: WARNING: queues (%d) on "
|
||||
"%s, resetting\n", ntxq, pkt_dev->odev->name);
|
||||
pkt_dev->queue_map_max = ntxq - 1;
|
||||
}
|
||||
|
||||
/* Default to the interface's mac if not explicitly set. */
|
||||
|
||||
if (is_zero_ether_addr(pkt_dev->src_mac))
|
||||
|
@ -474,6 +474,11 @@ static int dccp_setsockopt_change(struct sock *sk, int type,
|
||||
|
||||
if (copy_from_user(&opt, optval, sizeof(opt)))
|
||||
return -EFAULT;
|
||||
/*
|
||||
* rfc4340: 6.1. Change Options
|
||||
*/
|
||||
if (opt.dccpsf_len < 1)
|
||||
return -EINVAL;
|
||||
|
||||
val = kmalloc(opt.dccpsf_len, GFP_KERNEL);
|
||||
if (!val)
|
||||
|
@ -289,6 +289,7 @@ static struct sk_buff *igmpv3_newpack(struct net_device *dev, int size)
|
||||
struct rtable *rt;
|
||||
struct iphdr *pip;
|
||||
struct igmpv3_report *pig;
|
||||
struct net *net = dev_net(dev);
|
||||
|
||||
skb = alloc_skb(size + LL_ALLOCATED_SPACE(dev), GFP_ATOMIC);
|
||||
if (skb == NULL)
|
||||
@ -299,7 +300,7 @@ static struct sk_buff *igmpv3_newpack(struct net_device *dev, int size)
|
||||
.nl_u = { .ip4_u = {
|
||||
.daddr = IGMPV3_ALL_MCR } },
|
||||
.proto = IPPROTO_IGMP };
|
||||
if (ip_route_output_key(&init_net, &rt, &fl)) {
|
||||
if (ip_route_output_key(net, &rt, &fl)) {
|
||||
kfree_skb(skb);
|
||||
return NULL;
|
||||
}
|
||||
@ -629,6 +630,7 @@ static int igmp_send_report(struct in_device *in_dev, struct ip_mc_list *pmc,
|
||||
struct igmphdr *ih;
|
||||
struct rtable *rt;
|
||||
struct net_device *dev = in_dev->dev;
|
||||
struct net *net = dev_net(dev);
|
||||
__be32 group = pmc ? pmc->multiaddr : 0;
|
||||
__be32 dst;
|
||||
|
||||
@ -643,7 +645,7 @@ static int igmp_send_report(struct in_device *in_dev, struct ip_mc_list *pmc,
|
||||
struct flowi fl = { .oif = dev->ifindex,
|
||||
.nl_u = { .ip4_u = { .daddr = dst } },
|
||||
.proto = IPPROTO_IGMP };
|
||||
if (ip_route_output_key(&init_net, &rt, &fl))
|
||||
if (ip_route_output_key(net, &rt, &fl))
|
||||
return -1;
|
||||
}
|
||||
if (rt->rt_src == 0) {
|
||||
@ -1196,9 +1198,6 @@ void ip_mc_inc_group(struct in_device *in_dev, __be32 addr)
|
||||
|
||||
ASSERT_RTNL();
|
||||
|
||||
if (!net_eq(dev_net(in_dev->dev), &init_net))
|
||||
return;
|
||||
|
||||
for (im=in_dev->mc_list; im; im=im->next) {
|
||||
if (im->multiaddr == addr) {
|
||||
im->users++;
|
||||
@ -1278,9 +1277,6 @@ void ip_mc_dec_group(struct in_device *in_dev, __be32 addr)
|
||||
|
||||
ASSERT_RTNL();
|
||||
|
||||
if (!net_eq(dev_net(in_dev->dev), &init_net))
|
||||
return;
|
||||
|
||||
for (ip=&in_dev->mc_list; (i=*ip)!=NULL; ip=&i->next) {
|
||||
if (i->multiaddr==addr) {
|
||||
if (--i->users == 0) {
|
||||
@ -1308,9 +1304,6 @@ void ip_mc_down(struct in_device *in_dev)
|
||||
|
||||
ASSERT_RTNL();
|
||||
|
||||
if (!net_eq(dev_net(in_dev->dev), &init_net))
|
||||
return;
|
||||
|
||||
for (i=in_dev->mc_list; i; i=i->next)
|
||||
igmp_group_dropped(i);
|
||||
|
||||
@ -1331,9 +1324,6 @@ void ip_mc_init_dev(struct in_device *in_dev)
|
||||
{
|
||||
ASSERT_RTNL();
|
||||
|
||||
if (!net_eq(dev_net(in_dev->dev), &init_net))
|
||||
return;
|
||||
|
||||
in_dev->mc_tomb = NULL;
|
||||
#ifdef CONFIG_IP_MULTICAST
|
||||
in_dev->mr_gq_running = 0;
|
||||
@ -1357,9 +1347,6 @@ void ip_mc_up(struct in_device *in_dev)
|
||||
|
||||
ASSERT_RTNL();
|
||||
|
||||
if (!net_eq(dev_net(in_dev->dev), &init_net))
|
||||
return;
|
||||
|
||||
ip_mc_inc_group(in_dev, IGMP_ALL_HOSTS);
|
||||
|
||||
for (i=in_dev->mc_list; i; i=i->next)
|
||||
@ -1376,9 +1363,6 @@ void ip_mc_destroy_dev(struct in_device *in_dev)
|
||||
|
||||
ASSERT_RTNL();
|
||||
|
||||
if (!net_eq(dev_net(in_dev->dev), &init_net))
|
||||
return;
|
||||
|
||||
/* Deactivate timers */
|
||||
ip_mc_down(in_dev);
|
||||
|
||||
@ -1395,7 +1379,7 @@ void ip_mc_destroy_dev(struct in_device *in_dev)
|
||||
write_unlock_bh(&in_dev->mc_list_lock);
|
||||
}
|
||||
|
||||
static struct in_device * ip_mc_find_dev(struct ip_mreqn *imr)
|
||||
static struct in_device *ip_mc_find_dev(struct net *net, struct ip_mreqn *imr)
|
||||
{
|
||||
struct flowi fl = { .nl_u = { .ip4_u =
|
||||
{ .daddr = imr->imr_multiaddr.s_addr } } };
|
||||
@ -1404,19 +1388,19 @@ static struct in_device * ip_mc_find_dev(struct ip_mreqn *imr)
|
||||
struct in_device *idev = NULL;
|
||||
|
||||
if (imr->imr_ifindex) {
|
||||
idev = inetdev_by_index(&init_net, imr->imr_ifindex);
|
||||
idev = inetdev_by_index(net, imr->imr_ifindex);
|
||||
if (idev)
|
||||
__in_dev_put(idev);
|
||||
return idev;
|
||||
}
|
||||
if (imr->imr_address.s_addr) {
|
||||
dev = ip_dev_find(&init_net, imr->imr_address.s_addr);
|
||||
dev = ip_dev_find(net, imr->imr_address.s_addr);
|
||||
if (!dev)
|
||||
return NULL;
|
||||
dev_put(dev);
|
||||
}
|
||||
|
||||
if (!dev && !ip_route_output_key(&init_net, &rt, &fl)) {
|
||||
if (!dev && !ip_route_output_key(net, &rt, &fl)) {
|
||||
dev = rt->u.dst.dev;
|
||||
ip_rt_put(rt);
|
||||
}
|
||||
@ -1754,18 +1738,16 @@ int ip_mc_join_group(struct sock *sk , struct ip_mreqn *imr)
|
||||
struct ip_mc_socklist *iml=NULL, *i;
|
||||
struct in_device *in_dev;
|
||||
struct inet_sock *inet = inet_sk(sk);
|
||||
struct net *net = sock_net(sk);
|
||||
int ifindex;
|
||||
int count = 0;
|
||||
|
||||
if (!ipv4_is_multicast(addr))
|
||||
return -EINVAL;
|
||||
|
||||
if (!net_eq(sock_net(sk), &init_net))
|
||||
return -EPROTONOSUPPORT;
|
||||
|
||||
rtnl_lock();
|
||||
|
||||
in_dev = ip_mc_find_dev(imr);
|
||||
in_dev = ip_mc_find_dev(net, imr);
|
||||
|
||||
if (!in_dev) {
|
||||
iml = NULL;
|
||||
@ -1827,15 +1809,13 @@ int ip_mc_leave_group(struct sock *sk, struct ip_mreqn *imr)
|
||||
struct inet_sock *inet = inet_sk(sk);
|
||||
struct ip_mc_socklist *iml, **imlp;
|
||||
struct in_device *in_dev;
|
||||
struct net *net = sock_net(sk);
|
||||
__be32 group = imr->imr_multiaddr.s_addr;
|
||||
u32 ifindex;
|
||||
int ret = -EADDRNOTAVAIL;
|
||||
|
||||
if (!net_eq(sock_net(sk), &init_net))
|
||||
return -EPROTONOSUPPORT;
|
||||
|
||||
rtnl_lock();
|
||||
in_dev = ip_mc_find_dev(imr);
|
||||
in_dev = ip_mc_find_dev(net, imr);
|
||||
ifindex = imr->imr_ifindex;
|
||||
for (imlp = &inet->mc_list; (iml = *imlp) != NULL; imlp = &iml->next) {
|
||||
if (iml->multi.imr_multiaddr.s_addr != group)
|
||||
@ -1873,21 +1853,19 @@ int ip_mc_source(int add, int omode, struct sock *sk, struct
|
||||
struct in_device *in_dev = NULL;
|
||||
struct inet_sock *inet = inet_sk(sk);
|
||||
struct ip_sf_socklist *psl;
|
||||
struct net *net = sock_net(sk);
|
||||
int leavegroup = 0;
|
||||
int i, j, rv;
|
||||
|
||||
if (!ipv4_is_multicast(addr))
|
||||
return -EINVAL;
|
||||
|
||||
if (!net_eq(sock_net(sk), &init_net))
|
||||
return -EPROTONOSUPPORT;
|
||||
|
||||
rtnl_lock();
|
||||
|
||||
imr.imr_multiaddr.s_addr = mreqs->imr_multiaddr;
|
||||
imr.imr_address.s_addr = mreqs->imr_interface;
|
||||
imr.imr_ifindex = ifindex;
|
||||
in_dev = ip_mc_find_dev(&imr);
|
||||
in_dev = ip_mc_find_dev(net, &imr);
|
||||
|
||||
if (!in_dev) {
|
||||
err = -ENODEV;
|
||||
@ -2007,6 +1985,7 @@ int ip_mc_msfilter(struct sock *sk, struct ip_msfilter *msf, int ifindex)
|
||||
struct in_device *in_dev;
|
||||
struct inet_sock *inet = inet_sk(sk);
|
||||
struct ip_sf_socklist *newpsl, *psl;
|
||||
struct net *net = sock_net(sk);
|
||||
int leavegroup = 0;
|
||||
|
||||
if (!ipv4_is_multicast(addr))
|
||||
@ -2015,15 +1994,12 @@ int ip_mc_msfilter(struct sock *sk, struct ip_msfilter *msf, int ifindex)
|
||||
msf->imsf_fmode != MCAST_EXCLUDE)
|
||||
return -EINVAL;
|
||||
|
||||
if (!net_eq(sock_net(sk), &init_net))
|
||||
return -EPROTONOSUPPORT;
|
||||
|
||||
rtnl_lock();
|
||||
|
||||
imr.imr_multiaddr.s_addr = msf->imsf_multiaddr;
|
||||
imr.imr_address.s_addr = msf->imsf_interface;
|
||||
imr.imr_ifindex = ifindex;
|
||||
in_dev = ip_mc_find_dev(&imr);
|
||||
in_dev = ip_mc_find_dev(net, &imr);
|
||||
|
||||
if (!in_dev) {
|
||||
err = -ENODEV;
|
||||
@ -2094,19 +2070,17 @@ int ip_mc_msfget(struct sock *sk, struct ip_msfilter *msf,
|
||||
struct in_device *in_dev;
|
||||
struct inet_sock *inet = inet_sk(sk);
|
||||
struct ip_sf_socklist *psl;
|
||||
struct net *net = sock_net(sk);
|
||||
|
||||
if (!ipv4_is_multicast(addr))
|
||||
return -EINVAL;
|
||||
|
||||
if (!net_eq(sock_net(sk), &init_net))
|
||||
return -EPROTONOSUPPORT;
|
||||
|
||||
rtnl_lock();
|
||||
|
||||
imr.imr_multiaddr.s_addr = msf->imsf_multiaddr;
|
||||
imr.imr_address.s_addr = msf->imsf_interface;
|
||||
imr.imr_ifindex = 0;
|
||||
in_dev = ip_mc_find_dev(&imr);
|
||||
in_dev = ip_mc_find_dev(net, &imr);
|
||||
|
||||
if (!in_dev) {
|
||||
err = -ENODEV;
|
||||
@ -2163,9 +2137,6 @@ int ip_mc_gsfget(struct sock *sk, struct group_filter *gsf,
|
||||
if (!ipv4_is_multicast(addr))
|
||||
return -EINVAL;
|
||||
|
||||
if (!net_eq(sock_net(sk), &init_net))
|
||||
return -EPROTONOSUPPORT;
|
||||
|
||||
rtnl_lock();
|
||||
|
||||
err = -EADDRNOTAVAIL;
|
||||
@ -2246,19 +2217,17 @@ void ip_mc_drop_socket(struct sock *sk)
|
||||
{
|
||||
struct inet_sock *inet = inet_sk(sk);
|
||||
struct ip_mc_socklist *iml;
|
||||
struct net *net = sock_net(sk);
|
||||
|
||||
if (inet->mc_list == NULL)
|
||||
return;
|
||||
|
||||
if (!net_eq(sock_net(sk), &init_net))
|
||||
return;
|
||||
|
||||
rtnl_lock();
|
||||
while ((iml = inet->mc_list) != NULL) {
|
||||
struct in_device *in_dev;
|
||||
inet->mc_list = iml->next;
|
||||
|
||||
in_dev = inetdev_by_index(&init_net, iml->multi.imr_ifindex);
|
||||
in_dev = inetdev_by_index(net, iml->multi.imr_ifindex);
|
||||
(void) ip_mc_leave_src(sk, iml, in_dev);
|
||||
if (in_dev != NULL) {
|
||||
ip_mc_dec_group(in_dev, iml->multi.imr_multiaddr.s_addr);
|
||||
|
@ -608,7 +608,7 @@ int ip_vs_skb_replace(struct sk_buff *skb, gfp_t pri,
|
||||
}
|
||||
|
||||
|
||||
int ip_vs_app_init(void)
|
||||
int __init ip_vs_app_init(void)
|
||||
{
|
||||
/* we will replace it with proc_net_ipvs_create() soon */
|
||||
proc_net_fops_create(&init_net, "ip_vs_app", 0, &ip_vs_app_fops);
|
||||
|
@ -965,7 +965,7 @@ static void ip_vs_conn_flush(void)
|
||||
}
|
||||
|
||||
|
||||
int ip_vs_conn_init(void)
|
||||
int __init ip_vs_conn_init(void)
|
||||
{
|
||||
int idx;
|
||||
|
||||
|
@ -683,9 +683,22 @@ static void
|
||||
ip_vs_zero_stats(struct ip_vs_stats *stats)
|
||||
{
|
||||
spin_lock_bh(&stats->lock);
|
||||
memset(stats, 0, (char *)&stats->lock - (char *)stats);
|
||||
spin_unlock_bh(&stats->lock);
|
||||
|
||||
stats->conns = 0;
|
||||
stats->inpkts = 0;
|
||||
stats->outpkts = 0;
|
||||
stats->inbytes = 0;
|
||||
stats->outbytes = 0;
|
||||
|
||||
stats->cps = 0;
|
||||
stats->inpps = 0;
|
||||
stats->outpps = 0;
|
||||
stats->inbps = 0;
|
||||
stats->outbps = 0;
|
||||
|
||||
ip_vs_zero_estimator(stats);
|
||||
|
||||
spin_unlock_bh(&stats->lock);
|
||||
}
|
||||
|
||||
/*
|
||||
@ -1589,7 +1602,7 @@ static struct ctl_table vs_vars[] = {
|
||||
{ .ctl_name = 0 }
|
||||
};
|
||||
|
||||
struct ctl_path net_vs_ctl_path[] = {
|
||||
const struct ctl_path net_vs_ctl_path[] = {
|
||||
{ .procname = "net", .ctl_name = CTL_NET, },
|
||||
{ .procname = "ipv4", .ctl_name = NET_IPV4, },
|
||||
{ .procname = "vs", },
|
||||
@ -1784,7 +1797,9 @@ static const struct file_operations ip_vs_info_fops = {
|
||||
|
||||
#endif
|
||||
|
||||
struct ip_vs_stats ip_vs_stats;
|
||||
struct ip_vs_stats ip_vs_stats = {
|
||||
.lock = __SPIN_LOCK_UNLOCKED(ip_vs_stats.lock),
|
||||
};
|
||||
|
||||
#ifdef CONFIG_PROC_FS
|
||||
static int ip_vs_stats_show(struct seq_file *seq, void *v)
|
||||
@ -2306,7 +2321,7 @@ static struct nf_sockopt_ops ip_vs_sockopts = {
|
||||
};
|
||||
|
||||
|
||||
int ip_vs_control_init(void)
|
||||
int __init ip_vs_control_init(void)
|
||||
{
|
||||
int ret;
|
||||
int idx;
|
||||
@ -2333,8 +2348,6 @@ int ip_vs_control_init(void)
|
||||
INIT_LIST_HEAD(&ip_vs_rtable[idx]);
|
||||
}
|
||||
|
||||
memset(&ip_vs_stats, 0, sizeof(ip_vs_stats));
|
||||
spin_lock_init(&ip_vs_stats.lock);
|
||||
ip_vs_new_estimator(&ip_vs_stats);
|
||||
|
||||
/* Hook the defense timer */
|
||||
|
@ -233,6 +233,7 @@ static struct ip_vs_scheduler ip_vs_dh_scheduler =
|
||||
.name = "dh",
|
||||
.refcnt = ATOMIC_INIT(0),
|
||||
.module = THIS_MODULE,
|
||||
.n_list = LIST_HEAD_INIT(ip_vs_dh_scheduler.n_list),
|
||||
.init_service = ip_vs_dh_init_svc,
|
||||
.done_service = ip_vs_dh_done_svc,
|
||||
.update_service = ip_vs_dh_update_svc,
|
||||
@ -242,7 +243,6 @@ static struct ip_vs_scheduler ip_vs_dh_scheduler =
|
||||
|
||||
static int __init ip_vs_dh_init(void)
|
||||
{
|
||||
INIT_LIST_HEAD(&ip_vs_dh_scheduler.n_list);
|
||||
return register_ip_vs_scheduler(&ip_vs_dh_scheduler);
|
||||
}
|
||||
|
||||
|
@ -17,6 +17,7 @@
|
||||
#include <linux/types.h>
|
||||
#include <linux/interrupt.h>
|
||||
#include <linux/sysctl.h>
|
||||
#include <linux/list.h>
|
||||
|
||||
#include <net/ip_vs.h>
|
||||
|
||||
@ -44,28 +45,11 @@
|
||||
*/
|
||||
|
||||
|
||||
struct ip_vs_estimator
|
||||
{
|
||||
struct ip_vs_estimator *next;
|
||||
struct ip_vs_stats *stats;
|
||||
static void estimation_timer(unsigned long arg);
|
||||
|
||||
u32 last_conns;
|
||||
u32 last_inpkts;
|
||||
u32 last_outpkts;
|
||||
u64 last_inbytes;
|
||||
u64 last_outbytes;
|
||||
|
||||
u32 cps;
|
||||
u32 inpps;
|
||||
u32 outpps;
|
||||
u32 inbps;
|
||||
u32 outbps;
|
||||
};
|
||||
|
||||
|
||||
static struct ip_vs_estimator *est_list = NULL;
|
||||
static DEFINE_RWLOCK(est_lock);
|
||||
static struct timer_list est_timer;
|
||||
static LIST_HEAD(est_list);
|
||||
static DEFINE_SPINLOCK(est_lock);
|
||||
static DEFINE_TIMER(est_timer, estimation_timer, 0, 0);
|
||||
|
||||
static void estimation_timer(unsigned long arg)
|
||||
{
|
||||
@ -76,9 +60,9 @@ static void estimation_timer(unsigned long arg)
|
||||
u64 n_inbytes, n_outbytes;
|
||||
u32 rate;
|
||||
|
||||
read_lock(&est_lock);
|
||||
for (e = est_list; e; e = e->next) {
|
||||
s = e->stats;
|
||||
spin_lock(&est_lock);
|
||||
list_for_each_entry(e, &est_list, list) {
|
||||
s = container_of(e, struct ip_vs_stats, est);
|
||||
|
||||
spin_lock(&s->lock);
|
||||
n_conns = s->conns;
|
||||
@ -114,19 +98,16 @@ static void estimation_timer(unsigned long arg)
|
||||
s->outbps = (e->outbps+0xF)>>5;
|
||||
spin_unlock(&s->lock);
|
||||
}
|
||||
read_unlock(&est_lock);
|
||||
spin_unlock(&est_lock);
|
||||
mod_timer(&est_timer, jiffies + 2*HZ);
|
||||
}
|
||||
|
||||
int ip_vs_new_estimator(struct ip_vs_stats *stats)
|
||||
void ip_vs_new_estimator(struct ip_vs_stats *stats)
|
||||
{
|
||||
struct ip_vs_estimator *est;
|
||||
struct ip_vs_estimator *est = &stats->est;
|
||||
|
||||
est = kzalloc(sizeof(*est), GFP_KERNEL);
|
||||
if (est == NULL)
|
||||
return -ENOMEM;
|
||||
INIT_LIST_HEAD(&est->list);
|
||||
|
||||
est->stats = stats;
|
||||
est->last_conns = stats->conns;
|
||||
est->cps = stats->cps<<10;
|
||||
|
||||
@ -142,59 +123,40 @@ int ip_vs_new_estimator(struct ip_vs_stats *stats)
|
||||
est->last_outbytes = stats->outbytes;
|
||||
est->outbps = stats->outbps<<5;
|
||||
|
||||
write_lock_bh(&est_lock);
|
||||
est->next = est_list;
|
||||
if (est->next == NULL) {
|
||||
setup_timer(&est_timer, estimation_timer, 0);
|
||||
est_timer.expires = jiffies + 2*HZ;
|
||||
add_timer(&est_timer);
|
||||
}
|
||||
est_list = est;
|
||||
write_unlock_bh(&est_lock);
|
||||
return 0;
|
||||
spin_lock_bh(&est_lock);
|
||||
if (list_empty(&est_list))
|
||||
mod_timer(&est_timer, jiffies + 2 * HZ);
|
||||
list_add(&est->list, &est_list);
|
||||
spin_unlock_bh(&est_lock);
|
||||
}
|
||||
|
||||
void ip_vs_kill_estimator(struct ip_vs_stats *stats)
|
||||
{
|
||||
struct ip_vs_estimator *est, **pest;
|
||||
int killed = 0;
|
||||
struct ip_vs_estimator *est = &stats->est;
|
||||
|
||||
write_lock_bh(&est_lock);
|
||||
pest = &est_list;
|
||||
while ((est=*pest) != NULL) {
|
||||
if (est->stats != stats) {
|
||||
pest = &est->next;
|
||||
continue;
|
||||
}
|
||||
*pest = est->next;
|
||||
kfree(est);
|
||||
killed++;
|
||||
spin_lock_bh(&est_lock);
|
||||
list_del(&est->list);
|
||||
while (list_empty(&est_list) && try_to_del_timer_sync(&est_timer) < 0) {
|
||||
spin_unlock_bh(&est_lock);
|
||||
cpu_relax();
|
||||
spin_lock_bh(&est_lock);
|
||||
}
|
||||
if (killed && est_list == NULL)
|
||||
del_timer_sync(&est_timer);
|
||||
write_unlock_bh(&est_lock);
|
||||
spin_unlock_bh(&est_lock);
|
||||
}
|
||||
|
||||
void ip_vs_zero_estimator(struct ip_vs_stats *stats)
|
||||
{
|
||||
struct ip_vs_estimator *e;
|
||||
struct ip_vs_estimator *est = &stats->est;
|
||||
|
||||
write_lock_bh(&est_lock);
|
||||
for (e = est_list; e; e = e->next) {
|
||||
if (e->stats != stats)
|
||||
continue;
|
||||
|
||||
/* set counters zero */
|
||||
e->last_conns = 0;
|
||||
e->last_inpkts = 0;
|
||||
e->last_outpkts = 0;
|
||||
e->last_inbytes = 0;
|
||||
e->last_outbytes = 0;
|
||||
e->cps = 0;
|
||||
e->inpps = 0;
|
||||
e->outpps = 0;
|
||||
e->inbps = 0;
|
||||
e->outbps = 0;
|
||||
}
|
||||
write_unlock_bh(&est_lock);
|
||||
/* set counters zero, caller must hold the stats->lock lock */
|
||||
est->last_inbytes = 0;
|
||||
est->last_outbytes = 0;
|
||||
est->last_conns = 0;
|
||||
est->last_inpkts = 0;
|
||||
est->last_outpkts = 0;
|
||||
est->cps = 0;
|
||||
est->inpps = 0;
|
||||
est->outpps = 0;
|
||||
est->inbps = 0;
|
||||
est->outbps = 0;
|
||||
}
|
||||
|
@ -539,6 +539,7 @@ static struct ip_vs_scheduler ip_vs_lblc_scheduler =
|
||||
.name = "lblc",
|
||||
.refcnt = ATOMIC_INIT(0),
|
||||
.module = THIS_MODULE,
|
||||
.n_list = LIST_HEAD_INIT(ip_vs_lblc_scheduler.n_list),
|
||||
.init_service = ip_vs_lblc_init_svc,
|
||||
.done_service = ip_vs_lblc_done_svc,
|
||||
.update_service = ip_vs_lblc_update_svc,
|
||||
@ -550,7 +551,6 @@ static int __init ip_vs_lblc_init(void)
|
||||
{
|
||||
int ret;
|
||||
|
||||
INIT_LIST_HEAD(&ip_vs_lblc_scheduler.n_list);
|
||||
sysctl_header = register_sysctl_paths(net_vs_ctl_path, vs_vars_table);
|
||||
ret = register_ip_vs_scheduler(&ip_vs_lblc_scheduler);
|
||||
if (ret)
|
||||
|
@ -728,6 +728,7 @@ static struct ip_vs_scheduler ip_vs_lblcr_scheduler =
|
||||
.name = "lblcr",
|
||||
.refcnt = ATOMIC_INIT(0),
|
||||
.module = THIS_MODULE,
|
||||
.n_list = LIST_HEAD_INIT(ip_vs_lblcr_scheduler.n_list),
|
||||
.init_service = ip_vs_lblcr_init_svc,
|
||||
.done_service = ip_vs_lblcr_done_svc,
|
||||
.update_service = ip_vs_lblcr_update_svc,
|
||||
@ -739,7 +740,6 @@ static int __init ip_vs_lblcr_init(void)
|
||||
{
|
||||
int ret;
|
||||
|
||||
INIT_LIST_HEAD(&ip_vs_lblcr_scheduler.n_list);
|
||||
sysctl_header = register_sysctl_paths(net_vs_ctl_path, vs_vars_table);
|
||||
ret = register_ip_vs_scheduler(&ip_vs_lblcr_scheduler);
|
||||
if (ret)
|
||||
|
@ -98,6 +98,7 @@ static struct ip_vs_scheduler ip_vs_lc_scheduler = {
|
||||
.name = "lc",
|
||||
.refcnt = ATOMIC_INIT(0),
|
||||
.module = THIS_MODULE,
|
||||
.n_list = LIST_HEAD_INIT(ip_vs_lc_scheduler.n_list),
|
||||
.init_service = ip_vs_lc_init_svc,
|
||||
.done_service = ip_vs_lc_done_svc,
|
||||
.update_service = ip_vs_lc_update_svc,
|
||||
@ -107,7 +108,6 @@ static struct ip_vs_scheduler ip_vs_lc_scheduler = {
|
||||
|
||||
static int __init ip_vs_lc_init(void)
|
||||
{
|
||||
INIT_LIST_HEAD(&ip_vs_lc_scheduler.n_list);
|
||||
return register_ip_vs_scheduler(&ip_vs_lc_scheduler) ;
|
||||
}
|
||||
|
||||
|
@ -136,6 +136,7 @@ static struct ip_vs_scheduler ip_vs_nq_scheduler =
|
||||
.name = "nq",
|
||||
.refcnt = ATOMIC_INIT(0),
|
||||
.module = THIS_MODULE,
|
||||
.n_list = LIST_HEAD_INIT(ip_vs_nq_scheduler.n_list),
|
||||
.init_service = ip_vs_nq_init_svc,
|
||||
.done_service = ip_vs_nq_done_svc,
|
||||
.update_service = ip_vs_nq_update_svc,
|
||||
@ -145,7 +146,6 @@ static struct ip_vs_scheduler ip_vs_nq_scheduler =
|
||||
|
||||
static int __init ip_vs_nq_init(void)
|
||||
{
|
||||
INIT_LIST_HEAD(&ip_vs_nq_scheduler.n_list);
|
||||
return register_ip_vs_scheduler(&ip_vs_nq_scheduler);
|
||||
}
|
||||
|
||||
|
@ -43,7 +43,7 @@ static struct ip_vs_protocol *ip_vs_proto_table[IP_VS_PROTO_TAB_SIZE];
|
||||
/*
|
||||
* register an ipvs protocol
|
||||
*/
|
||||
static int __used register_ip_vs_protocol(struct ip_vs_protocol *pp)
|
||||
static int __used __init register_ip_vs_protocol(struct ip_vs_protocol *pp)
|
||||
{
|
||||
unsigned hash = IP_VS_PROTO_HASH(pp->protocol);
|
||||
|
||||
@ -190,7 +190,7 @@ ip_vs_tcpudp_debug_packet(struct ip_vs_protocol *pp,
|
||||
}
|
||||
|
||||
|
||||
int ip_vs_protocol_init(void)
|
||||
int __init ip_vs_protocol_init(void)
|
||||
{
|
||||
char protocols[64];
|
||||
#define REGISTER_PROTOCOL(p) \
|
||||
|
@ -94,6 +94,7 @@ static struct ip_vs_scheduler ip_vs_rr_scheduler = {
|
||||
.name = "rr", /* name */
|
||||
.refcnt = ATOMIC_INIT(0),
|
||||
.module = THIS_MODULE,
|
||||
.n_list = LIST_HEAD_INIT(ip_vs_rr_scheduler.n_list),
|
||||
.init_service = ip_vs_rr_init_svc,
|
||||
.done_service = ip_vs_rr_done_svc,
|
||||
.update_service = ip_vs_rr_update_svc,
|
||||
@ -102,7 +103,6 @@ static struct ip_vs_scheduler ip_vs_rr_scheduler = {
|
||||
|
||||
static int __init ip_vs_rr_init(void)
|
||||
{
|
||||
INIT_LIST_HEAD(&ip_vs_rr_scheduler.n_list);
|
||||
return register_ip_vs_scheduler(&ip_vs_rr_scheduler);
|
||||
}
|
||||
|
||||
|
@ -184,7 +184,7 @@ int register_ip_vs_scheduler(struct ip_vs_scheduler *scheduler)
|
||||
|
||||
write_lock_bh(&__ip_vs_sched_lock);
|
||||
|
||||
if (scheduler->n_list.next != &scheduler->n_list) {
|
||||
if (!list_empty(&scheduler->n_list)) {
|
||||
write_unlock_bh(&__ip_vs_sched_lock);
|
||||
ip_vs_use_count_dec();
|
||||
IP_VS_ERR("register_ip_vs_scheduler(): [%s] scheduler "
|
||||
@ -229,7 +229,7 @@ int unregister_ip_vs_scheduler(struct ip_vs_scheduler *scheduler)
|
||||
}
|
||||
|
||||
write_lock_bh(&__ip_vs_sched_lock);
|
||||
if (scheduler->n_list.next == &scheduler->n_list) {
|
||||
if (list_empty(&scheduler->n_list)) {
|
||||
write_unlock_bh(&__ip_vs_sched_lock);
|
||||
IP_VS_ERR("unregister_ip_vs_scheduler(): [%s] scheduler "
|
||||
"is not in the list. failed\n", scheduler->name);
|
||||
|
@ -138,6 +138,7 @@ static struct ip_vs_scheduler ip_vs_sed_scheduler =
|
||||
.name = "sed",
|
||||
.refcnt = ATOMIC_INIT(0),
|
||||
.module = THIS_MODULE,
|
||||
.n_list = LIST_HEAD_INIT(ip_vs_sed_scheduler.n_list),
|
||||
.init_service = ip_vs_sed_init_svc,
|
||||
.done_service = ip_vs_sed_done_svc,
|
||||
.update_service = ip_vs_sed_update_svc,
|
||||
@ -147,7 +148,6 @@ static struct ip_vs_scheduler ip_vs_sed_scheduler =
|
||||
|
||||
static int __init ip_vs_sed_init(void)
|
||||
{
|
||||
INIT_LIST_HEAD(&ip_vs_sed_scheduler.n_list);
|
||||
return register_ip_vs_scheduler(&ip_vs_sed_scheduler);
|
||||
}
|
||||
|
||||
|
@ -230,6 +230,7 @@ static struct ip_vs_scheduler ip_vs_sh_scheduler =
|
||||
.name = "sh",
|
||||
.refcnt = ATOMIC_INIT(0),
|
||||
.module = THIS_MODULE,
|
||||
.n_list = LIST_HEAD_INIT(ip_vs_sh_scheduler.n_list),
|
||||
.init_service = ip_vs_sh_init_svc,
|
||||
.done_service = ip_vs_sh_done_svc,
|
||||
.update_service = ip_vs_sh_update_svc,
|
||||
@ -239,7 +240,6 @@ static struct ip_vs_scheduler ip_vs_sh_scheduler =
|
||||
|
||||
static int __init ip_vs_sh_init(void)
|
||||
{
|
||||
INIT_LIST_HEAD(&ip_vs_sh_scheduler.n_list);
|
||||
return register_ip_vs_scheduler(&ip_vs_sh_scheduler);
|
||||
}
|
||||
|
||||
|
@ -904,9 +904,9 @@ int stop_sync_thread(int state)
|
||||
* progress of stopping the master sync daemon.
|
||||
*/
|
||||
|
||||
spin_lock(&ip_vs_sync_lock);
|
||||
spin_lock_bh(&ip_vs_sync_lock);
|
||||
ip_vs_sync_state &= ~IP_VS_STATE_MASTER;
|
||||
spin_unlock(&ip_vs_sync_lock);
|
||||
spin_unlock_bh(&ip_vs_sync_lock);
|
||||
kthread_stop(sync_master_thread);
|
||||
sync_master_thread = NULL;
|
||||
} else if (state == IP_VS_STATE_BACKUP) {
|
||||
|
@ -126,6 +126,7 @@ static struct ip_vs_scheduler ip_vs_wlc_scheduler =
|
||||
.name = "wlc",
|
||||
.refcnt = ATOMIC_INIT(0),
|
||||
.module = THIS_MODULE,
|
||||
.n_list = LIST_HEAD_INIT(ip_vs_wlc_scheduler.n_list),
|
||||
.init_service = ip_vs_wlc_init_svc,
|
||||
.done_service = ip_vs_wlc_done_svc,
|
||||
.update_service = ip_vs_wlc_update_svc,
|
||||
@ -135,7 +136,6 @@ static struct ip_vs_scheduler ip_vs_wlc_scheduler =
|
||||
|
||||
static int __init ip_vs_wlc_init(void)
|
||||
{
|
||||
INIT_LIST_HEAD(&ip_vs_wlc_scheduler.n_list);
|
||||
return register_ip_vs_scheduler(&ip_vs_wlc_scheduler);
|
||||
}
|
||||
|
||||
|
@ -212,6 +212,7 @@ static struct ip_vs_scheduler ip_vs_wrr_scheduler = {
|
||||
.name = "wrr",
|
||||
.refcnt = ATOMIC_INIT(0),
|
||||
.module = THIS_MODULE,
|
||||
.n_list = LIST_HEAD_INIT(ip_vs_wrr_scheduler.n_list),
|
||||
.init_service = ip_vs_wrr_init_svc,
|
||||
.done_service = ip_vs_wrr_done_svc,
|
||||
.update_service = ip_vs_wrr_update_svc,
|
||||
@ -220,7 +221,6 @@ static struct ip_vs_scheduler ip_vs_wrr_scheduler = {
|
||||
|
||||
static int __init ip_vs_wrr_init(void)
|
||||
{
|
||||
INIT_LIST_HEAD(&ip_vs_wrr_scheduler.n_list);
|
||||
return register_ip_vs_scheduler(&ip_vs_wrr_scheduler) ;
|
||||
}
|
||||
|
||||
|
@ -989,7 +989,9 @@ int udp_queue_rcv_skb(struct sock * sk, struct sk_buff *skb)
|
||||
up->encap_rcv != NULL) {
|
||||
int ret;
|
||||
|
||||
bh_unlock_sock(sk);
|
||||
ret = (*up->encap_rcv)(sk, skb);
|
||||
bh_lock_sock(sk);
|
||||
if (ret <= 0) {
|
||||
UDP_INC_STATS_BH(sock_net(sk),
|
||||
UDP_MIB_INDATAGRAMS,
|
||||
@ -1092,7 +1094,7 @@ static int __udp4_lib_mcast_deliver(struct net *net, struct sk_buff *skb,
|
||||
if (skb1) {
|
||||
int ret = 0;
|
||||
|
||||
bh_lock_sock_nested(sk);
|
||||
bh_lock_sock(sk);
|
||||
if (!sock_owned_by_user(sk))
|
||||
ret = udp_queue_rcv_skb(sk, skb1);
|
||||
else
|
||||
@ -1194,7 +1196,7 @@ int __udp4_lib_rcv(struct sk_buff *skb, struct hlist_head udptable[],
|
||||
|
||||
if (sk != NULL) {
|
||||
int ret = 0;
|
||||
bh_lock_sock_nested(sk);
|
||||
bh_lock_sock(sk);
|
||||
if (!sock_owned_by_user(sk))
|
||||
ret = udp_queue_rcv_skb(sk, skb);
|
||||
else
|
||||
|
@ -2187,8 +2187,9 @@ static int rt6_fill_node(struct sk_buff *skb, struct rt6_info *rt,
|
||||
#endif
|
||||
NLA_PUT_U32(skb, RTA_IIF, iif);
|
||||
} else if (dst) {
|
||||
struct inet6_dev *idev = ip6_dst_idev(&rt->u.dst);
|
||||
struct in6_addr saddr_buf;
|
||||
if (ipv6_dev_get_saddr(ip6_dst_idev(&rt->u.dst)->dev,
|
||||
if (ipv6_dev_get_saddr(idev ? idev->dev : NULL,
|
||||
dst, 0, &saddr_buf) == 0)
|
||||
NLA_PUT(skb, RTA_PREFSRC, 16, &saddr_buf);
|
||||
}
|
||||
|
@ -379,7 +379,7 @@ static int __udp6_lib_mcast_deliver(struct net *net, struct sk_buff *skb,
|
||||
uh->source, saddr, dif))) {
|
||||
struct sk_buff *buff = skb_clone(skb, GFP_ATOMIC);
|
||||
if (buff) {
|
||||
bh_lock_sock_nested(sk2);
|
||||
bh_lock_sock(sk2);
|
||||
if (!sock_owned_by_user(sk2))
|
||||
udpv6_queue_rcv_skb(sk2, buff);
|
||||
else
|
||||
@ -387,7 +387,7 @@ static int __udp6_lib_mcast_deliver(struct net *net, struct sk_buff *skb,
|
||||
bh_unlock_sock(sk2);
|
||||
}
|
||||
}
|
||||
bh_lock_sock_nested(sk);
|
||||
bh_lock_sock(sk);
|
||||
if (!sock_owned_by_user(sk))
|
||||
udpv6_queue_rcv_skb(sk, skb);
|
||||
else
|
||||
@ -508,7 +508,7 @@ int __udp6_lib_rcv(struct sk_buff *skb, struct hlist_head udptable[],
|
||||
|
||||
/* deliver */
|
||||
|
||||
bh_lock_sock_nested(sk);
|
||||
bh_lock_sock(sk);
|
||||
if (!sock_owned_by_user(sk))
|
||||
udpv6_queue_rcv_skb(sk, skb);
|
||||
else
|
||||
|
@ -100,7 +100,7 @@ static int rxrpc_accept_incoming_call(struct rxrpc_local *local,
|
||||
|
||||
trans = rxrpc_get_transport(local, peer, GFP_NOIO);
|
||||
rxrpc_put_peer(peer);
|
||||
if (!trans) {
|
||||
if (IS_ERR(trans)) {
|
||||
_debug("no trans");
|
||||
ret = -EBUSY;
|
||||
goto error;
|
||||
|
@ -751,7 +751,7 @@ static int tca_action_flush(struct nlattr *nla, struct nlmsghdr *n, u32 pid)
|
||||
struct nlattr *tb[TCA_ACT_MAX+1];
|
||||
struct nlattr *kind;
|
||||
struct tc_action *a = create_a(0);
|
||||
int err = -EINVAL;
|
||||
int err = -ENOMEM;
|
||||
|
||||
if (a == NULL) {
|
||||
printk("tca_action_flush: couldnt create tc_action\n");
|
||||
@ -762,7 +762,7 @@ static int tca_action_flush(struct nlattr *nla, struct nlmsghdr *n, u32 pid)
|
||||
if (!skb) {
|
||||
printk("tca_action_flush: failed skb alloc\n");
|
||||
kfree(a);
|
||||
return -ENOBUFS;
|
||||
return err;
|
||||
}
|
||||
|
||||
b = skb_tail_pointer(skb);
|
||||
@ -790,6 +790,8 @@ static int tca_action_flush(struct nlattr *nla, struct nlmsghdr *n, u32 pid)
|
||||
err = a->ops->walk(skb, &dcb, RTM_DELACTION, a);
|
||||
if (err < 0)
|
||||
goto nla_put_failure;
|
||||
if (err == 0)
|
||||
goto noflush_out;
|
||||
|
||||
nla_nest_end(skb, nest);
|
||||
|
||||
@ -807,6 +809,7 @@ static int tca_action_flush(struct nlattr *nla, struct nlmsghdr *n, u32 pid)
|
||||
nlmsg_failure:
|
||||
module_put(a->ops->owner);
|
||||
err_out:
|
||||
noflush_out:
|
||||
kfree_skb(skb);
|
||||
kfree(a);
|
||||
return err;
|
||||
@ -824,8 +827,10 @@ tca_action_gd(struct nlattr *nla, struct nlmsghdr *n, u32 pid, int event)
|
||||
return ret;
|
||||
|
||||
if (event == RTM_DELACTION && n->nlmsg_flags&NLM_F_ROOT) {
|
||||
if (tb[0] != NULL && tb[1] == NULL)
|
||||
return tca_action_flush(tb[0], n, pid);
|
||||
if (tb[1] != NULL)
|
||||
return tca_action_flush(tb[1], n, pid);
|
||||
else
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
for (i = 1; i <= TCA_ACT_MAX_PRIO && tb[i]; i++) {
|
||||
|
@ -183,6 +183,21 @@ EXPORT_SYMBOL(unregister_qdisc);
|
||||
(root qdisc, all its children, children of children etc.)
|
||||
*/
|
||||
|
||||
struct Qdisc *qdisc_match_from_root(struct Qdisc *root, u32 handle)
|
||||
{
|
||||
struct Qdisc *q;
|
||||
|
||||
if (!(root->flags & TCQ_F_BUILTIN) &&
|
||||
root->handle == handle)
|
||||
return root;
|
||||
|
||||
list_for_each_entry(q, &root->list, list) {
|
||||
if (q->handle == handle)
|
||||
return q;
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
|
||||
struct Qdisc *qdisc_lookup(struct net_device *dev, u32 handle)
|
||||
{
|
||||
unsigned int i;
|
||||
@ -191,16 +206,11 @@ struct Qdisc *qdisc_lookup(struct net_device *dev, u32 handle)
|
||||
struct netdev_queue *txq = netdev_get_tx_queue(dev, i);
|
||||
struct Qdisc *q, *txq_root = txq->qdisc_sleeping;
|
||||
|
||||
if (!(txq_root->flags & TCQ_F_BUILTIN) &&
|
||||
txq_root->handle == handle)
|
||||
return txq_root;
|
||||
|
||||
list_for_each_entry(q, &txq_root->list, list) {
|
||||
if (q->handle == handle)
|
||||
return q;
|
||||
}
|
||||
q = qdisc_match_from_root(txq_root, handle);
|
||||
if (q)
|
||||
return q;
|
||||
}
|
||||
return NULL;
|
||||
return qdisc_match_from_root(dev->rx_queue.qdisc_sleeping, handle);
|
||||
}
|
||||
|
||||
static struct Qdisc *qdisc_leaf(struct Qdisc *p, u32 classid)
|
||||
@ -321,7 +331,7 @@ static struct qdisc_size_table *qdisc_get_stab(struct nlattr *opt)
|
||||
if (!s || tsize != s->tsize || (!tab && tsize > 0))
|
||||
return ERR_PTR(-EINVAL);
|
||||
|
||||
spin_lock(&qdisc_stab_lock);
|
||||
spin_lock_bh(&qdisc_stab_lock);
|
||||
|
||||
list_for_each_entry(stab, &qdisc_stab_list, list) {
|
||||
if (memcmp(&stab->szopts, s, sizeof(*s)))
|
||||
@ -329,11 +339,11 @@ static struct qdisc_size_table *qdisc_get_stab(struct nlattr *opt)
|
||||
if (tsize > 0 && memcmp(stab->data, tab, tsize * sizeof(u16)))
|
||||
continue;
|
||||
stab->refcnt++;
|
||||
spin_unlock(&qdisc_stab_lock);
|
||||
spin_unlock_bh(&qdisc_stab_lock);
|
||||
return stab;
|
||||
}
|
||||
|
||||
spin_unlock(&qdisc_stab_lock);
|
||||
spin_unlock_bh(&qdisc_stab_lock);
|
||||
|
||||
stab = kmalloc(sizeof(*stab) + tsize * sizeof(u16), GFP_KERNEL);
|
||||
if (!stab)
|
||||
@ -344,9 +354,9 @@ static struct qdisc_size_table *qdisc_get_stab(struct nlattr *opt)
|
||||
if (tsize > 0)
|
||||
memcpy(stab->data, tab, tsize * sizeof(u16));
|
||||
|
||||
spin_lock(&qdisc_stab_lock);
|
||||
spin_lock_bh(&qdisc_stab_lock);
|
||||
list_add_tail(&stab->list, &qdisc_stab_list);
|
||||
spin_unlock(&qdisc_stab_lock);
|
||||
spin_unlock_bh(&qdisc_stab_lock);
|
||||
|
||||
return stab;
|
||||
}
|
||||
@ -356,14 +366,14 @@ void qdisc_put_stab(struct qdisc_size_table *tab)
|
||||
if (!tab)
|
||||
return;
|
||||
|
||||
spin_lock(&qdisc_stab_lock);
|
||||
spin_lock_bh(&qdisc_stab_lock);
|
||||
|
||||
if (--tab->refcnt == 0) {
|
||||
list_del(&tab->list);
|
||||
kfree(tab);
|
||||
}
|
||||
|
||||
spin_unlock(&qdisc_stab_lock);
|
||||
spin_unlock_bh(&qdisc_stab_lock);
|
||||
}
|
||||
EXPORT_SYMBOL(qdisc_put_stab);
|
||||
|
||||
@ -908,7 +918,7 @@ static int tc_get_qdisc(struct sk_buff *skb, struct nlmsghdr *n, void *arg)
|
||||
return -ENOENT;
|
||||
q = qdisc_leaf(p, clid);
|
||||
} else { /* ingress */
|
||||
q = dev->rx_queue.qdisc;
|
||||
q = dev->rx_queue.qdisc_sleeping;
|
||||
}
|
||||
} else {
|
||||
struct netdev_queue *dev_queue;
|
||||
@ -978,7 +988,7 @@ static int tc_modify_qdisc(struct sk_buff *skb, struct nlmsghdr *n, void *arg)
|
||||
return -ENOENT;
|
||||
q = qdisc_leaf(p, clid);
|
||||
} else { /*ingress */
|
||||
q = dev->rx_queue.qdisc;
|
||||
q = dev->rx_queue.qdisc_sleeping;
|
||||
}
|
||||
} else {
|
||||
struct netdev_queue *dev_queue;
|
||||
@ -1529,11 +1539,11 @@ static int tc_dump_tclass(struct sk_buff *skb, struct netlink_callback *cb)
|
||||
t = 0;
|
||||
|
||||
dev_queue = netdev_get_tx_queue(dev, 0);
|
||||
if (tc_dump_tclass_root(dev_queue->qdisc, skb, tcm, cb, &t, s_t) < 0)
|
||||
if (tc_dump_tclass_root(dev_queue->qdisc_sleeping, skb, tcm, cb, &t, s_t) < 0)
|
||||
goto done;
|
||||
|
||||
dev_queue = &dev->rx_queue;
|
||||
if (tc_dump_tclass_root(dev_queue->qdisc, skb, tcm, cb, &t, s_t) < 0)
|
||||
if (tc_dump_tclass_root(dev_queue->qdisc_sleeping, skb, tcm, cb, &t, s_t) < 0)
|
||||
goto done;
|
||||
|
||||
done:
|
||||
|
@ -647,7 +647,7 @@ static void dev_deactivate_queue(struct net_device *dev,
|
||||
}
|
||||
}
|
||||
|
||||
static bool some_qdisc_is_running(struct net_device *dev, int lock)
|
||||
static bool some_qdisc_is_busy(struct net_device *dev, int lock)
|
||||
{
|
||||
unsigned int i;
|
||||
|
||||
@ -658,13 +658,14 @@ static bool some_qdisc_is_running(struct net_device *dev, int lock)
|
||||
int val;
|
||||
|
||||
dev_queue = netdev_get_tx_queue(dev, i);
|
||||
q = dev_queue->qdisc;
|
||||
q = dev_queue->qdisc_sleeping;
|
||||
root_lock = qdisc_lock(q);
|
||||
|
||||
if (lock)
|
||||
spin_lock_bh(root_lock);
|
||||
|
||||
val = test_bit(__QDISC_STATE_RUNNING, &q->state);
|
||||
val = (test_bit(__QDISC_STATE_RUNNING, &q->state) ||
|
||||
test_bit(__QDISC_STATE_SCHED, &q->state));
|
||||
|
||||
if (lock)
|
||||
spin_unlock_bh(root_lock);
|
||||
@ -689,14 +690,14 @@ void dev_deactivate(struct net_device *dev)
|
||||
|
||||
/* Wait for outstanding qdisc_run calls. */
|
||||
do {
|
||||
while (some_qdisc_is_running(dev, 0))
|
||||
while (some_qdisc_is_busy(dev, 0))
|
||||
yield();
|
||||
|
||||
/*
|
||||
* Double-check inside queue lock to ensure that all effects
|
||||
* of the queue run are visible when we return.
|
||||
*/
|
||||
running = some_qdisc_is_running(dev, 1);
|
||||
running = some_qdisc_is_busy(dev, 1);
|
||||
|
||||
/*
|
||||
* The running flag should never be set at this point because
|
||||
|
@ -1279,7 +1279,8 @@ static int htb_delete(struct Qdisc *sch, unsigned long arg)
|
||||
|
||||
/* delete from hash and active; remainder in destroy_class */
|
||||
qdisc_class_hash_remove(&q->clhash, &cl->common);
|
||||
cl->parent->children--;
|
||||
if (cl->parent)
|
||||
cl->parent->children--;
|
||||
|
||||
if (cl->prio_activity)
|
||||
htb_deactivate(q, cl);
|
||||
|
@ -85,7 +85,7 @@ static struct top_srv topsrv = { 0 };
|
||||
|
||||
static u32 htohl(u32 in, int swap)
|
||||
{
|
||||
return swap ? (u32)___constant_swab32(in) : in;
|
||||
return swap ? swab32(in) : in;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -1277,6 +1277,7 @@ static int rtnetlink_fill_iwinfo(struct sk_buff *skb, struct net_device *dev,
|
||||
r->ifi_flags = dev_get_flags(dev);
|
||||
r->ifi_change = 0; /* Wireless changes don't affect those flags */
|
||||
|
||||
NLA_PUT_STRING(skb, IFLA_IFNAME, dev->name);
|
||||
/* Add the wireless events in the netlink packet */
|
||||
NLA_PUT(skb, IFLA_WIRELESS, event_len, event);
|
||||
|
||||
|
@ -112,16 +112,13 @@ static int xfrm_output_one(struct sk_buff *skb, int err)
|
||||
int xfrm_output_resume(struct sk_buff *skb, int err)
|
||||
{
|
||||
while (likely((err = xfrm_output_one(skb, err)) == 0)) {
|
||||
struct xfrm_state *x;
|
||||
|
||||
nf_reset(skb);
|
||||
|
||||
err = skb->dst->ops->local_out(skb);
|
||||
if (unlikely(err != 1))
|
||||
goto out;
|
||||
|
||||
x = skb->dst->xfrm;
|
||||
if (!x)
|
||||
if (!skb->dst->xfrm)
|
||||
return dst_output(skb);
|
||||
|
||||
err = nf_hook(skb->dst->ops->family,
|
||||
|
Loading…
Reference in New Issue
Block a user