On Thu, 2017-06-08 at 19:07 -0500, Denis Kenzior wrote: > > > Fundamentally there is a race between the genl/nl80211 socket to > > > the > > > kernel and the PAE socket that handles the authentication > > > aspects. I > > > think the only way to > > > fix this is to make sure that PAE flows over the genl/nl80211 > > > socket > > > to preserve the proper order of events. Correct. > > > However there are lots of > > > dragons in the kernel > > > side of this and we haven't been brave enough to venture into the > > > depths yet :) We've actually discussed doing precisely this, for - among other things - this reason. Just nobody stepped up yet to propose the necessary APIs and do the remaining work to use it etc. > > I think that would just push the problem lower. Probably a real > > fix > > would be to somehow propagate > > the tx-status for the specific packet back to the supplicant and > > only > > then it would know that the > > key could be set. That's actually possible today, with the wifi-ack sockopt. It's not really a full solution though I think, there are other issues to solve. We also discussed this at the last workshop, IIRC. > Having userspace track individual packets in the kernel sounds wrong > to me. This also won't help with the packets being received out-of- > order. It would be nice if both the RX and TX ordering was > preserved. Hence my thinking about running PAE over NL80211. It > would then be up to the kernel / drivers to guarantee that the > various packets are ordered appropriately. That's actually not possible, since ordering set_key operations vs. transmitted packets isn't something that's easily done by drivers. However, the solution is far simpler! Once you have nl80211 PAE transport, you can easily even set the key before transmitting the packet and simply indicate that this particular packet should _not_ be encrypted regardless of key presence. johannes