diff options
author | Pekka Enberg <penberg@cs.helsinki.fi> | 2008-06-23 07:36:18 -0400 |
---|---|---|
committer | Jeff Garzik <jgarzik@redhat.com> | 2008-07-04 08:46:53 -0400 |
commit | 39f205854c829294f9b4db65100d3abdf9c9c145 (patch) | |
tree | fc400cb85716334d52bf9f63be16ede3d7842c09 /drivers/net | |
parent | 18a9cdb9c7ec88f6e94cd8dcb03fb6cded067119 (diff) |
ipg: per-device rxsupport_size
Add a ->max_rxframe member to struct ipg_nic_private and convert the users of
IPG_RXSUPPORT_SIZE to use it instead to enable per-device jumbo frame
configuration.
Tested-by: Andrew Savchenko <Bircoph@list.ru>
Signed-off-by: Pekka Enberg <penberg@cs.helsinki.fi>
Signed-off-by: Jeff Garzik <jgarzik@redhat.com>
Diffstat (limited to 'drivers/net')
-rw-r--r-- | drivers/net/ipg.c | 9 | ||||
-rw-r--r-- | drivers/net/ipg.h | 1 |
2 files changed, 6 insertions, 4 deletions
diff --git a/drivers/net/ipg.c b/drivers/net/ipg.c index 5c5653bd48c1..51d5f30e0afe 100644 --- a/drivers/net/ipg.c +++ b/drivers/net/ipg.c | |||
@@ -730,7 +730,7 @@ static int ipg_get_rxbuff(struct net_device *dev, int entry) | |||
730 | 730 | ||
731 | IPG_DEBUG_MSG("_get_rxbuff\n"); | 731 | IPG_DEBUG_MSG("_get_rxbuff\n"); |
732 | 732 | ||
733 | skb = netdev_alloc_skb(dev, IPG_RXSUPPORT_SIZE + NET_IP_ALIGN); | 733 | skb = netdev_alloc_skb(dev, sp->rxsupport_size + NET_IP_ALIGN); |
734 | if (!skb) { | 734 | if (!skb) { |
735 | sp->rx_buff[entry] = NULL; | 735 | sp->rx_buff[entry] = NULL; |
736 | return -ENOMEM; | 736 | return -ENOMEM; |
@@ -1270,7 +1270,7 @@ static void ipg_nic_rx_with_end(struct net_device *dev, | |||
1270 | framelen = le64_to_cpu(rxfd->rfs) & IPG_RFS_RXFRAMELEN; | 1270 | framelen = le64_to_cpu(rxfd->rfs) & IPG_RFS_RXFRAMELEN; |
1271 | 1271 | ||
1272 | endframelen = framelen - jumbo->current_size; | 1272 | endframelen = framelen - jumbo->current_size; |
1273 | if (framelen > IPG_RXSUPPORT_SIZE) | 1273 | if (framelen > sp->rxsupport_size) |
1274 | dev_kfree_skb_irq(jumbo->skb); | 1274 | dev_kfree_skb_irq(jumbo->skb); |
1275 | else { | 1275 | else { |
1276 | memcpy(skb_put(jumbo->skb, endframelen), | 1276 | memcpy(skb_put(jumbo->skb, endframelen), |
@@ -1311,7 +1311,7 @@ static void ipg_nic_rx_no_start_no_end(struct net_device *dev, | |||
1311 | if (skb) { | 1311 | if (skb) { |
1312 | if (jumbo->found_start) { | 1312 | if (jumbo->found_start) { |
1313 | jumbo->current_size += sp->rxfrag_size; | 1313 | jumbo->current_size += sp->rxfrag_size; |
1314 | if (jumbo->current_size <= IPG_RXSUPPORT_SIZE) { | 1314 | if (jumbo->current_size <= sp->rxsupport_size) { |
1315 | memcpy(skb_put(jumbo->skb, | 1315 | memcpy(skb_put(jumbo->skb, |
1316 | sp->rxfrag_size), | 1316 | sp->rxfrag_size), |
1317 | skb->data, sp->rxfrag_size); | 1317 | skb->data, sp->rxfrag_size); |
@@ -1744,7 +1744,7 @@ static int ipg_nic_open(struct net_device *dev) | |||
1744 | 1744 | ||
1745 | IPG_DEBUG_MSG("_nic_open\n"); | 1745 | IPG_DEBUG_MSG("_nic_open\n"); |
1746 | 1746 | ||
1747 | sp->rx_buf_sz = IPG_RXSUPPORT_SIZE; | 1747 | sp->rx_buf_sz = sp->rxsupport_size; |
1748 | 1748 | ||
1749 | /* Check for interrupt line conflicts, and request interrupt | 1749 | /* Check for interrupt line conflicts, and request interrupt |
1750 | * line for IPG. | 1750 | * line for IPG. |
@@ -2237,6 +2237,7 @@ static int __devinit ipg_probe(struct pci_dev *pdev, | |||
2237 | 2237 | ||
2238 | sp->is_jumbo = IPG_JUMBO; | 2238 | sp->is_jumbo = IPG_JUMBO; |
2239 | sp->rxfrag_size = IPG_RXFRAG_SIZE; | 2239 | sp->rxfrag_size = IPG_RXFRAG_SIZE; |
2240 | sp->rxsupport_size = IPG_RXSUPPORT_SIZE; | ||
2240 | 2241 | ||
2241 | /* Declare IPG NIC functions for Ethernet device methods. | 2242 | /* Declare IPG NIC functions for Ethernet device methods. |
2242 | */ | 2243 | */ |
diff --git a/drivers/net/ipg.h b/drivers/net/ipg.h index 83e311ebf0cb..9ff4511d21cb 100644 --- a/drivers/net/ipg.h +++ b/drivers/net/ipg.h | |||
@@ -797,6 +797,7 @@ struct ipg_nic_private { | |||
797 | bool is_jumbo; | 797 | bool is_jumbo; |
798 | struct ipg_jumbo jumbo; | 798 | struct ipg_jumbo jumbo; |
799 | unsigned long rxfrag_size; | 799 | unsigned long rxfrag_size; |
800 | unsigned long rxsupport_size; | ||
800 | unsigned int rx_buf_sz; | 801 | unsigned int rx_buf_sz; |
801 | struct pci_dev *pdev; | 802 | struct pci_dev *pdev; |
802 | struct net_device *dev; | 803 | struct net_device *dev; |