1
0
mirror of https://git.FreeBSD.org/src.git synced 2024-12-22 11:17:19 +00:00

Add the "enable at reset" functionality to trigger spectral scan upon

a channel change/reset.
This commit is contained in:
Adrian Chadd 2013-01-09 18:50:06 +00:00
parent 164051cea5
commit 1efdee81a9
Notes: svn2git 2020-12-20 02:59:44 +00:00
svn path=/head/; revision=245231

View File

@ -187,6 +187,29 @@ spectral_stop(struct spectralhandler *spectral)
err(1, spectral->atd.ad_name); err(1, spectral->atd.ad_name);
} }
static void
spectral_enable_at_reset(struct spectralhandler *spectral, int val)
{
int v = val;
spectral->atd.ad_id = SPECTRAL_CONTROL_ENABLE_AT_RESET
| ATH_DIAG_IN;
/*
* XXX don't need these, but need to eliminate the ATH_DIAG_DYN flag
* and debug
*/
spectral->atd.ad_out_data = NULL;
spectral->atd.ad_out_size = 0;
spectral->atd.ad_in_data = (caddr_t) &v;
spectral->atd.ad_in_size = sizeof(v);
printf("%s: val=%d\n", __func__, v);
if (ioctl(spectral->s, SIOCGATHSPECTRAL, &spectral->atd) < 0)
err(1, spectral->atd.ad_name);
}
static int static int
spectral_set_param(struct spectralhandler *spectral, const char *param, spectral_set_param(struct spectralhandler *spectral, const char *param,
const char *val) const char *val)
@ -258,6 +281,7 @@ usage(const char *progname)
printf("\tset <param> <value>:\t\tSet spectral parameter\n"); printf("\tset <param> <value>:\t\tSet spectral parameter\n");
printf("\tstart: Start spectral scan\n"); printf("\tstart: Start spectral scan\n");
printf("\tstop: Stop spectral scan\n"); printf("\tstop: Stop spectral scan\n");
printf("\tenable_at_reset <0|1>: enable reporting upon channel reset\n");
} }
int int
@ -312,6 +336,12 @@ main(int argc, char *argv[])
spectral_start(&spectral); spectral_start(&spectral);
} else if (strcasecmp(argv[1], "stop") == 0) { } else if (strcasecmp(argv[1], "stop") == 0) {
spectral_stop(&spectral); spectral_stop(&spectral);
} else if (strcasecmp(argv[1], "enable_at_reset") == 0) {
if (argc < 3) {
usage(progname);
exit(127);
}
spectral_enable_at_reset(&spectral, atoi(argv[2]));
} else { } else {
usage(progname); usage(progname);
exit(127); exit(127);