Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 600a897d authored by Arend van Spriel's avatar Arend van Spriel Committed by John W. Linville
Browse files

brcmfmac: determine chanspec from struct cfg80211_chan_def info



The struct cfg80211_chan_def contains additional info to derive the
bandwidth and side-band information of the chanspec. This patch adds
chandef_to_chanspec() function used in IBSS join and starting AP
operation.

Reviewed-by: default avatarFranky Lin <frankyl@broadcom.com>
Reviewed-by: default avatarHante Meuleman <meuleman@broadcom.com>
Signed-off-by: default avatarArend van Spriel <arend@broadcom.com>
Signed-off-by: default avatarJohn W. Linville <linville@tuxdriver.com>
parent ee942ecc
Loading
Loading
Loading
Loading
+57 −3
Original line number Original line Diff line number Diff line
@@ -341,6 +341,60 @@ static u8 brcmf_mw_to_qdbm(u16 mw)
	return qdbm;
	return qdbm;
}
}


u16 chandef_to_chanspec(struct brcmu_d11inf *d11inf,
			struct cfg80211_chan_def *ch)
{
	struct brcmu_chan ch_inf;
	s32 primary_offset;

	brcmf_dbg(TRACE, "chandef: control %d center %d width %d\n",
		  ch->chan->center_freq, ch->center_freq1, ch->width);
	ch_inf.chnum = ieee80211_frequency_to_channel(ch->center_freq1);
	primary_offset = ch->center_freq1 - ch->chan->center_freq;
	switch (ch->width) {
	case NL80211_CHAN_WIDTH_20:
		ch_inf.bw = BRCMU_CHAN_BW_20;
		WARN_ON(primary_offset != 0);
		break;
	case NL80211_CHAN_WIDTH_40:
		ch_inf.bw = BRCMU_CHAN_BW_40;
		if (primary_offset < 0)
			ch_inf.sb = BRCMU_CHAN_SB_U;
		else
			ch_inf.sb = BRCMU_CHAN_SB_L;
		break;
	case NL80211_CHAN_WIDTH_80:
		ch_inf.bw = BRCMU_CHAN_BW_80;
		if (primary_offset < 0) {
			if (primary_offset < -CH_10MHZ_APART)
				ch_inf.sb = BRCMU_CHAN_SB_UU;
			else
				ch_inf.sb = BRCMU_CHAN_SB_UL;
		} else {
			if (primary_offset > CH_10MHZ_APART)
				ch_inf.sb = BRCMU_CHAN_SB_LL;
			else
				ch_inf.sb = BRCMU_CHAN_SB_LU;
		}
		break;
	default:
		WARN_ON_ONCE(1);
	}
	switch (ch->chan->band) {
	case IEEE80211_BAND_2GHZ:
		ch_inf.band = BRCMU_CHAN_BAND_2G;
		break;
	case IEEE80211_BAND_5GHZ:
		ch_inf.band = BRCMU_CHAN_BAND_5G;
		break;
	default:
		WARN_ON_ONCE(1);
	}
	d11inf->encchspec(&ch_inf);

	return ch_inf.chspec;
}

u16 channel_to_chanspec(struct brcmu_d11inf *d11inf,
u16 channel_to_chanspec(struct brcmu_d11inf *d11inf,
			struct ieee80211_channel *ch)
			struct ieee80211_channel *ch)
{
{
@@ -1236,8 +1290,8 @@ brcmf_cfg80211_join_ibss(struct wiphy *wiphy, struct net_device *ndev,
				params->chandef.chan->center_freq);
				params->chandef.chan->center_freq);
		if (params->channel_fixed) {
		if (params->channel_fixed) {
			/* adding chanspec */
			/* adding chanspec */
			chanspec = channel_to_chanspec(&cfg->d11inf,
			chanspec = chandef_to_chanspec(&cfg->d11inf,
						       params->chandef.chan);
						       &params->chandef);
			join_params.params_le.chanspec_list[0] =
			join_params.params_le.chanspec_list[0] =
				cpu_to_le16(chanspec);
				cpu_to_le16(chanspec);
			join_params.params_le.chanspec_num = cpu_to_le32(1);
			join_params.params_le.chanspec_num = cpu_to_le32(1);
@@ -3810,7 +3864,7 @@ brcmf_cfg80211_start_ap(struct wiphy *wiphy, struct net_device *ndev,


	brcmf_config_ap_mgmt_ie(ifp->vif, &settings->beacon);
	brcmf_config_ap_mgmt_ie(ifp->vif, &settings->beacon);


	chanspec = channel_to_chanspec(&cfg->d11inf, settings->chandef.chan);
	chanspec = chandef_to_chanspec(&cfg->d11inf, &settings->chandef);
	err = brcmf_fil_iovar_int_set(ifp, "chanspec", chanspec);
	err = brcmf_fil_iovar_int_set(ifp, "chanspec", chanspec);
	if (err < 0) {
	if (err < 0) {
		brcmf_err("Set Channel failed: chspec=%d, %d\n", chanspec, err);
		brcmf_err("Set Channel failed: chspec=%d, %d\n", chanspec, err);