Search Linux Wireless

Re: [PATCHv6 3/6] nl80211/cfg80211: add radar detection command/event

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

 



On Thu, 2013-01-17 at 14:40 +0100, Simon Wunderlich wrote:

> Actually there is no limit how long a channel is considered "available", at
> least in ETSI. ETSI EN 301-893 v1.4.1 had a limit of 24 hours for that,
> but that was removed in v1.5.1 and didn't re-appear since then (current is
> v1.7.1).

Huh indeed, I would have expected that to be there. It does have a
non-occupancy time though (30 minutes), maybe we should implement that?

I'm also thinking with the next regdb format update we should allow
specifying these timeouts etc. there.

Does anyone have the relevant FCC rules? I can't find anything with
google ...

> But we can move the CAC/timeout in the wdev and have keep a flag field in
> the channel struct instead, marking the channel as available, unavailable, etc.
> 
> What do you think?

I think that would make sense. Probably available/unavailable and
"non-occupancy until"?

> > I have a feeling this change should take into account the channel width,
> > and whether CAC completed successfully?
> > 
> 
> All channels used for operation are checked already in cfg80211_chandef_usable()
> for the flags.
> 
> If the channel width is supported at all is checked with cfg80211_can_use_iftype_chan()
> before/after.
> 
> So I don't see the neccesity for further checking width, or am I missing something?

Hmm, cfg80211_reg_can_beacon() is exported and usable by other modules,
so it should probably do more checking?

> > > +	err = rdev->ops->start_radar_detection(&rdev->wiphy, dev, &chandef);
> > > +	if (!err) {
> > > +		wdev->preset_chandef = chandef;
> > > +		chandef.chan->cac_started = true;
> > > +		chandef.chan->radar_detect_timeout = jiffies +
> > > +			msecs_to_jiffies(NL80211_DFS_MIN_CAC_TIME_MS);
> > > +	}
> > > +
> > > +	return err;
> > > +}
> > 
> > This still seems somewhat wrong. For the duration of the CAC, the
> > channel should be "locked" in some way, no? As it stands now, nothing
> > prevents userspace from adding another vif and using it for something
> > entirely different, while cfg80211 thinks the CAC is actually running.
> > 
> 
> Hmm, we can put the "CAC state" in the wdev then, and use it for locking?

I think it may need to be the CAC chandef? Not sure, but we definitely
need something to use in cfg80211_get_chan_state().

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