Add a new BSS attribute to allow hostapd to set the current HT opmode.
Otherwise drivers won't be able to set up protection for HT rates in
AP mode.
Cc: Johannes Berg <johannes@sipsolutions.net>
Signed-off-by: Helmut Schaa <helmut.schaa@googlemail.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
  *     flag isn't set, the frame will be rejected. This is also used as an
  *     nl80211 capability flag.
  *
+ * @NL80211_ATTR_BSS_HTOPMODE: HT operation mode (u16)
+ *
  * @NL80211_ATTR_MAX: highest attribute number currently defined
  * @__NL80211_ATTR_AFTER_LAST: internal use
  */
 
        NL80211_ATTR_OFFCHANNEL_TX_OK,
 
+       NL80211_ATTR_BSS_HT_OPMODE,
+
        /* add attributes here, update the policy in nl80211.c */
 
        __NL80211_ATTR_AFTER_LAST,
 
  *     (or NULL for no change)
  * @basic_rates_len: number of basic rates
  * @ap_isolate: do not forward packets between connected stations
+ * @ht_opmode: HT Operation mode
+ *     (u16 = opmode, -1 = do not change)
  */
 struct bss_parameters {
        int use_cts_prot;
        u8 *basic_rates;
        u8 basic_rates_len;
        int ap_isolate;
+       int ht_opmode;
 };
 
 /*
 
        [NL80211_ATTR_BSS_SHORT_SLOT_TIME] = { .type = NLA_U8 },
        [NL80211_ATTR_BSS_BASIC_RATES] = { .type = NLA_BINARY,
                                           .len = NL80211_MAX_SUPP_RATES },
+       [NL80211_ATTR_BSS_HT_OPMODE] = { .type = NLA_U16 },
 
        [NL80211_ATTR_MESH_PARAMS] = { .type = NLA_NESTED },
 
        params.use_short_preamble = -1;
        params.use_short_slot_time = -1;
        params.ap_isolate = -1;
+       params.ht_opmode = -1;
 
        if (info->attrs[NL80211_ATTR_BSS_CTS_PROT])
                params.use_cts_prot =
        }
        if (info->attrs[NL80211_ATTR_AP_ISOLATE])
                params.ap_isolate = !!nla_get_u8(info->attrs[NL80211_ATTR_AP_ISOLATE]);
+       if (info->attrs[NL80211_ATTR_BSS_HT_OPMODE])
+               params.ht_opmode =
+                       nla_get_u16(info->attrs[NL80211_ATTR_BSS_HT_OPMODE]);
 
        if (!rdev->ops->change_bss)
                return -EOPNOTSUPP;