1 /* SPDX-License-Identifier: GPL-2.0 */ 2 /* 3 * Portions of this file 4 * Copyright(c) 2016-2017 Intel Deutschland GmbH 5 * Copyright (C) 2018, 2021-2024 Intel Corporation 6 */ 7 #ifndef __CFG80211_RDEV_OPS 8 #define __CFG80211_RDEV_OPS 9 10 #include <linux/rtnetlink.h> 11 #include <net/cfg80211.h> 12 #include "core.h" 13 #include "trace.h" 14 15 static inline int rdev_suspend(struct cfg80211_registered_device *rdev, 16 struct cfg80211_wowlan *wowlan) 17 { 18 int ret; 19 trace_rdev_suspend(&rdev->wiphy, wowlan); 20 ret = rdev->ops->suspend(&rdev->wiphy, wowlan); 21 trace_rdev_return_int(&rdev->wiphy, ret); 22 return ret; 23 } 24 25 static inline int rdev_resume(struct cfg80211_registered_device *rdev) 26 { 27 int ret; 28 trace_rdev_resume(&rdev->wiphy); 29 ret = rdev->ops->resume(&rdev->wiphy); 30 trace_rdev_return_int(&rdev->wiphy, ret); 31 return ret; 32 } 33 34 static inline void rdev_set_wakeup(struct cfg80211_registered_device *rdev, 35 bool enabled) 36 { 37 trace_rdev_set_wakeup(&rdev->wiphy, enabled); 38 rdev->ops->set_wakeup(&rdev->wiphy, enabled); 39 trace_rdev_return_void(&rdev->wiphy); 40 } 41 42 static inline struct wireless_dev 43 *rdev_add_virtual_intf(struct cfg80211_registered_device *rdev, char *name, 44 unsigned char name_assign_type, 45 enum nl80211_iftype type, 46 struct vif_params *params) 47 { 48 struct wireless_dev *ret; 49 trace_rdev_add_virtual_intf(&rdev->wiphy, name, type); 50 ret = rdev->ops->add_virtual_intf(&rdev->wiphy, name, name_assign_type, 51 type, params); 52 trace_rdev_return_wdev(&rdev->wiphy, ret); 53 return ret; 54 } 55 56 static inline int 57 rdev_del_virtual_intf(struct cfg80211_registered_device *rdev, 58 struct wireless_dev *wdev) 59 { 60 int ret; 61 trace_rdev_del_virtual_intf(&rdev->wiphy, wdev); 62 ret = rdev->ops->del_virtual_intf(&rdev->wiphy, wdev); 63 trace_rdev_return_int(&rdev->wiphy, ret); 64 return ret; 65 } 66 67 static inline int 68 rdev_change_virtual_intf(struct cfg80211_registered_device *rdev, 69 struct net_device *dev, enum nl80211_iftype type, 70 struct vif_params *params) 71 { 72 int ret; 73 trace_rdev_change_virtual_intf(&rdev->wiphy, dev, type); 74 ret = rdev->ops->change_virtual_intf(&rdev->wiphy, dev, type, params); 75 trace_rdev_return_int(&rdev->wiphy, ret); 76 return ret; 77 } 78 79 static inline int rdev_add_key(struct cfg80211_registered_device *rdev, 80 struct net_device *netdev, int link_id, 81 u8 key_index, bool pairwise, const u8 *mac_addr, 82 struct key_params *params) 83 { 84 int ret; 85 trace_rdev_add_key(&rdev->wiphy, netdev, link_id, key_index, pairwise, 86 mac_addr, params->mode); 87 ret = rdev->ops->add_key(&rdev->wiphy, netdev, link_id, key_index, 88 pairwise, mac_addr, params); 89 trace_rdev_return_int(&rdev->wiphy, ret); 90 return ret; 91 } 92 93 static inline int 94 rdev_get_key(struct cfg80211_registered_device *rdev, struct net_device *netdev, 95 int link_id, u8 key_index, bool pairwise, const u8 *mac_addr, 96 void *cookie, 97 void (*callback)(void *cookie, struct key_params*)) 98 { 99 int ret; 100 trace_rdev_get_key(&rdev->wiphy, netdev, link_id, key_index, pairwise, 101 mac_addr); 102 ret = rdev->ops->get_key(&rdev->wiphy, netdev, link_id, key_index, 103 pairwise, mac_addr, cookie, callback); 104 trace_rdev_return_int(&rdev->wiphy, ret); 105 return ret; 106 } 107 108 static inline int rdev_del_key(struct cfg80211_registered_device *rdev, 109 struct net_device *netdev, int link_id, 110 u8 key_index, bool pairwise, const u8 *mac_addr) 111 { 112 int ret; 113 trace_rdev_del_key(&rdev->wiphy, netdev, link_id, key_index, pairwise, 114 mac_addr); 115 ret = rdev->ops->del_key(&rdev->wiphy, netdev, link_id, key_index, 116 pairwise, mac_addr); 117 trace_rdev_return_int(&rdev->wiphy, ret); 118 return ret; 119 } 120 121 static inline int 122 rdev_set_default_key(struct cfg80211_registered_device *rdev, 123 struct net_device *netdev, int link_id, u8 key_index, 124 bool unicast, bool multicast) 125 { 126 int ret; 127 trace_rdev_set_default_key(&rdev->wiphy, netdev, link_id, key_index, 128 unicast, multicast); 129 ret = rdev->ops->set_default_key(&rdev->wiphy, netdev, link_id, 130 key_index, unicast, multicast); 131 trace_rdev_return_int(&rdev->wiphy, ret); 132 return ret; 133 } 134 135 static inline int 136 rdev_set_default_mgmt_key(struct cfg80211_registered_device *rdev, 137 struct net_device *netdev, int link_id, u8 key_index) 138 { 139 int ret; 140 trace_rdev_set_default_mgmt_key(&rdev->wiphy, netdev, link_id, 141 key_index); 142 ret = rdev->ops->set_default_mgmt_key(&rdev->wiphy, netdev, link_id, 143 key_index); 144 trace_rdev_return_int(&rdev->wiphy, ret); 145 return ret; 146 } 147 148 static inline int 149 rdev_set_default_beacon_key(struct cfg80211_registered_device *rdev, 150 struct net_device *netdev, int link_id, 151 u8 key_index) 152 { 153 int ret; 154 155 trace_rdev_set_default_beacon_key(&rdev->wiphy, netdev, link_id, 156 key_index); 157 ret = rdev->ops->set_default_beacon_key(&rdev->wiphy, netdev, link_id, 158 key_index); 159 trace_rdev_return_int(&rdev->wiphy, ret); 160 return ret; 161 } 162 163 static inline int rdev_start_ap(struct cfg80211_registered_device *rdev, 164 struct net_device *dev, 165 struct cfg80211_ap_settings *settings) 166 { 167 int ret; 168 trace_rdev_start_ap(&rdev->wiphy, dev, settings); 169 ret = rdev->ops->start_ap(&rdev->wiphy, dev, settings); 170 trace_rdev_return_int(&rdev->wiphy, ret); 171 return ret; 172 } 173 174 static inline int rdev_change_beacon(struct cfg80211_registered_device *rdev, 175 struct net_device *dev, 176 struct cfg80211_ap_update *info) 177 { 178 int ret; 179 trace_rdev_change_beacon(&rdev->wiphy, dev, info); 180 ret = rdev->ops->change_beacon(&rdev->wiphy, dev, info); 181 trace_rdev_return_int(&rdev->wiphy, ret); 182 return ret; 183 } 184 185 static inline int rdev_stop_ap(struct cfg80211_registered_device *rdev, 186 struct net_device *dev, unsigned int link_id) 187 { 188 int ret; 189 trace_rdev_stop_ap(&rdev->wiphy, dev, link_id); 190 ret = rdev->ops->stop_ap(&rdev->wiphy, dev, link_id); 191 trace_rdev_return_int(&rdev->wiphy, ret); 192 return ret; 193 } 194 195 static inline int rdev_add_station(struct cfg80211_registered_device *rdev, 196 struct net_device *dev, u8 *mac, 197 struct station_parameters *params) 198 { 199 int ret; 200 trace_rdev_add_station(&rdev->wiphy, dev, mac, params); 201 ret = rdev->ops->add_station(&rdev->wiphy, dev, mac, params); 202 trace_rdev_return_int(&rdev->wiphy, ret); 203 return ret; 204 } 205 206 static inline int rdev_del_station(struct cfg80211_registered_device *rdev, 207 struct net_device *dev, 208 struct station_del_parameters *params) 209 { 210 int ret; 211 trace_rdev_del_station(&rdev->wiphy, dev, params); 212 ret = rdev->ops->del_station(&rdev->wiphy, dev, params); 213 trace_rdev_return_int(&rdev->wiphy, ret); 214 return ret; 215 } 216 217 static inline int rdev_change_station(struct cfg80211_registered_device *rdev, 218 struct net_device *dev, u8 *mac, 219 struct station_parameters *params) 220 { 221 int ret; 222 trace_rdev_change_station(&rdev->wiphy, dev, mac, params); 223 ret = rdev->ops->change_station(&rdev->wiphy, dev, mac, params); 224 trace_rdev_return_int(&rdev->wiphy, ret); 225 return ret; 226 } 227 228 static inline int rdev_get_station(struct cfg80211_registered_device *rdev, 229 struct net_device *dev, const u8 *mac, 230 struct station_info *sinfo) 231 { 232 int ret; 233 trace_rdev_get_station(&rdev->wiphy, dev, mac); 234 ret = rdev->ops->get_station(&rdev->wiphy, dev, mac, sinfo); 235 trace_rdev_return_int_station_info(&rdev->wiphy, ret, sinfo); 236 return ret; 237 } 238 239 static inline int rdev_dump_station(struct cfg80211_registered_device *rdev, 240 struct net_device *dev, int idx, u8 *mac, 241 struct station_info *sinfo) 242 { 243 int ret; 244 trace_rdev_dump_station(&rdev->wiphy, dev, idx, mac); 245 ret = rdev->ops->dump_station(&rdev->wiphy, dev, idx, mac, sinfo); 246 trace_rdev_return_int_station_info(&rdev->wiphy, ret, sinfo); 247 return ret; 248 } 249 250 static inline int rdev_add_mpath(struct cfg80211_registered_device *rdev, 251 struct net_device *dev, u8 *dst, u8 *next_hop) 252 { 253 int ret; 254 trace_rdev_add_mpath(&rdev->wiphy, dev, dst, next_hop); 255 ret = rdev->ops->add_mpath(&rdev->wiphy, dev, dst, next_hop); 256 trace_rdev_return_int(&rdev->wiphy, ret); 257 return ret; 258 } 259 260 static inline int rdev_del_mpath(struct cfg80211_registered_device *rdev, 261 struct net_device *dev, u8 *dst) 262 { 263 int ret; 264 trace_rdev_del_mpath(&rdev->wiphy, dev, dst); 265 ret = rdev->ops->del_mpath(&rdev->wiphy, dev, dst); 266 trace_rdev_return_int(&rdev->wiphy, ret); 267 return ret; 268 } 269 270 static inline int rdev_change_mpath(struct cfg80211_registered_device *rdev, 271 struct net_device *dev, u8 *dst, 272 u8 *next_hop) 273 { 274 int ret; 275 trace_rdev_change_mpath(&rdev->wiphy, dev, dst, next_hop); 276 ret = rdev->ops->change_mpath(&rdev->wiphy, dev, dst, next_hop); 277 trace_rdev_return_int(&rdev->wiphy, ret); 278 return ret; 279 } 280 281 static inline int rdev_get_mpath(struct cfg80211_registered_device *rdev, 282 struct net_device *dev, u8 *dst, u8 *next_hop, 283 struct mpath_info *pinfo) 284 { 285 int ret; 286 trace_rdev_get_mpath(&rdev->wiphy, dev, dst, next_hop); 287 ret = rdev->ops->get_mpath(&rdev->wiphy, dev, dst, next_hop, pinfo); 288 trace_rdev_return_int_mpath_info(&rdev->wiphy, ret, pinfo); 289 return ret; 290 291 } 292 293 static inline int rdev_get_mpp(struct cfg80211_registered_device *rdev, 294 struct net_device *dev, u8 *dst, u8 *mpp, 295 struct mpath_info *pinfo) 296 { 297 int ret; 298 299 trace_rdev_get_mpp(&rdev->wiphy, dev, dst, mpp); 300 ret = rdev->ops->get_mpp(&rdev->wiphy, dev, dst, mpp, pinfo); 301 trace_rdev_return_int_mpath_info(&rdev->wiphy, ret, pinfo); 302 return ret; 303 } 304 305 static inline int rdev_dump_mpath(struct cfg80211_registered_device *rdev, 306 struct net_device *dev, int idx, u8 *dst, 307 u8 *next_hop, struct mpath_info *pinfo) 308 309 { 310 int ret; 311 trace_rdev_dump_mpath(&rdev->wiphy, dev, idx, dst, next_hop); 312 ret = rdev->ops->dump_mpath(&rdev->wiphy, dev, idx, dst, next_hop, 313 pinfo); 314 trace_rdev_return_int_mpath_info(&rdev->wiphy, ret, pinfo); 315 return ret; 316 } 317 318 static inline int rdev_dump_mpp(struct cfg80211_registered_device *rdev, 319 struct net_device *dev, int idx, u8 *dst, 320 u8 *mpp, struct mpath_info *pinfo) 321 322 { 323 int ret; 324 325 trace_rdev_dump_mpp(&rdev->wiphy, dev, idx, dst, mpp); 326 ret = rdev->ops->dump_mpp(&rdev->wiphy, dev, idx, dst, mpp, pinfo); 327 trace_rdev_return_int_mpath_info(&rdev->wiphy, ret, pinfo); 328 return ret; 329 } 330 331 static inline int 332 rdev_get_mesh_config(struct cfg80211_registered_device *rdev, 333 struct net_device *dev, struct mesh_config *conf) 334 { 335 int ret; 336 trace_rdev_get_mesh_config(&rdev->wiphy, dev); 337 ret = rdev->ops->get_mesh_config(&rdev->wiphy, dev, conf); 338 trace_rdev_return_int_mesh_config(&rdev->wiphy, ret, conf); 339 return ret; 340 } 341 342 static inline int 343 rdev_update_mesh_config(struct cfg80211_registered_device *rdev, 344 struct net_device *dev, u32 mask, 345 const struct mesh_config *nconf) 346 { 347 int ret; 348 trace_rdev_update_mesh_config(&rdev->wiphy, dev, mask, nconf); 349 ret = rdev->ops->update_mesh_config(&rdev->wiphy, dev, mask, nconf); 350 trace_rdev_return_int(&rdev->wiphy, ret); 351 return ret; 352 } 353 354 static inline int rdev_join_mesh(struct cfg80211_registered_device *rdev, 355 struct net_device *dev, 356 const struct mesh_config *conf, 357 const struct mesh_setup *setup) 358 { 359 int ret; 360 trace_rdev_join_mesh(&rdev->wiphy, dev, conf, setup); 361 ret = rdev->ops->join_mesh(&rdev->wiphy, dev, conf, setup); 362 trace_rdev_return_int(&rdev->wiphy, ret); 363 return ret; 364 } 365 366 367 static inline int rdev_leave_mesh(struct cfg80211_registered_device *rdev, 368 struct net_device *dev) 369 { 370 int ret; 371 trace_rdev_leave_mesh(&rdev->wiphy, dev); 372 ret = rdev->ops->leave_mesh(&rdev->wiphy, dev); 373 trace_rdev_return_int(&rdev->wiphy, ret); 374 return ret; 375 } 376 377 static inline int rdev_join_ocb(struct cfg80211_registered_device *rdev, 378 struct net_device *dev, 379 struct ocb_setup *setup) 380 { 381 int ret; 382 trace_rdev_join_ocb(&rdev->wiphy, dev, setup); 383 ret = rdev->ops->join_ocb(&rdev->wiphy, dev, setup); 384 trace_rdev_return_int(&rdev->wiphy, ret); 385 return ret; 386 } 387 388 static inline int rdev_leave_ocb(struct cfg80211_registered_device *rdev, 389 struct net_device *dev) 390 { 391 int ret; 392 trace_rdev_leave_ocb(&rdev->wiphy, dev); 393 ret = rdev->ops->leave_ocb(&rdev->wiphy, dev); 394 trace_rdev_return_int(&rdev->wiphy, ret); 395 return ret; 396 } 397 398 static inline int rdev_change_bss(struct cfg80211_registered_device *rdev, 399 struct net_device *dev, 400 struct bss_parameters *params) 401 402 { 403 int ret; 404 trace_rdev_change_bss(&rdev->wiphy, dev, params); 405 ret = rdev->ops->change_bss(&rdev->wiphy, dev, params); 406 trace_rdev_return_int(&rdev->wiphy, ret); 407 return ret; 408 } 409 410 static inline void rdev_inform_bss(struct cfg80211_registered_device *rdev, 411 struct cfg80211_bss *bss, 412 const struct cfg80211_bss_ies *ies, 413 void *drv_data) 414 415 { 416 trace_rdev_inform_bss(&rdev->wiphy, bss); 417 if (rdev->ops->inform_bss) 418 rdev->ops->inform_bss(&rdev->wiphy, bss, ies, drv_data); 419 trace_rdev_return_void(&rdev->wiphy); 420 } 421 422 static inline int rdev_set_txq_params(struct cfg80211_registered_device *rdev, 423 struct net_device *dev, 424 struct ieee80211_txq_params *params) 425 426 { 427 int ret; 428 trace_rdev_set_txq_params(&rdev->wiphy, dev, params); 429 ret = rdev->ops->set_txq_params(&rdev->wiphy, dev, params); 430 trace_rdev_return_int(&rdev->wiphy, ret); 431 return ret; 432 } 433 434 static inline int 435 rdev_libertas_set_mesh_channel(struct cfg80211_registered_device *rdev, 436 struct net_device *dev, 437 struct ieee80211_channel *chan) 438 { 439 int ret; 440 trace_rdev_libertas_set_mesh_channel(&rdev->wiphy, dev, chan); 441 ret = rdev->ops->libertas_set_mesh_channel(&rdev->wiphy, dev, chan); 442 trace_rdev_return_int(&rdev->wiphy, ret); 443 return ret; 444 } 445 446 static inline int 447 rdev_set_monitor_channel(struct cfg80211_registered_device *rdev, 448 struct net_device *dev, 449 struct cfg80211_chan_def *chandef) 450 { 451 int ret; 452 trace_rdev_set_monitor_channel(&rdev->wiphy, dev, chandef); 453 ret = rdev->ops->set_monitor_channel(&rdev->wiphy, dev, chandef); 454 trace_rdev_return_int(&rdev->wiphy, ret); 455 return ret; 456 } 457 458 static inline int rdev_scan(struct cfg80211_registered_device *rdev, 459 struct cfg80211_scan_request *request) 460 { 461 int ret; 462 463 if (WARN_ON_ONCE(!request->n_ssids && request->ssids)) 464 return -EINVAL; 465 466 trace_rdev_scan(&rdev->wiphy, request); 467 ret = rdev->ops->scan(&rdev->wiphy, request); 468 trace_rdev_return_int(&rdev->wiphy, ret); 469 return ret; 470 } 471 472 static inline void rdev_abort_scan(struct cfg80211_registered_device *rdev, 473 struct wireless_dev *wdev) 474 { 475 trace_rdev_abort_scan(&rdev->wiphy, wdev); 476 rdev->ops->abort_scan(&rdev->wiphy, wdev); 477 trace_rdev_return_void(&rdev->wiphy); 478 } 479 480 static inline int rdev_auth(struct cfg80211_registered_device *rdev, 481 struct net_device *dev, 482 struct cfg80211_auth_request *req) 483 { 484 int ret; 485 trace_rdev_auth(&rdev->wiphy, dev, req); 486 ret = rdev->ops->auth(&rdev->wiphy, dev, req); 487 trace_rdev_return_int(&rdev->wiphy, ret); 488 return ret; 489 } 490 491 static inline int rdev_assoc(struct cfg80211_registered_device *rdev, 492 struct net_device *dev, 493 struct cfg80211_assoc_request *req) 494 { 495 int ret; 496 497 trace_rdev_assoc(&rdev->wiphy, dev, req); 498 ret = rdev->ops->assoc(&rdev->wiphy, dev, req); 499 trace_rdev_return_int(&rdev->wiphy, ret); 500 return ret; 501 } 502 503 static inline int rdev_deauth(struct cfg80211_registered_device *rdev, 504 struct net_device *dev, 505 struct cfg80211_deauth_request *req) 506 { 507 int ret; 508 trace_rdev_deauth(&rdev->wiphy, dev, req); 509 ret = rdev->ops->deauth(&rdev->wiphy, dev, req); 510 trace_rdev_return_int(&rdev->wiphy, ret); 511 return ret; 512 } 513 514 static inline int rdev_disassoc(struct cfg80211_registered_device *rdev, 515 struct net_device *dev, 516 struct cfg80211_disassoc_request *req) 517 { 518 int ret; 519 trace_rdev_disassoc(&rdev->wiphy, dev, req); 520 ret = rdev->ops->disassoc(&rdev->wiphy, dev, req); 521 trace_rdev_return_int(&rdev->wiphy, ret); 522 return ret; 523 } 524 525 static inline int rdev_connect(struct cfg80211_registered_device *rdev, 526 struct net_device *dev, 527 struct cfg80211_connect_params *sme) 528 { 529 int ret; 530 trace_rdev_connect(&rdev->wiphy, dev, sme); 531 ret = rdev->ops->connect(&rdev->wiphy, dev, sme); 532 trace_rdev_return_int(&rdev->wiphy, ret); 533 return ret; 534 } 535 536 static inline int 537 rdev_update_connect_params(struct cfg80211_registered_device *rdev, 538 struct net_device *dev, 539 struct cfg80211_connect_params *sme, u32 changed) 540 { 541 int ret; 542 trace_rdev_update_connect_params(&rdev->wiphy, dev, sme, changed); 543 ret = rdev->ops->update_connect_params(&rdev->wiphy, dev, sme, changed); 544 trace_rdev_return_int(&rdev->wiphy, ret); 545 return ret; 546 } 547 548 static inline int rdev_disconnect(struct cfg80211_registered_device *rdev, 549 struct net_device *dev, u16 reason_code) 550 { 551 int ret; 552 trace_rdev_disconnect(&rdev->wiphy, dev, reason_code); 553 ret = rdev->ops->disconnect(&rdev->wiphy, dev, reason_code); 554 trace_rdev_return_int(&rdev->wiphy, ret); 555 return ret; 556 } 557 558 static inline int rdev_join_ibss(struct cfg80211_registered_device *rdev, 559 struct net_device *dev, 560 struct cfg80211_ibss_params *params) 561 { 562 int ret; 563 trace_rdev_join_ibss(&rdev->wiphy, dev, params); 564 ret = rdev->ops->join_ibss(&rdev->wiphy, dev, params); 565 trace_rdev_return_int(&rdev->wiphy, ret); 566 return ret; 567 } 568 569 static inline int rdev_leave_ibss(struct cfg80211_registered_device *rdev, 570 struct net_device *dev) 571 { 572 int ret; 573 trace_rdev_leave_ibss(&rdev->wiphy, dev); 574 ret = rdev->ops->leave_ibss(&rdev->wiphy, dev); 575 trace_rdev_return_int(&rdev->wiphy, ret); 576 return ret; 577 } 578 579 static inline int 580 rdev_set_wiphy_params(struct cfg80211_registered_device *rdev, u32 changed) 581 { 582 int ret = -EOPNOTSUPP; 583 584 trace_rdev_set_wiphy_params(&rdev->wiphy, changed); 585 if (rdev->ops->set_wiphy_params) 586 ret = rdev->ops->set_wiphy_params(&rdev->wiphy, changed); 587 trace_rdev_return_int(&rdev->wiphy, ret); 588 return ret; 589 } 590 591 static inline int rdev_set_tx_power(struct cfg80211_registered_device *rdev, 592 struct wireless_dev *wdev, 593 enum nl80211_tx_power_setting type, int mbm) 594 { 595 int ret; 596 trace_rdev_set_tx_power(&rdev->wiphy, wdev, type, mbm); 597 ret = rdev->ops->set_tx_power(&rdev->wiphy, wdev, type, mbm); 598 trace_rdev_return_int(&rdev->wiphy, ret); 599 return ret; 600 } 601 602 static inline int rdev_get_tx_power(struct cfg80211_registered_device *rdev, 603 struct wireless_dev *wdev, int *dbm) 604 { 605 int ret; 606 trace_rdev_get_tx_power(&rdev->wiphy, wdev); 607 ret = rdev->ops->get_tx_power(&rdev->wiphy, wdev, dbm); 608 trace_rdev_return_int_int(&rdev->wiphy, ret, *dbm); 609 return ret; 610 } 611 612 static inline int 613 rdev_set_multicast_to_unicast(struct cfg80211_registered_device *rdev, 614 struct net_device *dev, 615 const bool enabled) 616 { 617 int ret; 618 trace_rdev_set_multicast_to_unicast(&rdev->wiphy, dev, enabled); 619 ret = rdev->ops->set_multicast_to_unicast(&rdev->wiphy, dev, enabled); 620 trace_rdev_return_int(&rdev->wiphy, ret); 621 return ret; 622 } 623 624 static inline int 625 rdev_get_txq_stats(struct cfg80211_registered_device *rdev, 626 struct wireless_dev *wdev, 627 struct cfg80211_txq_stats *txqstats) 628 { 629 int ret; 630 trace_rdev_get_txq_stats(&rdev->wiphy, wdev); 631 ret = rdev->ops->get_txq_stats(&rdev->wiphy, wdev, txqstats); 632 trace_rdev_return_int(&rdev->wiphy, ret); 633 return ret; 634 } 635 636 static inline void rdev_rfkill_poll(struct cfg80211_registered_device *rdev) 637 { 638 trace_rdev_rfkill_poll(&rdev->wiphy); 639 rdev->ops->rfkill_poll(&rdev->wiphy); 640 trace_rdev_return_void(&rdev->wiphy); 641 } 642 643 644 #ifdef CONFIG_NL80211_TESTMODE 645 static inline int rdev_testmode_cmd(struct cfg80211_registered_device *rdev, 646 struct wireless_dev *wdev, 647 void *data, int len) 648 { 649 int ret; 650 trace_rdev_testmode_cmd(&rdev->wiphy, wdev); 651 ret = rdev->ops->testmode_cmd(&rdev->wiphy, wdev, data, len); 652 trace_rdev_return_int(&rdev->wiphy, ret); 653 return ret; 654 } 655 656 static inline int rdev_testmode_dump(struct cfg80211_registered_device *rdev, 657 struct sk_buff *skb, 658 struct netlink_callback *cb, void *data, 659 int len) 660 { 661 int ret; 662 trace_rdev_testmode_dump(&rdev->wiphy); 663 ret = rdev->ops->testmode_dump(&rdev->wiphy, skb, cb, data, len); 664 trace_rdev_return_int(&rdev->wiphy, ret); 665 return ret; 666 } 667 #endif 668 669 static inline int 670 rdev_set_bitrate_mask(struct cfg80211_registered_device *rdev, 671 struct net_device *dev, unsigned int link_id, 672 const u8 *peer, 673 const struct cfg80211_bitrate_mask *mask) 674 { 675 int ret; 676 trace_rdev_set_bitrate_mask(&rdev->wiphy, dev, link_id, peer, mask); 677 ret = rdev->ops->set_bitrate_mask(&rdev->wiphy, dev, link_id, 678 peer, mask); 679 trace_rdev_return_int(&rdev->wiphy, ret); 680 return ret; 681 } 682 683 static inline int rdev_dump_survey(struct cfg80211_registered_device *rdev, 684 struct net_device *netdev, int idx, 685 struct survey_info *info) 686 { 687 int ret; 688 trace_rdev_dump_survey(&rdev->wiphy, netdev, idx); 689 ret = rdev->ops->dump_survey(&rdev->wiphy, netdev, idx, info); 690 if (ret < 0) 691 trace_rdev_return_int(&rdev->wiphy, ret); 692 else 693 trace_rdev_return_int_survey_info(&rdev->wiphy, ret, info); 694 return ret; 695 } 696 697 static inline int rdev_set_pmksa(struct cfg80211_registered_device *rdev, 698 struct net_device *netdev, 699 struct cfg80211_pmksa *pmksa) 700 { 701 int ret; 702 trace_rdev_set_pmksa(&rdev->wiphy, netdev, pmksa); 703 ret = rdev->ops->set_pmksa(&rdev->wiphy, netdev, pmksa); 704 trace_rdev_return_int(&rdev->wiphy, ret); 705 return ret; 706 } 707 708 static inline int rdev_del_pmksa(struct cfg80211_registered_device *rdev, 709 struct net_device *netdev, 710 struct cfg80211_pmksa *pmksa) 711 { 712 int ret; 713 trace_rdev_del_pmksa(&rdev->wiphy, netdev, pmksa); 714 ret = rdev->ops->del_pmksa(&rdev->wiphy, netdev, pmksa); 715 trace_rdev_return_int(&rdev->wiphy, ret); 716 return ret; 717 } 718 719 static inline int rdev_flush_pmksa(struct cfg80211_registered_device *rdev, 720 struct net_device *netdev) 721 { 722 int ret; 723 trace_rdev_flush_pmksa(&rdev->wiphy, netdev); 724 ret = rdev->ops->flush_pmksa(&rdev->wiphy, netdev); 725 trace_rdev_return_int(&rdev->wiphy, ret); 726 return ret; 727 } 728 729 static inline int 730 rdev_remain_on_channel(struct cfg80211_registered_device *rdev, 731 struct wireless_dev *wdev, 732 struct ieee80211_channel *chan, 733 unsigned int duration, u64 *cookie) 734 { 735 int ret; 736 trace_rdev_remain_on_channel(&rdev->wiphy, wdev, chan, duration); 737 ret = rdev->ops->remain_on_channel(&rdev->wiphy, wdev, chan, 738 duration, cookie); 739 trace_rdev_return_int_cookie(&rdev->wiphy, ret, *cookie); 740 return ret; 741 } 742 743 static inline int 744 rdev_cancel_remain_on_channel(struct cfg80211_registered_device *rdev, 745 struct wireless_dev *wdev, u64 cookie) 746 { 747 int ret; 748 trace_rdev_cancel_remain_on_channel(&rdev->wiphy, wdev, cookie); 749 ret = rdev->ops->cancel_remain_on_channel(&rdev->wiphy, wdev, cookie); 750 trace_rdev_return_int(&rdev->wiphy, ret); 751 return ret; 752 } 753 754 static inline int rdev_mgmt_tx(struct cfg80211_registered_device *rdev, 755 struct wireless_dev *wdev, 756 struct cfg80211_mgmt_tx_params *params, 757 u64 *cookie) 758 { 759 int ret; 760 trace_rdev_mgmt_tx(&rdev->wiphy, wdev, params); 761 ret = rdev->ops->mgmt_tx(&rdev->wiphy, wdev, params, cookie); 762 trace_rdev_return_int_cookie(&rdev->wiphy, ret, *cookie); 763 return ret; 764 } 765 766 static inline int rdev_tx_control_port(struct cfg80211_registered_device *rdev, 767 struct net_device *dev, 768 const void *buf, size_t len, 769 const u8 *dest, __be16 proto, 770 const bool noencrypt, int link, 771 u64 *cookie) 772 { 773 int ret; 774 trace_rdev_tx_control_port(&rdev->wiphy, dev, buf, len, 775 dest, proto, noencrypt, link); 776 ret = rdev->ops->tx_control_port(&rdev->wiphy, dev, buf, len, 777 dest, proto, noencrypt, link, cookie); 778 if (cookie) 779 trace_rdev_return_int_cookie(&rdev->wiphy, ret, *cookie); 780 else 781 trace_rdev_return_int(&rdev->wiphy, ret); 782 return ret; 783 } 784 785 static inline int 786 rdev_mgmt_tx_cancel_wait(struct cfg80211_registered_device *rdev, 787 struct wireless_dev *wdev, u64 cookie) 788 { 789 int ret; 790 trace_rdev_mgmt_tx_cancel_wait(&rdev->wiphy, wdev, cookie); 791 ret = rdev->ops->mgmt_tx_cancel_wait(&rdev->wiphy, wdev, cookie); 792 trace_rdev_return_int(&rdev->wiphy, ret); 793 return ret; 794 } 795 796 static inline int rdev_set_power_mgmt(struct cfg80211_registered_device *rdev, 797 struct net_device *dev, bool enabled, 798 int timeout) 799 { 800 int ret; 801 trace_rdev_set_power_mgmt(&rdev->wiphy, dev, enabled, timeout); 802 ret = rdev->ops->set_power_mgmt(&rdev->wiphy, dev, enabled, timeout); 803 trace_rdev_return_int(&rdev->wiphy, ret); 804 return ret; 805 } 806 807 static inline int 808 rdev_set_cqm_rssi_config(struct cfg80211_registered_device *rdev, 809 struct net_device *dev, s32 rssi_thold, u32 rssi_hyst) 810 { 811 int ret; 812 trace_rdev_set_cqm_rssi_config(&rdev->wiphy, dev, rssi_thold, 813 rssi_hyst); 814 ret = rdev->ops->set_cqm_rssi_config(&rdev->wiphy, dev, rssi_thold, 815 rssi_hyst); 816 trace_rdev_return_int(&rdev->wiphy, ret); 817 return ret; 818 } 819 820 static inline int 821 rdev_set_cqm_rssi_range_config(struct cfg80211_registered_device *rdev, 822 struct net_device *dev, s32 low, s32 high) 823 { 824 int ret; 825 trace_rdev_set_cqm_rssi_range_config(&rdev->wiphy, dev, low, high); 826 ret = rdev->ops->set_cqm_rssi_range_config(&rdev->wiphy, dev, 827 low, high); 828 trace_rdev_return_int(&rdev->wiphy, ret); 829 return ret; 830 } 831 832 static inline int 833 rdev_set_cqm_txe_config(struct cfg80211_registered_device *rdev, 834 struct net_device *dev, u32 rate, u32 pkts, u32 intvl) 835 { 836 int ret; 837 trace_rdev_set_cqm_txe_config(&rdev->wiphy, dev, rate, pkts, intvl); 838 ret = rdev->ops->set_cqm_txe_config(&rdev->wiphy, dev, rate, pkts, 839 intvl); 840 trace_rdev_return_int(&rdev->wiphy, ret); 841 return ret; 842 } 843 844 static inline void 845 rdev_update_mgmt_frame_registrations(struct cfg80211_registered_device *rdev, 846 struct wireless_dev *wdev, 847 struct mgmt_frame_regs *upd) 848 { 849 might_sleep(); 850 851 trace_rdev_update_mgmt_frame_registrations(&rdev->wiphy, wdev, upd); 852 if (rdev->ops->update_mgmt_frame_registrations) 853 rdev->ops->update_mgmt_frame_registrations(&rdev->wiphy, wdev, 854 upd); 855 trace_rdev_return_void(&rdev->wiphy); 856 } 857 858 static inline int rdev_set_antenna(struct cfg80211_registered_device *rdev, 859 u32 tx_ant, u32 rx_ant) 860 { 861 int ret; 862 trace_rdev_set_antenna(&rdev->wiphy, tx_ant, rx_ant); 863 ret = rdev->ops->set_antenna(&rdev->wiphy, tx_ant, rx_ant); 864 trace_rdev_return_int(&rdev->wiphy, ret); 865 return ret; 866 } 867 868 static inline int rdev_get_antenna(struct cfg80211_registered_device *rdev, 869 u32 *tx_ant, u32 *rx_ant) 870 { 871 int ret; 872 trace_rdev_get_antenna(&rdev->wiphy); 873 ret = rdev->ops->get_antenna(&rdev->wiphy, tx_ant, rx_ant); 874 if (ret) 875 trace_rdev_return_int(&rdev->wiphy, ret); 876 else 877 trace_rdev_return_int_tx_rx(&rdev->wiphy, ret, *tx_ant, 878 *rx_ant); 879 return ret; 880 } 881 882 static inline int 883 rdev_sched_scan_start(struct cfg80211_registered_device *rdev, 884 struct net_device *dev, 885 struct cfg80211_sched_scan_request *request) 886 { 887 int ret; 888 trace_rdev_sched_scan_start(&rdev->wiphy, dev, request->reqid); 889 ret = rdev->ops->sched_scan_start(&rdev->wiphy, dev, request); 890 trace_rdev_return_int(&rdev->wiphy, ret); 891 return ret; 892 } 893 894 static inline int rdev_sched_scan_stop(struct cfg80211_registered_device *rdev, 895 struct net_device *dev, u64 reqid) 896 { 897 int ret; 898 trace_rdev_sched_scan_stop(&rdev->wiphy, dev, reqid); 899 ret = rdev->ops->sched_scan_stop(&rdev->wiphy, dev, reqid); 900 trace_rdev_return_int(&rdev->wiphy, ret); 901 return ret; 902 } 903 904 static inline int rdev_set_rekey_data(struct cfg80211_registered_device *rdev, 905 struct net_device *dev, 906 struct cfg80211_gtk_rekey_data *data) 907 { 908 int ret; 909 trace_rdev_set_rekey_data(&rdev->wiphy, dev); 910 ret = rdev->ops->set_rekey_data(&rdev->wiphy, dev, data); 911 trace_rdev_return_int(&rdev->wiphy, ret); 912 return ret; 913 } 914 915 static inline int rdev_tdls_mgmt(struct cfg80211_registered_device *rdev, 916 struct net_device *dev, u8 *peer, 917 int link_id, u8 action_code, 918 u8 dialog_token, u16 status_code, 919 u32 peer_capability, bool initiator, 920 const u8 *buf, size_t len) 921 { 922 int ret; 923 trace_rdev_tdls_mgmt(&rdev->wiphy, dev, peer, link_id, action_code, 924 dialog_token, status_code, peer_capability, 925 initiator, buf, len); 926 ret = rdev->ops->tdls_mgmt(&rdev->wiphy, dev, peer, link_id, 927 action_code, dialog_token, status_code, 928 peer_capability, initiator, buf, len); 929 trace_rdev_return_int(&rdev->wiphy, ret); 930 return ret; 931 } 932 933 static inline int rdev_tdls_oper(struct cfg80211_registered_device *rdev, 934 struct net_device *dev, u8 *peer, 935 enum nl80211_tdls_operation oper) 936 { 937 int ret; 938 trace_rdev_tdls_oper(&rdev->wiphy, dev, peer, oper); 939 ret = rdev->ops->tdls_oper(&rdev->wiphy, dev, peer, oper); 940 trace_rdev_return_int(&rdev->wiphy, ret); 941 return ret; 942 } 943 944 static inline int rdev_probe_client(struct cfg80211_registered_device *rdev, 945 struct net_device *dev, const u8 *peer, 946 u64 *cookie) 947 { 948 int ret; 949 trace_rdev_probe_client(&rdev->wiphy, dev, peer); 950 ret = rdev->ops->probe_client(&rdev->wiphy, dev, peer, cookie); 951 trace_rdev_return_int_cookie(&rdev->wiphy, ret, *cookie); 952 return ret; 953 } 954 955 static inline int rdev_set_noack_map(struct cfg80211_registered_device *rdev, 956 struct net_device *dev, u16 noack_map) 957 { 958 int ret; 959 trace_rdev_set_noack_map(&rdev->wiphy, dev, noack_map); 960 ret = rdev->ops->set_noack_map(&rdev->wiphy, dev, noack_map); 961 trace_rdev_return_int(&rdev->wiphy, ret); 962 return ret; 963 } 964 965 static inline int 966 rdev_get_channel(struct cfg80211_registered_device *rdev, 967 struct wireless_dev *wdev, 968 unsigned int link_id, 969 struct cfg80211_chan_def *chandef) 970 { 971 int ret; 972 973 trace_rdev_get_channel(&rdev->wiphy, wdev, link_id); 974 ret = rdev->ops->get_channel(&rdev->wiphy, wdev, link_id, chandef); 975 trace_rdev_return_chandef(&rdev->wiphy, ret, chandef); 976 977 return ret; 978 } 979 980 static inline int rdev_start_p2p_device(struct cfg80211_registered_device *rdev, 981 struct wireless_dev *wdev) 982 { 983 int ret; 984 985 trace_rdev_start_p2p_device(&rdev->wiphy, wdev); 986 ret = rdev->ops->start_p2p_device(&rdev->wiphy, wdev); 987 trace_rdev_return_int(&rdev->wiphy, ret); 988 return ret; 989 } 990 991 static inline void rdev_stop_p2p_device(struct cfg80211_registered_device *rdev, 992 struct wireless_dev *wdev) 993 { 994 trace_rdev_stop_p2p_device(&rdev->wiphy, wdev); 995 rdev->ops->stop_p2p_device(&rdev->wiphy, wdev); 996 trace_rdev_return_void(&rdev->wiphy); 997 } 998 999 static inline int rdev_start_nan(struct cfg80211_registered_device *rdev, 1000 struct wireless_dev *wdev, 1001 struct cfg80211_nan_conf *conf) 1002 { 1003 int ret; 1004 1005 trace_rdev_start_nan(&rdev->wiphy, wdev, conf); 1006 ret = rdev->ops->start_nan(&rdev->wiphy, wdev, conf); 1007 trace_rdev_return_int(&rdev->wiphy, ret); 1008 return ret; 1009 } 1010 1011 static inline void rdev_stop_nan(struct cfg80211_registered_device *rdev, 1012 struct wireless_dev *wdev) 1013 { 1014 trace_rdev_stop_nan(&rdev->wiphy, wdev); 1015 rdev->ops->stop_nan(&rdev->wiphy, wdev); 1016 trace_rdev_return_void(&rdev->wiphy); 1017 } 1018 1019 static inline int 1020 rdev_add_nan_func(struct cfg80211_registered_device *rdev, 1021 struct wireless_dev *wdev, 1022 struct cfg80211_nan_func *nan_func) 1023 { 1024 int ret; 1025 1026 trace_rdev_add_nan_func(&rdev->wiphy, wdev, nan_func); 1027 ret = rdev->ops->add_nan_func(&rdev->wiphy, wdev, nan_func); 1028 trace_rdev_return_int(&rdev->wiphy, ret); 1029 return ret; 1030 } 1031 1032 static inline void rdev_del_nan_func(struct cfg80211_registered_device *rdev, 1033 struct wireless_dev *wdev, u64 cookie) 1034 { 1035 trace_rdev_del_nan_func(&rdev->wiphy, wdev, cookie); 1036 rdev->ops->del_nan_func(&rdev->wiphy, wdev, cookie); 1037 trace_rdev_return_void(&rdev->wiphy); 1038 } 1039 1040 static inline int 1041 rdev_nan_change_conf(struct cfg80211_registered_device *rdev, 1042 struct wireless_dev *wdev, 1043 struct cfg80211_nan_conf *conf, u32 changes) 1044 { 1045 int ret; 1046 1047 trace_rdev_nan_change_conf(&rdev->wiphy, wdev, conf, changes); 1048 if (rdev->ops->nan_change_conf) 1049 ret = rdev->ops->nan_change_conf(&rdev->wiphy, wdev, conf, 1050 changes); 1051 else 1052 ret = -EOPNOTSUPP; 1053 trace_rdev_return_int(&rdev->wiphy, ret); 1054 return ret; 1055 } 1056 1057 static inline int rdev_set_mac_acl(struct cfg80211_registered_device *rdev, 1058 struct net_device *dev, 1059 struct cfg80211_acl_data *params) 1060 { 1061 int ret; 1062 1063 trace_rdev_set_mac_acl(&rdev->wiphy, dev, params); 1064 ret = rdev->ops->set_mac_acl(&rdev->wiphy, dev, params); 1065 trace_rdev_return_int(&rdev->wiphy, ret); 1066 return ret; 1067 } 1068 1069 static inline int rdev_update_ft_ies(struct cfg80211_registered_device *rdev, 1070 struct net_device *dev, 1071 struct cfg80211_update_ft_ies_params *ftie) 1072 { 1073 int ret; 1074 1075 trace_rdev_update_ft_ies(&rdev->wiphy, dev, ftie); 1076 ret = rdev->ops->update_ft_ies(&rdev->wiphy, dev, ftie); 1077 trace_rdev_return_int(&rdev->wiphy, ret); 1078 return ret; 1079 } 1080 1081 static inline int rdev_crit_proto_start(struct cfg80211_registered_device *rdev, 1082 struct wireless_dev *wdev, 1083 enum nl80211_crit_proto_id protocol, 1084 u16 duration) 1085 { 1086 int ret; 1087 1088 trace_rdev_crit_proto_start(&rdev->wiphy, wdev, protocol, duration); 1089 ret = rdev->ops->crit_proto_start(&rdev->wiphy, wdev, 1090 protocol, duration); 1091 trace_rdev_return_int(&rdev->wiphy, ret); 1092 return ret; 1093 } 1094 1095 static inline void rdev_crit_proto_stop(struct cfg80211_registered_device *rdev, 1096 struct wireless_dev *wdev) 1097 { 1098 trace_rdev_crit_proto_stop(&rdev->wiphy, wdev); 1099 rdev->ops->crit_proto_stop(&rdev->wiphy, wdev); 1100 trace_rdev_return_void(&rdev->wiphy); 1101 } 1102 1103 static inline int rdev_channel_switch(struct cfg80211_registered_device *rdev, 1104 struct net_device *dev, 1105 struct cfg80211_csa_settings *params) 1106 { 1107 int ret; 1108 1109 trace_rdev_channel_switch(&rdev->wiphy, dev, params); 1110 ret = rdev->ops->channel_switch(&rdev->wiphy, dev, params); 1111 trace_rdev_return_int(&rdev->wiphy, ret); 1112 return ret; 1113 } 1114 1115 static inline int rdev_set_qos_map(struct cfg80211_registered_device *rdev, 1116 struct net_device *dev, 1117 struct cfg80211_qos_map *qos_map) 1118 { 1119 int ret = -EOPNOTSUPP; 1120 1121 if (rdev->ops->set_qos_map) { 1122 trace_rdev_set_qos_map(&rdev->wiphy, dev, qos_map); 1123 ret = rdev->ops->set_qos_map(&rdev->wiphy, dev, qos_map); 1124 trace_rdev_return_int(&rdev->wiphy, ret); 1125 } 1126 1127 return ret; 1128 } 1129 1130 static inline int 1131 rdev_set_ap_chanwidth(struct cfg80211_registered_device *rdev, 1132 struct net_device *dev, 1133 unsigned int link_id, 1134 struct cfg80211_chan_def *chandef) 1135 { 1136 int ret; 1137 1138 trace_rdev_set_ap_chanwidth(&rdev->wiphy, dev, link_id, chandef); 1139 ret = rdev->ops->set_ap_chanwidth(&rdev->wiphy, dev, link_id, chandef); 1140 trace_rdev_return_int(&rdev->wiphy, ret); 1141 1142 return ret; 1143 } 1144 1145 static inline int 1146 rdev_add_tx_ts(struct cfg80211_registered_device *rdev, 1147 struct net_device *dev, u8 tsid, const u8 *peer, 1148 u8 user_prio, u16 admitted_time) 1149 { 1150 int ret = -EOPNOTSUPP; 1151 1152 trace_rdev_add_tx_ts(&rdev->wiphy, dev, tsid, peer, 1153 user_prio, admitted_time); 1154 if (rdev->ops->add_tx_ts) 1155 ret = rdev->ops->add_tx_ts(&rdev->wiphy, dev, tsid, peer, 1156 user_prio, admitted_time); 1157 trace_rdev_return_int(&rdev->wiphy, ret); 1158 1159 return ret; 1160 } 1161 1162 static inline int 1163 rdev_del_tx_ts(struct cfg80211_registered_device *rdev, 1164 struct net_device *dev, u8 tsid, const u8 *peer) 1165 { 1166 int ret = -EOPNOTSUPP; 1167 1168 trace_rdev_del_tx_ts(&rdev->wiphy, dev, tsid, peer); 1169 if (rdev->ops->del_tx_ts) 1170 ret = rdev->ops->del_tx_ts(&rdev->wiphy, dev, tsid, peer); 1171 trace_rdev_return_int(&rdev->wiphy, ret); 1172 1173 return ret; 1174 } 1175 1176 static inline int 1177 rdev_tdls_channel_switch(struct cfg80211_registered_device *rdev, 1178 struct net_device *dev, const u8 *addr, 1179 u8 oper_class, struct cfg80211_chan_def *chandef) 1180 { 1181 int ret; 1182 1183 trace_rdev_tdls_channel_switch(&rdev->wiphy, dev, addr, oper_class, 1184 chandef); 1185 ret = rdev->ops->tdls_channel_switch(&rdev->wiphy, dev, addr, 1186 oper_class, chandef); 1187 trace_rdev_return_int(&rdev->wiphy, ret); 1188 return ret; 1189 } 1190 1191 static inline void 1192 rdev_tdls_cancel_channel_switch(struct cfg80211_registered_device *rdev, 1193 struct net_device *dev, const u8 *addr) 1194 { 1195 trace_rdev_tdls_cancel_channel_switch(&rdev->wiphy, dev, addr); 1196 rdev->ops->tdls_cancel_channel_switch(&rdev->wiphy, dev, addr); 1197 trace_rdev_return_void(&rdev->wiphy); 1198 } 1199 1200 static inline int 1201 rdev_start_radar_detection(struct cfg80211_registered_device *rdev, 1202 struct net_device *dev, 1203 struct cfg80211_chan_def *chandef, 1204 u32 cac_time_ms, int link_id) 1205 { 1206 int ret = -EOPNOTSUPP; 1207 1208 trace_rdev_start_radar_detection(&rdev->wiphy, dev, chandef, 1209 cac_time_ms, link_id); 1210 if (rdev->ops->start_radar_detection) 1211 ret = rdev->ops->start_radar_detection(&rdev->wiphy, dev, 1212 chandef, cac_time_ms, 1213 link_id); 1214 trace_rdev_return_int(&rdev->wiphy, ret); 1215 return ret; 1216 } 1217 1218 static inline void 1219 rdev_end_cac(struct cfg80211_registered_device *rdev, 1220 struct net_device *dev, unsigned int link_id) 1221 { 1222 trace_rdev_end_cac(&rdev->wiphy, dev, link_id); 1223 if (rdev->ops->end_cac) 1224 rdev->ops->end_cac(&rdev->wiphy, dev, link_id); 1225 trace_rdev_return_void(&rdev->wiphy); 1226 } 1227 1228 static inline int 1229 rdev_set_mcast_rate(struct cfg80211_registered_device *rdev, 1230 struct net_device *dev, 1231 int mcast_rate[NUM_NL80211_BANDS]) 1232 { 1233 int ret = -EOPNOTSUPP; 1234 1235 trace_rdev_set_mcast_rate(&rdev->wiphy, dev, mcast_rate); 1236 if (rdev->ops->set_mcast_rate) 1237 ret = rdev->ops->set_mcast_rate(&rdev->wiphy, dev, mcast_rate); 1238 trace_rdev_return_int(&rdev->wiphy, ret); 1239 return ret; 1240 } 1241 1242 static inline int 1243 rdev_set_coalesce(struct cfg80211_registered_device *rdev, 1244 struct cfg80211_coalesce *coalesce) 1245 { 1246 int ret = -EOPNOTSUPP; 1247 1248 trace_rdev_set_coalesce(&rdev->wiphy, coalesce); 1249 if (rdev->ops->set_coalesce) 1250 ret = rdev->ops->set_coalesce(&rdev->wiphy, coalesce); 1251 trace_rdev_return_int(&rdev->wiphy, ret); 1252 return ret; 1253 } 1254 1255 static inline int rdev_set_pmk(struct cfg80211_registered_device *rdev, 1256 struct net_device *dev, 1257 struct cfg80211_pmk_conf *pmk_conf) 1258 { 1259 int ret = -EOPNOTSUPP; 1260 1261 trace_rdev_set_pmk(&rdev->wiphy, dev, pmk_conf); 1262 if (rdev->ops->set_pmk) 1263 ret = rdev->ops->set_pmk(&rdev->wiphy, dev, pmk_conf); 1264 trace_rdev_return_int(&rdev->wiphy, ret); 1265 return ret; 1266 } 1267 1268 static inline int rdev_del_pmk(struct cfg80211_registered_device *rdev, 1269 struct net_device *dev, const u8 *aa) 1270 { 1271 int ret = -EOPNOTSUPP; 1272 1273 trace_rdev_del_pmk(&rdev->wiphy, dev, aa); 1274 if (rdev->ops->del_pmk) 1275 ret = rdev->ops->del_pmk(&rdev->wiphy, dev, aa); 1276 trace_rdev_return_int(&rdev->wiphy, ret); 1277 return ret; 1278 } 1279 1280 static inline int 1281 rdev_external_auth(struct cfg80211_registered_device *rdev, 1282 struct net_device *dev, 1283 struct cfg80211_external_auth_params *params) 1284 { 1285 int ret = -EOPNOTSUPP; 1286 1287 trace_rdev_external_auth(&rdev->wiphy, dev, params); 1288 if (rdev->ops->external_auth) 1289 ret = rdev->ops->external_auth(&rdev->wiphy, dev, params); 1290 trace_rdev_return_int(&rdev->wiphy, ret); 1291 return ret; 1292 } 1293 1294 static inline int 1295 rdev_get_ftm_responder_stats(struct cfg80211_registered_device *rdev, 1296 struct net_device *dev, 1297 struct cfg80211_ftm_responder_stats *ftm_stats) 1298 { 1299 int ret = -EOPNOTSUPP; 1300 1301 trace_rdev_get_ftm_responder_stats(&rdev->wiphy, dev, ftm_stats); 1302 if (rdev->ops->get_ftm_responder_stats) 1303 ret = rdev->ops->get_ftm_responder_stats(&rdev->wiphy, dev, 1304 ftm_stats); 1305 trace_rdev_return_int(&rdev->wiphy, ret); 1306 return ret; 1307 } 1308 1309 static inline int 1310 rdev_start_pmsr(struct cfg80211_registered_device *rdev, 1311 struct wireless_dev *wdev, 1312 struct cfg80211_pmsr_request *request) 1313 { 1314 int ret = -EOPNOTSUPP; 1315 1316 trace_rdev_start_pmsr(&rdev->wiphy, wdev, request->cookie); 1317 if (rdev->ops->start_pmsr) 1318 ret = rdev->ops->start_pmsr(&rdev->wiphy, wdev, request); 1319 trace_rdev_return_int(&rdev->wiphy, ret); 1320 return ret; 1321 } 1322 1323 static inline void 1324 rdev_abort_pmsr(struct cfg80211_registered_device *rdev, 1325 struct wireless_dev *wdev, 1326 struct cfg80211_pmsr_request *request) 1327 { 1328 trace_rdev_abort_pmsr(&rdev->wiphy, wdev, request->cookie); 1329 if (rdev->ops->abort_pmsr) 1330 rdev->ops->abort_pmsr(&rdev->wiphy, wdev, request); 1331 trace_rdev_return_void(&rdev->wiphy); 1332 } 1333 1334 static inline int rdev_update_owe_info(struct cfg80211_registered_device *rdev, 1335 struct net_device *dev, 1336 struct cfg80211_update_owe_info *oweinfo) 1337 { 1338 int ret = -EOPNOTSUPP; 1339 1340 trace_rdev_update_owe_info(&rdev->wiphy, dev, oweinfo); 1341 if (rdev->ops->update_owe_info) 1342 ret = rdev->ops->update_owe_info(&rdev->wiphy, dev, oweinfo); 1343 trace_rdev_return_int(&rdev->wiphy, ret); 1344 return ret; 1345 } 1346 1347 static inline int 1348 rdev_probe_mesh_link(struct cfg80211_registered_device *rdev, 1349 struct net_device *dev, const u8 *dest, 1350 const void *buf, size_t len) 1351 { 1352 int ret; 1353 1354 trace_rdev_probe_mesh_link(&rdev->wiphy, dev, dest, buf, len); 1355 ret = rdev->ops->probe_mesh_link(&rdev->wiphy, dev, buf, len); 1356 trace_rdev_return_int(&rdev->wiphy, ret); 1357 return ret; 1358 } 1359 1360 static inline int rdev_set_tid_config(struct cfg80211_registered_device *rdev, 1361 struct net_device *dev, 1362 struct cfg80211_tid_config *tid_conf) 1363 { 1364 int ret; 1365 1366 trace_rdev_set_tid_config(&rdev->wiphy, dev, tid_conf); 1367 ret = rdev->ops->set_tid_config(&rdev->wiphy, dev, tid_conf); 1368 trace_rdev_return_int(&rdev->wiphy, ret); 1369 return ret; 1370 } 1371 1372 static inline int rdev_reset_tid_config(struct cfg80211_registered_device *rdev, 1373 struct net_device *dev, const u8 *peer, 1374 u8 tids) 1375 { 1376 int ret; 1377 1378 trace_rdev_reset_tid_config(&rdev->wiphy, dev, peer, tids); 1379 ret = rdev->ops->reset_tid_config(&rdev->wiphy, dev, peer, tids); 1380 trace_rdev_return_int(&rdev->wiphy, ret); 1381 return ret; 1382 } 1383 1384 static inline int rdev_set_sar_specs(struct cfg80211_registered_device *rdev, 1385 struct cfg80211_sar_specs *sar) 1386 { 1387 int ret; 1388 1389 trace_rdev_set_sar_specs(&rdev->wiphy, sar); 1390 ret = rdev->ops->set_sar_specs(&rdev->wiphy, sar); 1391 trace_rdev_return_int(&rdev->wiphy, ret); 1392 1393 return ret; 1394 } 1395 1396 static inline int rdev_color_change(struct cfg80211_registered_device *rdev, 1397 struct net_device *dev, 1398 struct cfg80211_color_change_settings *params) 1399 { 1400 int ret; 1401 1402 trace_rdev_color_change(&rdev->wiphy, dev, params); 1403 ret = rdev->ops->color_change(&rdev->wiphy, dev, params); 1404 trace_rdev_return_int(&rdev->wiphy, ret); 1405 1406 return ret; 1407 } 1408 1409 static inline int 1410 rdev_set_fils_aad(struct cfg80211_registered_device *rdev, 1411 struct net_device *dev, struct cfg80211_fils_aad *fils_aad) 1412 { 1413 int ret = -EOPNOTSUPP; 1414 1415 trace_rdev_set_fils_aad(&rdev->wiphy, dev, fils_aad); 1416 if (rdev->ops->set_fils_aad) 1417 ret = rdev->ops->set_fils_aad(&rdev->wiphy, dev, fils_aad); 1418 trace_rdev_return_int(&rdev->wiphy, ret); 1419 1420 return ret; 1421 } 1422 1423 static inline int 1424 rdev_set_radar_background(struct cfg80211_registered_device *rdev, 1425 struct cfg80211_chan_def *chandef) 1426 { 1427 struct wiphy *wiphy = &rdev->wiphy; 1428 int ret = -EOPNOTSUPP; 1429 1430 trace_rdev_set_radar_background(wiphy, chandef); 1431 if (rdev->ops->set_radar_background) 1432 ret = rdev->ops->set_radar_background(wiphy, chandef); 1433 trace_rdev_return_int(wiphy, ret); 1434 1435 return ret; 1436 } 1437 1438 static inline int 1439 rdev_add_intf_link(struct cfg80211_registered_device *rdev, 1440 struct wireless_dev *wdev, 1441 unsigned int link_id) 1442 { 1443 int ret = 0; 1444 1445 trace_rdev_add_intf_link(&rdev->wiphy, wdev, link_id); 1446 if (rdev->ops->add_intf_link) 1447 ret = rdev->ops->add_intf_link(&rdev->wiphy, wdev, link_id); 1448 trace_rdev_return_int(&rdev->wiphy, ret); 1449 1450 return ret; 1451 } 1452 1453 static inline void 1454 rdev_del_intf_link(struct cfg80211_registered_device *rdev, 1455 struct wireless_dev *wdev, 1456 unsigned int link_id) 1457 { 1458 trace_rdev_del_intf_link(&rdev->wiphy, wdev, link_id); 1459 if (rdev->ops->del_intf_link) 1460 rdev->ops->del_intf_link(&rdev->wiphy, wdev, link_id); 1461 trace_rdev_return_void(&rdev->wiphy); 1462 } 1463 1464 static inline int 1465 rdev_add_link_station(struct cfg80211_registered_device *rdev, 1466 struct net_device *dev, 1467 struct link_station_parameters *params) 1468 { 1469 int ret = -EOPNOTSUPP; 1470 1471 trace_rdev_add_link_station(&rdev->wiphy, dev, params); 1472 if (rdev->ops->add_link_station) 1473 ret = rdev->ops->add_link_station(&rdev->wiphy, dev, params); 1474 trace_rdev_return_int(&rdev->wiphy, ret); 1475 return ret; 1476 } 1477 1478 static inline int 1479 rdev_mod_link_station(struct cfg80211_registered_device *rdev, 1480 struct net_device *dev, 1481 struct link_station_parameters *params) 1482 { 1483 int ret = -EOPNOTSUPP; 1484 1485 trace_rdev_mod_link_station(&rdev->wiphy, dev, params); 1486 if (rdev->ops->mod_link_station) 1487 ret = rdev->ops->mod_link_station(&rdev->wiphy, dev, params); 1488 trace_rdev_return_int(&rdev->wiphy, ret); 1489 return ret; 1490 } 1491 1492 static inline int 1493 rdev_del_link_station(struct cfg80211_registered_device *rdev, 1494 struct net_device *dev, 1495 struct link_station_del_parameters *params) 1496 { 1497 int ret = -EOPNOTSUPP; 1498 1499 trace_rdev_del_link_station(&rdev->wiphy, dev, params); 1500 if (rdev->ops->del_link_station) 1501 ret = rdev->ops->del_link_station(&rdev->wiphy, dev, params); 1502 trace_rdev_return_int(&rdev->wiphy, ret); 1503 return ret; 1504 } 1505 1506 static inline int 1507 rdev_set_hw_timestamp(struct cfg80211_registered_device *rdev, 1508 struct net_device *dev, 1509 struct cfg80211_set_hw_timestamp *hwts) 1510 { 1511 struct wiphy *wiphy = &rdev->wiphy; 1512 int ret = -EOPNOTSUPP; 1513 1514 trace_rdev_set_hw_timestamp(wiphy, dev, hwts); 1515 if (rdev->ops->set_hw_timestamp) 1516 ret = rdev->ops->set_hw_timestamp(wiphy, dev, hwts); 1517 trace_rdev_return_int(wiphy, ret); 1518 1519 return ret; 1520 } 1521 1522 static inline int 1523 rdev_set_ttlm(struct cfg80211_registered_device *rdev, 1524 struct net_device *dev, 1525 struct cfg80211_ttlm_params *params) 1526 { 1527 struct wiphy *wiphy = &rdev->wiphy; 1528 int ret = -EOPNOTSUPP; 1529 1530 trace_rdev_set_ttlm(wiphy, dev, params); 1531 if (rdev->ops->set_ttlm) 1532 ret = rdev->ops->set_ttlm(wiphy, dev, params); 1533 trace_rdev_return_int(wiphy, ret); 1534 1535 return ret; 1536 } 1537 1538 static inline u32 1539 rdev_get_radio_mask(struct cfg80211_registered_device *rdev, 1540 struct net_device *dev) 1541 { 1542 struct wiphy *wiphy = &rdev->wiphy; 1543 1544 if (!rdev->ops->get_radio_mask) 1545 return 0; 1546 1547 return rdev->ops->get_radio_mask(wiphy, dev); 1548 } 1549 #endif /* __CFG80211_RDEV_OPS */ 1550