mirror of
https://github.com/lwip-tcpip/lwip.git
synced 2025-01-26 09:35:23 +00:00
PPP, PPPoE, fixed bug #42138, pppoe_destroy() called with wrong pointer, PPPoE control block was never freed
This commit is contained in:
parent
3fd7bc8058
commit
a7745e9a86
@ -168,7 +168,7 @@ struct pppoe_softc {
|
||||
#define pppoe_init() /* compatibility define, no initialization needed */
|
||||
|
||||
err_t pppoe_create(struct netif *ethif, ppp_pcb *pcb, void (*link_status_cb)(ppp_pcb *pcb, int up), struct pppoe_softc **scptr);
|
||||
err_t pppoe_destroy(struct netif *ifp);
|
||||
err_t pppoe_destroy(struct pppoe_softc *sc);
|
||||
|
||||
int pppoe_connect(struct pppoe_softc *sc);
|
||||
void pppoe_disconnect(struct pppoe_softc *sc);
|
||||
|
@ -540,7 +540,7 @@ int ppp_free(ppp_pcb *pcb) {
|
||||
|
||||
#if PPPOE_SUPPORT
|
||||
if (pcb->pppoe_sc) {
|
||||
pppoe_destroy(&pcb->netif);
|
||||
pppoe_destroy(pcb->pppoe_sc);
|
||||
pcb->pppoe_sc = NULL;
|
||||
}
|
||||
#endif /* PPPOE_SUPPORT */
|
||||
|
@ -165,17 +165,18 @@ pppoe_create(struct netif *ethif, ppp_pcb *pcb, void (*link_status_cb)(ppp_pcb *
|
||||
}
|
||||
|
||||
err_t
|
||||
pppoe_destroy(struct netif *ifp)
|
||||
pppoe_destroy(struct pppoe_softc *sc)
|
||||
{
|
||||
struct pppoe_softc *sc, *prev = NULL;
|
||||
struct pppoe_softc *cur, *prev = NULL;
|
||||
|
||||
for (sc = pppoe_softc_list; sc != NULL; prev = sc, sc = sc->next) {
|
||||
if (sc->sc_ethif == ifp) {
|
||||
/* find previous linked list entry */
|
||||
for (cur = pppoe_softc_list; cur != NULL; prev = cur, cur = cur->next) {
|
||||
if (sc == cur) {
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if(!(sc && (sc->sc_ethif == ifp))) {
|
||||
if (cur != sc) {
|
||||
return ERR_IF;
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user