On Thu, 2018-10-11 at 07:23 +0000, Tony Chuang wrote: > > > + switch (vif->type) { > > > + case NL80211_IFTYPE_AP: > > > + case NL80211_IFTYPE_MESH_POINT: > > > + net_type = RTW_NET_AP_MODE; > > > + break; > > > + case NL80211_IFTYPE_ADHOC: > > > + net_type = RTW_NET_AD_HOC; > > > + break; > > > + default: > > > + net_type = RTW_NET_NO_LINK; > > > > you might to add STATION and then fail in the default case? > > > Yeah, station starts with NO_LINK until it's associated with an AP Right. I was just thinking of the switch statement - you might want to handle STATION explicitly, instead of in the default case, and then fail in the default case for this to be a little more readable and robust. Not all that important. > > This will provoke error messages to be printed for e.g. CMAC keys, or do > > you really not support protected management frames? If you were to pick > > "-EOPNOTSUPP" then no errors would be printed. > > We do not support PMF hw encryption/decryption now, perhaps we need > to register the cipher_schemes when ieee80211_register_hw. Ok, that's fine. > Even if HW does not support it, I think mac80211 can use SW encryption/decryption > after driver failed to upload key to hardware? Yes. > So if driver has not declared MFP_CAPABLE, the mac80211 will ignore it and > wpa_supplicant will guess we cannot perform MFP. It is strange. Right, no, it's not strange. That was my point though, if you do want to support it you should set MFP_CAPABLE, but you should return a different error code to avoid an error message being printed from mac80211. That's all. The logic is fine, just use -EOPNOTSUPP (rather than -ENOTSUPP) to suppress any error messages. > > why should statistics be reset evyer 2 seconds? > > All of our statistics are counted in 2 seconds, ex. pkts, bytes, fa ... > So just reset them every seconds. No other device behaves this way though, so you shouldn't do this either. > > > + ieee80211_hw_set(hw, MFP_CAPABLE); > > > > so you do have MFP - I guess you should test it and check for spurious > > hardware crypto messages > > We don't have now, should remove them. But as I have mentioned, if we don't > declare it here, mac80211 will discard the cipher and pass it to wiphy. > And we still should be able to work with MFP because mac80211 can do > software encryption/decryption for us. Right. So this is fine, see above regarding the error message that gets printed. > Finally, I removed the vif_list and sta_list. And use the iterator > provided by mac80211, > But there is one question that how can we find all of the sta associated > with specific vif, > Has there an only way to iterate every sta and see if (sta->vif == vif) ? Yes, looks like that's the only way - I guess you could pass the vif as the data pointer. I suppose we could add a vif filter argument to the iteration and ignore it if it's NULL, but is it worth it? johannes