svn commit: r227323 - head/sys/dev/ti
Pyun YongHyeon
yongari at FreeBSD.org
Mon Nov 7 22:53:06 UTC 2011
Author: yongari
Date: Mon Nov 7 22:53:06 2011
New Revision: 227323
URL: http://svn.freebsd.org/changeset/base/227323
Log:
If ti_chipinit() fails in ti_stop(), ignore the error and release
all allocated TX/RX buffer resources. If the interface is brought
to up again after the error, we will leak allocated TX/RX buffers.
Modified:
head/sys/dev/ti/if_ti.c
Modified: head/sys/dev/ti/if_ti.c
==============================================================================
--- head/sys/dev/ti/if_ti.c Mon Nov 7 22:47:25 2011 (r227322)
+++ head/sys/dev/ti/if_ti.c Mon Nov 7 22:53:06 2011 (r227323)
@@ -3845,11 +3845,11 @@ ti_stop(struct ti_softc *sc)
TI_DO_CMD(TI_CMD_HOST_STATE, TI_CMD_CODE_STACK_DOWN, 0);
/* Halt and reinitialize. */
- if (ti_chipinit(sc) != 0)
- return;
- ti_mem_zero(sc, 0x2000, 0x100000 - 0x2000);
- if (ti_chipinit(sc) != 0)
- return;
+ if (ti_chipinit(sc) == 0) {
+ ti_mem_zero(sc, 0x2000, 0x100000 - 0x2000);
+ /* XXX ignore init errors. */
+ ti_chipinit(sc);
+ }
/* Free the RX lists. */
ti_free_rx_ring_std(sc);
More information about the svn-src-head
mailing list