diff options
author | Michael Brown <mcb30@etherboot.org> | 2007-07-03 04:05:30 +0100 |
---|---|---|
committer | Michael Brown <mcb30@etherboot.org> | 2007-07-03 04:05:30 +0100 |
commit | 5f92f0bd820647ce6f8847e26c0f42607efd4c8f (patch) | |
tree | aa83f58299d1e719e46356505b96eec0a14696f2 /src | |
parent | 290280f90ee58d2f51e753b5499f9de8961988ad (diff) | |
download | ipxe-5f92f0bd820647ce6f8847e26c0f42607efd4c8f.zip ipxe-5f92f0bd820647ce6f8847e26c0f42607efd4c8f.tar.gz ipxe-5f92f0bd820647ce6f8847e26c0f42607efd4c8f.tar.bz2 |
Reserve space for link-layer header in pxenv_undi_transmit() when not
handed a P_UNKNOWN packet.
Diffstat (limited to 'src')
-rw-r--r-- | src/interface/pxe/pxe_undi.c | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/src/interface/pxe/pxe_undi.c b/src/interface/pxe/pxe_undi.c index e085a93..0ce4b29 100644 --- a/src/interface/pxe/pxe_undi.c +++ b/src/interface/pxe/pxe_undi.c @@ -179,6 +179,7 @@ PXENV_EXIT_t pxenv_undi_transmit ( struct s_PXENV_UNDI_TRANSMIT struct net_protocol *net_protocol; char destaddr[MAX_LL_ADDR_LEN]; const void *ll_dest; + size_t ll_hlen = pxe_netdev->ll_protocol->ll_header_len; size_t len; unsigned int i; int rc; @@ -190,27 +191,34 @@ PXENV_EXIT_t pxenv_undi_transmit ( struct s_PXENV_UNDI_TRANSMIT case P_IP: net_protocol = &ipv4_protocol; break; case P_ARP: net_protocol = &arp_protocol; break; case P_RARP: net_protocol = &rarp_protocol; break; - case P_UNKNOWN: net_protocol = NULL; break; + case P_UNKNOWN: + net_protocol = NULL; + ll_hlen = 0; + break; default: undi_transmit->Status = PXENV_STATUS_UNDI_INVALID_PARAMETER; return PXENV_EXIT_FAILURE; } + DBG ( " %s", ( net_protocol ? net_protocol->name : "UNKNOWN" ) ); /* Calculate total packet length */ copy_from_real ( &tbd, undi_transmit->TBD.segment, undi_transmit->TBD.offset, sizeof ( tbd ) ); len = tbd.ImmedLength; + DBG ( " %zd", tbd.ImmedLength ); for ( i = 0 ; i < tbd.DataBlkCount ; i++ ) { datablk = &tbd.DataBlock[i]; len += datablk->TDDataLen; + DBG ( "+%zd", datablk->TDDataLen ); } /* Allocate and fill I/O buffer */ - iobuf = alloc_iob ( len ); + iobuf = alloc_iob ( ll_hlen + len ); if ( ! iobuf ) { undi_transmit->Status = PXENV_STATUS_OUT_OF_RESOURCES; return PXENV_EXIT_FAILURE; } + iob_reserve ( iobuf, ll_hlen ); copy_from_real ( iob_put ( iobuf, tbd.ImmedLength ), tbd.Xmit.segment, tbd.Xmit.offset, tbd.ImmedLength ); for ( i = 0 ; i < tbd.DataBlkCount ; i++ ) { |