summaryrefslogtreecommitdiffstats
path: root/src/drivers/net/efi/snpnet.c
diff options
context:
space:
mode:
authorMichael Brown2016-05-11 23:02:26 +0200
committerMichael Brown2016-05-12 00:02:10 +0200
commit6164741f81fbb80d25ba3877251f4b31de3ed6a0 (patch)
treeffa86f6ffa6c484d695a0557ef786bc98811c5c9 /src/drivers/net/efi/snpnet.c
parent[arm] Add optimised TCP/IP checksumming for 64-bit ARM (diff)
downloadipxe-6164741f81fbb80d25ba3877251f4b31de3ed6a0.tar.gz
ipxe-6164741f81fbb80d25ba3877251f4b31de3ed6a0.tar.xz
ipxe-6164741f81fbb80d25ba3877251f4b31de3ed6a0.zip
[efi] Guard against GetStatus() failing to return a NULL TX buffer
The UEFI specification requires the EFI_SIMPLE_NETWORK_PROTOCOL GetStatus() method to set TxBuf to NULL if there are no transmit buffers to recycle. Some implementations (observed with Lan9118Dxe in EDK2) fill in TxBuf only when there is a transmit buffer to recycle, which leads to large numbers of "spurious TX completion" errors. Work around this problem by initialising TxBuf to NULL before calling the GetStatus() method. Signed-off-by: Michael Brown <mcb30@ipxe.org>
Diffstat (limited to 'src/drivers/net/efi/snpnet.c')
-rw-r--r--src/drivers/net/efi/snpnet.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/src/drivers/net/efi/snpnet.c b/src/drivers/net/efi/snpnet.c
index 0d876b63..88474b0b 100644
--- a/src/drivers/net/efi/snpnet.c
+++ b/src/drivers/net/efi/snpnet.c
@@ -191,6 +191,7 @@ static void snpnet_poll_tx ( struct net_device *netdev ) {
int rc;
/* Get status */
+ txbuf = NULL;
if ( ( efirc = snp->snp->GetStatus ( snp->snp, &irq, &txbuf ) ) != 0 ) {
rc = -EEFI ( efirc );
DBGC ( snp, "SNP %s could not get status: %s\n",