On Wed, 2012-12-05 at 12:33 +0200, Eliad Peller wrote: > On Wed, Dec 5, 2012 at 12:22 PM, Luciano Coelho <coelho@xxxxxx> wrote: > > On Wed, 2012-12-05 at 12:17 +0200, Eliad Peller wrote: > >> On Wed, Dec 5, 2012 at 11:35 AM, Luciano Coelho <coelho@xxxxxx> wrote: > >> > On Wed, 2012-11-28 at 11:42 +0200, Arik Nemtsov wrote: > >> >> From: Eliad Peller <eliad@xxxxxxxxxx> > >> >> > >> >> ACX_PEER_CAP command is just ACX_PEER_HT_CAP, but allows > >> >> configuring the peer's support rates as well. > >> >> > >> >> this is needed because we start the station role when > >> >> the remote rates are not known yet. > >> >> > >> >> the two commands should be unified in future fw versions, > >> >> but for now add a new set_peer_cap per-hw op, that will > >> >> use ACX_PEER_CAP for 18xx, and ACX_PEER_HT_CAP for 12xx. > >> >> > >> >> Signed-off-by: Eliad Peller <eliad@xxxxxxxxxx> > >> >> Signed-off-by: Arik Nemtsov <arik@xxxxxxxxxx> > >> >> --- > >> > > >> > [...] > >> > > >> >> diff --git a/drivers/net/wireless/ti/wlcore/wlcore.h b/drivers/net/wireless/ti/wlcore/wlcore.h > >> >> index 71137aa..ecdd5e6 100644 > >> >> --- a/drivers/net/wireless/ti/wlcore/wlcore.h > >> >> +++ b/drivers/net/wireless/ti/wlcore/wlcore.h > >> >> @@ -106,6 +106,11 @@ struct wlcore_ops { > >> >> u32 (*pre_pkt_send)(struct wl1271 *wl, u32 buf_offset, u32 last_len); > >> >> void (*sta_rc_update)(struct wl1271 *wl, struct wl12xx_vif *wlvif, > >> >> struct ieee80211_sta *sta, u32 changed); > >> >> + int (*set_peer_cap)(struct wl1271 *wl, > >> >> + struct ieee80211_sta_ht_cap *ht_cap, > >> >> + bool allow_ht_operation, > >> >> + u32 rate_set, u8 hlid); > >> >> + > >> > > >> > I think it would be much nicer to do all this with a quirk instead. > >> > Then we don't need to add ops that will have to be removed later and > >> > make all this ping-pong of calls between the modules. > >> > > >> i'm not sure what do you mean by using a quirk here. > >> currently, this is 18xx-specific command, so we need this op. > > > > I meant that the new ACX could be fully implemented in wlcore (because > > the expectation was that it would also become available in wl12xx in the > > future) and we would have a quirk to tell wlcore not to use the new ACX > > for wl12xx until it becomes available (when we would disable the quirk). > > > well, i don't think it fits our current abstraction. > e.g. ACX_PEER_CAP is defined only in 18xx, so it means we'll have to > separate the 18xx-specific commands into 2 enums. Oh, crap! Now I see that this is already in the wl18xx-specific acx enum. > i agree this is all pretty ugly, but these are the fw interfaces that > we were given... Yes, it's very annoying. No matter how many zillions of times we ask them to at least think about API consistency between the two firmwares. But no, that seems to be way too difficult... :( > > With the quirk, we could even continue supporting older wl12xx firmware > > versions quite easily. > we already support it quite easily... Ahm, yeah there would be other ways to support older firmwares, but I was thinking about checking the FW version and setting the quirk accordingly (as we've already done in the past). > i suggest keeping it that way for now, and if this command will be > implemented in 12xx as well, we can easily remove this op, as you > suggested. I agree. In any case, that won't be 100% straight-forward, because the new ACX is in the wl18xx-specific range. So we would probably have to break both firmware APIs again to be able to use common code for both. :( I'll take this in as it is. -- Luca. -- 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