Message ID | 1556179487-147593-1-git-send-email-wright.feng@cypress.com (mailing list archive) |
---|---|
State | Changes Requested |
Delegated to: | Kalle Valo |
Headers | show |
Series | brcmfmac: allocate msgbuf pktid from 1 to pktids array size | expand |
On 4/25/2019 10:04 AM, Wright Feng wrote: > Some PCIE firmwares drop txstatus if pktid is 0 and make packet held in > host side and not be released. If that packet type is 802.1x, the > pend_8021x_cnt value will be always greater than 0 and show "Timed out > waiting for no pending 802.1x packets" error message when sending key to > dongle. > > To be compatible with all firmwares, host should allocate msgbuf pktid > from 1 instead of from 0. looking at it we are wasting entry 0 with this patch. Could we avoid that? Regards, Arend > Signed-off-by: Wright Feng <wright.feng@cypress.com> > --- > drivers/net/wireless/broadcom/brcm80211/brcmfmac/msgbuf.c | 2 +- > 1 file changed, 1 insertion(+), 1 deletion(-) > > diff --git a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/msgbuf.c b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/msgbuf.c > index d3780ea..b2fab3c 100644 > --- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/msgbuf.c > +++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/msgbuf.c > @@ -348,7 +348,7 @@ brcmf_msgbuf_alloc_pktid(struct device *dev, > do { > (*idx)++; > if (*idx == pktids->array_size) > - *idx = 0; > + *idx = 1; > if (array[*idx].allocated.counter == 0) > if (atomic_cmpxchg(&array[*idx].allocated, 0, 1) == 0) > break; >
On 2019/4/25 下午 07:22, Arend Van Spriel wrote: > On 4/25/2019 10:04 AM, Wright Feng wrote: >> Some PCIE firmwares drop txstatus if pktid is 0 and make packet held in >> host side and not be released. If that packet type is 802.1x, the >> pend_8021x_cnt value will be always greater than 0 and show "Timed out >> waiting for no pending 802.1x packets" error message when sending key to >> dongle. >> >> To be compatible with all firmwares, host should allocate msgbuf pktid >> from 1 instead of from 0. > > looking at it we are wasting entry 0 with this patch. Could we avoid that? > > Regards, > Arend > Hi Arend, Thanks for the suggestion. To avoid wasting index zero entry, I just increase request ID in TXflow and decrease request ID when handling txstatus. I've posted patch v2. Regards, Wright >> Signed-off-by: Wright Feng <wright.feng@cypress.com> >> --- >> drivers/net/wireless/broadcom/brcm80211/brcmfmac/msgbuf.c | 2 +- >> 1 file changed, 1 insertion(+), 1 deletion(-) >> >> diff --git a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/msgbuf.c >> b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/msgbuf.c >> index d3780ea..b2fab3c 100644 >> --- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/msgbuf.c >> +++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/msgbuf.c >> @@ -348,7 +348,7 @@ brcmf_msgbuf_alloc_pktid(struct device *dev, >> do { >> (*idx)++; >> if (*idx == pktids->array_size) >> - *idx = 0; >> + *idx = 1; >> if (array[*idx].allocated.counter == 0) >> if (atomic_cmpxchg(&array[*idx].allocated, 0, 1) == 0) >> break; >>
diff --git a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/msgbuf.c b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/msgbuf.c index d3780ea..b2fab3c 100644 --- a/drivers/net/wireless/broadcom/brcm80211/brcmfmac/msgbuf.c +++ b/drivers/net/wireless/broadcom/brcm80211/brcmfmac/msgbuf.c @@ -348,7 +348,7 @@ brcmf_msgbuf_alloc_pktid(struct device *dev, do { (*idx)++; if (*idx == pktids->array_size) - *idx = 0; + *idx = 1; if (array[*idx].allocated.counter == 0) if (atomic_cmpxchg(&array[*idx].allocated, 0, 1) == 0) break;
Some PCIE firmwares drop txstatus if pktid is 0 and make packet held in host side and not be released. If that packet type is 802.1x, the pend_8021x_cnt value will be always greater than 0 and show "Timed out waiting for no pending 802.1x packets" error message when sending key to dongle. To be compatible with all firmwares, host should allocate msgbuf pktid from 1 instead of from 0. Signed-off-by: Wright Feng <wright.feng@cypress.com> --- drivers/net/wireless/broadcom/brcm80211/brcmfmac/msgbuf.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-)