Search Linux Wireless

Re: [RFC 1/2] mac80211: Use a cfg80211_chan_def in ieee80211_hw_conf_chan

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, 2013-03-18 at 22:14 +0100, Karl Beldan wrote:
> On Mon, Mar 18, 2013 at 08:25:10PM +0100, Johannes Berg wrote:
> > On Sun, 2013-03-17 at 21:30 +0100, Karl Beldan wrote:
> > 
> > > +	if (conf->chandef.chan)
> > 
> > > +	else
> > > +		wiphy_debug(hw->wiphy,
> > > +			    "%s (freq=0/%s idle=%d ps=%d smps=%s)\n",
> > 
> > I don't think the else should be allowed to happen.
> > 
> 
> Although I saw the hw config got an initial channel right from the start
> in ieee80211_register_hw, the original checks in the code confused since
> it tested for it in the tracing of drv_config.
> I'll get rid of it (in trace.h too).

It has to check in tracing because tracing can be invoked when the
driver uses chanctx, in which case it will be NULL. And indeed, that's
also the reason for hwsim -- it can operate in both chanctx and
non-chanctx modes. Sorry about the confusion!

> > > +static int ieee80211_chandef_cmp(const struct cfg80211_chan_def *def1,
> > > +				 const struct cfg80211_chan_def *def2)
> > 
> > indentation
> > 
> This one is good, it's just the side effect of the addition of the
> leading '+'.

Ahrg, yeah, I can't trust my email client any more. It used to get this
right :-(

> > >  		/* update the device channel directly */
> > > -		sdata->local->hw.conf.channel = sdata->local->_oper_channel;
> > > +		sdata->local->hw.conf.chandef.chan = sdata->local->oper_chandef.chan;
> > >  	}
> > 
> > All of this is now even more obviously wrong. If it's an HT40 channel,
> > it previously would try to switch to the same HT40 channel, but now it'd
> > result in an invalid chandef, the center_freq1 would now be wrong.
> > 
> Yes, thanks ! I was careless here.
> We should replace the csa_channel with a csa_chandef and get the freqs
> with the vif processed in ieee80211_sta_process_chanswitch, or is it
> utterly wrong ?

It's all kinda bad. We really have to implement extended CSA that tells
us what channel width to switch to, I have some patches but it's tricky
and I can't really test it :-(

johannes

--
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


[Index of Archives]     [Linux Host AP]     [ATH6KL]     [Linux Wireless Personal Area Network]     [Linux Bluetooth]     [Linux Netdev]     [Kernel Newbies]     [Linux Kernel]     [IDE]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite Hiking]     [MIPS Linux]     [ARM Linux]     [Linux RAID]

  Powered by Linux