1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */ 2*4882a593Smuzhiyun #undef TRACE_SYSTEM 3*4882a593Smuzhiyun #define TRACE_SYSTEM cfg80211 4*4882a593Smuzhiyun 5*4882a593Smuzhiyun #if !defined(__RDEV_OPS_TRACE) || defined(TRACE_HEADER_MULTI_READ) 6*4882a593Smuzhiyun #define __RDEV_OPS_TRACE 7*4882a593Smuzhiyun 8*4882a593Smuzhiyun #include <linux/tracepoint.h> 9*4882a593Smuzhiyun 10*4882a593Smuzhiyun #include <linux/rtnetlink.h> 11*4882a593Smuzhiyun #include <linux/etherdevice.h> 12*4882a593Smuzhiyun #include <net/cfg80211.h> 13*4882a593Smuzhiyun #include "core.h" 14*4882a593Smuzhiyun 15*4882a593Smuzhiyun #define MAC_ENTRY(entry_mac) __array(u8, entry_mac, ETH_ALEN) 16*4882a593Smuzhiyun #define MAC_ASSIGN(entry_mac, given_mac) do { \ 17*4882a593Smuzhiyun if (given_mac) \ 18*4882a593Smuzhiyun memcpy(__entry->entry_mac, given_mac, ETH_ALEN); \ 19*4882a593Smuzhiyun else \ 20*4882a593Smuzhiyun eth_zero_addr(__entry->entry_mac); \ 21*4882a593Smuzhiyun } while (0) 22*4882a593Smuzhiyun #define MAC_PR_FMT "%pM" 23*4882a593Smuzhiyun #define MAC_PR_ARG(entry_mac) (__entry->entry_mac) 24*4882a593Smuzhiyun 25*4882a593Smuzhiyun #define MAXNAME 32 26*4882a593Smuzhiyun #define WIPHY_ENTRY __array(char, wiphy_name, 32) 27*4882a593Smuzhiyun #define WIPHY_ASSIGN strlcpy(__entry->wiphy_name, wiphy_name(wiphy), MAXNAME) 28*4882a593Smuzhiyun #define WIPHY_PR_FMT "%s" 29*4882a593Smuzhiyun #define WIPHY_PR_ARG __entry->wiphy_name 30*4882a593Smuzhiyun 31*4882a593Smuzhiyun #define WDEV_ENTRY __field(u32, id) 32*4882a593Smuzhiyun #define WDEV_ASSIGN (__entry->id) = (!IS_ERR_OR_NULL(wdev) \ 33*4882a593Smuzhiyun ? wdev->identifier : 0) 34*4882a593Smuzhiyun #define WDEV_PR_FMT "wdev(%u)" 35*4882a593Smuzhiyun #define WDEV_PR_ARG (__entry->id) 36*4882a593Smuzhiyun 37*4882a593Smuzhiyun #define NETDEV_ENTRY __array(char, name, IFNAMSIZ) \ 38*4882a593Smuzhiyun __field(int, ifindex) 39*4882a593Smuzhiyun #define NETDEV_ASSIGN \ 40*4882a593Smuzhiyun do { \ 41*4882a593Smuzhiyun memcpy(__entry->name, netdev->name, IFNAMSIZ); \ 42*4882a593Smuzhiyun (__entry->ifindex) = (netdev->ifindex); \ 43*4882a593Smuzhiyun } while (0) 44*4882a593Smuzhiyun #define NETDEV_PR_FMT "netdev:%s(%d)" 45*4882a593Smuzhiyun #define NETDEV_PR_ARG __entry->name, __entry->ifindex 46*4882a593Smuzhiyun 47*4882a593Smuzhiyun #define MESH_CFG_ENTRY __field(u16, dot11MeshRetryTimeout) \ 48*4882a593Smuzhiyun __field(u16, dot11MeshConfirmTimeout) \ 49*4882a593Smuzhiyun __field(u16, dot11MeshHoldingTimeout) \ 50*4882a593Smuzhiyun __field(u16, dot11MeshMaxPeerLinks) \ 51*4882a593Smuzhiyun __field(u8, dot11MeshMaxRetries) \ 52*4882a593Smuzhiyun __field(u8, dot11MeshTTL) \ 53*4882a593Smuzhiyun __field(u8, element_ttl) \ 54*4882a593Smuzhiyun __field(bool, auto_open_plinks) \ 55*4882a593Smuzhiyun __field(u32, dot11MeshNbrOffsetMaxNeighbor) \ 56*4882a593Smuzhiyun __field(u8, dot11MeshHWMPmaxPREQretries) \ 57*4882a593Smuzhiyun __field(u32, path_refresh_time) \ 58*4882a593Smuzhiyun __field(u32, dot11MeshHWMPactivePathTimeout) \ 59*4882a593Smuzhiyun __field(u16, min_discovery_timeout) \ 60*4882a593Smuzhiyun __field(u16, dot11MeshHWMPpreqMinInterval) \ 61*4882a593Smuzhiyun __field(u16, dot11MeshHWMPperrMinInterval) \ 62*4882a593Smuzhiyun __field(u16, dot11MeshHWMPnetDiameterTraversalTime) \ 63*4882a593Smuzhiyun __field(u8, dot11MeshHWMPRootMode) \ 64*4882a593Smuzhiyun __field(u16, dot11MeshHWMPRannInterval) \ 65*4882a593Smuzhiyun __field(bool, dot11MeshGateAnnouncementProtocol) \ 66*4882a593Smuzhiyun __field(bool, dot11MeshForwarding) \ 67*4882a593Smuzhiyun __field(s32, rssi_threshold) \ 68*4882a593Smuzhiyun __field(u16, ht_opmode) \ 69*4882a593Smuzhiyun __field(u32, dot11MeshHWMPactivePathToRootTimeout) \ 70*4882a593Smuzhiyun __field(u16, dot11MeshHWMProotInterval) \ 71*4882a593Smuzhiyun __field(u16, dot11MeshHWMPconfirmationInterval) \ 72*4882a593Smuzhiyun __field(bool, dot11MeshNolearn) 73*4882a593Smuzhiyun #define MESH_CFG_ASSIGN \ 74*4882a593Smuzhiyun do { \ 75*4882a593Smuzhiyun __entry->dot11MeshRetryTimeout = conf->dot11MeshRetryTimeout; \ 76*4882a593Smuzhiyun __entry->dot11MeshConfirmTimeout = \ 77*4882a593Smuzhiyun conf->dot11MeshConfirmTimeout; \ 78*4882a593Smuzhiyun __entry->dot11MeshHoldingTimeout = \ 79*4882a593Smuzhiyun conf->dot11MeshHoldingTimeout; \ 80*4882a593Smuzhiyun __entry->dot11MeshMaxPeerLinks = conf->dot11MeshMaxPeerLinks; \ 81*4882a593Smuzhiyun __entry->dot11MeshMaxRetries = conf->dot11MeshMaxRetries; \ 82*4882a593Smuzhiyun __entry->dot11MeshTTL = conf->dot11MeshTTL; \ 83*4882a593Smuzhiyun __entry->element_ttl = conf->element_ttl; \ 84*4882a593Smuzhiyun __entry->auto_open_plinks = conf->auto_open_plinks; \ 85*4882a593Smuzhiyun __entry->dot11MeshNbrOffsetMaxNeighbor = \ 86*4882a593Smuzhiyun conf->dot11MeshNbrOffsetMaxNeighbor; \ 87*4882a593Smuzhiyun __entry->dot11MeshHWMPmaxPREQretries = \ 88*4882a593Smuzhiyun conf->dot11MeshHWMPmaxPREQretries; \ 89*4882a593Smuzhiyun __entry->path_refresh_time = conf->path_refresh_time; \ 90*4882a593Smuzhiyun __entry->dot11MeshHWMPactivePathTimeout = \ 91*4882a593Smuzhiyun conf->dot11MeshHWMPactivePathTimeout; \ 92*4882a593Smuzhiyun __entry->min_discovery_timeout = conf->min_discovery_timeout; \ 93*4882a593Smuzhiyun __entry->dot11MeshHWMPpreqMinInterval = \ 94*4882a593Smuzhiyun conf->dot11MeshHWMPpreqMinInterval; \ 95*4882a593Smuzhiyun __entry->dot11MeshHWMPperrMinInterval = \ 96*4882a593Smuzhiyun conf->dot11MeshHWMPperrMinInterval; \ 97*4882a593Smuzhiyun __entry->dot11MeshHWMPnetDiameterTraversalTime = \ 98*4882a593Smuzhiyun conf->dot11MeshHWMPnetDiameterTraversalTime; \ 99*4882a593Smuzhiyun __entry->dot11MeshHWMPRootMode = conf->dot11MeshHWMPRootMode; \ 100*4882a593Smuzhiyun __entry->dot11MeshHWMPRannInterval = \ 101*4882a593Smuzhiyun conf->dot11MeshHWMPRannInterval; \ 102*4882a593Smuzhiyun __entry->dot11MeshGateAnnouncementProtocol = \ 103*4882a593Smuzhiyun conf->dot11MeshGateAnnouncementProtocol; \ 104*4882a593Smuzhiyun __entry->dot11MeshForwarding = conf->dot11MeshForwarding; \ 105*4882a593Smuzhiyun __entry->rssi_threshold = conf->rssi_threshold; \ 106*4882a593Smuzhiyun __entry->ht_opmode = conf->ht_opmode; \ 107*4882a593Smuzhiyun __entry->dot11MeshHWMPactivePathToRootTimeout = \ 108*4882a593Smuzhiyun conf->dot11MeshHWMPactivePathToRootTimeout; \ 109*4882a593Smuzhiyun __entry->dot11MeshHWMProotInterval = \ 110*4882a593Smuzhiyun conf->dot11MeshHWMProotInterval; \ 111*4882a593Smuzhiyun __entry->dot11MeshHWMPconfirmationInterval = \ 112*4882a593Smuzhiyun conf->dot11MeshHWMPconfirmationInterval; \ 113*4882a593Smuzhiyun __entry->dot11MeshNolearn = conf->dot11MeshNolearn; \ 114*4882a593Smuzhiyun } while (0) 115*4882a593Smuzhiyun 116*4882a593Smuzhiyun #define CHAN_ENTRY __field(enum nl80211_band, band) \ 117*4882a593Smuzhiyun __field(u32, center_freq) \ 118*4882a593Smuzhiyun __field(u16, freq_offset) 119*4882a593Smuzhiyun #define CHAN_ASSIGN(chan) \ 120*4882a593Smuzhiyun do { \ 121*4882a593Smuzhiyun if (chan) { \ 122*4882a593Smuzhiyun __entry->band = chan->band; \ 123*4882a593Smuzhiyun __entry->center_freq = chan->center_freq; \ 124*4882a593Smuzhiyun __entry->freq_offset = chan->freq_offset; \ 125*4882a593Smuzhiyun } else { \ 126*4882a593Smuzhiyun __entry->band = 0; \ 127*4882a593Smuzhiyun __entry->center_freq = 0; \ 128*4882a593Smuzhiyun __entry->freq_offset = 0; \ 129*4882a593Smuzhiyun } \ 130*4882a593Smuzhiyun } while (0) 131*4882a593Smuzhiyun #define CHAN_PR_FMT "band: %d, freq: %u.%03u" 132*4882a593Smuzhiyun #define CHAN_PR_ARG __entry->band, __entry->center_freq, __entry->freq_offset 133*4882a593Smuzhiyun 134*4882a593Smuzhiyun #define CHAN_DEF_ENTRY __field(enum nl80211_band, band) \ 135*4882a593Smuzhiyun __field(u32, control_freq) \ 136*4882a593Smuzhiyun __field(u32, freq_offset) \ 137*4882a593Smuzhiyun __field(u32, width) \ 138*4882a593Smuzhiyun __field(u32, center_freq1) \ 139*4882a593Smuzhiyun __field(u32, freq1_offset) \ 140*4882a593Smuzhiyun __field(u32, center_freq2) 141*4882a593Smuzhiyun #define CHAN_DEF_ASSIGN(chandef) \ 142*4882a593Smuzhiyun do { \ 143*4882a593Smuzhiyun if ((chandef) && (chandef)->chan) { \ 144*4882a593Smuzhiyun __entry->band = (chandef)->chan->band; \ 145*4882a593Smuzhiyun __entry->control_freq = \ 146*4882a593Smuzhiyun (chandef)->chan->center_freq; \ 147*4882a593Smuzhiyun __entry->freq_offset = \ 148*4882a593Smuzhiyun (chandef)->chan->freq_offset; \ 149*4882a593Smuzhiyun __entry->width = (chandef)->width; \ 150*4882a593Smuzhiyun __entry->center_freq1 = (chandef)->center_freq1;\ 151*4882a593Smuzhiyun __entry->freq1_offset = (chandef)->freq1_offset;\ 152*4882a593Smuzhiyun __entry->center_freq2 = (chandef)->center_freq2;\ 153*4882a593Smuzhiyun } else { \ 154*4882a593Smuzhiyun __entry->band = 0; \ 155*4882a593Smuzhiyun __entry->control_freq = 0; \ 156*4882a593Smuzhiyun __entry->freq_offset = 0; \ 157*4882a593Smuzhiyun __entry->width = 0; \ 158*4882a593Smuzhiyun __entry->center_freq1 = 0; \ 159*4882a593Smuzhiyun __entry->freq1_offset = 0; \ 160*4882a593Smuzhiyun __entry->center_freq2 = 0; \ 161*4882a593Smuzhiyun } \ 162*4882a593Smuzhiyun } while (0) 163*4882a593Smuzhiyun #define CHAN_DEF_PR_FMT \ 164*4882a593Smuzhiyun "band: %d, control freq: %u.%03u, width: %d, cf1: %u.%03u, cf2: %u" 165*4882a593Smuzhiyun #define CHAN_DEF_PR_ARG __entry->band, __entry->control_freq, \ 166*4882a593Smuzhiyun __entry->freq_offset, __entry->width, \ 167*4882a593Smuzhiyun __entry->center_freq1, __entry->freq1_offset, \ 168*4882a593Smuzhiyun __entry->center_freq2 169*4882a593Smuzhiyun 170*4882a593Smuzhiyun #define SINFO_ENTRY __field(int, generation) \ 171*4882a593Smuzhiyun __field(u32, connected_time) \ 172*4882a593Smuzhiyun __field(u32, inactive_time) \ 173*4882a593Smuzhiyun __field(u32, rx_bytes) \ 174*4882a593Smuzhiyun __field(u32, tx_bytes) \ 175*4882a593Smuzhiyun __field(u32, rx_packets) \ 176*4882a593Smuzhiyun __field(u32, tx_packets) \ 177*4882a593Smuzhiyun __field(u32, tx_retries) \ 178*4882a593Smuzhiyun __field(u32, tx_failed) \ 179*4882a593Smuzhiyun __field(u32, rx_dropped_misc) \ 180*4882a593Smuzhiyun __field(u32, beacon_loss_count) \ 181*4882a593Smuzhiyun __field(u16, llid) \ 182*4882a593Smuzhiyun __field(u16, plid) \ 183*4882a593Smuzhiyun __field(u8, plink_state) 184*4882a593Smuzhiyun #define SINFO_ASSIGN \ 185*4882a593Smuzhiyun do { \ 186*4882a593Smuzhiyun __entry->generation = sinfo->generation; \ 187*4882a593Smuzhiyun __entry->connected_time = sinfo->connected_time; \ 188*4882a593Smuzhiyun __entry->inactive_time = sinfo->inactive_time; \ 189*4882a593Smuzhiyun __entry->rx_bytes = sinfo->rx_bytes; \ 190*4882a593Smuzhiyun __entry->tx_bytes = sinfo->tx_bytes; \ 191*4882a593Smuzhiyun __entry->rx_packets = sinfo->rx_packets; \ 192*4882a593Smuzhiyun __entry->tx_packets = sinfo->tx_packets; \ 193*4882a593Smuzhiyun __entry->tx_retries = sinfo->tx_retries; \ 194*4882a593Smuzhiyun __entry->tx_failed = sinfo->tx_failed; \ 195*4882a593Smuzhiyun __entry->rx_dropped_misc = sinfo->rx_dropped_misc; \ 196*4882a593Smuzhiyun __entry->beacon_loss_count = sinfo->beacon_loss_count; \ 197*4882a593Smuzhiyun __entry->llid = sinfo->llid; \ 198*4882a593Smuzhiyun __entry->plid = sinfo->plid; \ 199*4882a593Smuzhiyun __entry->plink_state = sinfo->plink_state; \ 200*4882a593Smuzhiyun } while (0) 201*4882a593Smuzhiyun 202*4882a593Smuzhiyun #define BOOL_TO_STR(bo) (bo) ? "true" : "false" 203*4882a593Smuzhiyun 204*4882a593Smuzhiyun #define QOS_MAP_ENTRY __field(u8, num_des) \ 205*4882a593Smuzhiyun __array(u8, dscp_exception, \ 206*4882a593Smuzhiyun 2 * IEEE80211_QOS_MAP_MAX_EX) \ 207*4882a593Smuzhiyun __array(u8, up, IEEE80211_QOS_MAP_LEN_MIN) 208*4882a593Smuzhiyun #define QOS_MAP_ASSIGN(qos_map) \ 209*4882a593Smuzhiyun do { \ 210*4882a593Smuzhiyun if ((qos_map)) { \ 211*4882a593Smuzhiyun __entry->num_des = (qos_map)->num_des; \ 212*4882a593Smuzhiyun memcpy(__entry->dscp_exception, \ 213*4882a593Smuzhiyun &(qos_map)->dscp_exception, \ 214*4882a593Smuzhiyun 2 * IEEE80211_QOS_MAP_MAX_EX); \ 215*4882a593Smuzhiyun memcpy(__entry->up, &(qos_map)->up, \ 216*4882a593Smuzhiyun IEEE80211_QOS_MAP_LEN_MIN); \ 217*4882a593Smuzhiyun } else { \ 218*4882a593Smuzhiyun __entry->num_des = 0; \ 219*4882a593Smuzhiyun memset(__entry->dscp_exception, 0, \ 220*4882a593Smuzhiyun 2 * IEEE80211_QOS_MAP_MAX_EX); \ 221*4882a593Smuzhiyun memset(__entry->up, 0, \ 222*4882a593Smuzhiyun IEEE80211_QOS_MAP_LEN_MIN); \ 223*4882a593Smuzhiyun } \ 224*4882a593Smuzhiyun } while (0) 225*4882a593Smuzhiyun 226*4882a593Smuzhiyun /************************************************************* 227*4882a593Smuzhiyun * rdev->ops traces * 228*4882a593Smuzhiyun *************************************************************/ 229*4882a593Smuzhiyun 230*4882a593Smuzhiyun TRACE_EVENT(rdev_suspend, 231*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct cfg80211_wowlan *wow), 232*4882a593Smuzhiyun TP_ARGS(wiphy, wow), 233*4882a593Smuzhiyun TP_STRUCT__entry( 234*4882a593Smuzhiyun WIPHY_ENTRY 235*4882a593Smuzhiyun __field(bool, any) 236*4882a593Smuzhiyun __field(bool, disconnect) 237*4882a593Smuzhiyun __field(bool, magic_pkt) 238*4882a593Smuzhiyun __field(bool, gtk_rekey_failure) 239*4882a593Smuzhiyun __field(bool, eap_identity_req) 240*4882a593Smuzhiyun __field(bool, four_way_handshake) 241*4882a593Smuzhiyun __field(bool, rfkill_release) 242*4882a593Smuzhiyun __field(bool, valid_wow) 243*4882a593Smuzhiyun ), 244*4882a593Smuzhiyun TP_fast_assign( 245*4882a593Smuzhiyun WIPHY_ASSIGN; 246*4882a593Smuzhiyun if (wow) { 247*4882a593Smuzhiyun __entry->any = wow->any; 248*4882a593Smuzhiyun __entry->disconnect = wow->disconnect; 249*4882a593Smuzhiyun __entry->magic_pkt = wow->magic_pkt; 250*4882a593Smuzhiyun __entry->gtk_rekey_failure = wow->gtk_rekey_failure; 251*4882a593Smuzhiyun __entry->eap_identity_req = wow->eap_identity_req; 252*4882a593Smuzhiyun __entry->four_way_handshake = wow->four_way_handshake; 253*4882a593Smuzhiyun __entry->rfkill_release = wow->rfkill_release; 254*4882a593Smuzhiyun __entry->valid_wow = true; 255*4882a593Smuzhiyun } else { 256*4882a593Smuzhiyun __entry->valid_wow = false; 257*4882a593Smuzhiyun } 258*4882a593Smuzhiyun ), 259*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", wow%s - any: %d, disconnect: %d, " 260*4882a593Smuzhiyun "magic pkt: %d, gtk rekey failure: %d, eap identify req: %d, " 261*4882a593Smuzhiyun "four way handshake: %d, rfkill release: %d.", 262*4882a593Smuzhiyun WIPHY_PR_ARG, __entry->valid_wow ? "" : "(Not configured!)", 263*4882a593Smuzhiyun __entry->any, __entry->disconnect, __entry->magic_pkt, 264*4882a593Smuzhiyun __entry->gtk_rekey_failure, __entry->eap_identity_req, 265*4882a593Smuzhiyun __entry->four_way_handshake, __entry->rfkill_release) 266*4882a593Smuzhiyun ); 267*4882a593Smuzhiyun 268*4882a593Smuzhiyun TRACE_EVENT(rdev_return_int, 269*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, int ret), 270*4882a593Smuzhiyun TP_ARGS(wiphy, ret), 271*4882a593Smuzhiyun TP_STRUCT__entry( 272*4882a593Smuzhiyun WIPHY_ENTRY 273*4882a593Smuzhiyun __field(int, ret) 274*4882a593Smuzhiyun ), 275*4882a593Smuzhiyun TP_fast_assign( 276*4882a593Smuzhiyun WIPHY_ASSIGN; 277*4882a593Smuzhiyun __entry->ret = ret; 278*4882a593Smuzhiyun ), 279*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", returned: %d", WIPHY_PR_ARG, __entry->ret) 280*4882a593Smuzhiyun ); 281*4882a593Smuzhiyun 282*4882a593Smuzhiyun TRACE_EVENT(rdev_scan, 283*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct cfg80211_scan_request *request), 284*4882a593Smuzhiyun TP_ARGS(wiphy, request), 285*4882a593Smuzhiyun TP_STRUCT__entry( 286*4882a593Smuzhiyun WIPHY_ENTRY 287*4882a593Smuzhiyun ), 288*4882a593Smuzhiyun TP_fast_assign( 289*4882a593Smuzhiyun WIPHY_ASSIGN; 290*4882a593Smuzhiyun ), 291*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT, WIPHY_PR_ARG) 292*4882a593Smuzhiyun ); 293*4882a593Smuzhiyun 294*4882a593Smuzhiyun DECLARE_EVENT_CLASS(wiphy_only_evt, 295*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy), 296*4882a593Smuzhiyun TP_ARGS(wiphy), 297*4882a593Smuzhiyun TP_STRUCT__entry( 298*4882a593Smuzhiyun WIPHY_ENTRY 299*4882a593Smuzhiyun ), 300*4882a593Smuzhiyun TP_fast_assign( 301*4882a593Smuzhiyun WIPHY_ASSIGN; 302*4882a593Smuzhiyun ), 303*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT, WIPHY_PR_ARG) 304*4882a593Smuzhiyun ); 305*4882a593Smuzhiyun 306*4882a593Smuzhiyun DEFINE_EVENT(wiphy_only_evt, rdev_resume, 307*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy), 308*4882a593Smuzhiyun TP_ARGS(wiphy) 309*4882a593Smuzhiyun ); 310*4882a593Smuzhiyun 311*4882a593Smuzhiyun DEFINE_EVENT(wiphy_only_evt, rdev_return_void, 312*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy), 313*4882a593Smuzhiyun TP_ARGS(wiphy) 314*4882a593Smuzhiyun ); 315*4882a593Smuzhiyun 316*4882a593Smuzhiyun DEFINE_EVENT(wiphy_only_evt, rdev_get_antenna, 317*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy), 318*4882a593Smuzhiyun TP_ARGS(wiphy) 319*4882a593Smuzhiyun ); 320*4882a593Smuzhiyun 321*4882a593Smuzhiyun DEFINE_EVENT(wiphy_only_evt, rdev_rfkill_poll, 322*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy), 323*4882a593Smuzhiyun TP_ARGS(wiphy) 324*4882a593Smuzhiyun ); 325*4882a593Smuzhiyun 326*4882a593Smuzhiyun DECLARE_EVENT_CLASS(wiphy_enabled_evt, 327*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, bool enabled), 328*4882a593Smuzhiyun TP_ARGS(wiphy, enabled), 329*4882a593Smuzhiyun TP_STRUCT__entry( 330*4882a593Smuzhiyun WIPHY_ENTRY 331*4882a593Smuzhiyun __field(bool, enabled) 332*4882a593Smuzhiyun ), 333*4882a593Smuzhiyun TP_fast_assign( 334*4882a593Smuzhiyun WIPHY_ASSIGN; 335*4882a593Smuzhiyun __entry->enabled = enabled; 336*4882a593Smuzhiyun ), 337*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", %senabled ", 338*4882a593Smuzhiyun WIPHY_PR_ARG, __entry->enabled ? "" : "not ") 339*4882a593Smuzhiyun ); 340*4882a593Smuzhiyun 341*4882a593Smuzhiyun DEFINE_EVENT(wiphy_enabled_evt, rdev_set_wakeup, 342*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, bool enabled), 343*4882a593Smuzhiyun TP_ARGS(wiphy, enabled) 344*4882a593Smuzhiyun ); 345*4882a593Smuzhiyun 346*4882a593Smuzhiyun TRACE_EVENT(rdev_add_virtual_intf, 347*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, char *name, enum nl80211_iftype type), 348*4882a593Smuzhiyun TP_ARGS(wiphy, name, type), 349*4882a593Smuzhiyun TP_STRUCT__entry( 350*4882a593Smuzhiyun WIPHY_ENTRY 351*4882a593Smuzhiyun __string(vir_intf_name, name ? name : "<noname>") 352*4882a593Smuzhiyun __field(enum nl80211_iftype, type) 353*4882a593Smuzhiyun ), 354*4882a593Smuzhiyun TP_fast_assign( 355*4882a593Smuzhiyun WIPHY_ASSIGN; 356*4882a593Smuzhiyun __assign_str(vir_intf_name, name ? name : "<noname>"); 357*4882a593Smuzhiyun __entry->type = type; 358*4882a593Smuzhiyun ), 359*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", virtual intf name: %s, type: %d", 360*4882a593Smuzhiyun WIPHY_PR_ARG, __get_str(vir_intf_name), __entry->type) 361*4882a593Smuzhiyun ); 362*4882a593Smuzhiyun 363*4882a593Smuzhiyun DECLARE_EVENT_CLASS(wiphy_wdev_evt, 364*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev), 365*4882a593Smuzhiyun TP_ARGS(wiphy, wdev), 366*4882a593Smuzhiyun TP_STRUCT__entry( 367*4882a593Smuzhiyun WIPHY_ENTRY 368*4882a593Smuzhiyun WDEV_ENTRY 369*4882a593Smuzhiyun ), 370*4882a593Smuzhiyun TP_fast_assign( 371*4882a593Smuzhiyun WIPHY_ASSIGN; 372*4882a593Smuzhiyun WDEV_ASSIGN; 373*4882a593Smuzhiyun ), 374*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " WDEV_PR_FMT, WIPHY_PR_ARG, WDEV_PR_ARG) 375*4882a593Smuzhiyun ); 376*4882a593Smuzhiyun 377*4882a593Smuzhiyun DECLARE_EVENT_CLASS(wiphy_wdev_cookie_evt, 378*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie), 379*4882a593Smuzhiyun TP_ARGS(wiphy, wdev, cookie), 380*4882a593Smuzhiyun TP_STRUCT__entry( 381*4882a593Smuzhiyun WIPHY_ENTRY 382*4882a593Smuzhiyun WDEV_ENTRY 383*4882a593Smuzhiyun __field(u64, cookie) 384*4882a593Smuzhiyun ), 385*4882a593Smuzhiyun TP_fast_assign( 386*4882a593Smuzhiyun WIPHY_ASSIGN; 387*4882a593Smuzhiyun WDEV_ASSIGN; 388*4882a593Smuzhiyun __entry->cookie = cookie; 389*4882a593Smuzhiyun ), 390*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " WDEV_PR_FMT ", cookie: %lld", 391*4882a593Smuzhiyun WIPHY_PR_ARG, WDEV_PR_ARG, 392*4882a593Smuzhiyun (unsigned long long)__entry->cookie) 393*4882a593Smuzhiyun ); 394*4882a593Smuzhiyun 395*4882a593Smuzhiyun DEFINE_EVENT(wiphy_wdev_evt, rdev_return_wdev, 396*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev), 397*4882a593Smuzhiyun TP_ARGS(wiphy, wdev) 398*4882a593Smuzhiyun ); 399*4882a593Smuzhiyun 400*4882a593Smuzhiyun DEFINE_EVENT(wiphy_wdev_evt, rdev_del_virtual_intf, 401*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev), 402*4882a593Smuzhiyun TP_ARGS(wiphy, wdev) 403*4882a593Smuzhiyun ); 404*4882a593Smuzhiyun 405*4882a593Smuzhiyun TRACE_EVENT(rdev_change_virtual_intf, 406*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 407*4882a593Smuzhiyun enum nl80211_iftype type), 408*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, type), 409*4882a593Smuzhiyun TP_STRUCT__entry( 410*4882a593Smuzhiyun WIPHY_ENTRY 411*4882a593Smuzhiyun NETDEV_ENTRY 412*4882a593Smuzhiyun __field(enum nl80211_iftype, type) 413*4882a593Smuzhiyun ), 414*4882a593Smuzhiyun TP_fast_assign( 415*4882a593Smuzhiyun WIPHY_ASSIGN; 416*4882a593Smuzhiyun NETDEV_ASSIGN; 417*4882a593Smuzhiyun __entry->type = type; 418*4882a593Smuzhiyun ), 419*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", type: %d", 420*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->type) 421*4882a593Smuzhiyun ); 422*4882a593Smuzhiyun 423*4882a593Smuzhiyun DECLARE_EVENT_CLASS(key_handle, 424*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, u8 key_index, 425*4882a593Smuzhiyun bool pairwise, const u8 *mac_addr), 426*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, key_index, pairwise, mac_addr), 427*4882a593Smuzhiyun TP_STRUCT__entry( 428*4882a593Smuzhiyun WIPHY_ENTRY 429*4882a593Smuzhiyun NETDEV_ENTRY 430*4882a593Smuzhiyun MAC_ENTRY(mac_addr) 431*4882a593Smuzhiyun __field(u8, key_index) 432*4882a593Smuzhiyun __field(bool, pairwise) 433*4882a593Smuzhiyun ), 434*4882a593Smuzhiyun TP_fast_assign( 435*4882a593Smuzhiyun WIPHY_ASSIGN; 436*4882a593Smuzhiyun NETDEV_ASSIGN; 437*4882a593Smuzhiyun MAC_ASSIGN(mac_addr, mac_addr); 438*4882a593Smuzhiyun __entry->key_index = key_index; 439*4882a593Smuzhiyun __entry->pairwise = pairwise; 440*4882a593Smuzhiyun ), 441*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", key_index: %u, pairwise: %s, mac addr: " MAC_PR_FMT, 442*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->key_index, 443*4882a593Smuzhiyun BOOL_TO_STR(__entry->pairwise), MAC_PR_ARG(mac_addr)) 444*4882a593Smuzhiyun ); 445*4882a593Smuzhiyun 446*4882a593Smuzhiyun DEFINE_EVENT(key_handle, rdev_get_key, 447*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, u8 key_index, 448*4882a593Smuzhiyun bool pairwise, const u8 *mac_addr), 449*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, key_index, pairwise, mac_addr) 450*4882a593Smuzhiyun ); 451*4882a593Smuzhiyun 452*4882a593Smuzhiyun DEFINE_EVENT(key_handle, rdev_del_key, 453*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, u8 key_index, 454*4882a593Smuzhiyun bool pairwise, const u8 *mac_addr), 455*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, key_index, pairwise, mac_addr) 456*4882a593Smuzhiyun ); 457*4882a593Smuzhiyun 458*4882a593Smuzhiyun TRACE_EVENT(rdev_add_key, 459*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, u8 key_index, 460*4882a593Smuzhiyun bool pairwise, const u8 *mac_addr, u8 mode), 461*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, key_index, pairwise, mac_addr, mode), 462*4882a593Smuzhiyun TP_STRUCT__entry( 463*4882a593Smuzhiyun WIPHY_ENTRY 464*4882a593Smuzhiyun NETDEV_ENTRY 465*4882a593Smuzhiyun MAC_ENTRY(mac_addr) 466*4882a593Smuzhiyun __field(u8, key_index) 467*4882a593Smuzhiyun __field(bool, pairwise) 468*4882a593Smuzhiyun __field(u8, mode) 469*4882a593Smuzhiyun ), 470*4882a593Smuzhiyun TP_fast_assign( 471*4882a593Smuzhiyun WIPHY_ASSIGN; 472*4882a593Smuzhiyun NETDEV_ASSIGN; 473*4882a593Smuzhiyun MAC_ASSIGN(mac_addr, mac_addr); 474*4882a593Smuzhiyun __entry->key_index = key_index; 475*4882a593Smuzhiyun __entry->pairwise = pairwise; 476*4882a593Smuzhiyun __entry->mode = mode; 477*4882a593Smuzhiyun ), 478*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", key_index: %u, " 479*4882a593Smuzhiyun "mode: %u, pairwise: %s, mac addr: " MAC_PR_FMT, 480*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->key_index, 481*4882a593Smuzhiyun __entry->mode, BOOL_TO_STR(__entry->pairwise), 482*4882a593Smuzhiyun MAC_PR_ARG(mac_addr)) 483*4882a593Smuzhiyun ); 484*4882a593Smuzhiyun 485*4882a593Smuzhiyun TRACE_EVENT(rdev_set_default_key, 486*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, u8 key_index, 487*4882a593Smuzhiyun bool unicast, bool multicast), 488*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, key_index, unicast, multicast), 489*4882a593Smuzhiyun TP_STRUCT__entry( 490*4882a593Smuzhiyun WIPHY_ENTRY 491*4882a593Smuzhiyun NETDEV_ENTRY 492*4882a593Smuzhiyun __field(u8, key_index) 493*4882a593Smuzhiyun __field(bool, unicast) 494*4882a593Smuzhiyun __field(bool, multicast) 495*4882a593Smuzhiyun ), 496*4882a593Smuzhiyun TP_fast_assign( 497*4882a593Smuzhiyun WIPHY_ASSIGN; 498*4882a593Smuzhiyun NETDEV_ASSIGN; 499*4882a593Smuzhiyun __entry->key_index = key_index; 500*4882a593Smuzhiyun __entry->unicast = unicast; 501*4882a593Smuzhiyun __entry->multicast = multicast; 502*4882a593Smuzhiyun ), 503*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", key index: %u, unicast: %s, multicast: %s", 504*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->key_index, 505*4882a593Smuzhiyun BOOL_TO_STR(__entry->unicast), 506*4882a593Smuzhiyun BOOL_TO_STR(__entry->multicast)) 507*4882a593Smuzhiyun ); 508*4882a593Smuzhiyun 509*4882a593Smuzhiyun TRACE_EVENT(rdev_set_default_mgmt_key, 510*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, u8 key_index), 511*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, key_index), 512*4882a593Smuzhiyun TP_STRUCT__entry( 513*4882a593Smuzhiyun WIPHY_ENTRY 514*4882a593Smuzhiyun NETDEV_ENTRY 515*4882a593Smuzhiyun __field(u8, key_index) 516*4882a593Smuzhiyun ), 517*4882a593Smuzhiyun TP_fast_assign( 518*4882a593Smuzhiyun WIPHY_ASSIGN; 519*4882a593Smuzhiyun NETDEV_ASSIGN; 520*4882a593Smuzhiyun __entry->key_index = key_index; 521*4882a593Smuzhiyun ), 522*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", key index: %u", 523*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->key_index) 524*4882a593Smuzhiyun ); 525*4882a593Smuzhiyun 526*4882a593Smuzhiyun TRACE_EVENT(rdev_set_default_beacon_key, 527*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, u8 key_index), 528*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, key_index), 529*4882a593Smuzhiyun TP_STRUCT__entry( 530*4882a593Smuzhiyun WIPHY_ENTRY 531*4882a593Smuzhiyun NETDEV_ENTRY 532*4882a593Smuzhiyun __field(u8, key_index) 533*4882a593Smuzhiyun ), 534*4882a593Smuzhiyun TP_fast_assign( 535*4882a593Smuzhiyun WIPHY_ASSIGN; 536*4882a593Smuzhiyun NETDEV_ASSIGN; 537*4882a593Smuzhiyun __entry->key_index = key_index; 538*4882a593Smuzhiyun ), 539*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", key index: %u", 540*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->key_index) 541*4882a593Smuzhiyun ); 542*4882a593Smuzhiyun 543*4882a593Smuzhiyun TRACE_EVENT(rdev_start_ap, 544*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 545*4882a593Smuzhiyun struct cfg80211_ap_settings *settings), 546*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, settings), 547*4882a593Smuzhiyun TP_STRUCT__entry( 548*4882a593Smuzhiyun WIPHY_ENTRY 549*4882a593Smuzhiyun NETDEV_ENTRY 550*4882a593Smuzhiyun CHAN_DEF_ENTRY 551*4882a593Smuzhiyun __field(int, beacon_interval) 552*4882a593Smuzhiyun __field(int, dtim_period) 553*4882a593Smuzhiyun __array(char, ssid, IEEE80211_MAX_SSID_LEN + 1) 554*4882a593Smuzhiyun __field(enum nl80211_hidden_ssid, hidden_ssid) 555*4882a593Smuzhiyun __field(u32, wpa_ver) 556*4882a593Smuzhiyun __field(bool, privacy) 557*4882a593Smuzhiyun __field(enum nl80211_auth_type, auth_type) 558*4882a593Smuzhiyun __field(int, inactivity_timeout) 559*4882a593Smuzhiyun ), 560*4882a593Smuzhiyun TP_fast_assign( 561*4882a593Smuzhiyun WIPHY_ASSIGN; 562*4882a593Smuzhiyun NETDEV_ASSIGN; 563*4882a593Smuzhiyun CHAN_DEF_ASSIGN(&settings->chandef); 564*4882a593Smuzhiyun __entry->beacon_interval = settings->beacon_interval; 565*4882a593Smuzhiyun __entry->dtim_period = settings->dtim_period; 566*4882a593Smuzhiyun __entry->hidden_ssid = settings->hidden_ssid; 567*4882a593Smuzhiyun __entry->wpa_ver = settings->crypto.wpa_versions; 568*4882a593Smuzhiyun __entry->privacy = settings->privacy; 569*4882a593Smuzhiyun __entry->auth_type = settings->auth_type; 570*4882a593Smuzhiyun __entry->inactivity_timeout = settings->inactivity_timeout; 571*4882a593Smuzhiyun memset(__entry->ssid, 0, IEEE80211_MAX_SSID_LEN + 1); 572*4882a593Smuzhiyun memcpy(__entry->ssid, settings->ssid, settings->ssid_len); 573*4882a593Smuzhiyun ), 574*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", AP settings - ssid: %s, " 575*4882a593Smuzhiyun CHAN_DEF_PR_FMT ", beacon interval: %d, dtim period: %d, " 576*4882a593Smuzhiyun "hidden ssid: %d, wpa versions: %u, privacy: %s, " 577*4882a593Smuzhiyun "auth type: %d, inactivity timeout: %d", 578*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->ssid, CHAN_DEF_PR_ARG, 579*4882a593Smuzhiyun __entry->beacon_interval, __entry->dtim_period, 580*4882a593Smuzhiyun __entry->hidden_ssid, __entry->wpa_ver, 581*4882a593Smuzhiyun BOOL_TO_STR(__entry->privacy), __entry->auth_type, 582*4882a593Smuzhiyun __entry->inactivity_timeout) 583*4882a593Smuzhiyun ); 584*4882a593Smuzhiyun 585*4882a593Smuzhiyun TRACE_EVENT(rdev_change_beacon, 586*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 587*4882a593Smuzhiyun struct cfg80211_beacon_data *info), 588*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, info), 589*4882a593Smuzhiyun TP_STRUCT__entry( 590*4882a593Smuzhiyun WIPHY_ENTRY 591*4882a593Smuzhiyun NETDEV_ENTRY 592*4882a593Smuzhiyun __dynamic_array(u8, head, info ? info->head_len : 0) 593*4882a593Smuzhiyun __dynamic_array(u8, tail, info ? info->tail_len : 0) 594*4882a593Smuzhiyun __dynamic_array(u8, beacon_ies, info ? info->beacon_ies_len : 0) 595*4882a593Smuzhiyun __dynamic_array(u8, proberesp_ies, 596*4882a593Smuzhiyun info ? info->proberesp_ies_len : 0) 597*4882a593Smuzhiyun __dynamic_array(u8, assocresp_ies, 598*4882a593Smuzhiyun info ? info->assocresp_ies_len : 0) 599*4882a593Smuzhiyun __dynamic_array(u8, probe_resp, info ? info->probe_resp_len : 0) 600*4882a593Smuzhiyun ), 601*4882a593Smuzhiyun TP_fast_assign( 602*4882a593Smuzhiyun WIPHY_ASSIGN; 603*4882a593Smuzhiyun NETDEV_ASSIGN; 604*4882a593Smuzhiyun if (info) { 605*4882a593Smuzhiyun if (info->head) 606*4882a593Smuzhiyun memcpy(__get_dynamic_array(head), info->head, 607*4882a593Smuzhiyun info->head_len); 608*4882a593Smuzhiyun if (info->tail) 609*4882a593Smuzhiyun memcpy(__get_dynamic_array(tail), info->tail, 610*4882a593Smuzhiyun info->tail_len); 611*4882a593Smuzhiyun if (info->beacon_ies) 612*4882a593Smuzhiyun memcpy(__get_dynamic_array(beacon_ies), 613*4882a593Smuzhiyun info->beacon_ies, info->beacon_ies_len); 614*4882a593Smuzhiyun if (info->proberesp_ies) 615*4882a593Smuzhiyun memcpy(__get_dynamic_array(proberesp_ies), 616*4882a593Smuzhiyun info->proberesp_ies, 617*4882a593Smuzhiyun info->proberesp_ies_len); 618*4882a593Smuzhiyun if (info->assocresp_ies) 619*4882a593Smuzhiyun memcpy(__get_dynamic_array(assocresp_ies), 620*4882a593Smuzhiyun info->assocresp_ies, 621*4882a593Smuzhiyun info->assocresp_ies_len); 622*4882a593Smuzhiyun if (info->probe_resp) 623*4882a593Smuzhiyun memcpy(__get_dynamic_array(probe_resp), 624*4882a593Smuzhiyun info->probe_resp, info->probe_resp_len); 625*4882a593Smuzhiyun } 626*4882a593Smuzhiyun ), 627*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT, WIPHY_PR_ARG, NETDEV_PR_ARG) 628*4882a593Smuzhiyun ); 629*4882a593Smuzhiyun 630*4882a593Smuzhiyun DECLARE_EVENT_CLASS(wiphy_netdev_evt, 631*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev), 632*4882a593Smuzhiyun TP_ARGS(wiphy, netdev), 633*4882a593Smuzhiyun TP_STRUCT__entry( 634*4882a593Smuzhiyun WIPHY_ENTRY 635*4882a593Smuzhiyun NETDEV_ENTRY 636*4882a593Smuzhiyun ), 637*4882a593Smuzhiyun TP_fast_assign( 638*4882a593Smuzhiyun WIPHY_ASSIGN; 639*4882a593Smuzhiyun NETDEV_ASSIGN; 640*4882a593Smuzhiyun ), 641*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT, WIPHY_PR_ARG, NETDEV_PR_ARG) 642*4882a593Smuzhiyun ); 643*4882a593Smuzhiyun 644*4882a593Smuzhiyun DEFINE_EVENT(wiphy_netdev_evt, rdev_stop_ap, 645*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev), 646*4882a593Smuzhiyun TP_ARGS(wiphy, netdev) 647*4882a593Smuzhiyun ); 648*4882a593Smuzhiyun 649*4882a593Smuzhiyun DEFINE_EVENT(wiphy_netdev_evt, rdev_set_rekey_data, 650*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev), 651*4882a593Smuzhiyun TP_ARGS(wiphy, netdev) 652*4882a593Smuzhiyun ); 653*4882a593Smuzhiyun 654*4882a593Smuzhiyun DEFINE_EVENT(wiphy_netdev_evt, rdev_get_mesh_config, 655*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev), 656*4882a593Smuzhiyun TP_ARGS(wiphy, netdev) 657*4882a593Smuzhiyun ); 658*4882a593Smuzhiyun 659*4882a593Smuzhiyun DEFINE_EVENT(wiphy_netdev_evt, rdev_leave_mesh, 660*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev), 661*4882a593Smuzhiyun TP_ARGS(wiphy, netdev) 662*4882a593Smuzhiyun ); 663*4882a593Smuzhiyun 664*4882a593Smuzhiyun DEFINE_EVENT(wiphy_netdev_evt, rdev_leave_ibss, 665*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev), 666*4882a593Smuzhiyun TP_ARGS(wiphy, netdev) 667*4882a593Smuzhiyun ); 668*4882a593Smuzhiyun 669*4882a593Smuzhiyun DEFINE_EVENT(wiphy_netdev_evt, rdev_leave_ocb, 670*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev), 671*4882a593Smuzhiyun TP_ARGS(wiphy, netdev) 672*4882a593Smuzhiyun ); 673*4882a593Smuzhiyun 674*4882a593Smuzhiyun DEFINE_EVENT(wiphy_netdev_evt, rdev_flush_pmksa, 675*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev), 676*4882a593Smuzhiyun TP_ARGS(wiphy, netdev) 677*4882a593Smuzhiyun ); 678*4882a593Smuzhiyun 679*4882a593Smuzhiyun DEFINE_EVENT(wiphy_netdev_evt, rdev_end_cac, 680*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev), 681*4882a593Smuzhiyun TP_ARGS(wiphy, netdev) 682*4882a593Smuzhiyun ); 683*4882a593Smuzhiyun 684*4882a593Smuzhiyun DECLARE_EVENT_CLASS(station_add_change, 685*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, u8 *mac, 686*4882a593Smuzhiyun struct station_parameters *params), 687*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, mac, params), 688*4882a593Smuzhiyun TP_STRUCT__entry( 689*4882a593Smuzhiyun WIPHY_ENTRY 690*4882a593Smuzhiyun NETDEV_ENTRY 691*4882a593Smuzhiyun MAC_ENTRY(sta_mac) 692*4882a593Smuzhiyun __field(u32, sta_flags_mask) 693*4882a593Smuzhiyun __field(u32, sta_flags_set) 694*4882a593Smuzhiyun __field(u32, sta_modify_mask) 695*4882a593Smuzhiyun __field(int, listen_interval) 696*4882a593Smuzhiyun __field(u16, capability) 697*4882a593Smuzhiyun __field(u16, aid) 698*4882a593Smuzhiyun __field(u8, plink_action) 699*4882a593Smuzhiyun __field(u8, plink_state) 700*4882a593Smuzhiyun __field(u8, uapsd_queues) 701*4882a593Smuzhiyun __field(u8, max_sp) 702*4882a593Smuzhiyun __field(u8, opmode_notif) 703*4882a593Smuzhiyun __field(bool, opmode_notif_used) 704*4882a593Smuzhiyun __array(u8, ht_capa, (int)sizeof(struct ieee80211_ht_cap)) 705*4882a593Smuzhiyun __array(u8, vht_capa, (int)sizeof(struct ieee80211_vht_cap)) 706*4882a593Smuzhiyun __array(char, vlan, IFNAMSIZ) 707*4882a593Smuzhiyun __dynamic_array(u8, supported_rates, 708*4882a593Smuzhiyun params->supported_rates_len) 709*4882a593Smuzhiyun __dynamic_array(u8, ext_capab, params->ext_capab_len) 710*4882a593Smuzhiyun __dynamic_array(u8, supported_channels, 711*4882a593Smuzhiyun params->supported_channels_len) 712*4882a593Smuzhiyun __dynamic_array(u8, supported_oper_classes, 713*4882a593Smuzhiyun params->supported_oper_classes_len) 714*4882a593Smuzhiyun ), 715*4882a593Smuzhiyun TP_fast_assign( 716*4882a593Smuzhiyun WIPHY_ASSIGN; 717*4882a593Smuzhiyun NETDEV_ASSIGN; 718*4882a593Smuzhiyun MAC_ASSIGN(sta_mac, mac); 719*4882a593Smuzhiyun __entry->sta_flags_mask = params->sta_flags_mask; 720*4882a593Smuzhiyun __entry->sta_flags_set = params->sta_flags_set; 721*4882a593Smuzhiyun __entry->sta_modify_mask = params->sta_modify_mask; 722*4882a593Smuzhiyun __entry->listen_interval = params->listen_interval; 723*4882a593Smuzhiyun __entry->aid = params->aid; 724*4882a593Smuzhiyun __entry->plink_action = params->plink_action; 725*4882a593Smuzhiyun __entry->plink_state = params->plink_state; 726*4882a593Smuzhiyun __entry->uapsd_queues = params->uapsd_queues; 727*4882a593Smuzhiyun memset(__entry->ht_capa, 0, sizeof(struct ieee80211_ht_cap)); 728*4882a593Smuzhiyun if (params->ht_capa) 729*4882a593Smuzhiyun memcpy(__entry->ht_capa, params->ht_capa, 730*4882a593Smuzhiyun sizeof(struct ieee80211_ht_cap)); 731*4882a593Smuzhiyun memset(__entry->vht_capa, 0, sizeof(struct ieee80211_vht_cap)); 732*4882a593Smuzhiyun if (params->vht_capa) 733*4882a593Smuzhiyun memcpy(__entry->vht_capa, params->vht_capa, 734*4882a593Smuzhiyun sizeof(struct ieee80211_vht_cap)); 735*4882a593Smuzhiyun memset(__entry->vlan, 0, sizeof(__entry->vlan)); 736*4882a593Smuzhiyun if (params->vlan) 737*4882a593Smuzhiyun memcpy(__entry->vlan, params->vlan->name, IFNAMSIZ); 738*4882a593Smuzhiyun if (params->supported_rates && params->supported_rates_len) 739*4882a593Smuzhiyun memcpy(__get_dynamic_array(supported_rates), 740*4882a593Smuzhiyun params->supported_rates, 741*4882a593Smuzhiyun params->supported_rates_len); 742*4882a593Smuzhiyun if (params->ext_capab && params->ext_capab_len) 743*4882a593Smuzhiyun memcpy(__get_dynamic_array(ext_capab), 744*4882a593Smuzhiyun params->ext_capab, 745*4882a593Smuzhiyun params->ext_capab_len); 746*4882a593Smuzhiyun if (params->supported_channels && 747*4882a593Smuzhiyun params->supported_channels_len) 748*4882a593Smuzhiyun memcpy(__get_dynamic_array(supported_channels), 749*4882a593Smuzhiyun params->supported_channels, 750*4882a593Smuzhiyun params->supported_channels_len); 751*4882a593Smuzhiyun if (params->supported_oper_classes && 752*4882a593Smuzhiyun params->supported_oper_classes_len) 753*4882a593Smuzhiyun memcpy(__get_dynamic_array(supported_oper_classes), 754*4882a593Smuzhiyun params->supported_oper_classes, 755*4882a593Smuzhiyun params->supported_oper_classes_len); 756*4882a593Smuzhiyun __entry->max_sp = params->max_sp; 757*4882a593Smuzhiyun __entry->capability = params->capability; 758*4882a593Smuzhiyun __entry->opmode_notif = params->opmode_notif; 759*4882a593Smuzhiyun __entry->opmode_notif_used = params->opmode_notif_used; 760*4882a593Smuzhiyun ), 761*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", station mac: " MAC_PR_FMT 762*4882a593Smuzhiyun ", station flags mask: %u, station flags set: %u, " 763*4882a593Smuzhiyun "station modify mask: %u, listen interval: %d, aid: %u, " 764*4882a593Smuzhiyun "plink action: %u, plink state: %u, uapsd queues: %u, vlan:%s", 765*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(sta_mac), 766*4882a593Smuzhiyun __entry->sta_flags_mask, __entry->sta_flags_set, 767*4882a593Smuzhiyun __entry->sta_modify_mask, __entry->listen_interval, 768*4882a593Smuzhiyun __entry->aid, __entry->plink_action, __entry->plink_state, 769*4882a593Smuzhiyun __entry->uapsd_queues, __entry->vlan) 770*4882a593Smuzhiyun ); 771*4882a593Smuzhiyun 772*4882a593Smuzhiyun DEFINE_EVENT(station_add_change, rdev_add_station, 773*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, u8 *mac, 774*4882a593Smuzhiyun struct station_parameters *params), 775*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, mac, params) 776*4882a593Smuzhiyun ); 777*4882a593Smuzhiyun 778*4882a593Smuzhiyun DEFINE_EVENT(station_add_change, rdev_change_station, 779*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, u8 *mac, 780*4882a593Smuzhiyun struct station_parameters *params), 781*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, mac, params) 782*4882a593Smuzhiyun ); 783*4882a593Smuzhiyun 784*4882a593Smuzhiyun DECLARE_EVENT_CLASS(wiphy_netdev_mac_evt, 785*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, const u8 *mac), 786*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, mac), 787*4882a593Smuzhiyun TP_STRUCT__entry( 788*4882a593Smuzhiyun WIPHY_ENTRY 789*4882a593Smuzhiyun NETDEV_ENTRY 790*4882a593Smuzhiyun MAC_ENTRY(sta_mac) 791*4882a593Smuzhiyun ), 792*4882a593Smuzhiyun TP_fast_assign( 793*4882a593Smuzhiyun WIPHY_ASSIGN; 794*4882a593Smuzhiyun NETDEV_ASSIGN; 795*4882a593Smuzhiyun MAC_ASSIGN(sta_mac, mac); 796*4882a593Smuzhiyun ), 797*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", mac: " MAC_PR_FMT, 798*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(sta_mac)) 799*4882a593Smuzhiyun ); 800*4882a593Smuzhiyun 801*4882a593Smuzhiyun DECLARE_EVENT_CLASS(station_del, 802*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 803*4882a593Smuzhiyun struct station_del_parameters *params), 804*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, params), 805*4882a593Smuzhiyun TP_STRUCT__entry( 806*4882a593Smuzhiyun WIPHY_ENTRY 807*4882a593Smuzhiyun NETDEV_ENTRY 808*4882a593Smuzhiyun MAC_ENTRY(sta_mac) 809*4882a593Smuzhiyun __field(u8, subtype) 810*4882a593Smuzhiyun __field(u16, reason_code) 811*4882a593Smuzhiyun ), 812*4882a593Smuzhiyun TP_fast_assign( 813*4882a593Smuzhiyun WIPHY_ASSIGN; 814*4882a593Smuzhiyun NETDEV_ASSIGN; 815*4882a593Smuzhiyun MAC_ASSIGN(sta_mac, params->mac); 816*4882a593Smuzhiyun __entry->subtype = params->subtype; 817*4882a593Smuzhiyun __entry->reason_code = params->reason_code; 818*4882a593Smuzhiyun ), 819*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", station mac: " MAC_PR_FMT 820*4882a593Smuzhiyun ", subtype: %u, reason_code: %u", 821*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(sta_mac), 822*4882a593Smuzhiyun __entry->subtype, __entry->reason_code) 823*4882a593Smuzhiyun ); 824*4882a593Smuzhiyun 825*4882a593Smuzhiyun DEFINE_EVENT(station_del, rdev_del_station, 826*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 827*4882a593Smuzhiyun struct station_del_parameters *params), 828*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, params) 829*4882a593Smuzhiyun ); 830*4882a593Smuzhiyun 831*4882a593Smuzhiyun DEFINE_EVENT(wiphy_netdev_mac_evt, rdev_get_station, 832*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, const u8 *mac), 833*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, mac) 834*4882a593Smuzhiyun ); 835*4882a593Smuzhiyun 836*4882a593Smuzhiyun DEFINE_EVENT(wiphy_netdev_mac_evt, rdev_del_mpath, 837*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, const u8 *mac), 838*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, mac) 839*4882a593Smuzhiyun ); 840*4882a593Smuzhiyun 841*4882a593Smuzhiyun DEFINE_EVENT(wiphy_netdev_mac_evt, rdev_set_wds_peer, 842*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, const u8 *mac), 843*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, mac) 844*4882a593Smuzhiyun ); 845*4882a593Smuzhiyun 846*4882a593Smuzhiyun TRACE_EVENT(rdev_dump_station, 847*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, int _idx, 848*4882a593Smuzhiyun u8 *mac), 849*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, _idx, mac), 850*4882a593Smuzhiyun TP_STRUCT__entry( 851*4882a593Smuzhiyun WIPHY_ENTRY 852*4882a593Smuzhiyun NETDEV_ENTRY 853*4882a593Smuzhiyun MAC_ENTRY(sta_mac) 854*4882a593Smuzhiyun __field(int, idx) 855*4882a593Smuzhiyun ), 856*4882a593Smuzhiyun TP_fast_assign( 857*4882a593Smuzhiyun WIPHY_ASSIGN; 858*4882a593Smuzhiyun NETDEV_ASSIGN; 859*4882a593Smuzhiyun MAC_ASSIGN(sta_mac, mac); 860*4882a593Smuzhiyun __entry->idx = _idx; 861*4882a593Smuzhiyun ), 862*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", station mac: " MAC_PR_FMT ", idx: %d", 863*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(sta_mac), 864*4882a593Smuzhiyun __entry->idx) 865*4882a593Smuzhiyun ); 866*4882a593Smuzhiyun 867*4882a593Smuzhiyun TRACE_EVENT(rdev_return_int_station_info, 868*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, int ret, struct station_info *sinfo), 869*4882a593Smuzhiyun TP_ARGS(wiphy, ret, sinfo), 870*4882a593Smuzhiyun TP_STRUCT__entry( 871*4882a593Smuzhiyun WIPHY_ENTRY 872*4882a593Smuzhiyun __field(int, ret) 873*4882a593Smuzhiyun SINFO_ENTRY 874*4882a593Smuzhiyun ), 875*4882a593Smuzhiyun TP_fast_assign( 876*4882a593Smuzhiyun WIPHY_ASSIGN; 877*4882a593Smuzhiyun __entry->ret = ret; 878*4882a593Smuzhiyun SINFO_ASSIGN; 879*4882a593Smuzhiyun ), 880*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", returned %d" , 881*4882a593Smuzhiyun WIPHY_PR_ARG, __entry->ret) 882*4882a593Smuzhiyun ); 883*4882a593Smuzhiyun 884*4882a593Smuzhiyun DECLARE_EVENT_CLASS(mpath_evt, 885*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, u8 *dst, 886*4882a593Smuzhiyun u8 *next_hop), 887*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, dst, next_hop), 888*4882a593Smuzhiyun TP_STRUCT__entry( 889*4882a593Smuzhiyun WIPHY_ENTRY 890*4882a593Smuzhiyun NETDEV_ENTRY 891*4882a593Smuzhiyun MAC_ENTRY(dst) 892*4882a593Smuzhiyun MAC_ENTRY(next_hop) 893*4882a593Smuzhiyun ), 894*4882a593Smuzhiyun TP_fast_assign( 895*4882a593Smuzhiyun WIPHY_ASSIGN; 896*4882a593Smuzhiyun NETDEV_ASSIGN; 897*4882a593Smuzhiyun MAC_ASSIGN(dst, dst); 898*4882a593Smuzhiyun MAC_ASSIGN(next_hop, next_hop); 899*4882a593Smuzhiyun ), 900*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", destination: " MAC_PR_FMT ", next hop: " MAC_PR_FMT, 901*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(dst), 902*4882a593Smuzhiyun MAC_PR_ARG(next_hop)) 903*4882a593Smuzhiyun ); 904*4882a593Smuzhiyun 905*4882a593Smuzhiyun DEFINE_EVENT(mpath_evt, rdev_add_mpath, 906*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, u8 *dst, 907*4882a593Smuzhiyun u8 *next_hop), 908*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, dst, next_hop) 909*4882a593Smuzhiyun ); 910*4882a593Smuzhiyun 911*4882a593Smuzhiyun DEFINE_EVENT(mpath_evt, rdev_change_mpath, 912*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, u8 *dst, 913*4882a593Smuzhiyun u8 *next_hop), 914*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, dst, next_hop) 915*4882a593Smuzhiyun ); 916*4882a593Smuzhiyun 917*4882a593Smuzhiyun DEFINE_EVENT(mpath_evt, rdev_get_mpath, 918*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, u8 *dst, 919*4882a593Smuzhiyun u8 *next_hop), 920*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, dst, next_hop) 921*4882a593Smuzhiyun ); 922*4882a593Smuzhiyun 923*4882a593Smuzhiyun TRACE_EVENT(rdev_dump_mpath, 924*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, int _idx, 925*4882a593Smuzhiyun u8 *dst, u8 *next_hop), 926*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, _idx, dst, next_hop), 927*4882a593Smuzhiyun TP_STRUCT__entry( 928*4882a593Smuzhiyun WIPHY_ENTRY 929*4882a593Smuzhiyun NETDEV_ENTRY 930*4882a593Smuzhiyun MAC_ENTRY(dst) 931*4882a593Smuzhiyun MAC_ENTRY(next_hop) 932*4882a593Smuzhiyun __field(int, idx) 933*4882a593Smuzhiyun ), 934*4882a593Smuzhiyun TP_fast_assign( 935*4882a593Smuzhiyun WIPHY_ASSIGN; 936*4882a593Smuzhiyun NETDEV_ASSIGN; 937*4882a593Smuzhiyun MAC_ASSIGN(dst, dst); 938*4882a593Smuzhiyun MAC_ASSIGN(next_hop, next_hop); 939*4882a593Smuzhiyun __entry->idx = _idx; 940*4882a593Smuzhiyun ), 941*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", index: %d, destination: " 942*4882a593Smuzhiyun MAC_PR_FMT ", next hop: " MAC_PR_FMT, 943*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->idx, MAC_PR_ARG(dst), 944*4882a593Smuzhiyun MAC_PR_ARG(next_hop)) 945*4882a593Smuzhiyun ); 946*4882a593Smuzhiyun 947*4882a593Smuzhiyun TRACE_EVENT(rdev_get_mpp, 948*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 949*4882a593Smuzhiyun u8 *dst, u8 *mpp), 950*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, dst, mpp), 951*4882a593Smuzhiyun TP_STRUCT__entry( 952*4882a593Smuzhiyun WIPHY_ENTRY 953*4882a593Smuzhiyun NETDEV_ENTRY 954*4882a593Smuzhiyun MAC_ENTRY(dst) 955*4882a593Smuzhiyun MAC_ENTRY(mpp) 956*4882a593Smuzhiyun ), 957*4882a593Smuzhiyun TP_fast_assign( 958*4882a593Smuzhiyun WIPHY_ASSIGN; 959*4882a593Smuzhiyun NETDEV_ASSIGN; 960*4882a593Smuzhiyun MAC_ASSIGN(dst, dst); 961*4882a593Smuzhiyun MAC_ASSIGN(mpp, mpp); 962*4882a593Smuzhiyun ), 963*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", destination: " MAC_PR_FMT 964*4882a593Smuzhiyun ", mpp: " MAC_PR_FMT, WIPHY_PR_ARG, NETDEV_PR_ARG, 965*4882a593Smuzhiyun MAC_PR_ARG(dst), MAC_PR_ARG(mpp)) 966*4882a593Smuzhiyun ); 967*4882a593Smuzhiyun 968*4882a593Smuzhiyun TRACE_EVENT(rdev_dump_mpp, 969*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, int _idx, 970*4882a593Smuzhiyun u8 *dst, u8 *mpp), 971*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, _idx, mpp, dst), 972*4882a593Smuzhiyun TP_STRUCT__entry( 973*4882a593Smuzhiyun WIPHY_ENTRY 974*4882a593Smuzhiyun NETDEV_ENTRY 975*4882a593Smuzhiyun MAC_ENTRY(dst) 976*4882a593Smuzhiyun MAC_ENTRY(mpp) 977*4882a593Smuzhiyun __field(int, idx) 978*4882a593Smuzhiyun ), 979*4882a593Smuzhiyun TP_fast_assign( 980*4882a593Smuzhiyun WIPHY_ASSIGN; 981*4882a593Smuzhiyun NETDEV_ASSIGN; 982*4882a593Smuzhiyun MAC_ASSIGN(dst, dst); 983*4882a593Smuzhiyun MAC_ASSIGN(mpp, mpp); 984*4882a593Smuzhiyun __entry->idx = _idx; 985*4882a593Smuzhiyun ), 986*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", index: %d, destination: " 987*4882a593Smuzhiyun MAC_PR_FMT ", mpp: " MAC_PR_FMT, 988*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->idx, MAC_PR_ARG(dst), 989*4882a593Smuzhiyun MAC_PR_ARG(mpp)) 990*4882a593Smuzhiyun ); 991*4882a593Smuzhiyun 992*4882a593Smuzhiyun TRACE_EVENT(rdev_return_int_mpath_info, 993*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, int ret, struct mpath_info *pinfo), 994*4882a593Smuzhiyun TP_ARGS(wiphy, ret, pinfo), 995*4882a593Smuzhiyun TP_STRUCT__entry( 996*4882a593Smuzhiyun WIPHY_ENTRY 997*4882a593Smuzhiyun __field(int, ret) 998*4882a593Smuzhiyun __field(int, generation) 999*4882a593Smuzhiyun __field(u32, filled) 1000*4882a593Smuzhiyun __field(u32, frame_qlen) 1001*4882a593Smuzhiyun __field(u32, sn) 1002*4882a593Smuzhiyun __field(u32, metric) 1003*4882a593Smuzhiyun __field(u32, exptime) 1004*4882a593Smuzhiyun __field(u32, discovery_timeout) 1005*4882a593Smuzhiyun __field(u8, discovery_retries) 1006*4882a593Smuzhiyun __field(u8, flags) 1007*4882a593Smuzhiyun ), 1008*4882a593Smuzhiyun TP_fast_assign( 1009*4882a593Smuzhiyun WIPHY_ASSIGN; 1010*4882a593Smuzhiyun __entry->ret = ret; 1011*4882a593Smuzhiyun __entry->generation = pinfo->generation; 1012*4882a593Smuzhiyun __entry->filled = pinfo->filled; 1013*4882a593Smuzhiyun __entry->frame_qlen = pinfo->frame_qlen; 1014*4882a593Smuzhiyun __entry->sn = pinfo->sn; 1015*4882a593Smuzhiyun __entry->metric = pinfo->metric; 1016*4882a593Smuzhiyun __entry->exptime = pinfo->exptime; 1017*4882a593Smuzhiyun __entry->discovery_timeout = pinfo->discovery_timeout; 1018*4882a593Smuzhiyun __entry->discovery_retries = pinfo->discovery_retries; 1019*4882a593Smuzhiyun __entry->flags = pinfo->flags; 1020*4882a593Smuzhiyun ), 1021*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", returned %d. mpath info - generation: %d, " 1022*4882a593Smuzhiyun "filled: %u, frame qlen: %u, sn: %u, metric: %u, exptime: %u," 1023*4882a593Smuzhiyun " discovery timeout: %u, discovery retries: %u, flags: %u", 1024*4882a593Smuzhiyun WIPHY_PR_ARG, __entry->ret, __entry->generation, 1025*4882a593Smuzhiyun __entry->filled, __entry->frame_qlen, __entry->sn, 1026*4882a593Smuzhiyun __entry->metric, __entry->exptime, __entry->discovery_timeout, 1027*4882a593Smuzhiyun __entry->discovery_retries, __entry->flags) 1028*4882a593Smuzhiyun ); 1029*4882a593Smuzhiyun 1030*4882a593Smuzhiyun TRACE_EVENT(rdev_return_int_mesh_config, 1031*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, int ret, struct mesh_config *conf), 1032*4882a593Smuzhiyun TP_ARGS(wiphy, ret, conf), 1033*4882a593Smuzhiyun TP_STRUCT__entry( 1034*4882a593Smuzhiyun WIPHY_ENTRY 1035*4882a593Smuzhiyun MESH_CFG_ENTRY 1036*4882a593Smuzhiyun __field(int, ret) 1037*4882a593Smuzhiyun ), 1038*4882a593Smuzhiyun TP_fast_assign( 1039*4882a593Smuzhiyun WIPHY_ASSIGN; 1040*4882a593Smuzhiyun MESH_CFG_ASSIGN; 1041*4882a593Smuzhiyun __entry->ret = ret; 1042*4882a593Smuzhiyun ), 1043*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", returned: %d", 1044*4882a593Smuzhiyun WIPHY_PR_ARG, __entry->ret) 1045*4882a593Smuzhiyun ); 1046*4882a593Smuzhiyun 1047*4882a593Smuzhiyun TRACE_EVENT(rdev_update_mesh_config, 1048*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, u32 mask, 1049*4882a593Smuzhiyun const struct mesh_config *conf), 1050*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, mask, conf), 1051*4882a593Smuzhiyun TP_STRUCT__entry( 1052*4882a593Smuzhiyun WIPHY_ENTRY 1053*4882a593Smuzhiyun NETDEV_ENTRY 1054*4882a593Smuzhiyun MESH_CFG_ENTRY 1055*4882a593Smuzhiyun __field(u32, mask) 1056*4882a593Smuzhiyun ), 1057*4882a593Smuzhiyun TP_fast_assign( 1058*4882a593Smuzhiyun WIPHY_ASSIGN; 1059*4882a593Smuzhiyun NETDEV_ASSIGN; 1060*4882a593Smuzhiyun MESH_CFG_ASSIGN; 1061*4882a593Smuzhiyun __entry->mask = mask; 1062*4882a593Smuzhiyun ), 1063*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", mask: %u", 1064*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->mask) 1065*4882a593Smuzhiyun ); 1066*4882a593Smuzhiyun 1067*4882a593Smuzhiyun TRACE_EVENT(rdev_join_mesh, 1068*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1069*4882a593Smuzhiyun const struct mesh_config *conf, 1070*4882a593Smuzhiyun const struct mesh_setup *setup), 1071*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, conf, setup), 1072*4882a593Smuzhiyun TP_STRUCT__entry( 1073*4882a593Smuzhiyun WIPHY_ENTRY 1074*4882a593Smuzhiyun NETDEV_ENTRY 1075*4882a593Smuzhiyun MESH_CFG_ENTRY 1076*4882a593Smuzhiyun ), 1077*4882a593Smuzhiyun TP_fast_assign( 1078*4882a593Smuzhiyun WIPHY_ASSIGN; 1079*4882a593Smuzhiyun NETDEV_ASSIGN; 1080*4882a593Smuzhiyun MESH_CFG_ASSIGN; 1081*4882a593Smuzhiyun ), 1082*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT, 1083*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG) 1084*4882a593Smuzhiyun ); 1085*4882a593Smuzhiyun 1086*4882a593Smuzhiyun TRACE_EVENT(rdev_change_bss, 1087*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1088*4882a593Smuzhiyun struct bss_parameters *params), 1089*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, params), 1090*4882a593Smuzhiyun TP_STRUCT__entry( 1091*4882a593Smuzhiyun WIPHY_ENTRY 1092*4882a593Smuzhiyun NETDEV_ENTRY 1093*4882a593Smuzhiyun __field(int, use_cts_prot) 1094*4882a593Smuzhiyun __field(int, use_short_preamble) 1095*4882a593Smuzhiyun __field(int, use_short_slot_time) 1096*4882a593Smuzhiyun __field(int, ap_isolate) 1097*4882a593Smuzhiyun __field(int, ht_opmode) 1098*4882a593Smuzhiyun ), 1099*4882a593Smuzhiyun TP_fast_assign( 1100*4882a593Smuzhiyun WIPHY_ASSIGN; 1101*4882a593Smuzhiyun NETDEV_ASSIGN; 1102*4882a593Smuzhiyun __entry->use_cts_prot = params->use_cts_prot; 1103*4882a593Smuzhiyun __entry->use_short_preamble = params->use_short_preamble; 1104*4882a593Smuzhiyun __entry->use_short_slot_time = params->use_short_slot_time; 1105*4882a593Smuzhiyun __entry->ap_isolate = params->ap_isolate; 1106*4882a593Smuzhiyun __entry->ht_opmode = params->ht_opmode; 1107*4882a593Smuzhiyun ), 1108*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", use cts prot: %d, " 1109*4882a593Smuzhiyun "use short preamble: %d, use short slot time: %d, " 1110*4882a593Smuzhiyun "ap isolate: %d, ht opmode: %d", 1111*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->use_cts_prot, 1112*4882a593Smuzhiyun __entry->use_short_preamble, __entry->use_short_slot_time, 1113*4882a593Smuzhiyun __entry->ap_isolate, __entry->ht_opmode) 1114*4882a593Smuzhiyun ); 1115*4882a593Smuzhiyun 1116*4882a593Smuzhiyun TRACE_EVENT(rdev_set_txq_params, 1117*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1118*4882a593Smuzhiyun struct ieee80211_txq_params *params), 1119*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, params), 1120*4882a593Smuzhiyun TP_STRUCT__entry( 1121*4882a593Smuzhiyun WIPHY_ENTRY 1122*4882a593Smuzhiyun NETDEV_ENTRY 1123*4882a593Smuzhiyun __field(enum nl80211_ac, ac) 1124*4882a593Smuzhiyun __field(u16, txop) 1125*4882a593Smuzhiyun __field(u16, cwmin) 1126*4882a593Smuzhiyun __field(u16, cwmax) 1127*4882a593Smuzhiyun __field(u8, aifs) 1128*4882a593Smuzhiyun ), 1129*4882a593Smuzhiyun TP_fast_assign( 1130*4882a593Smuzhiyun WIPHY_ASSIGN; 1131*4882a593Smuzhiyun NETDEV_ASSIGN; 1132*4882a593Smuzhiyun __entry->ac = params->ac; 1133*4882a593Smuzhiyun __entry->txop = params->txop; 1134*4882a593Smuzhiyun __entry->cwmin = params->cwmin; 1135*4882a593Smuzhiyun __entry->cwmax = params->cwmax; 1136*4882a593Smuzhiyun __entry->aifs = params->aifs; 1137*4882a593Smuzhiyun ), 1138*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", ac: %d, txop: %u, cwmin: %u, cwmax: %u, aifs: %u", 1139*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->ac, __entry->txop, 1140*4882a593Smuzhiyun __entry->cwmin, __entry->cwmax, __entry->aifs) 1141*4882a593Smuzhiyun ); 1142*4882a593Smuzhiyun 1143*4882a593Smuzhiyun TRACE_EVENT(rdev_libertas_set_mesh_channel, 1144*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1145*4882a593Smuzhiyun struct ieee80211_channel *chan), 1146*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, chan), 1147*4882a593Smuzhiyun TP_STRUCT__entry( 1148*4882a593Smuzhiyun WIPHY_ENTRY 1149*4882a593Smuzhiyun NETDEV_ENTRY 1150*4882a593Smuzhiyun CHAN_ENTRY 1151*4882a593Smuzhiyun ), 1152*4882a593Smuzhiyun TP_fast_assign( 1153*4882a593Smuzhiyun WIPHY_ASSIGN; 1154*4882a593Smuzhiyun NETDEV_ASSIGN; 1155*4882a593Smuzhiyun CHAN_ASSIGN(chan); 1156*4882a593Smuzhiyun ), 1157*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", " CHAN_PR_FMT, WIPHY_PR_ARG, 1158*4882a593Smuzhiyun NETDEV_PR_ARG, CHAN_PR_ARG) 1159*4882a593Smuzhiyun ); 1160*4882a593Smuzhiyun 1161*4882a593Smuzhiyun TRACE_EVENT(rdev_set_monitor_channel, 1162*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, 1163*4882a593Smuzhiyun struct cfg80211_chan_def *chandef), 1164*4882a593Smuzhiyun TP_ARGS(wiphy, chandef), 1165*4882a593Smuzhiyun TP_STRUCT__entry( 1166*4882a593Smuzhiyun WIPHY_ENTRY 1167*4882a593Smuzhiyun CHAN_DEF_ENTRY 1168*4882a593Smuzhiyun ), 1169*4882a593Smuzhiyun TP_fast_assign( 1170*4882a593Smuzhiyun WIPHY_ASSIGN; 1171*4882a593Smuzhiyun CHAN_DEF_ASSIGN(chandef); 1172*4882a593Smuzhiyun ), 1173*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " CHAN_DEF_PR_FMT, 1174*4882a593Smuzhiyun WIPHY_PR_ARG, CHAN_DEF_PR_ARG) 1175*4882a593Smuzhiyun ); 1176*4882a593Smuzhiyun 1177*4882a593Smuzhiyun TRACE_EVENT(rdev_auth, 1178*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1179*4882a593Smuzhiyun struct cfg80211_auth_request *req), 1180*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, req), 1181*4882a593Smuzhiyun TP_STRUCT__entry( 1182*4882a593Smuzhiyun WIPHY_ENTRY 1183*4882a593Smuzhiyun NETDEV_ENTRY 1184*4882a593Smuzhiyun MAC_ENTRY(bssid) 1185*4882a593Smuzhiyun __field(enum nl80211_auth_type, auth_type) 1186*4882a593Smuzhiyun ), 1187*4882a593Smuzhiyun TP_fast_assign( 1188*4882a593Smuzhiyun WIPHY_ASSIGN; 1189*4882a593Smuzhiyun NETDEV_ASSIGN; 1190*4882a593Smuzhiyun if (req->bss) 1191*4882a593Smuzhiyun MAC_ASSIGN(bssid, req->bss->bssid); 1192*4882a593Smuzhiyun else 1193*4882a593Smuzhiyun eth_zero_addr(__entry->bssid); 1194*4882a593Smuzhiyun __entry->auth_type = req->auth_type; 1195*4882a593Smuzhiyun ), 1196*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", auth type: %d, bssid: " MAC_PR_FMT, 1197*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->auth_type, 1198*4882a593Smuzhiyun MAC_PR_ARG(bssid)) 1199*4882a593Smuzhiyun ); 1200*4882a593Smuzhiyun 1201*4882a593Smuzhiyun TRACE_EVENT(rdev_assoc, 1202*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1203*4882a593Smuzhiyun struct cfg80211_assoc_request *req), 1204*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, req), 1205*4882a593Smuzhiyun TP_STRUCT__entry( 1206*4882a593Smuzhiyun WIPHY_ENTRY 1207*4882a593Smuzhiyun NETDEV_ENTRY 1208*4882a593Smuzhiyun MAC_ENTRY(bssid) 1209*4882a593Smuzhiyun MAC_ENTRY(prev_bssid) 1210*4882a593Smuzhiyun __field(bool, use_mfp) 1211*4882a593Smuzhiyun __field(u32, flags) 1212*4882a593Smuzhiyun ), 1213*4882a593Smuzhiyun TP_fast_assign( 1214*4882a593Smuzhiyun WIPHY_ASSIGN; 1215*4882a593Smuzhiyun NETDEV_ASSIGN; 1216*4882a593Smuzhiyun if (req->bss) 1217*4882a593Smuzhiyun MAC_ASSIGN(bssid, req->bss->bssid); 1218*4882a593Smuzhiyun else 1219*4882a593Smuzhiyun eth_zero_addr(__entry->bssid); 1220*4882a593Smuzhiyun MAC_ASSIGN(prev_bssid, req->prev_bssid); 1221*4882a593Smuzhiyun __entry->use_mfp = req->use_mfp; 1222*4882a593Smuzhiyun __entry->flags = req->flags; 1223*4882a593Smuzhiyun ), 1224*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", bssid: " MAC_PR_FMT 1225*4882a593Smuzhiyun ", previous bssid: " MAC_PR_FMT ", use mfp: %s, flags: %u", 1226*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(bssid), 1227*4882a593Smuzhiyun MAC_PR_ARG(prev_bssid), BOOL_TO_STR(__entry->use_mfp), 1228*4882a593Smuzhiyun __entry->flags) 1229*4882a593Smuzhiyun ); 1230*4882a593Smuzhiyun 1231*4882a593Smuzhiyun TRACE_EVENT(rdev_deauth, 1232*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1233*4882a593Smuzhiyun struct cfg80211_deauth_request *req), 1234*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, req), 1235*4882a593Smuzhiyun TP_STRUCT__entry( 1236*4882a593Smuzhiyun WIPHY_ENTRY 1237*4882a593Smuzhiyun NETDEV_ENTRY 1238*4882a593Smuzhiyun MAC_ENTRY(bssid) 1239*4882a593Smuzhiyun __field(u16, reason_code) 1240*4882a593Smuzhiyun ), 1241*4882a593Smuzhiyun TP_fast_assign( 1242*4882a593Smuzhiyun WIPHY_ASSIGN; 1243*4882a593Smuzhiyun NETDEV_ASSIGN; 1244*4882a593Smuzhiyun MAC_ASSIGN(bssid, req->bssid); 1245*4882a593Smuzhiyun __entry->reason_code = req->reason_code; 1246*4882a593Smuzhiyun ), 1247*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", bssid: " MAC_PR_FMT ", reason: %u", 1248*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(bssid), 1249*4882a593Smuzhiyun __entry->reason_code) 1250*4882a593Smuzhiyun ); 1251*4882a593Smuzhiyun 1252*4882a593Smuzhiyun TRACE_EVENT(rdev_disassoc, 1253*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1254*4882a593Smuzhiyun struct cfg80211_disassoc_request *req), 1255*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, req), 1256*4882a593Smuzhiyun TP_STRUCT__entry( 1257*4882a593Smuzhiyun WIPHY_ENTRY 1258*4882a593Smuzhiyun NETDEV_ENTRY 1259*4882a593Smuzhiyun MAC_ENTRY(bssid) 1260*4882a593Smuzhiyun __field(u16, reason_code) 1261*4882a593Smuzhiyun __field(bool, local_state_change) 1262*4882a593Smuzhiyun ), 1263*4882a593Smuzhiyun TP_fast_assign( 1264*4882a593Smuzhiyun WIPHY_ASSIGN; 1265*4882a593Smuzhiyun NETDEV_ASSIGN; 1266*4882a593Smuzhiyun if (req->bss) 1267*4882a593Smuzhiyun MAC_ASSIGN(bssid, req->bss->bssid); 1268*4882a593Smuzhiyun else 1269*4882a593Smuzhiyun eth_zero_addr(__entry->bssid); 1270*4882a593Smuzhiyun __entry->reason_code = req->reason_code; 1271*4882a593Smuzhiyun __entry->local_state_change = req->local_state_change; 1272*4882a593Smuzhiyun ), 1273*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", bssid: " MAC_PR_FMT 1274*4882a593Smuzhiyun ", reason: %u, local state change: %s", 1275*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(bssid), 1276*4882a593Smuzhiyun __entry->reason_code, 1277*4882a593Smuzhiyun BOOL_TO_STR(__entry->local_state_change)) 1278*4882a593Smuzhiyun ); 1279*4882a593Smuzhiyun 1280*4882a593Smuzhiyun TRACE_EVENT(rdev_mgmt_tx_cancel_wait, 1281*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, 1282*4882a593Smuzhiyun struct wireless_dev *wdev, u64 cookie), 1283*4882a593Smuzhiyun TP_ARGS(wiphy, wdev, cookie), 1284*4882a593Smuzhiyun TP_STRUCT__entry( 1285*4882a593Smuzhiyun WIPHY_ENTRY 1286*4882a593Smuzhiyun WDEV_ENTRY 1287*4882a593Smuzhiyun __field(u64, cookie) 1288*4882a593Smuzhiyun ), 1289*4882a593Smuzhiyun TP_fast_assign( 1290*4882a593Smuzhiyun WIPHY_ASSIGN; 1291*4882a593Smuzhiyun WDEV_ASSIGN; 1292*4882a593Smuzhiyun __entry->cookie = cookie; 1293*4882a593Smuzhiyun ), 1294*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " WDEV_PR_FMT ", cookie: %llu ", 1295*4882a593Smuzhiyun WIPHY_PR_ARG, WDEV_PR_ARG, __entry->cookie) 1296*4882a593Smuzhiyun ); 1297*4882a593Smuzhiyun 1298*4882a593Smuzhiyun TRACE_EVENT(rdev_set_power_mgmt, 1299*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1300*4882a593Smuzhiyun bool enabled, int timeout), 1301*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, enabled, timeout), 1302*4882a593Smuzhiyun TP_STRUCT__entry( 1303*4882a593Smuzhiyun WIPHY_ENTRY 1304*4882a593Smuzhiyun NETDEV_ENTRY 1305*4882a593Smuzhiyun __field(bool, enabled) 1306*4882a593Smuzhiyun __field(int, timeout) 1307*4882a593Smuzhiyun ), 1308*4882a593Smuzhiyun TP_fast_assign( 1309*4882a593Smuzhiyun WIPHY_ASSIGN; 1310*4882a593Smuzhiyun NETDEV_ASSIGN; 1311*4882a593Smuzhiyun __entry->enabled = enabled; 1312*4882a593Smuzhiyun __entry->timeout = timeout; 1313*4882a593Smuzhiyun ), 1314*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", %senabled, timeout: %d ", 1315*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, 1316*4882a593Smuzhiyun __entry->enabled ? "" : "not ", __entry->timeout) 1317*4882a593Smuzhiyun ); 1318*4882a593Smuzhiyun 1319*4882a593Smuzhiyun TRACE_EVENT(rdev_connect, 1320*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1321*4882a593Smuzhiyun struct cfg80211_connect_params *sme), 1322*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, sme), 1323*4882a593Smuzhiyun TP_STRUCT__entry( 1324*4882a593Smuzhiyun WIPHY_ENTRY 1325*4882a593Smuzhiyun NETDEV_ENTRY 1326*4882a593Smuzhiyun MAC_ENTRY(bssid) 1327*4882a593Smuzhiyun __array(char, ssid, IEEE80211_MAX_SSID_LEN + 1) 1328*4882a593Smuzhiyun __field(enum nl80211_auth_type, auth_type) 1329*4882a593Smuzhiyun __field(bool, privacy) 1330*4882a593Smuzhiyun __field(u32, wpa_versions) 1331*4882a593Smuzhiyun __field(u32, flags) 1332*4882a593Smuzhiyun MAC_ENTRY(prev_bssid) 1333*4882a593Smuzhiyun ), 1334*4882a593Smuzhiyun TP_fast_assign( 1335*4882a593Smuzhiyun WIPHY_ASSIGN; 1336*4882a593Smuzhiyun NETDEV_ASSIGN; 1337*4882a593Smuzhiyun MAC_ASSIGN(bssid, sme->bssid); 1338*4882a593Smuzhiyun memset(__entry->ssid, 0, IEEE80211_MAX_SSID_LEN + 1); 1339*4882a593Smuzhiyun memcpy(__entry->ssid, sme->ssid, sme->ssid_len); 1340*4882a593Smuzhiyun __entry->auth_type = sme->auth_type; 1341*4882a593Smuzhiyun __entry->privacy = sme->privacy; 1342*4882a593Smuzhiyun __entry->wpa_versions = sme->crypto.wpa_versions; 1343*4882a593Smuzhiyun __entry->flags = sme->flags; 1344*4882a593Smuzhiyun MAC_ASSIGN(prev_bssid, sme->prev_bssid); 1345*4882a593Smuzhiyun ), 1346*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", bssid: " MAC_PR_FMT 1347*4882a593Smuzhiyun ", ssid: %s, auth type: %d, privacy: %s, wpa versions: %u, " 1348*4882a593Smuzhiyun "flags: %u, previous bssid: " MAC_PR_FMT, 1349*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(bssid), __entry->ssid, 1350*4882a593Smuzhiyun __entry->auth_type, BOOL_TO_STR(__entry->privacy), 1351*4882a593Smuzhiyun __entry->wpa_versions, __entry->flags, MAC_PR_ARG(prev_bssid)) 1352*4882a593Smuzhiyun ); 1353*4882a593Smuzhiyun 1354*4882a593Smuzhiyun TRACE_EVENT(rdev_update_connect_params, 1355*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1356*4882a593Smuzhiyun struct cfg80211_connect_params *sme, u32 changed), 1357*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, sme, changed), 1358*4882a593Smuzhiyun TP_STRUCT__entry( 1359*4882a593Smuzhiyun WIPHY_ENTRY 1360*4882a593Smuzhiyun NETDEV_ENTRY 1361*4882a593Smuzhiyun __field(u32, changed) 1362*4882a593Smuzhiyun ), 1363*4882a593Smuzhiyun TP_fast_assign( 1364*4882a593Smuzhiyun WIPHY_ASSIGN; 1365*4882a593Smuzhiyun NETDEV_ASSIGN; 1366*4882a593Smuzhiyun __entry->changed = changed; 1367*4882a593Smuzhiyun ), 1368*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", parameters changed: %u", 1369*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->changed) 1370*4882a593Smuzhiyun ); 1371*4882a593Smuzhiyun 1372*4882a593Smuzhiyun TRACE_EVENT(rdev_set_cqm_rssi_config, 1373*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, 1374*4882a593Smuzhiyun struct net_device *netdev, s32 rssi_thold, 1375*4882a593Smuzhiyun u32 rssi_hyst), 1376*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, rssi_thold, rssi_hyst), 1377*4882a593Smuzhiyun TP_STRUCT__entry( 1378*4882a593Smuzhiyun WIPHY_ENTRY 1379*4882a593Smuzhiyun NETDEV_ENTRY 1380*4882a593Smuzhiyun __field(s32, rssi_thold) 1381*4882a593Smuzhiyun __field(u32, rssi_hyst) 1382*4882a593Smuzhiyun ), 1383*4882a593Smuzhiyun TP_fast_assign( 1384*4882a593Smuzhiyun WIPHY_ASSIGN; 1385*4882a593Smuzhiyun NETDEV_ASSIGN; 1386*4882a593Smuzhiyun __entry->rssi_thold = rssi_thold; 1387*4882a593Smuzhiyun __entry->rssi_hyst = rssi_hyst; 1388*4882a593Smuzhiyun ), 1389*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT 1390*4882a593Smuzhiyun ", rssi_thold: %d, rssi_hyst: %u ", 1391*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, 1392*4882a593Smuzhiyun __entry->rssi_thold, __entry->rssi_hyst) 1393*4882a593Smuzhiyun ); 1394*4882a593Smuzhiyun 1395*4882a593Smuzhiyun TRACE_EVENT(rdev_set_cqm_rssi_range_config, 1396*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, 1397*4882a593Smuzhiyun struct net_device *netdev, s32 low, s32 high), 1398*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, low, high), 1399*4882a593Smuzhiyun TP_STRUCT__entry( 1400*4882a593Smuzhiyun WIPHY_ENTRY 1401*4882a593Smuzhiyun NETDEV_ENTRY 1402*4882a593Smuzhiyun __field(s32, rssi_low) 1403*4882a593Smuzhiyun __field(s32, rssi_high) 1404*4882a593Smuzhiyun ), 1405*4882a593Smuzhiyun TP_fast_assign( 1406*4882a593Smuzhiyun WIPHY_ASSIGN; 1407*4882a593Smuzhiyun NETDEV_ASSIGN; 1408*4882a593Smuzhiyun __entry->rssi_low = low; 1409*4882a593Smuzhiyun __entry->rssi_high = high; 1410*4882a593Smuzhiyun ), 1411*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT 1412*4882a593Smuzhiyun ", range: %d - %d ", 1413*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, 1414*4882a593Smuzhiyun __entry->rssi_low, __entry->rssi_high) 1415*4882a593Smuzhiyun ); 1416*4882a593Smuzhiyun 1417*4882a593Smuzhiyun TRACE_EVENT(rdev_set_cqm_txe_config, 1418*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, u32 rate, 1419*4882a593Smuzhiyun u32 pkts, u32 intvl), 1420*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, rate, pkts, intvl), 1421*4882a593Smuzhiyun TP_STRUCT__entry( 1422*4882a593Smuzhiyun WIPHY_ENTRY 1423*4882a593Smuzhiyun NETDEV_ENTRY 1424*4882a593Smuzhiyun __field(u32, rate) 1425*4882a593Smuzhiyun __field(u32, pkts) 1426*4882a593Smuzhiyun __field(u32, intvl) 1427*4882a593Smuzhiyun ), 1428*4882a593Smuzhiyun TP_fast_assign( 1429*4882a593Smuzhiyun WIPHY_ASSIGN; 1430*4882a593Smuzhiyun NETDEV_ASSIGN; 1431*4882a593Smuzhiyun __entry->rate = rate; 1432*4882a593Smuzhiyun __entry->pkts = pkts; 1433*4882a593Smuzhiyun __entry->intvl = intvl; 1434*4882a593Smuzhiyun ), 1435*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", rate: %u, packets: %u, interval: %u", 1436*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->rate, __entry->pkts, 1437*4882a593Smuzhiyun __entry->intvl) 1438*4882a593Smuzhiyun ); 1439*4882a593Smuzhiyun 1440*4882a593Smuzhiyun TRACE_EVENT(rdev_disconnect, 1441*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1442*4882a593Smuzhiyun u16 reason_code), 1443*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, reason_code), 1444*4882a593Smuzhiyun TP_STRUCT__entry( 1445*4882a593Smuzhiyun WIPHY_ENTRY 1446*4882a593Smuzhiyun NETDEV_ENTRY 1447*4882a593Smuzhiyun __field(u16, reason_code) 1448*4882a593Smuzhiyun ), 1449*4882a593Smuzhiyun TP_fast_assign( 1450*4882a593Smuzhiyun WIPHY_ASSIGN; 1451*4882a593Smuzhiyun NETDEV_ASSIGN; 1452*4882a593Smuzhiyun __entry->reason_code = reason_code; 1453*4882a593Smuzhiyun ), 1454*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", reason code: %u", WIPHY_PR_ARG, 1455*4882a593Smuzhiyun NETDEV_PR_ARG, __entry->reason_code) 1456*4882a593Smuzhiyun ); 1457*4882a593Smuzhiyun 1458*4882a593Smuzhiyun TRACE_EVENT(rdev_join_ibss, 1459*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1460*4882a593Smuzhiyun struct cfg80211_ibss_params *params), 1461*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, params), 1462*4882a593Smuzhiyun TP_STRUCT__entry( 1463*4882a593Smuzhiyun WIPHY_ENTRY 1464*4882a593Smuzhiyun NETDEV_ENTRY 1465*4882a593Smuzhiyun MAC_ENTRY(bssid) 1466*4882a593Smuzhiyun __array(char, ssid, IEEE80211_MAX_SSID_LEN + 1) 1467*4882a593Smuzhiyun ), 1468*4882a593Smuzhiyun TP_fast_assign( 1469*4882a593Smuzhiyun WIPHY_ASSIGN; 1470*4882a593Smuzhiyun NETDEV_ASSIGN; 1471*4882a593Smuzhiyun MAC_ASSIGN(bssid, params->bssid); 1472*4882a593Smuzhiyun memset(__entry->ssid, 0, IEEE80211_MAX_SSID_LEN + 1); 1473*4882a593Smuzhiyun memcpy(__entry->ssid, params->ssid, params->ssid_len); 1474*4882a593Smuzhiyun ), 1475*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", bssid: " MAC_PR_FMT ", ssid: %s", 1476*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(bssid), __entry->ssid) 1477*4882a593Smuzhiyun ); 1478*4882a593Smuzhiyun 1479*4882a593Smuzhiyun TRACE_EVENT(rdev_join_ocb, 1480*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1481*4882a593Smuzhiyun const struct ocb_setup *setup), 1482*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, setup), 1483*4882a593Smuzhiyun TP_STRUCT__entry( 1484*4882a593Smuzhiyun WIPHY_ENTRY 1485*4882a593Smuzhiyun NETDEV_ENTRY 1486*4882a593Smuzhiyun ), 1487*4882a593Smuzhiyun TP_fast_assign( 1488*4882a593Smuzhiyun WIPHY_ASSIGN; 1489*4882a593Smuzhiyun NETDEV_ASSIGN; 1490*4882a593Smuzhiyun ), 1491*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT, 1492*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG) 1493*4882a593Smuzhiyun ); 1494*4882a593Smuzhiyun 1495*4882a593Smuzhiyun TRACE_EVENT(rdev_set_wiphy_params, 1496*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, u32 changed), 1497*4882a593Smuzhiyun TP_ARGS(wiphy, changed), 1498*4882a593Smuzhiyun TP_STRUCT__entry( 1499*4882a593Smuzhiyun WIPHY_ENTRY 1500*4882a593Smuzhiyun __field(u32, changed) 1501*4882a593Smuzhiyun ), 1502*4882a593Smuzhiyun TP_fast_assign( 1503*4882a593Smuzhiyun WIPHY_ASSIGN; 1504*4882a593Smuzhiyun __entry->changed = changed; 1505*4882a593Smuzhiyun ), 1506*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", changed: %u", 1507*4882a593Smuzhiyun WIPHY_PR_ARG, __entry->changed) 1508*4882a593Smuzhiyun ); 1509*4882a593Smuzhiyun 1510*4882a593Smuzhiyun DEFINE_EVENT(wiphy_wdev_evt, rdev_get_tx_power, 1511*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev), 1512*4882a593Smuzhiyun TP_ARGS(wiphy, wdev) 1513*4882a593Smuzhiyun ); 1514*4882a593Smuzhiyun 1515*4882a593Smuzhiyun TRACE_EVENT(rdev_set_tx_power, 1516*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev, 1517*4882a593Smuzhiyun enum nl80211_tx_power_setting type, int mbm), 1518*4882a593Smuzhiyun TP_ARGS(wiphy, wdev, type, mbm), 1519*4882a593Smuzhiyun TP_STRUCT__entry( 1520*4882a593Smuzhiyun WIPHY_ENTRY 1521*4882a593Smuzhiyun WDEV_ENTRY 1522*4882a593Smuzhiyun __field(enum nl80211_tx_power_setting, type) 1523*4882a593Smuzhiyun __field(int, mbm) 1524*4882a593Smuzhiyun ), 1525*4882a593Smuzhiyun TP_fast_assign( 1526*4882a593Smuzhiyun WIPHY_ASSIGN; 1527*4882a593Smuzhiyun WDEV_ASSIGN; 1528*4882a593Smuzhiyun __entry->type = type; 1529*4882a593Smuzhiyun __entry->mbm = mbm; 1530*4882a593Smuzhiyun ), 1531*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " WDEV_PR_FMT ", type: %u, mbm: %d", 1532*4882a593Smuzhiyun WIPHY_PR_ARG, WDEV_PR_ARG,__entry->type, __entry->mbm) 1533*4882a593Smuzhiyun ); 1534*4882a593Smuzhiyun 1535*4882a593Smuzhiyun TRACE_EVENT(rdev_return_int_int, 1536*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, int func_ret, int func_fill), 1537*4882a593Smuzhiyun TP_ARGS(wiphy, func_ret, func_fill), 1538*4882a593Smuzhiyun TP_STRUCT__entry( 1539*4882a593Smuzhiyun WIPHY_ENTRY 1540*4882a593Smuzhiyun __field(int, func_ret) 1541*4882a593Smuzhiyun __field(int, func_fill) 1542*4882a593Smuzhiyun ), 1543*4882a593Smuzhiyun TP_fast_assign( 1544*4882a593Smuzhiyun WIPHY_ASSIGN; 1545*4882a593Smuzhiyun __entry->func_ret = func_ret; 1546*4882a593Smuzhiyun __entry->func_fill = func_fill; 1547*4882a593Smuzhiyun ), 1548*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", function returns: %d, function filled: %d", 1549*4882a593Smuzhiyun WIPHY_PR_ARG, __entry->func_ret, __entry->func_fill) 1550*4882a593Smuzhiyun ); 1551*4882a593Smuzhiyun 1552*4882a593Smuzhiyun #ifdef CONFIG_NL80211_TESTMODE 1553*4882a593Smuzhiyun TRACE_EVENT(rdev_testmode_cmd, 1554*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev), 1555*4882a593Smuzhiyun TP_ARGS(wiphy, wdev), 1556*4882a593Smuzhiyun TP_STRUCT__entry( 1557*4882a593Smuzhiyun WIPHY_ENTRY 1558*4882a593Smuzhiyun WDEV_ENTRY 1559*4882a593Smuzhiyun ), 1560*4882a593Smuzhiyun TP_fast_assign( 1561*4882a593Smuzhiyun WIPHY_ASSIGN; 1562*4882a593Smuzhiyun WDEV_ASSIGN; 1563*4882a593Smuzhiyun ), 1564*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT WDEV_PR_FMT, WIPHY_PR_ARG, WDEV_PR_ARG) 1565*4882a593Smuzhiyun ); 1566*4882a593Smuzhiyun 1567*4882a593Smuzhiyun TRACE_EVENT(rdev_testmode_dump, 1568*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy), 1569*4882a593Smuzhiyun TP_ARGS(wiphy), 1570*4882a593Smuzhiyun TP_STRUCT__entry( 1571*4882a593Smuzhiyun WIPHY_ENTRY 1572*4882a593Smuzhiyun ), 1573*4882a593Smuzhiyun TP_fast_assign( 1574*4882a593Smuzhiyun WIPHY_ASSIGN; 1575*4882a593Smuzhiyun ), 1576*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT, WIPHY_PR_ARG) 1577*4882a593Smuzhiyun ); 1578*4882a593Smuzhiyun #endif /* CONFIG_NL80211_TESTMODE */ 1579*4882a593Smuzhiyun 1580*4882a593Smuzhiyun TRACE_EVENT(rdev_set_bitrate_mask, 1581*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1582*4882a593Smuzhiyun const u8 *peer, const struct cfg80211_bitrate_mask *mask), 1583*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, peer, mask), 1584*4882a593Smuzhiyun TP_STRUCT__entry( 1585*4882a593Smuzhiyun WIPHY_ENTRY 1586*4882a593Smuzhiyun NETDEV_ENTRY 1587*4882a593Smuzhiyun MAC_ENTRY(peer) 1588*4882a593Smuzhiyun ), 1589*4882a593Smuzhiyun TP_fast_assign( 1590*4882a593Smuzhiyun WIPHY_ASSIGN; 1591*4882a593Smuzhiyun NETDEV_ASSIGN; 1592*4882a593Smuzhiyun MAC_ASSIGN(peer, peer); 1593*4882a593Smuzhiyun ), 1594*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", peer: " MAC_PR_FMT, 1595*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(peer)) 1596*4882a593Smuzhiyun ); 1597*4882a593Smuzhiyun 1598*4882a593Smuzhiyun TRACE_EVENT(rdev_update_mgmt_frame_registrations, 1599*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev, 1600*4882a593Smuzhiyun struct mgmt_frame_regs *upd), 1601*4882a593Smuzhiyun TP_ARGS(wiphy, wdev, upd), 1602*4882a593Smuzhiyun TP_STRUCT__entry( 1603*4882a593Smuzhiyun WIPHY_ENTRY 1604*4882a593Smuzhiyun WDEV_ENTRY 1605*4882a593Smuzhiyun __field(u16, global_stypes) 1606*4882a593Smuzhiyun __field(u16, interface_stypes) 1607*4882a593Smuzhiyun ), 1608*4882a593Smuzhiyun TP_fast_assign( 1609*4882a593Smuzhiyun WIPHY_ASSIGN; 1610*4882a593Smuzhiyun WDEV_ASSIGN; 1611*4882a593Smuzhiyun __entry->global_stypes = upd->global_stypes; 1612*4882a593Smuzhiyun __entry->interface_stypes = upd->interface_stypes; 1613*4882a593Smuzhiyun ), 1614*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " WDEV_PR_FMT ", global: 0x%.2x, intf: 0x%.2x", 1615*4882a593Smuzhiyun WIPHY_PR_ARG, WDEV_PR_ARG, 1616*4882a593Smuzhiyun __entry->global_stypes, __entry->interface_stypes) 1617*4882a593Smuzhiyun ); 1618*4882a593Smuzhiyun 1619*4882a593Smuzhiyun TRACE_EVENT(rdev_return_int_tx_rx, 1620*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, int ret, u32 tx, u32 rx), 1621*4882a593Smuzhiyun TP_ARGS(wiphy, ret, tx, rx), 1622*4882a593Smuzhiyun TP_STRUCT__entry( 1623*4882a593Smuzhiyun WIPHY_ENTRY 1624*4882a593Smuzhiyun __field(int, ret) 1625*4882a593Smuzhiyun __field(u32, tx) 1626*4882a593Smuzhiyun __field(u32, rx) 1627*4882a593Smuzhiyun ), 1628*4882a593Smuzhiyun TP_fast_assign( 1629*4882a593Smuzhiyun WIPHY_ASSIGN; 1630*4882a593Smuzhiyun __entry->ret = ret; 1631*4882a593Smuzhiyun __entry->tx = tx; 1632*4882a593Smuzhiyun __entry->rx = rx; 1633*4882a593Smuzhiyun ), 1634*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", returned %d, tx: %u, rx: %u", 1635*4882a593Smuzhiyun WIPHY_PR_ARG, __entry->ret, __entry->tx, __entry->rx) 1636*4882a593Smuzhiyun ); 1637*4882a593Smuzhiyun 1638*4882a593Smuzhiyun TRACE_EVENT(rdev_return_void_tx_rx, 1639*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, u32 tx, u32 tx_max, 1640*4882a593Smuzhiyun u32 rx, u32 rx_max), 1641*4882a593Smuzhiyun TP_ARGS(wiphy, tx, tx_max, rx, rx_max), 1642*4882a593Smuzhiyun TP_STRUCT__entry( 1643*4882a593Smuzhiyun WIPHY_ENTRY 1644*4882a593Smuzhiyun __field(u32, tx) 1645*4882a593Smuzhiyun __field(u32, tx_max) 1646*4882a593Smuzhiyun __field(u32, rx) 1647*4882a593Smuzhiyun __field(u32, rx_max) 1648*4882a593Smuzhiyun ), 1649*4882a593Smuzhiyun TP_fast_assign( 1650*4882a593Smuzhiyun WIPHY_ASSIGN; 1651*4882a593Smuzhiyun __entry->tx = tx; 1652*4882a593Smuzhiyun __entry->tx_max = tx_max; 1653*4882a593Smuzhiyun __entry->rx = rx; 1654*4882a593Smuzhiyun __entry->rx_max = rx_max; 1655*4882a593Smuzhiyun ), 1656*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", tx: %u, tx_max: %u, rx: %u, rx_max: %u ", 1657*4882a593Smuzhiyun WIPHY_PR_ARG, __entry->tx, __entry->tx_max, __entry->rx, 1658*4882a593Smuzhiyun __entry->rx_max) 1659*4882a593Smuzhiyun ); 1660*4882a593Smuzhiyun 1661*4882a593Smuzhiyun DECLARE_EVENT_CLASS(tx_rx_evt, 1662*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, u32 tx, u32 rx), 1663*4882a593Smuzhiyun TP_ARGS(wiphy, rx, tx), 1664*4882a593Smuzhiyun TP_STRUCT__entry( 1665*4882a593Smuzhiyun WIPHY_ENTRY 1666*4882a593Smuzhiyun __field(u32, tx) 1667*4882a593Smuzhiyun __field(u32, rx) 1668*4882a593Smuzhiyun ), 1669*4882a593Smuzhiyun TP_fast_assign( 1670*4882a593Smuzhiyun WIPHY_ASSIGN; 1671*4882a593Smuzhiyun __entry->tx = tx; 1672*4882a593Smuzhiyun __entry->rx = rx; 1673*4882a593Smuzhiyun ), 1674*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", tx: %u, rx: %u ", 1675*4882a593Smuzhiyun WIPHY_PR_ARG, __entry->tx, __entry->rx) 1676*4882a593Smuzhiyun ); 1677*4882a593Smuzhiyun 1678*4882a593Smuzhiyun DEFINE_EVENT(tx_rx_evt, rdev_set_antenna, 1679*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, u32 tx, u32 rx), 1680*4882a593Smuzhiyun TP_ARGS(wiphy, rx, tx) 1681*4882a593Smuzhiyun ); 1682*4882a593Smuzhiyun 1683*4882a593Smuzhiyun DECLARE_EVENT_CLASS(wiphy_netdev_id_evt, 1684*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, u64 id), 1685*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, id), 1686*4882a593Smuzhiyun TP_STRUCT__entry( 1687*4882a593Smuzhiyun WIPHY_ENTRY 1688*4882a593Smuzhiyun NETDEV_ENTRY 1689*4882a593Smuzhiyun __field(u64, id) 1690*4882a593Smuzhiyun ), 1691*4882a593Smuzhiyun TP_fast_assign( 1692*4882a593Smuzhiyun WIPHY_ASSIGN; 1693*4882a593Smuzhiyun NETDEV_ASSIGN; 1694*4882a593Smuzhiyun __entry->id = id; 1695*4882a593Smuzhiyun ), 1696*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", id: %llu", 1697*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->id) 1698*4882a593Smuzhiyun ); 1699*4882a593Smuzhiyun 1700*4882a593Smuzhiyun DEFINE_EVENT(wiphy_netdev_id_evt, rdev_sched_scan_start, 1701*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, u64 id), 1702*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, id) 1703*4882a593Smuzhiyun ); 1704*4882a593Smuzhiyun 1705*4882a593Smuzhiyun DEFINE_EVENT(wiphy_netdev_id_evt, rdev_sched_scan_stop, 1706*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, u64 id), 1707*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, id) 1708*4882a593Smuzhiyun ); 1709*4882a593Smuzhiyun 1710*4882a593Smuzhiyun TRACE_EVENT(rdev_tdls_mgmt, 1711*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1712*4882a593Smuzhiyun u8 *peer, u8 action_code, u8 dialog_token, 1713*4882a593Smuzhiyun u16 status_code, u32 peer_capability, 1714*4882a593Smuzhiyun bool initiator, const u8 *buf, size_t len), 1715*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, peer, action_code, dialog_token, status_code, 1716*4882a593Smuzhiyun peer_capability, initiator, buf, len), 1717*4882a593Smuzhiyun TP_STRUCT__entry( 1718*4882a593Smuzhiyun WIPHY_ENTRY 1719*4882a593Smuzhiyun NETDEV_ENTRY 1720*4882a593Smuzhiyun MAC_ENTRY(peer) 1721*4882a593Smuzhiyun __field(u8, action_code) 1722*4882a593Smuzhiyun __field(u8, dialog_token) 1723*4882a593Smuzhiyun __field(u16, status_code) 1724*4882a593Smuzhiyun __field(u32, peer_capability) 1725*4882a593Smuzhiyun __field(bool, initiator) 1726*4882a593Smuzhiyun __dynamic_array(u8, buf, len) 1727*4882a593Smuzhiyun ), 1728*4882a593Smuzhiyun TP_fast_assign( 1729*4882a593Smuzhiyun WIPHY_ASSIGN; 1730*4882a593Smuzhiyun NETDEV_ASSIGN; 1731*4882a593Smuzhiyun MAC_ASSIGN(peer, peer); 1732*4882a593Smuzhiyun __entry->action_code = action_code; 1733*4882a593Smuzhiyun __entry->dialog_token = dialog_token; 1734*4882a593Smuzhiyun __entry->status_code = status_code; 1735*4882a593Smuzhiyun __entry->peer_capability = peer_capability; 1736*4882a593Smuzhiyun __entry->initiator = initiator; 1737*4882a593Smuzhiyun memcpy(__get_dynamic_array(buf), buf, len); 1738*4882a593Smuzhiyun ), 1739*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", " MAC_PR_FMT ", action_code: %u, " 1740*4882a593Smuzhiyun "dialog_token: %u, status_code: %u, peer_capability: %u " 1741*4882a593Smuzhiyun "initiator: %s buf: %#.2x ", 1742*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(peer), 1743*4882a593Smuzhiyun __entry->action_code, __entry->dialog_token, 1744*4882a593Smuzhiyun __entry->status_code, __entry->peer_capability, 1745*4882a593Smuzhiyun BOOL_TO_STR(__entry->initiator), 1746*4882a593Smuzhiyun ((u8 *)__get_dynamic_array(buf))[0]) 1747*4882a593Smuzhiyun ); 1748*4882a593Smuzhiyun 1749*4882a593Smuzhiyun TRACE_EVENT(rdev_dump_survey, 1750*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, int _idx), 1751*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, _idx), 1752*4882a593Smuzhiyun TP_STRUCT__entry( 1753*4882a593Smuzhiyun WIPHY_ENTRY 1754*4882a593Smuzhiyun NETDEV_ENTRY 1755*4882a593Smuzhiyun __field(int, idx) 1756*4882a593Smuzhiyun ), 1757*4882a593Smuzhiyun TP_fast_assign( 1758*4882a593Smuzhiyun WIPHY_ASSIGN; 1759*4882a593Smuzhiyun NETDEV_ASSIGN; 1760*4882a593Smuzhiyun __entry->idx = _idx; 1761*4882a593Smuzhiyun ), 1762*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", index: %d", 1763*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->idx) 1764*4882a593Smuzhiyun ); 1765*4882a593Smuzhiyun 1766*4882a593Smuzhiyun TRACE_EVENT(rdev_return_int_survey_info, 1767*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, int ret, struct survey_info *info), 1768*4882a593Smuzhiyun TP_ARGS(wiphy, ret, info), 1769*4882a593Smuzhiyun TP_STRUCT__entry( 1770*4882a593Smuzhiyun WIPHY_ENTRY 1771*4882a593Smuzhiyun CHAN_ENTRY 1772*4882a593Smuzhiyun __field(int, ret) 1773*4882a593Smuzhiyun __field(u64, time) 1774*4882a593Smuzhiyun __field(u64, time_busy) 1775*4882a593Smuzhiyun __field(u64, time_ext_busy) 1776*4882a593Smuzhiyun __field(u64, time_rx) 1777*4882a593Smuzhiyun __field(u64, time_tx) 1778*4882a593Smuzhiyun __field(u64, time_scan) 1779*4882a593Smuzhiyun __field(u32, filled) 1780*4882a593Smuzhiyun __field(s8, noise) 1781*4882a593Smuzhiyun ), 1782*4882a593Smuzhiyun TP_fast_assign( 1783*4882a593Smuzhiyun WIPHY_ASSIGN; 1784*4882a593Smuzhiyun CHAN_ASSIGN(info->channel); 1785*4882a593Smuzhiyun __entry->ret = ret; 1786*4882a593Smuzhiyun __entry->time = info->time; 1787*4882a593Smuzhiyun __entry->time_busy = info->time_busy; 1788*4882a593Smuzhiyun __entry->time_ext_busy = info->time_ext_busy; 1789*4882a593Smuzhiyun __entry->time_rx = info->time_rx; 1790*4882a593Smuzhiyun __entry->time_tx = info->time_tx; 1791*4882a593Smuzhiyun __entry->time_scan = info->time_scan; 1792*4882a593Smuzhiyun __entry->filled = info->filled; 1793*4882a593Smuzhiyun __entry->noise = info->noise; 1794*4882a593Smuzhiyun ), 1795*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", returned: %d, " CHAN_PR_FMT 1796*4882a593Smuzhiyun ", channel time: %llu, channel time busy: %llu, " 1797*4882a593Smuzhiyun "channel time extension busy: %llu, channel time rx: %llu, " 1798*4882a593Smuzhiyun "channel time tx: %llu, scan time: %llu, filled: %u, noise: %d", 1799*4882a593Smuzhiyun WIPHY_PR_ARG, __entry->ret, CHAN_PR_ARG, 1800*4882a593Smuzhiyun __entry->time, __entry->time_busy, 1801*4882a593Smuzhiyun __entry->time_ext_busy, __entry->time_rx, 1802*4882a593Smuzhiyun __entry->time_tx, __entry->time_scan, 1803*4882a593Smuzhiyun __entry->filled, __entry->noise) 1804*4882a593Smuzhiyun ); 1805*4882a593Smuzhiyun 1806*4882a593Smuzhiyun TRACE_EVENT(rdev_tdls_oper, 1807*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1808*4882a593Smuzhiyun u8 *peer, enum nl80211_tdls_operation oper), 1809*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, peer, oper), 1810*4882a593Smuzhiyun TP_STRUCT__entry( 1811*4882a593Smuzhiyun WIPHY_ENTRY 1812*4882a593Smuzhiyun NETDEV_ENTRY 1813*4882a593Smuzhiyun MAC_ENTRY(peer) 1814*4882a593Smuzhiyun __field(enum nl80211_tdls_operation, oper) 1815*4882a593Smuzhiyun ), 1816*4882a593Smuzhiyun TP_fast_assign( 1817*4882a593Smuzhiyun WIPHY_ASSIGN; 1818*4882a593Smuzhiyun NETDEV_ASSIGN; 1819*4882a593Smuzhiyun MAC_ASSIGN(peer, peer); 1820*4882a593Smuzhiyun __entry->oper = oper; 1821*4882a593Smuzhiyun ), 1822*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", " MAC_PR_FMT ", oper: %d", 1823*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(peer), __entry->oper) 1824*4882a593Smuzhiyun ); 1825*4882a593Smuzhiyun 1826*4882a593Smuzhiyun DECLARE_EVENT_CLASS(rdev_pmksa, 1827*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1828*4882a593Smuzhiyun struct cfg80211_pmksa *pmksa), 1829*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, pmksa), 1830*4882a593Smuzhiyun TP_STRUCT__entry( 1831*4882a593Smuzhiyun WIPHY_ENTRY 1832*4882a593Smuzhiyun NETDEV_ENTRY 1833*4882a593Smuzhiyun MAC_ENTRY(bssid) 1834*4882a593Smuzhiyun ), 1835*4882a593Smuzhiyun TP_fast_assign( 1836*4882a593Smuzhiyun WIPHY_ASSIGN; 1837*4882a593Smuzhiyun NETDEV_ASSIGN; 1838*4882a593Smuzhiyun MAC_ASSIGN(bssid, pmksa->bssid); 1839*4882a593Smuzhiyun ), 1840*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", bssid: " MAC_PR_FMT, 1841*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(bssid)) 1842*4882a593Smuzhiyun ); 1843*4882a593Smuzhiyun 1844*4882a593Smuzhiyun TRACE_EVENT(rdev_probe_client, 1845*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1846*4882a593Smuzhiyun const u8 *peer), 1847*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, peer), 1848*4882a593Smuzhiyun TP_STRUCT__entry( 1849*4882a593Smuzhiyun WIPHY_ENTRY 1850*4882a593Smuzhiyun NETDEV_ENTRY 1851*4882a593Smuzhiyun MAC_ENTRY(peer) 1852*4882a593Smuzhiyun ), 1853*4882a593Smuzhiyun TP_fast_assign( 1854*4882a593Smuzhiyun WIPHY_ASSIGN; 1855*4882a593Smuzhiyun NETDEV_ASSIGN; 1856*4882a593Smuzhiyun MAC_ASSIGN(peer, peer); 1857*4882a593Smuzhiyun ), 1858*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", " MAC_PR_FMT, 1859*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(peer)) 1860*4882a593Smuzhiyun ); 1861*4882a593Smuzhiyun 1862*4882a593Smuzhiyun DEFINE_EVENT(rdev_pmksa, rdev_set_pmksa, 1863*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1864*4882a593Smuzhiyun struct cfg80211_pmksa *pmksa), 1865*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, pmksa) 1866*4882a593Smuzhiyun ); 1867*4882a593Smuzhiyun 1868*4882a593Smuzhiyun DEFINE_EVENT(rdev_pmksa, rdev_del_pmksa, 1869*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1870*4882a593Smuzhiyun struct cfg80211_pmksa *pmksa), 1871*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, pmksa) 1872*4882a593Smuzhiyun ); 1873*4882a593Smuzhiyun 1874*4882a593Smuzhiyun TRACE_EVENT(rdev_remain_on_channel, 1875*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev, 1876*4882a593Smuzhiyun struct ieee80211_channel *chan, 1877*4882a593Smuzhiyun unsigned int duration), 1878*4882a593Smuzhiyun TP_ARGS(wiphy, wdev, chan, duration), 1879*4882a593Smuzhiyun TP_STRUCT__entry( 1880*4882a593Smuzhiyun WIPHY_ENTRY 1881*4882a593Smuzhiyun WDEV_ENTRY 1882*4882a593Smuzhiyun CHAN_ENTRY 1883*4882a593Smuzhiyun __field(unsigned int, duration) 1884*4882a593Smuzhiyun ), 1885*4882a593Smuzhiyun TP_fast_assign( 1886*4882a593Smuzhiyun WIPHY_ASSIGN; 1887*4882a593Smuzhiyun WDEV_ASSIGN; 1888*4882a593Smuzhiyun CHAN_ASSIGN(chan); 1889*4882a593Smuzhiyun __entry->duration = duration; 1890*4882a593Smuzhiyun ), 1891*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " WDEV_PR_FMT ", " CHAN_PR_FMT ", duration: %u", 1892*4882a593Smuzhiyun WIPHY_PR_ARG, WDEV_PR_ARG, CHAN_PR_ARG, __entry->duration) 1893*4882a593Smuzhiyun ); 1894*4882a593Smuzhiyun 1895*4882a593Smuzhiyun TRACE_EVENT(rdev_return_int_cookie, 1896*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, int ret, u64 cookie), 1897*4882a593Smuzhiyun TP_ARGS(wiphy, ret, cookie), 1898*4882a593Smuzhiyun TP_STRUCT__entry( 1899*4882a593Smuzhiyun WIPHY_ENTRY 1900*4882a593Smuzhiyun __field(int, ret) 1901*4882a593Smuzhiyun __field(u64, cookie) 1902*4882a593Smuzhiyun ), 1903*4882a593Smuzhiyun TP_fast_assign( 1904*4882a593Smuzhiyun WIPHY_ASSIGN; 1905*4882a593Smuzhiyun __entry->ret = ret; 1906*4882a593Smuzhiyun __entry->cookie = cookie; 1907*4882a593Smuzhiyun ), 1908*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", returned %d, cookie: %llu", 1909*4882a593Smuzhiyun WIPHY_PR_ARG, __entry->ret, __entry->cookie) 1910*4882a593Smuzhiyun ); 1911*4882a593Smuzhiyun 1912*4882a593Smuzhiyun TRACE_EVENT(rdev_cancel_remain_on_channel, 1913*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie), 1914*4882a593Smuzhiyun TP_ARGS(wiphy, wdev, cookie), 1915*4882a593Smuzhiyun TP_STRUCT__entry( 1916*4882a593Smuzhiyun WIPHY_ENTRY 1917*4882a593Smuzhiyun WDEV_ENTRY 1918*4882a593Smuzhiyun __field(u64, cookie) 1919*4882a593Smuzhiyun ), 1920*4882a593Smuzhiyun TP_fast_assign( 1921*4882a593Smuzhiyun WIPHY_ASSIGN; 1922*4882a593Smuzhiyun WDEV_ASSIGN; 1923*4882a593Smuzhiyun __entry->cookie = cookie; 1924*4882a593Smuzhiyun ), 1925*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " WDEV_PR_FMT ", cookie: %llu", 1926*4882a593Smuzhiyun WIPHY_PR_ARG, WDEV_PR_ARG, __entry->cookie) 1927*4882a593Smuzhiyun ); 1928*4882a593Smuzhiyun 1929*4882a593Smuzhiyun TRACE_EVENT(rdev_mgmt_tx, 1930*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev, 1931*4882a593Smuzhiyun struct cfg80211_mgmt_tx_params *params), 1932*4882a593Smuzhiyun TP_ARGS(wiphy, wdev, params), 1933*4882a593Smuzhiyun TP_STRUCT__entry( 1934*4882a593Smuzhiyun WIPHY_ENTRY 1935*4882a593Smuzhiyun WDEV_ENTRY 1936*4882a593Smuzhiyun CHAN_ENTRY 1937*4882a593Smuzhiyun __field(bool, offchan) 1938*4882a593Smuzhiyun __field(unsigned int, wait) 1939*4882a593Smuzhiyun __field(bool, no_cck) 1940*4882a593Smuzhiyun __field(bool, dont_wait_for_ack) 1941*4882a593Smuzhiyun ), 1942*4882a593Smuzhiyun TP_fast_assign( 1943*4882a593Smuzhiyun WIPHY_ASSIGN; 1944*4882a593Smuzhiyun WDEV_ASSIGN; 1945*4882a593Smuzhiyun CHAN_ASSIGN(params->chan); 1946*4882a593Smuzhiyun __entry->offchan = params->offchan; 1947*4882a593Smuzhiyun __entry->wait = params->wait; 1948*4882a593Smuzhiyun __entry->no_cck = params->no_cck; 1949*4882a593Smuzhiyun __entry->dont_wait_for_ack = params->dont_wait_for_ack; 1950*4882a593Smuzhiyun ), 1951*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " WDEV_PR_FMT ", " CHAN_PR_FMT ", offchan: %s," 1952*4882a593Smuzhiyun " wait: %u, no cck: %s, dont wait for ack: %s", 1953*4882a593Smuzhiyun WIPHY_PR_ARG, WDEV_PR_ARG, CHAN_PR_ARG, 1954*4882a593Smuzhiyun BOOL_TO_STR(__entry->offchan), __entry->wait, 1955*4882a593Smuzhiyun BOOL_TO_STR(__entry->no_cck), 1956*4882a593Smuzhiyun BOOL_TO_STR(__entry->dont_wait_for_ack)) 1957*4882a593Smuzhiyun ); 1958*4882a593Smuzhiyun 1959*4882a593Smuzhiyun TRACE_EVENT(rdev_tx_control_port, 1960*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1961*4882a593Smuzhiyun const u8 *buf, size_t len, const u8 *dest, __be16 proto, 1962*4882a593Smuzhiyun bool unencrypted), 1963*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, buf, len, dest, proto, unencrypted), 1964*4882a593Smuzhiyun TP_STRUCT__entry( 1965*4882a593Smuzhiyun WIPHY_ENTRY 1966*4882a593Smuzhiyun NETDEV_ENTRY 1967*4882a593Smuzhiyun MAC_ENTRY(dest) 1968*4882a593Smuzhiyun __field(__be16, proto) 1969*4882a593Smuzhiyun __field(bool, unencrypted) 1970*4882a593Smuzhiyun ), 1971*4882a593Smuzhiyun TP_fast_assign( 1972*4882a593Smuzhiyun WIPHY_ASSIGN; 1973*4882a593Smuzhiyun NETDEV_ASSIGN; 1974*4882a593Smuzhiyun MAC_ASSIGN(dest, dest); 1975*4882a593Smuzhiyun __entry->proto = proto; 1976*4882a593Smuzhiyun __entry->unencrypted = unencrypted; 1977*4882a593Smuzhiyun ), 1978*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", " MAC_PR_FMT "," 1979*4882a593Smuzhiyun " proto: 0x%x, unencrypted: %s", 1980*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(dest), 1981*4882a593Smuzhiyun be16_to_cpu(__entry->proto), 1982*4882a593Smuzhiyun BOOL_TO_STR(__entry->unencrypted)) 1983*4882a593Smuzhiyun ); 1984*4882a593Smuzhiyun 1985*4882a593Smuzhiyun TRACE_EVENT(rdev_set_noack_map, 1986*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 1987*4882a593Smuzhiyun u16 noack_map), 1988*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, noack_map), 1989*4882a593Smuzhiyun TP_STRUCT__entry( 1990*4882a593Smuzhiyun WIPHY_ENTRY 1991*4882a593Smuzhiyun NETDEV_ENTRY 1992*4882a593Smuzhiyun __field(u16, noack_map) 1993*4882a593Smuzhiyun ), 1994*4882a593Smuzhiyun TP_fast_assign( 1995*4882a593Smuzhiyun WIPHY_ASSIGN; 1996*4882a593Smuzhiyun NETDEV_ASSIGN; 1997*4882a593Smuzhiyun __entry->noack_map = noack_map; 1998*4882a593Smuzhiyun ), 1999*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", noack_map: %u", 2000*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->noack_map) 2001*4882a593Smuzhiyun ); 2002*4882a593Smuzhiyun 2003*4882a593Smuzhiyun DEFINE_EVENT(wiphy_wdev_evt, rdev_get_channel, 2004*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev), 2005*4882a593Smuzhiyun TP_ARGS(wiphy, wdev) 2006*4882a593Smuzhiyun ); 2007*4882a593Smuzhiyun 2008*4882a593Smuzhiyun TRACE_EVENT(rdev_return_chandef, 2009*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, int ret, 2010*4882a593Smuzhiyun struct cfg80211_chan_def *chandef), 2011*4882a593Smuzhiyun TP_ARGS(wiphy, ret, chandef), 2012*4882a593Smuzhiyun TP_STRUCT__entry( 2013*4882a593Smuzhiyun WIPHY_ENTRY 2014*4882a593Smuzhiyun __field(int, ret) 2015*4882a593Smuzhiyun CHAN_DEF_ENTRY 2016*4882a593Smuzhiyun ), 2017*4882a593Smuzhiyun TP_fast_assign( 2018*4882a593Smuzhiyun WIPHY_ASSIGN; 2019*4882a593Smuzhiyun if (ret == 0) 2020*4882a593Smuzhiyun CHAN_DEF_ASSIGN(chandef); 2021*4882a593Smuzhiyun else 2022*4882a593Smuzhiyun CHAN_DEF_ASSIGN((struct cfg80211_chan_def *)NULL); 2023*4882a593Smuzhiyun __entry->ret = ret; 2024*4882a593Smuzhiyun ), 2025*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " CHAN_DEF_PR_FMT ", ret: %d", 2026*4882a593Smuzhiyun WIPHY_PR_ARG, CHAN_DEF_PR_ARG, __entry->ret) 2027*4882a593Smuzhiyun ); 2028*4882a593Smuzhiyun 2029*4882a593Smuzhiyun DEFINE_EVENT(wiphy_wdev_evt, rdev_start_p2p_device, 2030*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev), 2031*4882a593Smuzhiyun TP_ARGS(wiphy, wdev) 2032*4882a593Smuzhiyun ); 2033*4882a593Smuzhiyun 2034*4882a593Smuzhiyun DEFINE_EVENT(wiphy_wdev_evt, rdev_stop_p2p_device, 2035*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev), 2036*4882a593Smuzhiyun TP_ARGS(wiphy, wdev) 2037*4882a593Smuzhiyun ); 2038*4882a593Smuzhiyun 2039*4882a593Smuzhiyun TRACE_EVENT(rdev_start_nan, 2040*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev, 2041*4882a593Smuzhiyun struct cfg80211_nan_conf *conf), 2042*4882a593Smuzhiyun TP_ARGS(wiphy, wdev, conf), 2043*4882a593Smuzhiyun TP_STRUCT__entry( 2044*4882a593Smuzhiyun WIPHY_ENTRY 2045*4882a593Smuzhiyun WDEV_ENTRY 2046*4882a593Smuzhiyun __field(u8, master_pref) 2047*4882a593Smuzhiyun __field(u8, bands) 2048*4882a593Smuzhiyun ), 2049*4882a593Smuzhiyun TP_fast_assign( 2050*4882a593Smuzhiyun WIPHY_ASSIGN; 2051*4882a593Smuzhiyun WDEV_ASSIGN; 2052*4882a593Smuzhiyun __entry->master_pref = conf->master_pref; 2053*4882a593Smuzhiyun __entry->bands = conf->bands; 2054*4882a593Smuzhiyun ), 2055*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " WDEV_PR_FMT 2056*4882a593Smuzhiyun ", master preference: %u, bands: 0x%0x", 2057*4882a593Smuzhiyun WIPHY_PR_ARG, WDEV_PR_ARG, __entry->master_pref, 2058*4882a593Smuzhiyun __entry->bands) 2059*4882a593Smuzhiyun ); 2060*4882a593Smuzhiyun 2061*4882a593Smuzhiyun TRACE_EVENT(rdev_nan_change_conf, 2062*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev, 2063*4882a593Smuzhiyun struct cfg80211_nan_conf *conf, u32 changes), 2064*4882a593Smuzhiyun TP_ARGS(wiphy, wdev, conf, changes), 2065*4882a593Smuzhiyun TP_STRUCT__entry( 2066*4882a593Smuzhiyun WIPHY_ENTRY 2067*4882a593Smuzhiyun WDEV_ENTRY 2068*4882a593Smuzhiyun __field(u8, master_pref) 2069*4882a593Smuzhiyun __field(u8, bands) 2070*4882a593Smuzhiyun __field(u32, changes) 2071*4882a593Smuzhiyun ), 2072*4882a593Smuzhiyun TP_fast_assign( 2073*4882a593Smuzhiyun WIPHY_ASSIGN; 2074*4882a593Smuzhiyun WDEV_ASSIGN; 2075*4882a593Smuzhiyun __entry->master_pref = conf->master_pref; 2076*4882a593Smuzhiyun __entry->bands = conf->bands; 2077*4882a593Smuzhiyun __entry->changes = changes; 2078*4882a593Smuzhiyun ), 2079*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " WDEV_PR_FMT 2080*4882a593Smuzhiyun ", master preference: %u, bands: 0x%0x, changes: %x", 2081*4882a593Smuzhiyun WIPHY_PR_ARG, WDEV_PR_ARG, __entry->master_pref, 2082*4882a593Smuzhiyun __entry->bands, __entry->changes) 2083*4882a593Smuzhiyun ); 2084*4882a593Smuzhiyun 2085*4882a593Smuzhiyun DEFINE_EVENT(wiphy_wdev_evt, rdev_stop_nan, 2086*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev), 2087*4882a593Smuzhiyun TP_ARGS(wiphy, wdev) 2088*4882a593Smuzhiyun ); 2089*4882a593Smuzhiyun 2090*4882a593Smuzhiyun TRACE_EVENT(rdev_add_nan_func, 2091*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev, 2092*4882a593Smuzhiyun const struct cfg80211_nan_func *func), 2093*4882a593Smuzhiyun TP_ARGS(wiphy, wdev, func), 2094*4882a593Smuzhiyun TP_STRUCT__entry( 2095*4882a593Smuzhiyun WIPHY_ENTRY 2096*4882a593Smuzhiyun WDEV_ENTRY 2097*4882a593Smuzhiyun __field(u8, func_type) 2098*4882a593Smuzhiyun __field(u64, cookie) 2099*4882a593Smuzhiyun ), 2100*4882a593Smuzhiyun TP_fast_assign( 2101*4882a593Smuzhiyun WIPHY_ASSIGN; 2102*4882a593Smuzhiyun WDEV_ASSIGN; 2103*4882a593Smuzhiyun __entry->func_type = func->type; 2104*4882a593Smuzhiyun __entry->cookie = func->cookie 2105*4882a593Smuzhiyun ), 2106*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " WDEV_PR_FMT ", type=%u, cookie=%llu", 2107*4882a593Smuzhiyun WIPHY_PR_ARG, WDEV_PR_ARG, __entry->func_type, 2108*4882a593Smuzhiyun __entry->cookie) 2109*4882a593Smuzhiyun ); 2110*4882a593Smuzhiyun 2111*4882a593Smuzhiyun TRACE_EVENT(rdev_del_nan_func, 2112*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev, 2113*4882a593Smuzhiyun u64 cookie), 2114*4882a593Smuzhiyun TP_ARGS(wiphy, wdev, cookie), 2115*4882a593Smuzhiyun TP_STRUCT__entry( 2116*4882a593Smuzhiyun WIPHY_ENTRY 2117*4882a593Smuzhiyun WDEV_ENTRY 2118*4882a593Smuzhiyun __field(u64, cookie) 2119*4882a593Smuzhiyun ), 2120*4882a593Smuzhiyun TP_fast_assign( 2121*4882a593Smuzhiyun WIPHY_ASSIGN; 2122*4882a593Smuzhiyun WDEV_ASSIGN; 2123*4882a593Smuzhiyun __entry->cookie = cookie; 2124*4882a593Smuzhiyun ), 2125*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " WDEV_PR_FMT ", cookie=%llu", 2126*4882a593Smuzhiyun WIPHY_PR_ARG, WDEV_PR_ARG, __entry->cookie) 2127*4882a593Smuzhiyun ); 2128*4882a593Smuzhiyun 2129*4882a593Smuzhiyun TRACE_EVENT(rdev_set_mac_acl, 2130*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 2131*4882a593Smuzhiyun struct cfg80211_acl_data *params), 2132*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, params), 2133*4882a593Smuzhiyun TP_STRUCT__entry( 2134*4882a593Smuzhiyun WIPHY_ENTRY 2135*4882a593Smuzhiyun NETDEV_ENTRY 2136*4882a593Smuzhiyun __field(u32, acl_policy) 2137*4882a593Smuzhiyun ), 2138*4882a593Smuzhiyun TP_fast_assign( 2139*4882a593Smuzhiyun WIPHY_ASSIGN; 2140*4882a593Smuzhiyun NETDEV_ASSIGN; 2141*4882a593Smuzhiyun __entry->acl_policy = params->acl_policy; 2142*4882a593Smuzhiyun ), 2143*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", acl policy: %d", 2144*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->acl_policy) 2145*4882a593Smuzhiyun ); 2146*4882a593Smuzhiyun 2147*4882a593Smuzhiyun TRACE_EVENT(rdev_update_ft_ies, 2148*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 2149*4882a593Smuzhiyun struct cfg80211_update_ft_ies_params *ftie), 2150*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, ftie), 2151*4882a593Smuzhiyun TP_STRUCT__entry( 2152*4882a593Smuzhiyun WIPHY_ENTRY 2153*4882a593Smuzhiyun NETDEV_ENTRY 2154*4882a593Smuzhiyun __field(u16, md) 2155*4882a593Smuzhiyun __dynamic_array(u8, ie, ftie->ie_len) 2156*4882a593Smuzhiyun ), 2157*4882a593Smuzhiyun TP_fast_assign( 2158*4882a593Smuzhiyun WIPHY_ASSIGN; 2159*4882a593Smuzhiyun NETDEV_ASSIGN; 2160*4882a593Smuzhiyun __entry->md = ftie->md; 2161*4882a593Smuzhiyun memcpy(__get_dynamic_array(ie), ftie->ie, ftie->ie_len); 2162*4882a593Smuzhiyun ), 2163*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", md: 0x%x", 2164*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->md) 2165*4882a593Smuzhiyun ); 2166*4882a593Smuzhiyun 2167*4882a593Smuzhiyun TRACE_EVENT(rdev_crit_proto_start, 2168*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev, 2169*4882a593Smuzhiyun enum nl80211_crit_proto_id protocol, u16 duration), 2170*4882a593Smuzhiyun TP_ARGS(wiphy, wdev, protocol, duration), 2171*4882a593Smuzhiyun TP_STRUCT__entry( 2172*4882a593Smuzhiyun WIPHY_ENTRY 2173*4882a593Smuzhiyun WDEV_ENTRY 2174*4882a593Smuzhiyun __field(u16, proto) 2175*4882a593Smuzhiyun __field(u16, duration) 2176*4882a593Smuzhiyun ), 2177*4882a593Smuzhiyun TP_fast_assign( 2178*4882a593Smuzhiyun WIPHY_ASSIGN; 2179*4882a593Smuzhiyun WDEV_ASSIGN; 2180*4882a593Smuzhiyun __entry->proto = protocol; 2181*4882a593Smuzhiyun __entry->duration = duration; 2182*4882a593Smuzhiyun ), 2183*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " WDEV_PR_FMT ", proto=%x, duration=%u", 2184*4882a593Smuzhiyun WIPHY_PR_ARG, WDEV_PR_ARG, __entry->proto, __entry->duration) 2185*4882a593Smuzhiyun ); 2186*4882a593Smuzhiyun 2187*4882a593Smuzhiyun TRACE_EVENT(rdev_crit_proto_stop, 2188*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev), 2189*4882a593Smuzhiyun TP_ARGS(wiphy, wdev), 2190*4882a593Smuzhiyun TP_STRUCT__entry( 2191*4882a593Smuzhiyun WIPHY_ENTRY 2192*4882a593Smuzhiyun WDEV_ENTRY 2193*4882a593Smuzhiyun ), 2194*4882a593Smuzhiyun TP_fast_assign( 2195*4882a593Smuzhiyun WIPHY_ASSIGN; 2196*4882a593Smuzhiyun WDEV_ASSIGN; 2197*4882a593Smuzhiyun ), 2198*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " WDEV_PR_FMT, 2199*4882a593Smuzhiyun WIPHY_PR_ARG, WDEV_PR_ARG) 2200*4882a593Smuzhiyun ); 2201*4882a593Smuzhiyun 2202*4882a593Smuzhiyun TRACE_EVENT(rdev_channel_switch, 2203*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 2204*4882a593Smuzhiyun struct cfg80211_csa_settings *params), 2205*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, params), 2206*4882a593Smuzhiyun TP_STRUCT__entry( 2207*4882a593Smuzhiyun WIPHY_ENTRY 2208*4882a593Smuzhiyun NETDEV_ENTRY 2209*4882a593Smuzhiyun CHAN_DEF_ENTRY 2210*4882a593Smuzhiyun __field(bool, radar_required) 2211*4882a593Smuzhiyun __field(bool, block_tx) 2212*4882a593Smuzhiyun __field(u8, count) 2213*4882a593Smuzhiyun __dynamic_array(u16, bcn_ofs, params->n_counter_offsets_beacon) 2214*4882a593Smuzhiyun __dynamic_array(u16, pres_ofs, params->n_counter_offsets_presp) 2215*4882a593Smuzhiyun ), 2216*4882a593Smuzhiyun TP_fast_assign( 2217*4882a593Smuzhiyun WIPHY_ASSIGN; 2218*4882a593Smuzhiyun NETDEV_ASSIGN; 2219*4882a593Smuzhiyun CHAN_DEF_ASSIGN(¶ms->chandef); 2220*4882a593Smuzhiyun __entry->radar_required = params->radar_required; 2221*4882a593Smuzhiyun __entry->block_tx = params->block_tx; 2222*4882a593Smuzhiyun __entry->count = params->count; 2223*4882a593Smuzhiyun memcpy(__get_dynamic_array(bcn_ofs), 2224*4882a593Smuzhiyun params->counter_offsets_beacon, 2225*4882a593Smuzhiyun params->n_counter_offsets_beacon * sizeof(u16)); 2226*4882a593Smuzhiyun 2227*4882a593Smuzhiyun /* probe response offsets are optional */ 2228*4882a593Smuzhiyun if (params->n_counter_offsets_presp) 2229*4882a593Smuzhiyun memcpy(__get_dynamic_array(pres_ofs), 2230*4882a593Smuzhiyun params->counter_offsets_presp, 2231*4882a593Smuzhiyun params->n_counter_offsets_presp * sizeof(u16)); 2232*4882a593Smuzhiyun ), 2233*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", " CHAN_DEF_PR_FMT 2234*4882a593Smuzhiyun ", block_tx: %d, count: %u, radar_required: %d", 2235*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, CHAN_DEF_PR_ARG, 2236*4882a593Smuzhiyun __entry->block_tx, __entry->count, __entry->radar_required) 2237*4882a593Smuzhiyun ); 2238*4882a593Smuzhiyun 2239*4882a593Smuzhiyun TRACE_EVENT(rdev_set_qos_map, 2240*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 2241*4882a593Smuzhiyun struct cfg80211_qos_map *qos_map), 2242*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, qos_map), 2243*4882a593Smuzhiyun TP_STRUCT__entry( 2244*4882a593Smuzhiyun WIPHY_ENTRY 2245*4882a593Smuzhiyun NETDEV_ENTRY 2246*4882a593Smuzhiyun QOS_MAP_ENTRY 2247*4882a593Smuzhiyun ), 2248*4882a593Smuzhiyun TP_fast_assign( 2249*4882a593Smuzhiyun WIPHY_ASSIGN; 2250*4882a593Smuzhiyun NETDEV_ASSIGN; 2251*4882a593Smuzhiyun QOS_MAP_ASSIGN(qos_map); 2252*4882a593Smuzhiyun ), 2253*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", num_des: %u", 2254*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, __entry->num_des) 2255*4882a593Smuzhiyun ); 2256*4882a593Smuzhiyun 2257*4882a593Smuzhiyun TRACE_EVENT(rdev_set_ap_chanwidth, 2258*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 2259*4882a593Smuzhiyun struct cfg80211_chan_def *chandef), 2260*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, chandef), 2261*4882a593Smuzhiyun TP_STRUCT__entry( 2262*4882a593Smuzhiyun WIPHY_ENTRY 2263*4882a593Smuzhiyun NETDEV_ENTRY 2264*4882a593Smuzhiyun CHAN_DEF_ENTRY 2265*4882a593Smuzhiyun ), 2266*4882a593Smuzhiyun TP_fast_assign( 2267*4882a593Smuzhiyun WIPHY_ASSIGN; 2268*4882a593Smuzhiyun NETDEV_ASSIGN; 2269*4882a593Smuzhiyun CHAN_DEF_ASSIGN(chandef); 2270*4882a593Smuzhiyun ), 2271*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", " CHAN_DEF_PR_FMT, 2272*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, CHAN_DEF_PR_ARG) 2273*4882a593Smuzhiyun ); 2274*4882a593Smuzhiyun 2275*4882a593Smuzhiyun TRACE_EVENT(rdev_add_tx_ts, 2276*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 2277*4882a593Smuzhiyun u8 tsid, const u8 *peer, u8 user_prio, u16 admitted_time), 2278*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, tsid, peer, user_prio, admitted_time), 2279*4882a593Smuzhiyun TP_STRUCT__entry( 2280*4882a593Smuzhiyun WIPHY_ENTRY 2281*4882a593Smuzhiyun NETDEV_ENTRY 2282*4882a593Smuzhiyun MAC_ENTRY(peer) 2283*4882a593Smuzhiyun __field(u8, tsid) 2284*4882a593Smuzhiyun __field(u8, user_prio) 2285*4882a593Smuzhiyun __field(u16, admitted_time) 2286*4882a593Smuzhiyun ), 2287*4882a593Smuzhiyun TP_fast_assign( 2288*4882a593Smuzhiyun WIPHY_ASSIGN; 2289*4882a593Smuzhiyun NETDEV_ASSIGN; 2290*4882a593Smuzhiyun MAC_ASSIGN(peer, peer); 2291*4882a593Smuzhiyun __entry->tsid = tsid; 2292*4882a593Smuzhiyun __entry->user_prio = user_prio; 2293*4882a593Smuzhiyun __entry->admitted_time = admitted_time; 2294*4882a593Smuzhiyun ), 2295*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", " MAC_PR_FMT ", TSID %d, UP %d, time %d", 2296*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(peer), 2297*4882a593Smuzhiyun __entry->tsid, __entry->user_prio, __entry->admitted_time) 2298*4882a593Smuzhiyun ); 2299*4882a593Smuzhiyun 2300*4882a593Smuzhiyun TRACE_EVENT(rdev_del_tx_ts, 2301*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 2302*4882a593Smuzhiyun u8 tsid, const u8 *peer), 2303*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, tsid, peer), 2304*4882a593Smuzhiyun TP_STRUCT__entry( 2305*4882a593Smuzhiyun WIPHY_ENTRY 2306*4882a593Smuzhiyun NETDEV_ENTRY 2307*4882a593Smuzhiyun MAC_ENTRY(peer) 2308*4882a593Smuzhiyun __field(u8, tsid) 2309*4882a593Smuzhiyun ), 2310*4882a593Smuzhiyun TP_fast_assign( 2311*4882a593Smuzhiyun WIPHY_ASSIGN; 2312*4882a593Smuzhiyun NETDEV_ASSIGN; 2313*4882a593Smuzhiyun MAC_ASSIGN(peer, peer); 2314*4882a593Smuzhiyun __entry->tsid = tsid; 2315*4882a593Smuzhiyun ), 2316*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", " MAC_PR_FMT ", TSID %d", 2317*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(peer), __entry->tsid) 2318*4882a593Smuzhiyun ); 2319*4882a593Smuzhiyun 2320*4882a593Smuzhiyun TRACE_EVENT(rdev_tdls_channel_switch, 2321*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 2322*4882a593Smuzhiyun const u8 *addr, u8 oper_class, 2323*4882a593Smuzhiyun struct cfg80211_chan_def *chandef), 2324*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, addr, oper_class, chandef), 2325*4882a593Smuzhiyun TP_STRUCT__entry( 2326*4882a593Smuzhiyun WIPHY_ENTRY 2327*4882a593Smuzhiyun NETDEV_ENTRY 2328*4882a593Smuzhiyun MAC_ENTRY(addr) 2329*4882a593Smuzhiyun __field(u8, oper_class) 2330*4882a593Smuzhiyun CHAN_DEF_ENTRY 2331*4882a593Smuzhiyun ), 2332*4882a593Smuzhiyun TP_fast_assign( 2333*4882a593Smuzhiyun WIPHY_ASSIGN; 2334*4882a593Smuzhiyun NETDEV_ASSIGN; 2335*4882a593Smuzhiyun MAC_ASSIGN(addr, addr); 2336*4882a593Smuzhiyun CHAN_DEF_ASSIGN(chandef); 2337*4882a593Smuzhiyun ), 2338*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", " MAC_PR_FMT 2339*4882a593Smuzhiyun " oper class %d, " CHAN_DEF_PR_FMT, 2340*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(addr), 2341*4882a593Smuzhiyun __entry->oper_class, CHAN_DEF_PR_ARG) 2342*4882a593Smuzhiyun ); 2343*4882a593Smuzhiyun 2344*4882a593Smuzhiyun TRACE_EVENT(rdev_tdls_cancel_channel_switch, 2345*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 2346*4882a593Smuzhiyun const u8 *addr), 2347*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, addr), 2348*4882a593Smuzhiyun TP_STRUCT__entry( 2349*4882a593Smuzhiyun WIPHY_ENTRY 2350*4882a593Smuzhiyun NETDEV_ENTRY 2351*4882a593Smuzhiyun MAC_ENTRY(addr) 2352*4882a593Smuzhiyun ), 2353*4882a593Smuzhiyun TP_fast_assign( 2354*4882a593Smuzhiyun WIPHY_ASSIGN; 2355*4882a593Smuzhiyun NETDEV_ASSIGN; 2356*4882a593Smuzhiyun MAC_ASSIGN(addr, addr); 2357*4882a593Smuzhiyun ), 2358*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", " MAC_PR_FMT, 2359*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(addr)) 2360*4882a593Smuzhiyun ); 2361*4882a593Smuzhiyun 2362*4882a593Smuzhiyun TRACE_EVENT(rdev_set_pmk, 2363*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 2364*4882a593Smuzhiyun struct cfg80211_pmk_conf *pmk_conf), 2365*4882a593Smuzhiyun 2366*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, pmk_conf), 2367*4882a593Smuzhiyun 2368*4882a593Smuzhiyun TP_STRUCT__entry( 2369*4882a593Smuzhiyun WIPHY_ENTRY 2370*4882a593Smuzhiyun NETDEV_ENTRY 2371*4882a593Smuzhiyun MAC_ENTRY(aa) 2372*4882a593Smuzhiyun __field(u8, pmk_len) 2373*4882a593Smuzhiyun __field(u8, pmk_r0_name_len) 2374*4882a593Smuzhiyun __dynamic_array(u8, pmk, pmk_conf->pmk_len) 2375*4882a593Smuzhiyun __dynamic_array(u8, pmk_r0_name, WLAN_PMK_NAME_LEN) 2376*4882a593Smuzhiyun ), 2377*4882a593Smuzhiyun 2378*4882a593Smuzhiyun TP_fast_assign( 2379*4882a593Smuzhiyun WIPHY_ASSIGN; 2380*4882a593Smuzhiyun NETDEV_ASSIGN; 2381*4882a593Smuzhiyun MAC_ASSIGN(aa, pmk_conf->aa); 2382*4882a593Smuzhiyun __entry->pmk_len = pmk_conf->pmk_len; 2383*4882a593Smuzhiyun __entry->pmk_r0_name_len = 2384*4882a593Smuzhiyun pmk_conf->pmk_r0_name ? WLAN_PMK_NAME_LEN : 0; 2385*4882a593Smuzhiyun memcpy(__get_dynamic_array(pmk), pmk_conf->pmk, 2386*4882a593Smuzhiyun pmk_conf->pmk_len); 2387*4882a593Smuzhiyun memcpy(__get_dynamic_array(pmk_r0_name), pmk_conf->pmk_r0_name, 2388*4882a593Smuzhiyun pmk_conf->pmk_r0_name ? WLAN_PMK_NAME_LEN : 0); 2389*4882a593Smuzhiyun ), 2390*4882a593Smuzhiyun 2391*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", " MAC_PR_FMT 2392*4882a593Smuzhiyun "pmk_len=%u, pmk: %s pmk_r0_name: %s", WIPHY_PR_ARG, 2393*4882a593Smuzhiyun NETDEV_PR_ARG, MAC_PR_ARG(aa), __entry->pmk_len, 2394*4882a593Smuzhiyun __print_array(__get_dynamic_array(pmk), 2395*4882a593Smuzhiyun __get_dynamic_array_len(pmk), 1), 2396*4882a593Smuzhiyun __entry->pmk_r0_name_len ? 2397*4882a593Smuzhiyun __print_array(__get_dynamic_array(pmk_r0_name), 2398*4882a593Smuzhiyun __get_dynamic_array_len(pmk_r0_name), 1) : "") 2399*4882a593Smuzhiyun ); 2400*4882a593Smuzhiyun 2401*4882a593Smuzhiyun TRACE_EVENT(rdev_del_pmk, 2402*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, const u8 *aa), 2403*4882a593Smuzhiyun 2404*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, aa), 2405*4882a593Smuzhiyun 2406*4882a593Smuzhiyun TP_STRUCT__entry( 2407*4882a593Smuzhiyun WIPHY_ENTRY 2408*4882a593Smuzhiyun NETDEV_ENTRY 2409*4882a593Smuzhiyun MAC_ENTRY(aa) 2410*4882a593Smuzhiyun ), 2411*4882a593Smuzhiyun 2412*4882a593Smuzhiyun TP_fast_assign( 2413*4882a593Smuzhiyun WIPHY_ASSIGN; 2414*4882a593Smuzhiyun NETDEV_ASSIGN; 2415*4882a593Smuzhiyun MAC_ASSIGN(aa, aa); 2416*4882a593Smuzhiyun ), 2417*4882a593Smuzhiyun 2418*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", " MAC_PR_FMT, 2419*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(aa)) 2420*4882a593Smuzhiyun ); 2421*4882a593Smuzhiyun 2422*4882a593Smuzhiyun TRACE_EVENT(rdev_external_auth, 2423*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 2424*4882a593Smuzhiyun struct cfg80211_external_auth_params *params), 2425*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, params), 2426*4882a593Smuzhiyun TP_STRUCT__entry(WIPHY_ENTRY 2427*4882a593Smuzhiyun NETDEV_ENTRY 2428*4882a593Smuzhiyun MAC_ENTRY(bssid) 2429*4882a593Smuzhiyun __array(u8, ssid, IEEE80211_MAX_SSID_LEN + 1) 2430*4882a593Smuzhiyun __field(u16, status) 2431*4882a593Smuzhiyun ), 2432*4882a593Smuzhiyun TP_fast_assign(WIPHY_ASSIGN; 2433*4882a593Smuzhiyun NETDEV_ASSIGN; 2434*4882a593Smuzhiyun MAC_ASSIGN(bssid, params->bssid); 2435*4882a593Smuzhiyun memset(__entry->ssid, 0, IEEE80211_MAX_SSID_LEN + 1); 2436*4882a593Smuzhiyun memcpy(__entry->ssid, params->ssid.ssid, 2437*4882a593Smuzhiyun params->ssid.ssid_len); 2438*4882a593Smuzhiyun __entry->status = params->status; 2439*4882a593Smuzhiyun ), 2440*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", bssid: " MAC_PR_FMT 2441*4882a593Smuzhiyun ", ssid: %s, status: %u", WIPHY_PR_ARG, NETDEV_PR_ARG, 2442*4882a593Smuzhiyun __entry->bssid, __entry->ssid, __entry->status) 2443*4882a593Smuzhiyun ); 2444*4882a593Smuzhiyun 2445*4882a593Smuzhiyun TRACE_EVENT(rdev_start_radar_detection, 2446*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 2447*4882a593Smuzhiyun struct cfg80211_chan_def *chandef, 2448*4882a593Smuzhiyun u32 cac_time_ms), 2449*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, chandef, cac_time_ms), 2450*4882a593Smuzhiyun TP_STRUCT__entry( 2451*4882a593Smuzhiyun WIPHY_ENTRY 2452*4882a593Smuzhiyun NETDEV_ENTRY 2453*4882a593Smuzhiyun CHAN_DEF_ENTRY 2454*4882a593Smuzhiyun __field(u32, cac_time_ms) 2455*4882a593Smuzhiyun ), 2456*4882a593Smuzhiyun TP_fast_assign( 2457*4882a593Smuzhiyun WIPHY_ASSIGN; 2458*4882a593Smuzhiyun NETDEV_ASSIGN; 2459*4882a593Smuzhiyun CHAN_DEF_ASSIGN(chandef); 2460*4882a593Smuzhiyun __entry->cac_time_ms = cac_time_ms; 2461*4882a593Smuzhiyun ), 2462*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", " CHAN_DEF_PR_FMT 2463*4882a593Smuzhiyun ", cac_time_ms=%u", 2464*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, CHAN_DEF_PR_ARG, 2465*4882a593Smuzhiyun __entry->cac_time_ms) 2466*4882a593Smuzhiyun ); 2467*4882a593Smuzhiyun 2468*4882a593Smuzhiyun TRACE_EVENT(rdev_set_mcast_rate, 2469*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 2470*4882a593Smuzhiyun int *mcast_rate), 2471*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, mcast_rate), 2472*4882a593Smuzhiyun TP_STRUCT__entry( 2473*4882a593Smuzhiyun WIPHY_ENTRY 2474*4882a593Smuzhiyun NETDEV_ENTRY 2475*4882a593Smuzhiyun __array(int, mcast_rate, NUM_NL80211_BANDS) 2476*4882a593Smuzhiyun ), 2477*4882a593Smuzhiyun TP_fast_assign( 2478*4882a593Smuzhiyun WIPHY_ASSIGN; 2479*4882a593Smuzhiyun NETDEV_ASSIGN; 2480*4882a593Smuzhiyun memcpy(__entry->mcast_rate, mcast_rate, 2481*4882a593Smuzhiyun sizeof(int) * NUM_NL80211_BANDS); 2482*4882a593Smuzhiyun ), 2483*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", " 2484*4882a593Smuzhiyun "mcast_rates [2.4GHz=0x%x, 5.2GHz=0x%x, 6GHz=0x%x, 60GHz=0x%x]", 2485*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, 2486*4882a593Smuzhiyun __entry->mcast_rate[NL80211_BAND_2GHZ], 2487*4882a593Smuzhiyun __entry->mcast_rate[NL80211_BAND_5GHZ], 2488*4882a593Smuzhiyun __entry->mcast_rate[NL80211_BAND_6GHZ], 2489*4882a593Smuzhiyun __entry->mcast_rate[NL80211_BAND_60GHZ]) 2490*4882a593Smuzhiyun ); 2491*4882a593Smuzhiyun 2492*4882a593Smuzhiyun TRACE_EVENT(rdev_set_coalesce, 2493*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct cfg80211_coalesce *coalesce), 2494*4882a593Smuzhiyun TP_ARGS(wiphy, coalesce), 2495*4882a593Smuzhiyun TP_STRUCT__entry( 2496*4882a593Smuzhiyun WIPHY_ENTRY 2497*4882a593Smuzhiyun __field(int, n_rules) 2498*4882a593Smuzhiyun ), 2499*4882a593Smuzhiyun TP_fast_assign( 2500*4882a593Smuzhiyun WIPHY_ASSIGN; 2501*4882a593Smuzhiyun __entry->n_rules = coalesce ? coalesce->n_rules : 0; 2502*4882a593Smuzhiyun ), 2503*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", n_rules=%d", 2504*4882a593Smuzhiyun WIPHY_PR_ARG, __entry->n_rules) 2505*4882a593Smuzhiyun ); 2506*4882a593Smuzhiyun 2507*4882a593Smuzhiyun DEFINE_EVENT(wiphy_wdev_evt, rdev_abort_scan, 2508*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev), 2509*4882a593Smuzhiyun TP_ARGS(wiphy, wdev) 2510*4882a593Smuzhiyun ); 2511*4882a593Smuzhiyun 2512*4882a593Smuzhiyun TRACE_EVENT(rdev_set_multicast_to_unicast, 2513*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 2514*4882a593Smuzhiyun const bool enabled), 2515*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, enabled), 2516*4882a593Smuzhiyun TP_STRUCT__entry( 2517*4882a593Smuzhiyun WIPHY_ENTRY 2518*4882a593Smuzhiyun NETDEV_ENTRY 2519*4882a593Smuzhiyun __field(bool, enabled) 2520*4882a593Smuzhiyun ), 2521*4882a593Smuzhiyun TP_fast_assign( 2522*4882a593Smuzhiyun WIPHY_ASSIGN; 2523*4882a593Smuzhiyun NETDEV_ASSIGN; 2524*4882a593Smuzhiyun __entry->enabled = enabled; 2525*4882a593Smuzhiyun ), 2526*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", unicast: %s", 2527*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, 2528*4882a593Smuzhiyun BOOL_TO_STR(__entry->enabled)) 2529*4882a593Smuzhiyun ); 2530*4882a593Smuzhiyun 2531*4882a593Smuzhiyun DEFINE_EVENT(wiphy_wdev_evt, rdev_get_txq_stats, 2532*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev), 2533*4882a593Smuzhiyun TP_ARGS(wiphy, wdev) 2534*4882a593Smuzhiyun ); 2535*4882a593Smuzhiyun 2536*4882a593Smuzhiyun TRACE_EVENT(rdev_get_ftm_responder_stats, 2537*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 2538*4882a593Smuzhiyun struct cfg80211_ftm_responder_stats *ftm_stats), 2539*4882a593Smuzhiyun 2540*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, ftm_stats), 2541*4882a593Smuzhiyun 2542*4882a593Smuzhiyun TP_STRUCT__entry( 2543*4882a593Smuzhiyun WIPHY_ENTRY 2544*4882a593Smuzhiyun NETDEV_ENTRY 2545*4882a593Smuzhiyun __field(u64, timestamp) 2546*4882a593Smuzhiyun __field(u32, success_num) 2547*4882a593Smuzhiyun __field(u32, partial_num) 2548*4882a593Smuzhiyun __field(u32, failed_num) 2549*4882a593Smuzhiyun __field(u32, asap_num) 2550*4882a593Smuzhiyun __field(u32, non_asap_num) 2551*4882a593Smuzhiyun __field(u64, duration) 2552*4882a593Smuzhiyun __field(u32, unknown_triggers) 2553*4882a593Smuzhiyun __field(u32, reschedule) 2554*4882a593Smuzhiyun __field(u32, out_of_window) 2555*4882a593Smuzhiyun ), 2556*4882a593Smuzhiyun 2557*4882a593Smuzhiyun TP_fast_assign( 2558*4882a593Smuzhiyun WIPHY_ASSIGN; 2559*4882a593Smuzhiyun NETDEV_ASSIGN; 2560*4882a593Smuzhiyun __entry->success_num = ftm_stats->success_num; 2561*4882a593Smuzhiyun __entry->partial_num = ftm_stats->partial_num; 2562*4882a593Smuzhiyun __entry->failed_num = ftm_stats->failed_num; 2563*4882a593Smuzhiyun __entry->asap_num = ftm_stats->asap_num; 2564*4882a593Smuzhiyun __entry->non_asap_num = ftm_stats->non_asap_num; 2565*4882a593Smuzhiyun __entry->duration = ftm_stats->total_duration_ms; 2566*4882a593Smuzhiyun __entry->unknown_triggers = ftm_stats->unknown_triggers_num; 2567*4882a593Smuzhiyun __entry->reschedule = ftm_stats->reschedule_requests_num; 2568*4882a593Smuzhiyun __entry->out_of_window = ftm_stats->out_of_window_triggers_num; 2569*4882a593Smuzhiyun ), 2570*4882a593Smuzhiyun 2571*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT "Ftm responder stats: success %u, partial %u, " 2572*4882a593Smuzhiyun "failed %u, asap %u, non asap %u, total duration %llu, unknown " 2573*4882a593Smuzhiyun "triggers %u, rescheduled %u, out of window %u", WIPHY_PR_ARG, 2574*4882a593Smuzhiyun __entry->success_num, __entry->partial_num, __entry->failed_num, 2575*4882a593Smuzhiyun __entry->asap_num, __entry->non_asap_num, __entry->duration, 2576*4882a593Smuzhiyun __entry->unknown_triggers, __entry->reschedule, 2577*4882a593Smuzhiyun __entry->out_of_window) 2578*4882a593Smuzhiyun ); 2579*4882a593Smuzhiyun 2580*4882a593Smuzhiyun DEFINE_EVENT(wiphy_wdev_cookie_evt, rdev_start_pmsr, 2581*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie), 2582*4882a593Smuzhiyun TP_ARGS(wiphy, wdev, cookie) 2583*4882a593Smuzhiyun ); 2584*4882a593Smuzhiyun 2585*4882a593Smuzhiyun DEFINE_EVENT(wiphy_wdev_cookie_evt, rdev_abort_pmsr, 2586*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie), 2587*4882a593Smuzhiyun TP_ARGS(wiphy, wdev, cookie) 2588*4882a593Smuzhiyun ); 2589*4882a593Smuzhiyun 2590*4882a593Smuzhiyun /************************************************************* 2591*4882a593Smuzhiyun * cfg80211 exported functions traces * 2592*4882a593Smuzhiyun *************************************************************/ 2593*4882a593Smuzhiyun 2594*4882a593Smuzhiyun TRACE_EVENT(cfg80211_return_bool, 2595*4882a593Smuzhiyun TP_PROTO(bool ret), 2596*4882a593Smuzhiyun TP_ARGS(ret), 2597*4882a593Smuzhiyun TP_STRUCT__entry( 2598*4882a593Smuzhiyun __field(bool, ret) 2599*4882a593Smuzhiyun ), 2600*4882a593Smuzhiyun TP_fast_assign( 2601*4882a593Smuzhiyun __entry->ret = ret; 2602*4882a593Smuzhiyun ), 2603*4882a593Smuzhiyun TP_printk("returned %s", BOOL_TO_STR(__entry->ret)) 2604*4882a593Smuzhiyun ); 2605*4882a593Smuzhiyun 2606*4882a593Smuzhiyun DECLARE_EVENT_CLASS(cfg80211_netdev_mac_evt, 2607*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, const u8 *macaddr), 2608*4882a593Smuzhiyun TP_ARGS(netdev, macaddr), 2609*4882a593Smuzhiyun TP_STRUCT__entry( 2610*4882a593Smuzhiyun NETDEV_ENTRY 2611*4882a593Smuzhiyun MAC_ENTRY(macaddr) 2612*4882a593Smuzhiyun ), 2613*4882a593Smuzhiyun TP_fast_assign( 2614*4882a593Smuzhiyun NETDEV_ASSIGN; 2615*4882a593Smuzhiyun MAC_ASSIGN(macaddr, macaddr); 2616*4882a593Smuzhiyun ), 2617*4882a593Smuzhiyun TP_printk(NETDEV_PR_FMT ", mac: " MAC_PR_FMT, 2618*4882a593Smuzhiyun NETDEV_PR_ARG, MAC_PR_ARG(macaddr)) 2619*4882a593Smuzhiyun ); 2620*4882a593Smuzhiyun 2621*4882a593Smuzhiyun DEFINE_EVENT(cfg80211_netdev_mac_evt, cfg80211_notify_new_peer_candidate, 2622*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, const u8 *macaddr), 2623*4882a593Smuzhiyun TP_ARGS(netdev, macaddr) 2624*4882a593Smuzhiyun ); 2625*4882a593Smuzhiyun 2626*4882a593Smuzhiyun DECLARE_EVENT_CLASS(netdev_evt_only, 2627*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev), 2628*4882a593Smuzhiyun TP_ARGS(netdev), 2629*4882a593Smuzhiyun TP_STRUCT__entry( 2630*4882a593Smuzhiyun NETDEV_ENTRY 2631*4882a593Smuzhiyun ), 2632*4882a593Smuzhiyun TP_fast_assign( 2633*4882a593Smuzhiyun NETDEV_ASSIGN; 2634*4882a593Smuzhiyun ), 2635*4882a593Smuzhiyun TP_printk(NETDEV_PR_FMT , NETDEV_PR_ARG) 2636*4882a593Smuzhiyun ); 2637*4882a593Smuzhiyun 2638*4882a593Smuzhiyun DEFINE_EVENT(netdev_evt_only, cfg80211_send_rx_auth, 2639*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev), 2640*4882a593Smuzhiyun TP_ARGS(netdev) 2641*4882a593Smuzhiyun ); 2642*4882a593Smuzhiyun 2643*4882a593Smuzhiyun TRACE_EVENT(cfg80211_send_rx_assoc, 2644*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, struct cfg80211_bss *bss), 2645*4882a593Smuzhiyun TP_ARGS(netdev, bss), 2646*4882a593Smuzhiyun TP_STRUCT__entry( 2647*4882a593Smuzhiyun NETDEV_ENTRY 2648*4882a593Smuzhiyun MAC_ENTRY(bssid) 2649*4882a593Smuzhiyun CHAN_ENTRY 2650*4882a593Smuzhiyun ), 2651*4882a593Smuzhiyun TP_fast_assign( 2652*4882a593Smuzhiyun NETDEV_ASSIGN; 2653*4882a593Smuzhiyun MAC_ASSIGN(bssid, bss->bssid); 2654*4882a593Smuzhiyun CHAN_ASSIGN(bss->channel); 2655*4882a593Smuzhiyun ), 2656*4882a593Smuzhiyun TP_printk(NETDEV_PR_FMT ", " MAC_PR_FMT ", " CHAN_PR_FMT, 2657*4882a593Smuzhiyun NETDEV_PR_ARG, MAC_PR_ARG(bssid), CHAN_PR_ARG) 2658*4882a593Smuzhiyun ); 2659*4882a593Smuzhiyun 2660*4882a593Smuzhiyun DECLARE_EVENT_CLASS(netdev_frame_event, 2661*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, const u8 *buf, int len), 2662*4882a593Smuzhiyun TP_ARGS(netdev, buf, len), 2663*4882a593Smuzhiyun TP_STRUCT__entry( 2664*4882a593Smuzhiyun NETDEV_ENTRY 2665*4882a593Smuzhiyun __dynamic_array(u8, frame, len) 2666*4882a593Smuzhiyun ), 2667*4882a593Smuzhiyun TP_fast_assign( 2668*4882a593Smuzhiyun NETDEV_ASSIGN; 2669*4882a593Smuzhiyun memcpy(__get_dynamic_array(frame), buf, len); 2670*4882a593Smuzhiyun ), 2671*4882a593Smuzhiyun TP_printk(NETDEV_PR_FMT ", ftype:0x%.2x", 2672*4882a593Smuzhiyun NETDEV_PR_ARG, 2673*4882a593Smuzhiyun le16_to_cpup((__le16 *)__get_dynamic_array(frame))) 2674*4882a593Smuzhiyun ); 2675*4882a593Smuzhiyun 2676*4882a593Smuzhiyun DEFINE_EVENT(netdev_frame_event, cfg80211_rx_unprot_mlme_mgmt, 2677*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, const u8 *buf, int len), 2678*4882a593Smuzhiyun TP_ARGS(netdev, buf, len) 2679*4882a593Smuzhiyun ); 2680*4882a593Smuzhiyun 2681*4882a593Smuzhiyun DEFINE_EVENT(netdev_frame_event, cfg80211_rx_mlme_mgmt, 2682*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, const u8 *buf, int len), 2683*4882a593Smuzhiyun TP_ARGS(netdev, buf, len) 2684*4882a593Smuzhiyun ); 2685*4882a593Smuzhiyun 2686*4882a593Smuzhiyun TRACE_EVENT(cfg80211_tx_mlme_mgmt, 2687*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, const u8 *buf, int len), 2688*4882a593Smuzhiyun TP_ARGS(netdev, buf, len), 2689*4882a593Smuzhiyun TP_STRUCT__entry( 2690*4882a593Smuzhiyun NETDEV_ENTRY 2691*4882a593Smuzhiyun __dynamic_array(u8, frame, len) 2692*4882a593Smuzhiyun ), 2693*4882a593Smuzhiyun TP_fast_assign( 2694*4882a593Smuzhiyun NETDEV_ASSIGN; 2695*4882a593Smuzhiyun memcpy(__get_dynamic_array(frame), buf, len); 2696*4882a593Smuzhiyun ), 2697*4882a593Smuzhiyun TP_printk(NETDEV_PR_FMT ", ftype:0x%.2x", 2698*4882a593Smuzhiyun NETDEV_PR_ARG, 2699*4882a593Smuzhiyun le16_to_cpup((__le16 *)__get_dynamic_array(frame))) 2700*4882a593Smuzhiyun ); 2701*4882a593Smuzhiyun 2702*4882a593Smuzhiyun DECLARE_EVENT_CLASS(netdev_mac_evt, 2703*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, const u8 *mac), 2704*4882a593Smuzhiyun TP_ARGS(netdev, mac), 2705*4882a593Smuzhiyun TP_STRUCT__entry( 2706*4882a593Smuzhiyun NETDEV_ENTRY 2707*4882a593Smuzhiyun MAC_ENTRY(mac) 2708*4882a593Smuzhiyun ), 2709*4882a593Smuzhiyun TP_fast_assign( 2710*4882a593Smuzhiyun NETDEV_ASSIGN; 2711*4882a593Smuzhiyun MAC_ASSIGN(mac, mac) 2712*4882a593Smuzhiyun ), 2713*4882a593Smuzhiyun TP_printk(NETDEV_PR_FMT ", mac: " MAC_PR_FMT, 2714*4882a593Smuzhiyun NETDEV_PR_ARG, MAC_PR_ARG(mac)) 2715*4882a593Smuzhiyun ); 2716*4882a593Smuzhiyun 2717*4882a593Smuzhiyun DEFINE_EVENT(netdev_mac_evt, cfg80211_send_auth_timeout, 2718*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, const u8 *mac), 2719*4882a593Smuzhiyun TP_ARGS(netdev, mac) 2720*4882a593Smuzhiyun ); 2721*4882a593Smuzhiyun 2722*4882a593Smuzhiyun DEFINE_EVENT(netdev_mac_evt, cfg80211_send_assoc_timeout, 2723*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, const u8 *mac), 2724*4882a593Smuzhiyun TP_ARGS(netdev, mac) 2725*4882a593Smuzhiyun ); 2726*4882a593Smuzhiyun 2727*4882a593Smuzhiyun TRACE_EVENT(cfg80211_michael_mic_failure, 2728*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, const u8 *addr, 2729*4882a593Smuzhiyun enum nl80211_key_type key_type, int key_id, const u8 *tsc), 2730*4882a593Smuzhiyun TP_ARGS(netdev, addr, key_type, key_id, tsc), 2731*4882a593Smuzhiyun TP_STRUCT__entry( 2732*4882a593Smuzhiyun NETDEV_ENTRY 2733*4882a593Smuzhiyun MAC_ENTRY(addr) 2734*4882a593Smuzhiyun __field(enum nl80211_key_type, key_type) 2735*4882a593Smuzhiyun __field(int, key_id) 2736*4882a593Smuzhiyun __array(u8, tsc, 6) 2737*4882a593Smuzhiyun ), 2738*4882a593Smuzhiyun TP_fast_assign( 2739*4882a593Smuzhiyun NETDEV_ASSIGN; 2740*4882a593Smuzhiyun MAC_ASSIGN(addr, addr); 2741*4882a593Smuzhiyun __entry->key_type = key_type; 2742*4882a593Smuzhiyun __entry->key_id = key_id; 2743*4882a593Smuzhiyun if (tsc) 2744*4882a593Smuzhiyun memcpy(__entry->tsc, tsc, 6); 2745*4882a593Smuzhiyun ), 2746*4882a593Smuzhiyun TP_printk(NETDEV_PR_FMT ", " MAC_PR_FMT ", key type: %d, key id: %d, tsc: %pm", 2747*4882a593Smuzhiyun NETDEV_PR_ARG, MAC_PR_ARG(addr), __entry->key_type, 2748*4882a593Smuzhiyun __entry->key_id, __entry->tsc) 2749*4882a593Smuzhiyun ); 2750*4882a593Smuzhiyun 2751*4882a593Smuzhiyun TRACE_EVENT(cfg80211_ready_on_channel, 2752*4882a593Smuzhiyun TP_PROTO(struct wireless_dev *wdev, u64 cookie, 2753*4882a593Smuzhiyun struct ieee80211_channel *chan, 2754*4882a593Smuzhiyun unsigned int duration), 2755*4882a593Smuzhiyun TP_ARGS(wdev, cookie, chan, duration), 2756*4882a593Smuzhiyun TP_STRUCT__entry( 2757*4882a593Smuzhiyun WDEV_ENTRY 2758*4882a593Smuzhiyun __field(u64, cookie) 2759*4882a593Smuzhiyun CHAN_ENTRY 2760*4882a593Smuzhiyun __field(unsigned int, duration) 2761*4882a593Smuzhiyun ), 2762*4882a593Smuzhiyun TP_fast_assign( 2763*4882a593Smuzhiyun WDEV_ASSIGN; 2764*4882a593Smuzhiyun __entry->cookie = cookie; 2765*4882a593Smuzhiyun CHAN_ASSIGN(chan); 2766*4882a593Smuzhiyun __entry->duration = duration; 2767*4882a593Smuzhiyun ), 2768*4882a593Smuzhiyun TP_printk(WDEV_PR_FMT ", cookie: %llu, " CHAN_PR_FMT ", duration: %u", 2769*4882a593Smuzhiyun WDEV_PR_ARG, __entry->cookie, CHAN_PR_ARG, 2770*4882a593Smuzhiyun __entry->duration) 2771*4882a593Smuzhiyun ); 2772*4882a593Smuzhiyun 2773*4882a593Smuzhiyun TRACE_EVENT(cfg80211_ready_on_channel_expired, 2774*4882a593Smuzhiyun TP_PROTO(struct wireless_dev *wdev, u64 cookie, 2775*4882a593Smuzhiyun struct ieee80211_channel *chan), 2776*4882a593Smuzhiyun TP_ARGS(wdev, cookie, chan), 2777*4882a593Smuzhiyun TP_STRUCT__entry( 2778*4882a593Smuzhiyun WDEV_ENTRY 2779*4882a593Smuzhiyun __field(u64, cookie) 2780*4882a593Smuzhiyun CHAN_ENTRY 2781*4882a593Smuzhiyun ), 2782*4882a593Smuzhiyun TP_fast_assign( 2783*4882a593Smuzhiyun WDEV_ASSIGN; 2784*4882a593Smuzhiyun __entry->cookie = cookie; 2785*4882a593Smuzhiyun CHAN_ASSIGN(chan); 2786*4882a593Smuzhiyun ), 2787*4882a593Smuzhiyun TP_printk(WDEV_PR_FMT ", cookie: %llu, " CHAN_PR_FMT, 2788*4882a593Smuzhiyun WDEV_PR_ARG, __entry->cookie, CHAN_PR_ARG) 2789*4882a593Smuzhiyun ); 2790*4882a593Smuzhiyun 2791*4882a593Smuzhiyun TRACE_EVENT(cfg80211_tx_mgmt_expired, 2792*4882a593Smuzhiyun TP_PROTO(struct wireless_dev *wdev, u64 cookie, 2793*4882a593Smuzhiyun struct ieee80211_channel *chan), 2794*4882a593Smuzhiyun TP_ARGS(wdev, cookie, chan), 2795*4882a593Smuzhiyun TP_STRUCT__entry( 2796*4882a593Smuzhiyun WDEV_ENTRY 2797*4882a593Smuzhiyun __field(u64, cookie) 2798*4882a593Smuzhiyun CHAN_ENTRY 2799*4882a593Smuzhiyun ), 2800*4882a593Smuzhiyun TP_fast_assign( 2801*4882a593Smuzhiyun WDEV_ASSIGN; 2802*4882a593Smuzhiyun __entry->cookie = cookie; 2803*4882a593Smuzhiyun CHAN_ASSIGN(chan); 2804*4882a593Smuzhiyun ), 2805*4882a593Smuzhiyun TP_printk(WDEV_PR_FMT ", cookie: %llu, " CHAN_PR_FMT, 2806*4882a593Smuzhiyun WDEV_PR_ARG, __entry->cookie, CHAN_PR_ARG) 2807*4882a593Smuzhiyun ); 2808*4882a593Smuzhiyun 2809*4882a593Smuzhiyun TRACE_EVENT(cfg80211_new_sta, 2810*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, const u8 *mac_addr, 2811*4882a593Smuzhiyun struct station_info *sinfo), 2812*4882a593Smuzhiyun TP_ARGS(netdev, mac_addr, sinfo), 2813*4882a593Smuzhiyun TP_STRUCT__entry( 2814*4882a593Smuzhiyun NETDEV_ENTRY 2815*4882a593Smuzhiyun MAC_ENTRY(mac_addr) 2816*4882a593Smuzhiyun SINFO_ENTRY 2817*4882a593Smuzhiyun ), 2818*4882a593Smuzhiyun TP_fast_assign( 2819*4882a593Smuzhiyun NETDEV_ASSIGN; 2820*4882a593Smuzhiyun MAC_ASSIGN(mac_addr, mac_addr); 2821*4882a593Smuzhiyun SINFO_ASSIGN; 2822*4882a593Smuzhiyun ), 2823*4882a593Smuzhiyun TP_printk(NETDEV_PR_FMT ", " MAC_PR_FMT, 2824*4882a593Smuzhiyun NETDEV_PR_ARG, MAC_PR_ARG(mac_addr)) 2825*4882a593Smuzhiyun ); 2826*4882a593Smuzhiyun 2827*4882a593Smuzhiyun DEFINE_EVENT(cfg80211_netdev_mac_evt, cfg80211_del_sta, 2828*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, const u8 *macaddr), 2829*4882a593Smuzhiyun TP_ARGS(netdev, macaddr) 2830*4882a593Smuzhiyun ); 2831*4882a593Smuzhiyun 2832*4882a593Smuzhiyun TRACE_EVENT(cfg80211_rx_mgmt, 2833*4882a593Smuzhiyun TP_PROTO(struct wireless_dev *wdev, int freq, int sig_dbm), 2834*4882a593Smuzhiyun TP_ARGS(wdev, freq, sig_dbm), 2835*4882a593Smuzhiyun TP_STRUCT__entry( 2836*4882a593Smuzhiyun WDEV_ENTRY 2837*4882a593Smuzhiyun __field(int, freq) 2838*4882a593Smuzhiyun __field(int, sig_dbm) 2839*4882a593Smuzhiyun ), 2840*4882a593Smuzhiyun TP_fast_assign( 2841*4882a593Smuzhiyun WDEV_ASSIGN; 2842*4882a593Smuzhiyun __entry->freq = freq; 2843*4882a593Smuzhiyun __entry->sig_dbm = sig_dbm; 2844*4882a593Smuzhiyun ), 2845*4882a593Smuzhiyun TP_printk(WDEV_PR_FMT ", freq: "KHZ_F", sig dbm: %d", 2846*4882a593Smuzhiyun WDEV_PR_ARG, PR_KHZ(__entry->freq), __entry->sig_dbm) 2847*4882a593Smuzhiyun ); 2848*4882a593Smuzhiyun 2849*4882a593Smuzhiyun TRACE_EVENT(cfg80211_mgmt_tx_status, 2850*4882a593Smuzhiyun TP_PROTO(struct wireless_dev *wdev, u64 cookie, bool ack), 2851*4882a593Smuzhiyun TP_ARGS(wdev, cookie, ack), 2852*4882a593Smuzhiyun TP_STRUCT__entry( 2853*4882a593Smuzhiyun WDEV_ENTRY 2854*4882a593Smuzhiyun __field(u64, cookie) 2855*4882a593Smuzhiyun __field(bool, ack) 2856*4882a593Smuzhiyun ), 2857*4882a593Smuzhiyun TP_fast_assign( 2858*4882a593Smuzhiyun WDEV_ASSIGN; 2859*4882a593Smuzhiyun __entry->cookie = cookie; 2860*4882a593Smuzhiyun __entry->ack = ack; 2861*4882a593Smuzhiyun ), 2862*4882a593Smuzhiyun TP_printk(WDEV_PR_FMT", cookie: %llu, ack: %s", 2863*4882a593Smuzhiyun WDEV_PR_ARG, __entry->cookie, BOOL_TO_STR(__entry->ack)) 2864*4882a593Smuzhiyun ); 2865*4882a593Smuzhiyun 2866*4882a593Smuzhiyun TRACE_EVENT(cfg80211_control_port_tx_status, 2867*4882a593Smuzhiyun TP_PROTO(struct wireless_dev *wdev, u64 cookie, bool ack), 2868*4882a593Smuzhiyun TP_ARGS(wdev, cookie, ack), 2869*4882a593Smuzhiyun TP_STRUCT__entry( 2870*4882a593Smuzhiyun WDEV_ENTRY 2871*4882a593Smuzhiyun __field(u64, cookie) 2872*4882a593Smuzhiyun __field(bool, ack) 2873*4882a593Smuzhiyun ), 2874*4882a593Smuzhiyun TP_fast_assign( 2875*4882a593Smuzhiyun WDEV_ASSIGN; 2876*4882a593Smuzhiyun __entry->cookie = cookie; 2877*4882a593Smuzhiyun __entry->ack = ack; 2878*4882a593Smuzhiyun ), 2879*4882a593Smuzhiyun TP_printk(WDEV_PR_FMT", cookie: %llu, ack: %s", 2880*4882a593Smuzhiyun WDEV_PR_ARG, __entry->cookie, BOOL_TO_STR(__entry->ack)) 2881*4882a593Smuzhiyun ); 2882*4882a593Smuzhiyun 2883*4882a593Smuzhiyun TRACE_EVENT(cfg80211_rx_control_port, 2884*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, struct sk_buff *skb, 2885*4882a593Smuzhiyun bool unencrypted), 2886*4882a593Smuzhiyun TP_ARGS(netdev, skb, unencrypted), 2887*4882a593Smuzhiyun TP_STRUCT__entry( 2888*4882a593Smuzhiyun NETDEV_ENTRY 2889*4882a593Smuzhiyun __field(int, len) 2890*4882a593Smuzhiyun MAC_ENTRY(from) 2891*4882a593Smuzhiyun __field(u16, proto) 2892*4882a593Smuzhiyun __field(bool, unencrypted) 2893*4882a593Smuzhiyun ), 2894*4882a593Smuzhiyun TP_fast_assign( 2895*4882a593Smuzhiyun NETDEV_ASSIGN; 2896*4882a593Smuzhiyun __entry->len = skb->len; 2897*4882a593Smuzhiyun MAC_ASSIGN(from, eth_hdr(skb)->h_source); 2898*4882a593Smuzhiyun __entry->proto = be16_to_cpu(skb->protocol); 2899*4882a593Smuzhiyun __entry->unencrypted = unencrypted; 2900*4882a593Smuzhiyun ), 2901*4882a593Smuzhiyun TP_printk(NETDEV_PR_FMT ", len=%d, " MAC_PR_FMT ", proto: 0x%x, unencrypted: %s", 2902*4882a593Smuzhiyun NETDEV_PR_ARG, __entry->len, MAC_PR_ARG(from), 2903*4882a593Smuzhiyun __entry->proto, BOOL_TO_STR(__entry->unencrypted)) 2904*4882a593Smuzhiyun ); 2905*4882a593Smuzhiyun 2906*4882a593Smuzhiyun TRACE_EVENT(cfg80211_cqm_rssi_notify, 2907*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, 2908*4882a593Smuzhiyun enum nl80211_cqm_rssi_threshold_event rssi_event, 2909*4882a593Smuzhiyun s32 rssi_level), 2910*4882a593Smuzhiyun TP_ARGS(netdev, rssi_event, rssi_level), 2911*4882a593Smuzhiyun TP_STRUCT__entry( 2912*4882a593Smuzhiyun NETDEV_ENTRY 2913*4882a593Smuzhiyun __field(enum nl80211_cqm_rssi_threshold_event, rssi_event) 2914*4882a593Smuzhiyun __field(s32, rssi_level) 2915*4882a593Smuzhiyun ), 2916*4882a593Smuzhiyun TP_fast_assign( 2917*4882a593Smuzhiyun NETDEV_ASSIGN; 2918*4882a593Smuzhiyun __entry->rssi_event = rssi_event; 2919*4882a593Smuzhiyun __entry->rssi_level = rssi_level; 2920*4882a593Smuzhiyun ), 2921*4882a593Smuzhiyun TP_printk(NETDEV_PR_FMT ", rssi event: %d, level: %d", 2922*4882a593Smuzhiyun NETDEV_PR_ARG, __entry->rssi_event, __entry->rssi_level) 2923*4882a593Smuzhiyun ); 2924*4882a593Smuzhiyun 2925*4882a593Smuzhiyun TRACE_EVENT(cfg80211_reg_can_beacon, 2926*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct cfg80211_chan_def *chandef, 2927*4882a593Smuzhiyun enum nl80211_iftype iftype, bool check_no_ir), 2928*4882a593Smuzhiyun TP_ARGS(wiphy, chandef, iftype, check_no_ir), 2929*4882a593Smuzhiyun TP_STRUCT__entry( 2930*4882a593Smuzhiyun WIPHY_ENTRY 2931*4882a593Smuzhiyun CHAN_DEF_ENTRY 2932*4882a593Smuzhiyun __field(enum nl80211_iftype, iftype) 2933*4882a593Smuzhiyun __field(bool, check_no_ir) 2934*4882a593Smuzhiyun ), 2935*4882a593Smuzhiyun TP_fast_assign( 2936*4882a593Smuzhiyun WIPHY_ASSIGN; 2937*4882a593Smuzhiyun CHAN_DEF_ASSIGN(chandef); 2938*4882a593Smuzhiyun __entry->iftype = iftype; 2939*4882a593Smuzhiyun __entry->check_no_ir = check_no_ir; 2940*4882a593Smuzhiyun ), 2941*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " CHAN_DEF_PR_FMT ", iftype=%d check_no_ir=%s", 2942*4882a593Smuzhiyun WIPHY_PR_ARG, CHAN_DEF_PR_ARG, __entry->iftype, 2943*4882a593Smuzhiyun BOOL_TO_STR(__entry->check_no_ir)) 2944*4882a593Smuzhiyun ); 2945*4882a593Smuzhiyun 2946*4882a593Smuzhiyun TRACE_EVENT(cfg80211_chandef_dfs_required, 2947*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct cfg80211_chan_def *chandef), 2948*4882a593Smuzhiyun TP_ARGS(wiphy, chandef), 2949*4882a593Smuzhiyun TP_STRUCT__entry( 2950*4882a593Smuzhiyun WIPHY_ENTRY 2951*4882a593Smuzhiyun CHAN_DEF_ENTRY 2952*4882a593Smuzhiyun ), 2953*4882a593Smuzhiyun TP_fast_assign( 2954*4882a593Smuzhiyun WIPHY_ASSIGN; 2955*4882a593Smuzhiyun CHAN_DEF_ASSIGN(chandef); 2956*4882a593Smuzhiyun ), 2957*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " CHAN_DEF_PR_FMT, 2958*4882a593Smuzhiyun WIPHY_PR_ARG, CHAN_DEF_PR_ARG) 2959*4882a593Smuzhiyun ); 2960*4882a593Smuzhiyun 2961*4882a593Smuzhiyun TRACE_EVENT(cfg80211_ch_switch_notify, 2962*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, 2963*4882a593Smuzhiyun struct cfg80211_chan_def *chandef), 2964*4882a593Smuzhiyun TP_ARGS(netdev, chandef), 2965*4882a593Smuzhiyun TP_STRUCT__entry( 2966*4882a593Smuzhiyun NETDEV_ENTRY 2967*4882a593Smuzhiyun CHAN_DEF_ENTRY 2968*4882a593Smuzhiyun ), 2969*4882a593Smuzhiyun TP_fast_assign( 2970*4882a593Smuzhiyun NETDEV_ASSIGN; 2971*4882a593Smuzhiyun CHAN_DEF_ASSIGN(chandef); 2972*4882a593Smuzhiyun ), 2973*4882a593Smuzhiyun TP_printk(NETDEV_PR_FMT ", " CHAN_DEF_PR_FMT, 2974*4882a593Smuzhiyun NETDEV_PR_ARG, CHAN_DEF_PR_ARG) 2975*4882a593Smuzhiyun ); 2976*4882a593Smuzhiyun 2977*4882a593Smuzhiyun TRACE_EVENT(cfg80211_ch_switch_started_notify, 2978*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, 2979*4882a593Smuzhiyun struct cfg80211_chan_def *chandef), 2980*4882a593Smuzhiyun TP_ARGS(netdev, chandef), 2981*4882a593Smuzhiyun TP_STRUCT__entry( 2982*4882a593Smuzhiyun NETDEV_ENTRY 2983*4882a593Smuzhiyun CHAN_DEF_ENTRY 2984*4882a593Smuzhiyun ), 2985*4882a593Smuzhiyun TP_fast_assign( 2986*4882a593Smuzhiyun NETDEV_ASSIGN; 2987*4882a593Smuzhiyun CHAN_DEF_ASSIGN(chandef); 2988*4882a593Smuzhiyun ), 2989*4882a593Smuzhiyun TP_printk(NETDEV_PR_FMT ", " CHAN_DEF_PR_FMT, 2990*4882a593Smuzhiyun NETDEV_PR_ARG, CHAN_DEF_PR_ARG) 2991*4882a593Smuzhiyun ); 2992*4882a593Smuzhiyun 2993*4882a593Smuzhiyun TRACE_EVENT(cfg80211_radar_event, 2994*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct cfg80211_chan_def *chandef), 2995*4882a593Smuzhiyun TP_ARGS(wiphy, chandef), 2996*4882a593Smuzhiyun TP_STRUCT__entry( 2997*4882a593Smuzhiyun WIPHY_ENTRY 2998*4882a593Smuzhiyun CHAN_DEF_ENTRY 2999*4882a593Smuzhiyun ), 3000*4882a593Smuzhiyun TP_fast_assign( 3001*4882a593Smuzhiyun WIPHY_ASSIGN; 3002*4882a593Smuzhiyun CHAN_DEF_ASSIGN(chandef); 3003*4882a593Smuzhiyun ), 3004*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " CHAN_DEF_PR_FMT, 3005*4882a593Smuzhiyun WIPHY_PR_ARG, CHAN_DEF_PR_ARG) 3006*4882a593Smuzhiyun ); 3007*4882a593Smuzhiyun 3008*4882a593Smuzhiyun TRACE_EVENT(cfg80211_cac_event, 3009*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, enum nl80211_radar_event evt), 3010*4882a593Smuzhiyun TP_ARGS(netdev, evt), 3011*4882a593Smuzhiyun TP_STRUCT__entry( 3012*4882a593Smuzhiyun NETDEV_ENTRY 3013*4882a593Smuzhiyun __field(enum nl80211_radar_event, evt) 3014*4882a593Smuzhiyun ), 3015*4882a593Smuzhiyun TP_fast_assign( 3016*4882a593Smuzhiyun NETDEV_ASSIGN; 3017*4882a593Smuzhiyun __entry->evt = evt; 3018*4882a593Smuzhiyun ), 3019*4882a593Smuzhiyun TP_printk(NETDEV_PR_FMT ", event: %d", 3020*4882a593Smuzhiyun NETDEV_PR_ARG, __entry->evt) 3021*4882a593Smuzhiyun ); 3022*4882a593Smuzhiyun 3023*4882a593Smuzhiyun DECLARE_EVENT_CLASS(cfg80211_rx_evt, 3024*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, const u8 *addr), 3025*4882a593Smuzhiyun TP_ARGS(netdev, addr), 3026*4882a593Smuzhiyun TP_STRUCT__entry( 3027*4882a593Smuzhiyun NETDEV_ENTRY 3028*4882a593Smuzhiyun MAC_ENTRY(addr) 3029*4882a593Smuzhiyun ), 3030*4882a593Smuzhiyun TP_fast_assign( 3031*4882a593Smuzhiyun NETDEV_ASSIGN; 3032*4882a593Smuzhiyun MAC_ASSIGN(addr, addr); 3033*4882a593Smuzhiyun ), 3034*4882a593Smuzhiyun TP_printk(NETDEV_PR_FMT ", " MAC_PR_FMT, NETDEV_PR_ARG, MAC_PR_ARG(addr)) 3035*4882a593Smuzhiyun ); 3036*4882a593Smuzhiyun 3037*4882a593Smuzhiyun DEFINE_EVENT(cfg80211_rx_evt, cfg80211_rx_spurious_frame, 3038*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, const u8 *addr), 3039*4882a593Smuzhiyun TP_ARGS(netdev, addr) 3040*4882a593Smuzhiyun ); 3041*4882a593Smuzhiyun 3042*4882a593Smuzhiyun DEFINE_EVENT(cfg80211_rx_evt, cfg80211_rx_unexpected_4addr_frame, 3043*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, const u8 *addr), 3044*4882a593Smuzhiyun TP_ARGS(netdev, addr) 3045*4882a593Smuzhiyun ); 3046*4882a593Smuzhiyun 3047*4882a593Smuzhiyun TRACE_EVENT(cfg80211_ibss_joined, 3048*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, const u8 *bssid, 3049*4882a593Smuzhiyun struct ieee80211_channel *channel), 3050*4882a593Smuzhiyun TP_ARGS(netdev, bssid, channel), 3051*4882a593Smuzhiyun TP_STRUCT__entry( 3052*4882a593Smuzhiyun NETDEV_ENTRY 3053*4882a593Smuzhiyun MAC_ENTRY(bssid) 3054*4882a593Smuzhiyun CHAN_ENTRY 3055*4882a593Smuzhiyun ), 3056*4882a593Smuzhiyun TP_fast_assign( 3057*4882a593Smuzhiyun NETDEV_ASSIGN; 3058*4882a593Smuzhiyun MAC_ASSIGN(bssid, bssid); 3059*4882a593Smuzhiyun CHAN_ASSIGN(channel); 3060*4882a593Smuzhiyun ), 3061*4882a593Smuzhiyun TP_printk(NETDEV_PR_FMT ", bssid: " MAC_PR_FMT ", " CHAN_PR_FMT, 3062*4882a593Smuzhiyun NETDEV_PR_ARG, MAC_PR_ARG(bssid), CHAN_PR_ARG) 3063*4882a593Smuzhiyun ); 3064*4882a593Smuzhiyun 3065*4882a593Smuzhiyun TRACE_EVENT(cfg80211_probe_status, 3066*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, const u8 *addr, u64 cookie, 3067*4882a593Smuzhiyun bool acked), 3068*4882a593Smuzhiyun TP_ARGS(netdev, addr, cookie, acked), 3069*4882a593Smuzhiyun TP_STRUCT__entry( 3070*4882a593Smuzhiyun NETDEV_ENTRY 3071*4882a593Smuzhiyun MAC_ENTRY(addr) 3072*4882a593Smuzhiyun __field(u64, cookie) 3073*4882a593Smuzhiyun __field(bool, acked) 3074*4882a593Smuzhiyun ), 3075*4882a593Smuzhiyun TP_fast_assign( 3076*4882a593Smuzhiyun NETDEV_ASSIGN; 3077*4882a593Smuzhiyun MAC_ASSIGN(addr, addr); 3078*4882a593Smuzhiyun __entry->cookie = cookie; 3079*4882a593Smuzhiyun __entry->acked = acked; 3080*4882a593Smuzhiyun ), 3081*4882a593Smuzhiyun TP_printk(NETDEV_PR_FMT " addr:" MAC_PR_FMT ", cookie: %llu, acked: %s", 3082*4882a593Smuzhiyun NETDEV_PR_ARG, MAC_PR_ARG(addr), __entry->cookie, 3083*4882a593Smuzhiyun BOOL_TO_STR(__entry->acked)) 3084*4882a593Smuzhiyun ); 3085*4882a593Smuzhiyun 3086*4882a593Smuzhiyun TRACE_EVENT(cfg80211_cqm_pktloss_notify, 3087*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, const u8 *peer, u32 num_packets), 3088*4882a593Smuzhiyun TP_ARGS(netdev, peer, num_packets), 3089*4882a593Smuzhiyun TP_STRUCT__entry( 3090*4882a593Smuzhiyun NETDEV_ENTRY 3091*4882a593Smuzhiyun MAC_ENTRY(peer) 3092*4882a593Smuzhiyun __field(u32, num_packets) 3093*4882a593Smuzhiyun ), 3094*4882a593Smuzhiyun TP_fast_assign( 3095*4882a593Smuzhiyun NETDEV_ASSIGN; 3096*4882a593Smuzhiyun MAC_ASSIGN(peer, peer); 3097*4882a593Smuzhiyun __entry->num_packets = num_packets; 3098*4882a593Smuzhiyun ), 3099*4882a593Smuzhiyun TP_printk(NETDEV_PR_FMT ", peer: " MAC_PR_FMT ", num of lost packets: %u", 3100*4882a593Smuzhiyun NETDEV_PR_ARG, MAC_PR_ARG(peer), __entry->num_packets) 3101*4882a593Smuzhiyun ); 3102*4882a593Smuzhiyun 3103*4882a593Smuzhiyun DEFINE_EVENT(cfg80211_netdev_mac_evt, cfg80211_gtk_rekey_notify, 3104*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, const u8 *macaddr), 3105*4882a593Smuzhiyun TP_ARGS(netdev, macaddr) 3106*4882a593Smuzhiyun ); 3107*4882a593Smuzhiyun 3108*4882a593Smuzhiyun TRACE_EVENT(cfg80211_pmksa_candidate_notify, 3109*4882a593Smuzhiyun TP_PROTO(struct net_device *netdev, int index, const u8 *bssid, 3110*4882a593Smuzhiyun bool preauth), 3111*4882a593Smuzhiyun TP_ARGS(netdev, index, bssid, preauth), 3112*4882a593Smuzhiyun TP_STRUCT__entry( 3113*4882a593Smuzhiyun NETDEV_ENTRY 3114*4882a593Smuzhiyun __field(int, index) 3115*4882a593Smuzhiyun MAC_ENTRY(bssid) 3116*4882a593Smuzhiyun __field(bool, preauth) 3117*4882a593Smuzhiyun ), 3118*4882a593Smuzhiyun TP_fast_assign( 3119*4882a593Smuzhiyun NETDEV_ASSIGN; 3120*4882a593Smuzhiyun __entry->index = index; 3121*4882a593Smuzhiyun MAC_ASSIGN(bssid, bssid); 3122*4882a593Smuzhiyun __entry->preauth = preauth; 3123*4882a593Smuzhiyun ), 3124*4882a593Smuzhiyun TP_printk(NETDEV_PR_FMT ", index:%d, bssid: " MAC_PR_FMT ", pre auth: %s", 3125*4882a593Smuzhiyun NETDEV_PR_ARG, __entry->index, MAC_PR_ARG(bssid), 3126*4882a593Smuzhiyun BOOL_TO_STR(__entry->preauth)) 3127*4882a593Smuzhiyun ); 3128*4882a593Smuzhiyun 3129*4882a593Smuzhiyun TRACE_EVENT(cfg80211_report_obss_beacon, 3130*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, const u8 *frame, size_t len, 3131*4882a593Smuzhiyun int freq, int sig_dbm), 3132*4882a593Smuzhiyun TP_ARGS(wiphy, frame, len, freq, sig_dbm), 3133*4882a593Smuzhiyun TP_STRUCT__entry( 3134*4882a593Smuzhiyun WIPHY_ENTRY 3135*4882a593Smuzhiyun __field(int, freq) 3136*4882a593Smuzhiyun __field(int, sig_dbm) 3137*4882a593Smuzhiyun ), 3138*4882a593Smuzhiyun TP_fast_assign( 3139*4882a593Smuzhiyun WIPHY_ASSIGN; 3140*4882a593Smuzhiyun __entry->freq = freq; 3141*4882a593Smuzhiyun __entry->sig_dbm = sig_dbm; 3142*4882a593Smuzhiyun ), 3143*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", freq: "KHZ_F", sig_dbm: %d", 3144*4882a593Smuzhiyun WIPHY_PR_ARG, PR_KHZ(__entry->freq), __entry->sig_dbm) 3145*4882a593Smuzhiyun ); 3146*4882a593Smuzhiyun 3147*4882a593Smuzhiyun TRACE_EVENT(cfg80211_tdls_oper_request, 3148*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, const u8 *peer, 3149*4882a593Smuzhiyun enum nl80211_tdls_operation oper, u16 reason_code), 3150*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, peer, oper, reason_code), 3151*4882a593Smuzhiyun TP_STRUCT__entry( 3152*4882a593Smuzhiyun WIPHY_ENTRY 3153*4882a593Smuzhiyun NETDEV_ENTRY 3154*4882a593Smuzhiyun MAC_ENTRY(peer) 3155*4882a593Smuzhiyun __field(enum nl80211_tdls_operation, oper) 3156*4882a593Smuzhiyun __field(u16, reason_code) 3157*4882a593Smuzhiyun ), 3158*4882a593Smuzhiyun TP_fast_assign( 3159*4882a593Smuzhiyun WIPHY_ASSIGN; 3160*4882a593Smuzhiyun NETDEV_ASSIGN; 3161*4882a593Smuzhiyun MAC_ASSIGN(peer, peer); 3162*4882a593Smuzhiyun __entry->oper = oper; 3163*4882a593Smuzhiyun __entry->reason_code = reason_code; 3164*4882a593Smuzhiyun ), 3165*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", peer: " MAC_PR_FMT ", oper: %d, reason_code %u", 3166*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(peer), __entry->oper, 3167*4882a593Smuzhiyun __entry->reason_code) 3168*4882a593Smuzhiyun ); 3169*4882a593Smuzhiyun 3170*4882a593Smuzhiyun TRACE_EVENT(cfg80211_scan_done, 3171*4882a593Smuzhiyun TP_PROTO(struct cfg80211_scan_request *request, 3172*4882a593Smuzhiyun struct cfg80211_scan_info *info), 3173*4882a593Smuzhiyun TP_ARGS(request, info), 3174*4882a593Smuzhiyun TP_STRUCT__entry( 3175*4882a593Smuzhiyun __field(u32, n_channels) 3176*4882a593Smuzhiyun __dynamic_array(u8, ie, request ? request->ie_len : 0) 3177*4882a593Smuzhiyun __array(u32, rates, NUM_NL80211_BANDS) 3178*4882a593Smuzhiyun __field(u32, wdev_id) 3179*4882a593Smuzhiyun MAC_ENTRY(wiphy_mac) 3180*4882a593Smuzhiyun __field(bool, no_cck) 3181*4882a593Smuzhiyun __field(bool, aborted) 3182*4882a593Smuzhiyun __field(u64, scan_start_tsf) 3183*4882a593Smuzhiyun MAC_ENTRY(tsf_bssid) 3184*4882a593Smuzhiyun ), 3185*4882a593Smuzhiyun TP_fast_assign( 3186*4882a593Smuzhiyun if (request) { 3187*4882a593Smuzhiyun memcpy(__get_dynamic_array(ie), request->ie, 3188*4882a593Smuzhiyun request->ie_len); 3189*4882a593Smuzhiyun memcpy(__entry->rates, request->rates, 3190*4882a593Smuzhiyun NUM_NL80211_BANDS); 3191*4882a593Smuzhiyun __entry->wdev_id = request->wdev ? 3192*4882a593Smuzhiyun request->wdev->identifier : 0; 3193*4882a593Smuzhiyun if (request->wiphy) 3194*4882a593Smuzhiyun MAC_ASSIGN(wiphy_mac, 3195*4882a593Smuzhiyun request->wiphy->perm_addr); 3196*4882a593Smuzhiyun __entry->no_cck = request->no_cck; 3197*4882a593Smuzhiyun } 3198*4882a593Smuzhiyun if (info) { 3199*4882a593Smuzhiyun __entry->aborted = info->aborted; 3200*4882a593Smuzhiyun __entry->scan_start_tsf = info->scan_start_tsf; 3201*4882a593Smuzhiyun MAC_ASSIGN(tsf_bssid, info->tsf_bssid); 3202*4882a593Smuzhiyun } 3203*4882a593Smuzhiyun ), 3204*4882a593Smuzhiyun TP_printk("aborted: %s, scan start (TSF): %llu, tsf_bssid: " MAC_PR_FMT, 3205*4882a593Smuzhiyun BOOL_TO_STR(__entry->aborted), 3206*4882a593Smuzhiyun (unsigned long long)__entry->scan_start_tsf, 3207*4882a593Smuzhiyun MAC_PR_ARG(tsf_bssid)) 3208*4882a593Smuzhiyun ); 3209*4882a593Smuzhiyun 3210*4882a593Smuzhiyun DECLARE_EVENT_CLASS(wiphy_id_evt, 3211*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, u64 id), 3212*4882a593Smuzhiyun TP_ARGS(wiphy, id), 3213*4882a593Smuzhiyun TP_STRUCT__entry( 3214*4882a593Smuzhiyun WIPHY_ENTRY 3215*4882a593Smuzhiyun __field(u64, id) 3216*4882a593Smuzhiyun ), 3217*4882a593Smuzhiyun TP_fast_assign( 3218*4882a593Smuzhiyun WIPHY_ASSIGN; 3219*4882a593Smuzhiyun __entry->id = id; 3220*4882a593Smuzhiyun ), 3221*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", id: %llu", WIPHY_PR_ARG, __entry->id) 3222*4882a593Smuzhiyun ); 3223*4882a593Smuzhiyun 3224*4882a593Smuzhiyun DEFINE_EVENT(wiphy_id_evt, cfg80211_sched_scan_stopped, 3225*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, u64 id), 3226*4882a593Smuzhiyun TP_ARGS(wiphy, id) 3227*4882a593Smuzhiyun ); 3228*4882a593Smuzhiyun 3229*4882a593Smuzhiyun DEFINE_EVENT(wiphy_id_evt, cfg80211_sched_scan_results, 3230*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, u64 id), 3231*4882a593Smuzhiyun TP_ARGS(wiphy, id) 3232*4882a593Smuzhiyun ); 3233*4882a593Smuzhiyun 3234*4882a593Smuzhiyun TRACE_EVENT(cfg80211_get_bss, 3235*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct ieee80211_channel *channel, 3236*4882a593Smuzhiyun const u8 *bssid, const u8 *ssid, size_t ssid_len, 3237*4882a593Smuzhiyun enum ieee80211_bss_type bss_type, 3238*4882a593Smuzhiyun enum ieee80211_privacy privacy), 3239*4882a593Smuzhiyun TP_ARGS(wiphy, channel, bssid, ssid, ssid_len, bss_type, privacy), 3240*4882a593Smuzhiyun TP_STRUCT__entry( 3241*4882a593Smuzhiyun WIPHY_ENTRY 3242*4882a593Smuzhiyun CHAN_ENTRY 3243*4882a593Smuzhiyun MAC_ENTRY(bssid) 3244*4882a593Smuzhiyun __dynamic_array(u8, ssid, ssid_len) 3245*4882a593Smuzhiyun __field(enum ieee80211_bss_type, bss_type) 3246*4882a593Smuzhiyun __field(enum ieee80211_privacy, privacy) 3247*4882a593Smuzhiyun ), 3248*4882a593Smuzhiyun TP_fast_assign( 3249*4882a593Smuzhiyun WIPHY_ASSIGN; 3250*4882a593Smuzhiyun CHAN_ASSIGN(channel); 3251*4882a593Smuzhiyun MAC_ASSIGN(bssid, bssid); 3252*4882a593Smuzhiyun memcpy(__get_dynamic_array(ssid), ssid, ssid_len); 3253*4882a593Smuzhiyun __entry->bss_type = bss_type; 3254*4882a593Smuzhiyun __entry->privacy = privacy; 3255*4882a593Smuzhiyun ), 3256*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " CHAN_PR_FMT ", " MAC_PR_FMT 3257*4882a593Smuzhiyun ", buf: %#.2x, bss_type: %d, privacy: %d", 3258*4882a593Smuzhiyun WIPHY_PR_ARG, CHAN_PR_ARG, MAC_PR_ARG(bssid), 3259*4882a593Smuzhiyun ((u8 *)__get_dynamic_array(ssid))[0], __entry->bss_type, 3260*4882a593Smuzhiyun __entry->privacy) 3261*4882a593Smuzhiyun ); 3262*4882a593Smuzhiyun 3263*4882a593Smuzhiyun TRACE_EVENT(cfg80211_inform_bss_frame, 3264*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct cfg80211_inform_bss *data, 3265*4882a593Smuzhiyun struct ieee80211_mgmt *mgmt, size_t len), 3266*4882a593Smuzhiyun TP_ARGS(wiphy, data, mgmt, len), 3267*4882a593Smuzhiyun TP_STRUCT__entry( 3268*4882a593Smuzhiyun WIPHY_ENTRY 3269*4882a593Smuzhiyun CHAN_ENTRY 3270*4882a593Smuzhiyun __field(enum nl80211_bss_scan_width, scan_width) 3271*4882a593Smuzhiyun __dynamic_array(u8, mgmt, len) 3272*4882a593Smuzhiyun __field(s32, signal) 3273*4882a593Smuzhiyun __field(u64, ts_boottime) 3274*4882a593Smuzhiyun __field(u64, parent_tsf) 3275*4882a593Smuzhiyun MAC_ENTRY(parent_bssid) 3276*4882a593Smuzhiyun ), 3277*4882a593Smuzhiyun TP_fast_assign( 3278*4882a593Smuzhiyun WIPHY_ASSIGN; 3279*4882a593Smuzhiyun CHAN_ASSIGN(data->chan); 3280*4882a593Smuzhiyun __entry->scan_width = data->scan_width; 3281*4882a593Smuzhiyun if (mgmt) 3282*4882a593Smuzhiyun memcpy(__get_dynamic_array(mgmt), mgmt, len); 3283*4882a593Smuzhiyun __entry->signal = data->signal; 3284*4882a593Smuzhiyun __entry->ts_boottime = data->boottime_ns; 3285*4882a593Smuzhiyun __entry->parent_tsf = data->parent_tsf; 3286*4882a593Smuzhiyun MAC_ASSIGN(parent_bssid, data->parent_bssid); 3287*4882a593Smuzhiyun ), 3288*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " CHAN_PR_FMT 3289*4882a593Smuzhiyun "(scan_width: %d) signal: %d, tsb:%llu, detect_tsf:%llu, tsf_bssid: " 3290*4882a593Smuzhiyun MAC_PR_FMT, WIPHY_PR_ARG, CHAN_PR_ARG, __entry->scan_width, 3291*4882a593Smuzhiyun __entry->signal, (unsigned long long)__entry->ts_boottime, 3292*4882a593Smuzhiyun (unsigned long long)__entry->parent_tsf, 3293*4882a593Smuzhiyun MAC_PR_ARG(parent_bssid)) 3294*4882a593Smuzhiyun ); 3295*4882a593Smuzhiyun 3296*4882a593Smuzhiyun DECLARE_EVENT_CLASS(cfg80211_bss_evt, 3297*4882a593Smuzhiyun TP_PROTO(struct cfg80211_bss *pub), 3298*4882a593Smuzhiyun TP_ARGS(pub), 3299*4882a593Smuzhiyun TP_STRUCT__entry( 3300*4882a593Smuzhiyun MAC_ENTRY(bssid) 3301*4882a593Smuzhiyun CHAN_ENTRY 3302*4882a593Smuzhiyun ), 3303*4882a593Smuzhiyun TP_fast_assign( 3304*4882a593Smuzhiyun MAC_ASSIGN(bssid, pub->bssid); 3305*4882a593Smuzhiyun CHAN_ASSIGN(pub->channel); 3306*4882a593Smuzhiyun ), 3307*4882a593Smuzhiyun TP_printk(MAC_PR_FMT ", " CHAN_PR_FMT, MAC_PR_ARG(bssid), CHAN_PR_ARG) 3308*4882a593Smuzhiyun ); 3309*4882a593Smuzhiyun 3310*4882a593Smuzhiyun DEFINE_EVENT(cfg80211_bss_evt, cfg80211_return_bss, 3311*4882a593Smuzhiyun TP_PROTO(struct cfg80211_bss *pub), 3312*4882a593Smuzhiyun TP_ARGS(pub) 3313*4882a593Smuzhiyun ); 3314*4882a593Smuzhiyun 3315*4882a593Smuzhiyun TRACE_EVENT(cfg80211_return_uint, 3316*4882a593Smuzhiyun TP_PROTO(unsigned int ret), 3317*4882a593Smuzhiyun TP_ARGS(ret), 3318*4882a593Smuzhiyun TP_STRUCT__entry( 3319*4882a593Smuzhiyun __field(unsigned int, ret) 3320*4882a593Smuzhiyun ), 3321*4882a593Smuzhiyun TP_fast_assign( 3322*4882a593Smuzhiyun __entry->ret = ret; 3323*4882a593Smuzhiyun ), 3324*4882a593Smuzhiyun TP_printk("ret: %d", __entry->ret) 3325*4882a593Smuzhiyun ); 3326*4882a593Smuzhiyun 3327*4882a593Smuzhiyun TRACE_EVENT(cfg80211_return_u32, 3328*4882a593Smuzhiyun TP_PROTO(u32 ret), 3329*4882a593Smuzhiyun TP_ARGS(ret), 3330*4882a593Smuzhiyun TP_STRUCT__entry( 3331*4882a593Smuzhiyun __field(u32, ret) 3332*4882a593Smuzhiyun ), 3333*4882a593Smuzhiyun TP_fast_assign( 3334*4882a593Smuzhiyun __entry->ret = ret; 3335*4882a593Smuzhiyun ), 3336*4882a593Smuzhiyun TP_printk("ret: %u", __entry->ret) 3337*4882a593Smuzhiyun ); 3338*4882a593Smuzhiyun 3339*4882a593Smuzhiyun TRACE_EVENT(cfg80211_report_wowlan_wakeup, 3340*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev, 3341*4882a593Smuzhiyun struct cfg80211_wowlan_wakeup *wakeup), 3342*4882a593Smuzhiyun TP_ARGS(wiphy, wdev, wakeup), 3343*4882a593Smuzhiyun TP_STRUCT__entry( 3344*4882a593Smuzhiyun WIPHY_ENTRY 3345*4882a593Smuzhiyun WDEV_ENTRY 3346*4882a593Smuzhiyun __field(bool, non_wireless) 3347*4882a593Smuzhiyun __field(bool, disconnect) 3348*4882a593Smuzhiyun __field(bool, magic_pkt) 3349*4882a593Smuzhiyun __field(bool, gtk_rekey_failure) 3350*4882a593Smuzhiyun __field(bool, eap_identity_req) 3351*4882a593Smuzhiyun __field(bool, four_way_handshake) 3352*4882a593Smuzhiyun __field(bool, rfkill_release) 3353*4882a593Smuzhiyun __field(s32, pattern_idx) 3354*4882a593Smuzhiyun __field(u32, packet_len) 3355*4882a593Smuzhiyun __dynamic_array(u8, packet, 3356*4882a593Smuzhiyun wakeup ? wakeup->packet_present_len : 0) 3357*4882a593Smuzhiyun ), 3358*4882a593Smuzhiyun TP_fast_assign( 3359*4882a593Smuzhiyun WIPHY_ASSIGN; 3360*4882a593Smuzhiyun WDEV_ASSIGN; 3361*4882a593Smuzhiyun __entry->non_wireless = !wakeup; 3362*4882a593Smuzhiyun __entry->disconnect = wakeup ? wakeup->disconnect : false; 3363*4882a593Smuzhiyun __entry->magic_pkt = wakeup ? wakeup->magic_pkt : false; 3364*4882a593Smuzhiyun __entry->gtk_rekey_failure = wakeup ? wakeup->gtk_rekey_failure : false; 3365*4882a593Smuzhiyun __entry->eap_identity_req = wakeup ? wakeup->eap_identity_req : false; 3366*4882a593Smuzhiyun __entry->four_way_handshake = wakeup ? wakeup->four_way_handshake : false; 3367*4882a593Smuzhiyun __entry->rfkill_release = wakeup ? wakeup->rfkill_release : false; 3368*4882a593Smuzhiyun __entry->pattern_idx = wakeup ? wakeup->pattern_idx : false; 3369*4882a593Smuzhiyun __entry->packet_len = wakeup ? wakeup->packet_len : false; 3370*4882a593Smuzhiyun if (wakeup && wakeup->packet && wakeup->packet_present_len) 3371*4882a593Smuzhiyun memcpy(__get_dynamic_array(packet), wakeup->packet, 3372*4882a593Smuzhiyun wakeup->packet_present_len); 3373*4882a593Smuzhiyun ), 3374*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " WDEV_PR_FMT, WIPHY_PR_ARG, WDEV_PR_ARG) 3375*4882a593Smuzhiyun ); 3376*4882a593Smuzhiyun 3377*4882a593Smuzhiyun TRACE_EVENT(cfg80211_ft_event, 3378*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 3379*4882a593Smuzhiyun struct cfg80211_ft_event_params *ft_event), 3380*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, ft_event), 3381*4882a593Smuzhiyun TP_STRUCT__entry( 3382*4882a593Smuzhiyun WIPHY_ENTRY 3383*4882a593Smuzhiyun NETDEV_ENTRY 3384*4882a593Smuzhiyun __dynamic_array(u8, ies, ft_event->ies_len) 3385*4882a593Smuzhiyun MAC_ENTRY(target_ap) 3386*4882a593Smuzhiyun __dynamic_array(u8, ric_ies, ft_event->ric_ies_len) 3387*4882a593Smuzhiyun ), 3388*4882a593Smuzhiyun TP_fast_assign( 3389*4882a593Smuzhiyun WIPHY_ASSIGN; 3390*4882a593Smuzhiyun NETDEV_ASSIGN; 3391*4882a593Smuzhiyun if (ft_event->ies) 3392*4882a593Smuzhiyun memcpy(__get_dynamic_array(ies), ft_event->ies, 3393*4882a593Smuzhiyun ft_event->ies_len); 3394*4882a593Smuzhiyun MAC_ASSIGN(target_ap, ft_event->target_ap); 3395*4882a593Smuzhiyun if (ft_event->ric_ies) 3396*4882a593Smuzhiyun memcpy(__get_dynamic_array(ric_ies), ft_event->ric_ies, 3397*4882a593Smuzhiyun ft_event->ric_ies_len); 3398*4882a593Smuzhiyun ), 3399*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", target_ap: " MAC_PR_FMT, 3400*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(target_ap)) 3401*4882a593Smuzhiyun ); 3402*4882a593Smuzhiyun 3403*4882a593Smuzhiyun TRACE_EVENT(cfg80211_stop_iface, 3404*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev), 3405*4882a593Smuzhiyun TP_ARGS(wiphy, wdev), 3406*4882a593Smuzhiyun TP_STRUCT__entry( 3407*4882a593Smuzhiyun WIPHY_ENTRY 3408*4882a593Smuzhiyun WDEV_ENTRY 3409*4882a593Smuzhiyun ), 3410*4882a593Smuzhiyun TP_fast_assign( 3411*4882a593Smuzhiyun WIPHY_ASSIGN; 3412*4882a593Smuzhiyun WDEV_ASSIGN; 3413*4882a593Smuzhiyun ), 3414*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " WDEV_PR_FMT, 3415*4882a593Smuzhiyun WIPHY_PR_ARG, WDEV_PR_ARG) 3416*4882a593Smuzhiyun ); 3417*4882a593Smuzhiyun 3418*4882a593Smuzhiyun TRACE_EVENT(cfg80211_pmsr_report, 3419*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev, 3420*4882a593Smuzhiyun u64 cookie, const u8 *addr), 3421*4882a593Smuzhiyun TP_ARGS(wiphy, wdev, cookie, addr), 3422*4882a593Smuzhiyun TP_STRUCT__entry( 3423*4882a593Smuzhiyun WIPHY_ENTRY 3424*4882a593Smuzhiyun WDEV_ENTRY 3425*4882a593Smuzhiyun __field(u64, cookie) 3426*4882a593Smuzhiyun MAC_ENTRY(addr) 3427*4882a593Smuzhiyun ), 3428*4882a593Smuzhiyun TP_fast_assign( 3429*4882a593Smuzhiyun WIPHY_ASSIGN; 3430*4882a593Smuzhiyun WDEV_ASSIGN; 3431*4882a593Smuzhiyun __entry->cookie = cookie; 3432*4882a593Smuzhiyun MAC_ASSIGN(addr, addr); 3433*4882a593Smuzhiyun ), 3434*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " WDEV_PR_FMT ", cookie:%lld, " MAC_PR_FMT, 3435*4882a593Smuzhiyun WIPHY_PR_ARG, WDEV_PR_ARG, 3436*4882a593Smuzhiyun (unsigned long long)__entry->cookie, 3437*4882a593Smuzhiyun MAC_PR_ARG(addr)) 3438*4882a593Smuzhiyun ); 3439*4882a593Smuzhiyun 3440*4882a593Smuzhiyun TRACE_EVENT(cfg80211_pmsr_complete, 3441*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct wireless_dev *wdev, u64 cookie), 3442*4882a593Smuzhiyun TP_ARGS(wiphy, wdev, cookie), 3443*4882a593Smuzhiyun TP_STRUCT__entry( 3444*4882a593Smuzhiyun WIPHY_ENTRY 3445*4882a593Smuzhiyun WDEV_ENTRY 3446*4882a593Smuzhiyun __field(u64, cookie) 3447*4882a593Smuzhiyun ), 3448*4882a593Smuzhiyun TP_fast_assign( 3449*4882a593Smuzhiyun WIPHY_ASSIGN; 3450*4882a593Smuzhiyun WDEV_ASSIGN; 3451*4882a593Smuzhiyun __entry->cookie = cookie; 3452*4882a593Smuzhiyun ), 3453*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " WDEV_PR_FMT ", cookie:%lld", 3454*4882a593Smuzhiyun WIPHY_PR_ARG, WDEV_PR_ARG, 3455*4882a593Smuzhiyun (unsigned long long)__entry->cookie) 3456*4882a593Smuzhiyun ); 3457*4882a593Smuzhiyun 3458*4882a593Smuzhiyun TRACE_EVENT(rdev_update_owe_info, 3459*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 3460*4882a593Smuzhiyun struct cfg80211_update_owe_info *owe_info), 3461*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, owe_info), 3462*4882a593Smuzhiyun TP_STRUCT__entry(WIPHY_ENTRY 3463*4882a593Smuzhiyun NETDEV_ENTRY 3464*4882a593Smuzhiyun MAC_ENTRY(peer) 3465*4882a593Smuzhiyun __field(u16, status) 3466*4882a593Smuzhiyun __dynamic_array(u8, ie, owe_info->ie_len)), 3467*4882a593Smuzhiyun TP_fast_assign(WIPHY_ASSIGN; 3468*4882a593Smuzhiyun NETDEV_ASSIGN; 3469*4882a593Smuzhiyun MAC_ASSIGN(peer, owe_info->peer); 3470*4882a593Smuzhiyun __entry->status = owe_info->status; 3471*4882a593Smuzhiyun memcpy(__get_dynamic_array(ie), 3472*4882a593Smuzhiyun owe_info->ie, owe_info->ie_len);), 3473*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", peer: " MAC_PR_FMT 3474*4882a593Smuzhiyun " status %d", WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(peer), 3475*4882a593Smuzhiyun __entry->status) 3476*4882a593Smuzhiyun ); 3477*4882a593Smuzhiyun 3478*4882a593Smuzhiyun TRACE_EVENT(cfg80211_update_owe_info_event, 3479*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 3480*4882a593Smuzhiyun struct cfg80211_update_owe_info *owe_info), 3481*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, owe_info), 3482*4882a593Smuzhiyun TP_STRUCT__entry(WIPHY_ENTRY 3483*4882a593Smuzhiyun NETDEV_ENTRY 3484*4882a593Smuzhiyun MAC_ENTRY(peer) 3485*4882a593Smuzhiyun __dynamic_array(u8, ie, owe_info->ie_len)), 3486*4882a593Smuzhiyun TP_fast_assign(WIPHY_ASSIGN; 3487*4882a593Smuzhiyun NETDEV_ASSIGN; 3488*4882a593Smuzhiyun MAC_ASSIGN(peer, owe_info->peer); 3489*4882a593Smuzhiyun memcpy(__get_dynamic_array(ie), owe_info->ie, 3490*4882a593Smuzhiyun owe_info->ie_len);), 3491*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", peer: " MAC_PR_FMT, 3492*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(peer)) 3493*4882a593Smuzhiyun ); 3494*4882a593Smuzhiyun 3495*4882a593Smuzhiyun TRACE_EVENT(rdev_probe_mesh_link, 3496*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 3497*4882a593Smuzhiyun const u8 *dest, const u8 *buf, size_t len), 3498*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, dest, buf, len), 3499*4882a593Smuzhiyun TP_STRUCT__entry( 3500*4882a593Smuzhiyun WIPHY_ENTRY 3501*4882a593Smuzhiyun NETDEV_ENTRY 3502*4882a593Smuzhiyun MAC_ENTRY(dest) 3503*4882a593Smuzhiyun ), 3504*4882a593Smuzhiyun TP_fast_assign( 3505*4882a593Smuzhiyun WIPHY_ASSIGN; 3506*4882a593Smuzhiyun NETDEV_ASSIGN; 3507*4882a593Smuzhiyun MAC_ASSIGN(dest, dest); 3508*4882a593Smuzhiyun ), 3509*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", " MAC_PR_FMT, 3510*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(dest)) 3511*4882a593Smuzhiyun ); 3512*4882a593Smuzhiyun 3513*4882a593Smuzhiyun TRACE_EVENT(rdev_set_tid_config, 3514*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 3515*4882a593Smuzhiyun struct cfg80211_tid_config *tid_conf), 3516*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, tid_conf), 3517*4882a593Smuzhiyun TP_STRUCT__entry( 3518*4882a593Smuzhiyun WIPHY_ENTRY 3519*4882a593Smuzhiyun NETDEV_ENTRY 3520*4882a593Smuzhiyun MAC_ENTRY(peer) 3521*4882a593Smuzhiyun ), 3522*4882a593Smuzhiyun TP_fast_assign( 3523*4882a593Smuzhiyun WIPHY_ASSIGN; 3524*4882a593Smuzhiyun NETDEV_ASSIGN; 3525*4882a593Smuzhiyun MAC_ASSIGN(peer, tid_conf->peer); 3526*4882a593Smuzhiyun ), 3527*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", peer: " MAC_PR_FMT, 3528*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(peer)) 3529*4882a593Smuzhiyun ); 3530*4882a593Smuzhiyun 3531*4882a593Smuzhiyun TRACE_EVENT(rdev_reset_tid_config, 3532*4882a593Smuzhiyun TP_PROTO(struct wiphy *wiphy, struct net_device *netdev, 3533*4882a593Smuzhiyun const u8 *peer, u8 tids), 3534*4882a593Smuzhiyun TP_ARGS(wiphy, netdev, peer, tids), 3535*4882a593Smuzhiyun TP_STRUCT__entry( 3536*4882a593Smuzhiyun WIPHY_ENTRY 3537*4882a593Smuzhiyun NETDEV_ENTRY 3538*4882a593Smuzhiyun MAC_ENTRY(peer) 3539*4882a593Smuzhiyun __field(u8, tids) 3540*4882a593Smuzhiyun ), 3541*4882a593Smuzhiyun TP_fast_assign( 3542*4882a593Smuzhiyun WIPHY_ASSIGN; 3543*4882a593Smuzhiyun NETDEV_ASSIGN; 3544*4882a593Smuzhiyun MAC_ASSIGN(peer, peer); 3545*4882a593Smuzhiyun __entry->tids = tids; 3546*4882a593Smuzhiyun ), 3547*4882a593Smuzhiyun TP_printk(WIPHY_PR_FMT ", " NETDEV_PR_FMT ", peer: " MAC_PR_FMT ", tids: 0x%x", 3548*4882a593Smuzhiyun WIPHY_PR_ARG, NETDEV_PR_ARG, MAC_PR_ARG(peer), __entry->tids) 3549*4882a593Smuzhiyun ); 3550*4882a593Smuzhiyun #endif /* !__RDEV_OPS_TRACE || TRACE_HEADER_MULTI_READ */ 3551*4882a593Smuzhiyun 3552*4882a593Smuzhiyun #undef TRACE_INCLUDE_PATH 3553*4882a593Smuzhiyun #define TRACE_INCLUDE_PATH . 3554*4882a593Smuzhiyun #undef TRACE_INCLUDE_FILE 3555*4882a593Smuzhiyun #define TRACE_INCLUDE_FILE trace 3556*4882a593Smuzhiyun #include <trace/define_trace.h> 3557