diff options
author | Holger Schurig <holgerschurig@gmail.com> | 2009-11-11 06:25:40 -0500 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2009-11-13 17:43:58 -0500 |
commit | 61fa713c751683da915fa0c1aa502be85822c357 (patch) | |
tree | a4f286a2bb59b9afd1f3b836cb62a8e81bafee98 /include | |
parent | a043897a314e8bcfc821d54fe4e591efed5936a3 (diff) |
cfg80211: return channel noise via survey API
This patch implements the NL80211_CMD_GET_SURVEY command and an get_survey()
ops that a driver can implement. The goal of this command is to allow a
drivers to report channel survey data (e.g. channel noise, channel
occupation).
For now, only the mechanism to report back channel noise has been
implemented.
In future, there will either be a survey-trigger command --- or the existing
scan-trigger command will be enhanced. This will allow user-space to
request survey for arbitrary channels.
Note: any driver that cannot report channel noise should not report
any value at all, e.g. made-up -92 dBm.
Signed-off-by: Holger Schurig <holgerschurig@gmail.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'include')
-rw-r--r-- | include/linux/nl80211.h | 34 | ||||
-rw-r--r-- | include/net/cfg80211.h | 34 |
2 files changed, 68 insertions, 0 deletions
diff --git a/include/linux/nl80211.h b/include/linux/nl80211.h index d2f276de9abe..45db17f81aa3 100644 --- a/include/linux/nl80211.h +++ b/include/linux/nl80211.h | |||
@@ -160,6 +160,11 @@ | |||
160 | * @NL80211_CMD_SCAN_ABORTED: scan was aborted, for unspecified reasons, | 160 | * @NL80211_CMD_SCAN_ABORTED: scan was aborted, for unspecified reasons, |
161 | * partial scan results may be available | 161 | * partial scan results may be available |
162 | * | 162 | * |
163 | * @NL80211_CMD_GET_SURVEY: get survey resuls, e.g. channel occupation | ||
164 | * or noise level | ||
165 | * @NL80211_CMD_NEW_SURVEY_RESULTS: survey data notification (as a reply to | ||
166 | * NL80211_CMD_GET_SURVEY and on the "scan" multicast group) | ||
167 | * | ||
163 | * @NL80211_CMD_REG_CHANGE: indicates to userspace the regulatory domain | 168 | * @NL80211_CMD_REG_CHANGE: indicates to userspace the regulatory domain |
164 | * has been changed and provides details of the request information | 169 | * has been changed and provides details of the request information |
165 | * that caused the change such as who initiated the regulatory request | 170 | * that caused the change such as who initiated the regulatory request |
@@ -341,6 +346,9 @@ enum nl80211_commands { | |||
341 | 346 | ||
342 | NL80211_CMD_SET_WIPHY_NETNS, | 347 | NL80211_CMD_SET_WIPHY_NETNS, |
343 | 348 | ||
349 | NL80211_CMD_GET_SURVEY, | ||
350 | NL80211_CMD_NEW_SURVEY_RESULTS, | ||
351 | |||
344 | /* add new commands above here */ | 352 | /* add new commands above here */ |
345 | 353 | ||
346 | /* used to define NL80211_CMD_MAX below */ | 354 | /* used to define NL80211_CMD_MAX below */ |
@@ -586,6 +594,10 @@ enum nl80211_commands { | |||
586 | * | 594 | * |
587 | * @NL80211_ATTR_4ADDR: Use 4-address frames on a virtual interface | 595 | * @NL80211_ATTR_4ADDR: Use 4-address frames on a virtual interface |
588 | * | 596 | * |
597 | * @NL80211_ATTR_SURVEY_INFO: survey information about a channel, part of | ||
598 | * the survey response for %NL80211_CMD_GET_SURVEY, nested attribute | ||
599 | * containing info as possible, see &enum survey_info. | ||
600 | * | ||
589 | * @NL80211_ATTR_MAX: highest attribute number currently defined | 601 | * @NL80211_ATTR_MAX: highest attribute number currently defined |
590 | * @__NL80211_ATTR_AFTER_LAST: internal use | 602 | * @__NL80211_ATTR_AFTER_LAST: internal use |
591 | */ | 603 | */ |
@@ -718,6 +730,8 @@ enum nl80211_attrs { | |||
718 | 730 | ||
719 | NL80211_ATTR_4ADDR, | 731 | NL80211_ATTR_4ADDR, |
720 | 732 | ||
733 | NL80211_ATTR_SURVEY_INFO, | ||
734 | |||
721 | /* add attributes here, update the policy in nl80211.c */ | 735 | /* add attributes here, update the policy in nl80211.c */ |
722 | 736 | ||
723 | __NL80211_ATTR_AFTER_LAST, | 737 | __NL80211_ATTR_AFTER_LAST, |
@@ -1121,6 +1135,26 @@ enum nl80211_reg_rule_flags { | |||
1121 | }; | 1135 | }; |
1122 | 1136 | ||
1123 | /** | 1137 | /** |
1138 | * enum nl80211_survey_info - survey information | ||
1139 | * | ||
1140 | * These attribute types are used with %NL80211_ATTR_SURVEY_INFO | ||
1141 | * when getting information about a survey. | ||
1142 | * | ||
1143 | * @__NL80211_SURVEY_INFO_INVALID: attribute number 0 is reserved | ||
1144 | * @NL80211_SURVEY_INFO_FREQUENCY: center frequency of channel | ||
1145 | * @NL80211_SURVEY_INFO_NOISE: noise level of channel (u8, dBm) | ||
1146 | */ | ||
1147 | enum nl80211_survey_info { | ||
1148 | __NL80211_SURVEY_INFO_INVALID, | ||
1149 | NL80211_SURVEY_INFO_FREQUENCY, | ||
1150 | NL80211_SURVEY_INFO_NOISE, | ||
1151 | |||
1152 | /* keep last */ | ||
1153 | __NL80211_SURVEY_INFO_AFTER_LAST, | ||
1154 | NL80211_SURVEY_INFO_MAX = __NL80211_SURVEY_INFO_AFTER_LAST - 1 | ||
1155 | }; | ||
1156 | |||
1157 | /** | ||
1124 | * enum nl80211_mntr_flags - monitor configuration flags | 1158 | * enum nl80211_mntr_flags - monitor configuration flags |
1125 | * | 1159 | * |
1126 | * Monitor configuration flags. | 1160 | * Monitor configuration flags. |
diff --git a/include/net/cfg80211.h b/include/net/cfg80211.h index 0e4c51fc63e5..21710fc17eaf 100644 --- a/include/net/cfg80211.h +++ b/include/net/cfg80211.h | |||
@@ -235,6 +235,35 @@ struct key_params { | |||
235 | }; | 235 | }; |
236 | 236 | ||
237 | /** | 237 | /** |
238 | * enum survey_info_flags - survey information flags | ||
239 | * | ||
240 | * Used by the driver to indicate which info in &struct survey_info | ||
241 | * it has filled in during the get_survey(). | ||
242 | */ | ||
243 | enum survey_info_flags { | ||
244 | SURVEY_INFO_NOISE_DBM = 1<<0, | ||
245 | }; | ||
246 | |||
247 | /** | ||
248 | * struct survey_info - channel survey response | ||
249 | * | ||
250 | * Used by dump_survey() to report back per-channel survey information. | ||
251 | * | ||
252 | * @channel: the channel this survey record reports, mandatory | ||
253 | * @filled: bitflag of flags from &enum survey_info_flags | ||
254 | * @noise: channel noise in dBm. This and all following fields are | ||
255 | * optional | ||
256 | * | ||
257 | * This structure can later be expanded with things like | ||
258 | * channel duty cycle etc. | ||
259 | */ | ||
260 | struct survey_info { | ||
261 | struct ieee80211_channel *channel; | ||
262 | u32 filled; | ||
263 | s8 noise; | ||
264 | }; | ||
265 | |||
266 | /** | ||
238 | * struct beacon_parameters - beacon parameters | 267 | * struct beacon_parameters - beacon parameters |
239 | * | 268 | * |
240 | * Used to configure the beacon for an interface. | 269 | * Used to configure the beacon for an interface. |
@@ -944,6 +973,8 @@ struct cfg80211_bitrate_mask { | |||
944 | * @rfkill_poll: polls the hw rfkill line, use cfg80211 reporting | 973 | * @rfkill_poll: polls the hw rfkill line, use cfg80211 reporting |
945 | * functions to adjust rfkill hw state | 974 | * functions to adjust rfkill hw state |
946 | * | 975 | * |
976 | * @dump_survey: get site survey information. | ||
977 | * | ||
947 | * @testmode_cmd: run a test mode command | 978 | * @testmode_cmd: run a test mode command |
948 | */ | 979 | */ |
949 | struct cfg80211_ops { | 980 | struct cfg80211_ops { |
@@ -1063,6 +1094,9 @@ struct cfg80211_ops { | |||
1063 | const u8 *peer, | 1094 | const u8 *peer, |
1064 | const struct cfg80211_bitrate_mask *mask); | 1095 | const struct cfg80211_bitrate_mask *mask); |
1065 | 1096 | ||
1097 | int (*dump_survey)(struct wiphy *wiphy, struct net_device *netdev, | ||
1098 | int idx, struct survey_info *info); | ||
1099 | |||
1066 | /* some temporary stuff to finish wext */ | 1100 | /* some temporary stuff to finish wext */ |
1067 | int (*set_power_mgmt)(struct wiphy *wiphy, struct net_device *dev, | 1101 | int (*set_power_mgmt)(struct wiphy *wiphy, struct net_device *dev, |
1068 | bool enabled, int timeout); | 1102 | bool enabled, int timeout); |