mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-13 14:40:22 +00:00
Fix if_timer logic to make sure that there is always a timeout
pending if there are packets queued for transmission. Several drivers still have the same problem. MFC after: 3 days
This commit is contained in:
parent
bcb9ef4fe6
commit
2e4fb41fa5
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=99165
@ -860,9 +860,6 @@ static void pcn_txeof(sc)
|
||||
|
||||
ifp = &sc->arpcom.ac_if;
|
||||
|
||||
/* Clear the timeout timer. */
|
||||
ifp->if_timer = 0;
|
||||
|
||||
/*
|
||||
* Go through our tx list and free mbufs for those
|
||||
* frames that have been transmitted.
|
||||
@ -899,13 +896,14 @@ static void pcn_txeof(sc)
|
||||
|
||||
sc->pcn_cdata.pcn_tx_cnt--;
|
||||
PCN_INC(idx, PCN_TX_LIST_CNT);
|
||||
ifp->if_timer = 0;
|
||||
}
|
||||
|
||||
sc->pcn_cdata.pcn_tx_cons = idx;
|
||||
|
||||
if (cur_tx != NULL)
|
||||
if (idx != sc->pcn_cdata.pcn_tx_cons) {
|
||||
/* Some buffers have been freed. */
|
||||
sc->pcn_cdata.pcn_tx_cons = idx;
|
||||
ifp->if_flags &= ~IFF_OACTIVE;
|
||||
}
|
||||
ifp->if_timer = (sc->pcn_cdata.pcn_tx_cnt == 0) ? 0 : 5;
|
||||
|
||||
return;
|
||||
}
|
||||
|
@ -1292,9 +1292,6 @@ static void rl_txeof(sc)
|
||||
|
||||
ifp = &sc->arpcom.ac_if;
|
||||
|
||||
/* Clear the timeout timer. */
|
||||
ifp->if_timer = 0;
|
||||
|
||||
/*
|
||||
* Go through our tx list and free mbufs for those
|
||||
* frames that have been uploaded.
|
||||
@ -1337,6 +1334,9 @@ static void rl_txeof(sc)
|
||||
ifp->if_flags &= ~IFF_OACTIVE;
|
||||
} while (sc->rl_cdata.last_tx != sc->rl_cdata.cur_tx);
|
||||
|
||||
ifp->if_timer =
|
||||
(sc->rl_cdata.last_tx == sc->rl_cdata.cur_tx) ? 0 : 5;
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user