aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net
diff options
context:
space:
mode:
authorSreenivasa Honnur <Sreenivasa.Honnur@neterion.com>2008-04-23 13:31:33 -0400
committerJeff Garzik <jgarzik@redhat.com>2008-04-25 02:07:11 -0400
commitc9fcbf4774d7a29b73078017af25d100f152a4af (patch)
tree3dad8c0860092e755ee69ab83fc09bf8082454ea /drivers/net
parent99993af6981aaf8d212a5efa888a19c9db152d58 (diff)
S2io: Removed rx_lock and put_lock
- Removed rx_lock and put_lock as the buffer replenishment and receive completion is handled serially. Signed-off-by: Surjit Reang <surjit.reang@neterion.com> Signed-off-by: Sreenivasa Honnur <sreenivasa.honnur@neterion.com> Signed-off-by: Ramkrishna Vepa <ram.vepa@neterion.com> Signed-off-by: Jeff Garzik <jgarzik@redhat.com>
Diffstat (limited to 'drivers/net')
-rw-r--r--drivers/net/s2io.c31
-rw-r--r--drivers/net/s2io.h6
2 files changed, 2 insertions, 35 deletions
diff --git a/drivers/net/s2io.c b/drivers/net/s2io.c
index 4344e6ed9041..157fd932e951 100644
--- a/drivers/net/s2io.c
+++ b/drivers/net/s2io.c
@@ -2530,7 +2530,6 @@ static int fill_rx_buffers(struct s2io_nic *nic, int ring_no)
2530 struct config_param *config; 2530 struct config_param *config;
2531 u64 tmp; 2531 u64 tmp;
2532 struct buffAdd *ba; 2532 struct buffAdd *ba;
2533 unsigned long flags;
2534 struct RxD_t *first_rxdp = NULL; 2533 struct RxD_t *first_rxdp = NULL;
2535 u64 Buffer0_ptr = 0, Buffer1_ptr = 0; 2534 u64 Buffer0_ptr = 0, Buffer1_ptr = 0;
2536 struct RxD1 *rxdp1; 2535 struct RxD1 *rxdp1;
@@ -2578,15 +2577,7 @@ static int fill_rx_buffers(struct s2io_nic *nic, int ring_no)
2578 DBG_PRINT(INTR_DBG, "%s: Next block at: %p\n", 2577 DBG_PRINT(INTR_DBG, "%s: Next block at: %p\n",
2579 dev->name, rxdp); 2578 dev->name, rxdp);
2580 } 2579 }
2581 if(!napi) { 2580
2582 spin_lock_irqsave(&nic->put_lock, flags);
2583 mac_control->rings[ring_no].put_pos =
2584 (block_no * (rxd_count[nic->rxd_mode] + 1)) + off;
2585 spin_unlock_irqrestore(&nic->put_lock, flags);
2586 } else {
2587 mac_control->rings[ring_no].put_pos =
2588 (block_no * (rxd_count[nic->rxd_mode] + 1)) + off;
2589 }
2590 if ((rxdp->Control_1 & RXD_OWN_XENA) && 2581 if ((rxdp->Control_1 & RXD_OWN_XENA) &&
2591 ((nic->rxd_mode == RXD_MODE_3B) && 2582 ((nic->rxd_mode == RXD_MODE_3B) &&
2592 (rxdp->Control_2 & s2BIT(0)))) { 2583 (rxdp->Control_2 & s2BIT(0)))) {
@@ -2964,7 +2955,7 @@ static void rx_intr_handler(struct ring_info *ring_data)
2964{ 2955{
2965 struct s2io_nic *nic = ring_data->nic; 2956 struct s2io_nic *nic = ring_data->nic;
2966 struct net_device *dev = (struct net_device *) nic->dev; 2957 struct net_device *dev = (struct net_device *) nic->dev;
2967 int get_block, put_block, put_offset; 2958 int get_block, put_block;
2968 struct rx_curr_get_info get_info, put_info; 2959 struct rx_curr_get_info get_info, put_info;
2969 struct RxD_t *rxdp; 2960 struct RxD_t *rxdp;
2970 struct sk_buff *skb; 2961 struct sk_buff *skb;
@@ -2973,19 +2964,11 @@ static void rx_intr_handler(struct ring_info *ring_data)
2973 struct RxD1* rxdp1; 2964 struct RxD1* rxdp1;
2974 struct RxD3* rxdp3; 2965 struct RxD3* rxdp3;
2975 2966
2976 spin_lock(&nic->rx_lock);
2977
2978 get_info = ring_data->rx_curr_get_info; 2967 get_info = ring_data->rx_curr_get_info;
2979 get_block = get_info.block_index; 2968 get_block = get_info.block_index;
2980 memcpy(&put_info, &ring_data->rx_curr_put_info, sizeof(put_info)); 2969 memcpy(&put_info, &ring_data->rx_curr_put_info, sizeof(put_info));
2981 put_block = put_info.block_index; 2970 put_block = put_info.block_index;
2982 rxdp = ring_data->rx_blocks[get_block].rxds[get_info.offset].virt_addr; 2971 rxdp = ring_data->rx_blocks[get_block].rxds[get_info.offset].virt_addr;
2983 if (!napi) {
2984 spin_lock(&nic->put_lock);
2985 put_offset = ring_data->put_pos;
2986 spin_unlock(&nic->put_lock);
2987 } else
2988 put_offset = ring_data->put_pos;
2989 2972
2990 while (RXD_IS_UP2DT(rxdp)) { 2973 while (RXD_IS_UP2DT(rxdp)) {
2991 /* 2974 /*
@@ -3002,7 +2985,6 @@ static void rx_intr_handler(struct ring_info *ring_data)
3002 DBG_PRINT(ERR_DBG, "%s: The skb is ", 2985 DBG_PRINT(ERR_DBG, "%s: The skb is ",
3003 dev->name); 2986 dev->name);
3004 DBG_PRINT(ERR_DBG, "Null in Rx Intr\n"); 2987 DBG_PRINT(ERR_DBG, "Null in Rx Intr\n");
3005 spin_unlock(&nic->rx_lock);
3006 return; 2988 return;
3007 } 2989 }
3008 if (nic->rxd_mode == RXD_MODE_1) { 2990 if (nic->rxd_mode == RXD_MODE_1) {
@@ -3058,8 +3040,6 @@ static void rx_intr_handler(struct ring_info *ring_data)
3058 } 3040 }
3059 } 3041 }
3060 } 3042 }
3061
3062 spin_unlock(&nic->rx_lock);
3063} 3043}
3064 3044
3065/** 3045/**
@@ -7083,7 +7063,6 @@ static void do_s2io_card_down(struct s2io_nic * sp, int do_io)
7083{ 7063{
7084 int cnt = 0; 7064 int cnt = 0;
7085 struct XENA_dev_config __iomem *bar0 = sp->bar0; 7065 struct XENA_dev_config __iomem *bar0 = sp->bar0;
7086 unsigned long flags;
7087 register u64 val64 = 0; 7066 register u64 val64 = 0;
7088 struct config_param *config; 7067 struct config_param *config;
7089 config = &sp->config; 7068 config = &sp->config;
@@ -7142,9 +7121,7 @@ static void do_s2io_card_down(struct s2io_nic * sp, int do_io)
7142 free_tx_buffers(sp); 7121 free_tx_buffers(sp);
7143 7122
7144 /* Free all Rx buffers */ 7123 /* Free all Rx buffers */
7145 spin_lock_irqsave(&sp->rx_lock, flags);
7146 free_rx_buffers(sp); 7124 free_rx_buffers(sp);
7147 spin_unlock_irqrestore(&sp->rx_lock, flags);
7148 7125
7149 clear_bit(__S2IO_STATE_LINK_TASK, &(sp->state)); 7126 clear_bit(__S2IO_STATE_LINK_TASK, &(sp->state));
7150} 7127}
@@ -8044,10 +8021,6 @@ s2io_init_nic(struct pci_dev *pdev, const struct pci_device_id *pre)
8044 for (i = 0; i < sp->config.tx_fifo_num; i++) 8021 for (i = 0; i < sp->config.tx_fifo_num; i++)
8045 spin_lock_init(&mac_control->fifos[i].tx_lock); 8022 spin_lock_init(&mac_control->fifos[i].tx_lock);
8046 8023
8047 if (!napi)
8048 spin_lock_init(&sp->put_lock);
8049 spin_lock_init(&sp->rx_lock);
8050
8051 /* 8024 /*
8052 * SXE-002: Configure link and activity LED to init state 8025 * SXE-002: Configure link and activity LED to init state
8053 * on driver load. 8026 * on driver load.
diff --git a/drivers/net/s2io.h b/drivers/net/s2io.h
index e3136cfd6db2..ce53a02105f2 100644
--- a/drivers/net/s2io.h
+++ b/drivers/net/s2io.h
@@ -703,9 +703,6 @@ struct ring_info {
703 */ 703 */
704 struct rx_curr_get_info rx_curr_get_info; 704 struct rx_curr_get_info rx_curr_get_info;
705 705
706 /* Index to the absolute position of the put pointer of Rx ring */
707 int put_pos;
708
709 /* Buffer Address store. */ 706 /* Buffer Address store. */
710 struct buffAdd **ba; 707 struct buffAdd **ba;
711 struct s2io_nic *nic; 708 struct s2io_nic *nic;
@@ -877,8 +874,6 @@ struct s2io_nic {
877 874
878 atomic_t rx_bufs_left[MAX_RX_RINGS]; 875 atomic_t rx_bufs_left[MAX_RX_RINGS];
879 876
880 spinlock_t put_lock;
881
882#define PROMISC 1 877#define PROMISC 1
883#define ALL_MULTI 2 878#define ALL_MULTI 2
884 879
@@ -962,7 +957,6 @@ struct s2io_nic {
962 u8 lro; 957 u8 lro;
963 u16 lro_max_aggr_per_sess; 958 u16 lro_max_aggr_per_sess;
964 volatile unsigned long state; 959 volatile unsigned long state;
965 spinlock_t rx_lock;
966 u64 general_int_mask; 960 u64 general_int_mask;
967#define VPD_STRING_LEN 80 961#define VPD_STRING_LEN 80
968 u8 product_name[VPD_STRING_LEN]; 962 u8 product_name[VPD_STRING_LEN];