2013-12-03 14:09:30 +01:00
/*
* Copyright ( C ) 2009 Johannes Berg < johannes @ sipsolutions . net >
*
* ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation ;
* version 2.1 of the License ( not later ! )
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU Lesser General Public License for more details .
*
* You should have received a copy of the GNU Lesser General Public
* License along with this program ; if not , see < http : //www.gnu.org/licenses>
*
* ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
*/
# include <stdio.h>
# include <stdlib.h>
# include <string.h>
# include "event-parse.h"
# define INDENT 65
static void print_string ( struct trace_seq * s , struct event_format * event ,
const char * name , const void * data )
{
2018-08-08 14:02:50 -04:00
struct format_field * f = tep_find_field ( event , name ) ;
2013-12-03 14:09:30 +01:00
int offset ;
int length ;
if ( ! f ) {
trace_seq_printf ( s , " NOTFOUND:%s " , name ) ;
return ;
}
offset = f - > offset ;
length = f - > size ;
if ( ! strncmp ( f - > type , " __data_loc " , 10 ) ) {
unsigned long long v ;
2018-08-08 14:02:53 -04:00
if ( tep_read_number_field ( f , data , & v ) ) {
2013-12-03 14:09:30 +01:00
trace_seq_printf ( s , " invalid_data_loc " ) ;
return ;
}
offset = v & 0xffff ;
length = v > > 16 ;
}
trace_seq_printf ( s , " %.*s " , length , ( char * ) data + offset ) ;
}
2018-08-08 14:02:52 -04:00
# define SF(fn) tep_print_num_field(s, fn ":%d", event, fn, record, 0)
# define SFX(fn) tep_print_num_field(s, fn ":%#x", event, fn, record, 0)
2013-12-03 14:09:30 +01:00
# define SP() trace_seq_putc(s, ' ')
static int drv_bss_info_changed ( struct trace_seq * s ,
2018-08-08 14:02:47 -04:00
struct tep_record * record ,
2013-12-03 14:09:30 +01:00
struct event_format * event , void * context )
{
void * data = record - > data ;
print_string ( s , event , " wiphy_name " , data ) ;
trace_seq_printf ( s , " vif: " ) ;
print_string ( s , event , " vif_name " , data ) ;
2018-08-08 14:02:52 -04:00
tep_print_num_field ( s , " (%d) " , event , " vif_type " , record , 1 ) ;
2013-12-03 14:09:30 +01:00
trace_seq_printf ( s , " \n %*s " , INDENT , " " ) ;
SF ( " assoc " ) ; SP ( ) ;
SF ( " aid " ) ; SP ( ) ;
SF ( " cts " ) ; SP ( ) ;
SF ( " shortpre " ) ; SP ( ) ;
SF ( " shortslot " ) ; SP ( ) ;
SF ( " dtimper " ) ; SP ( ) ;
trace_seq_printf ( s , " \n %*s " , INDENT , " " ) ;
SF ( " bcnint " ) ; SP ( ) ;
SFX ( " assoc_cap " ) ; SP ( ) ;
SFX ( " basic_rates " ) ; SP ( ) ;
SF ( " enable_beacon " ) ;
trace_seq_printf ( s , " \n %*s " , INDENT , " " ) ;
SF ( " ht_operation_mode " ) ;
return 0 ;
}
2018-08-08 14:02:48 -04:00
int TEP_PLUGIN_LOADER ( struct tep_handle * pevent )
2013-12-03 14:09:30 +01:00
{
2018-08-08 14:03:02 -04:00
tep_register_event_handler ( pevent , - 1 , " mac80211 " ,
" drv_bss_info_changed " ,
drv_bss_info_changed , NULL ) ;
2013-12-03 14:09:30 +01:00
return 0 ;
}
2014-01-16 11:31:14 +09:00
2018-08-08 14:02:48 -04:00
void TEP_PLUGIN_UNLOADER ( struct tep_handle * pevent )
2014-01-16 11:31:14 +09:00
{
2018-08-08 14:03:02 -04:00
tep_unregister_event_handler ( pevent , - 1 , " mac80211 " ,
" drv_bss_info_changed " ,
drv_bss_info_changed , NULL ) ;
2014-01-16 11:31:14 +09:00
}