diff options
| author | Michael Brown | 2007-01-11 06:25:50 +0100 |
|---|---|---|
| committer | Michael Brown | 2007-01-11 06:25:50 +0100 |
| commit | a3ed0cbbc7d81c345d791835cb4d97176dc404b6 (patch) | |
| tree | 34d6eeb572737852b54ce611c6bcc4a1027daaf6 /src/drivers/net | |
| parent | Change FTP to use a data buffer rather than a callback function. (diff) | |
| download | ipxe-a3ed0cbbc7d81c345d791835cb4d97176dc404b6.tar.gz ipxe-a3ed0cbbc7d81c345d791835cb4d97176dc404b6.tar.xz ipxe-a3ed0cbbc7d81c345d791835cb4d97176dc404b6.zip | |
Extract packet-padding login from rtl8139.c to a separate pkbpad.c file.
Diffstat (limited to 'src/drivers/net')
| -rw-r--r-- | src/drivers/net/rtl8139.c | 23 |
1 files changed, 2 insertions, 21 deletions
diff --git a/src/drivers/net/rtl8139.c b/src/drivers/net/rtl8139.c index 08130b230..81b6ccfb6 100644 --- a/src/drivers/net/rtl8139.c +++ b/src/drivers/net/rtl8139.c @@ -367,10 +367,6 @@ static void rtl_close ( struct net_device *netdev ) { */ static int rtl_transmit ( struct net_device *netdev, struct pk_buff *pkb ) { struct rtl8139_nic *rtl = netdev->priv; - void *data; - size_t len; - size_t headroom; - signed int pad_len; /* Check for space in TX ring */ if ( rtl->tx.pkb[rtl->tx.next] != NULL ) { @@ -378,23 +374,8 @@ static int rtl_transmit ( struct net_device *netdev, struct pk_buff *pkb ) { return -ENOBUFS; } - /* Move packet data to start of packet buffer. This will both - * align the data (since packet buffers are aligned to - * PKB_ALIGN) and give us sufficient space for the - * zero-padding - */ - data = pkb->data; - len = pkb_len ( pkb ); - headroom = pkb_headroom ( pkb ); - pkb_push ( pkb, headroom ); - memmove ( pkb->data, data, len ); - pkb_unput ( pkb, headroom ); - assert ( ( virt_to_bus ( pkb->data ) & 0x3 ) == 0 ); - - /* Pad to minimum packet length */ - pad_len = ( ETH_ZLEN - pkb_len ( pkb ) ); - if ( pad_len > 0 ) - memset ( pkb_put ( pkb, pad_len ), 0, pad_len ); + /* Pad and align packet */ + pkb_pad ( pkb, ETH_ZLEN ); /* Add to TX ring */ DBG ( "TX id %d at %lx+%x\n", rtl->tx.next, |
