On 02/09/2015 10:09 PM, Michal Kazior wrote: > On 9 February 2015 at 17:03, Ben Greear <greearb@xxxxxxxxxxxxxxx> wrote: >> On 02/08/2015 10:24 PM, Michal Kazior wrote: >>> On 6 February 2015 at 17:15, Ben Greear <greearb@xxxxxxxxxxxxxxx> wrote: > [...] >>>> At least in my tests, I could continue >>>> to receive network traffic while WMI was blocked. >>> >>> >>> Yeah. Traffic works with the tx-credit starvation as well but what >>> good is this if you have inconsistent driver-firmware state after >>> failing to send a few commands? >> >> >> I just mention it because someone debugging the system might >> wonder why the firmware is 'locked up' while it is still passing traffic. > > I might as well include this info in the commit log. > > >> If it is just powersave issue, could you force (overriding wmi tx-credits >> limit) >> a flush at the 1 second mark and hope it recovers by 3 second timeout? > > Well, there's a couple of problems with that. > > 1) you suggest to call wmi_flush() which calls wmi_cmd_send() *while* > in wmi_cmd_send(), > 2) you're out of credits, how do you intend to submit a frame, > 3) yes, you can force it, but that's super ugly, > 4) and this still doesn't guarantee you'll get your tx-credit due to > firmware quirkiness. If you do force the wmi send, ignoring credits, and even if you are running stock firmware with wmi credits replenishment issues, then you at least have a chance of recovering. (Upstream firmware requires lots of WMI messages to flush, I think..like you can only flush per peer or something like that, so maybe there is no realistic way to flush with small number of WMI messages.) I've hacked CT firmware to do a flush of all vdevs itself when it detects WMI hang. I don't have a good test bed to reproduce the problem reliably, but I should know after a few days if the flush works at all. If not, then it's a moot point anyway. Thanks, Ben -- Ben Greear <greearb@xxxxxxxxxxxxxxx> Candela Technologies Inc http://www.candelatech.com -- To unsubscribe from this list: send the line "unsubscribe linux-wireless" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html