mirror of
git://projects.qi-hardware.com/ben-wpan.git
synced 2024-11-20 02:59:42 +02:00
atspi-rssi cleanup: wait for interrupt, exit cleanly.
- tools/atspi-rssi/atspi-rssi.c: removed unnecessary inclusion of atspi/ep0.h - tools/atspi-rssi/atspi-rssi.c (sweep): instead of fixed delay, wait for the PLL lock interrupt - tools/atspi-rssi/atspi-rssi.c (die, main): catch SIGINT to exit cleanly - tools/atspi-rssi/atspi-rssi.c (main): shut down properly when done - tools/atspi-rssi/atspi-rssi.c (usage): print "usage:" before the program's name
This commit is contained in:
parent
2a245e1ee3
commit
4df6d2c2f9
@ -13,14 +13,16 @@
|
|||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#include <signal.h>
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
|
|
||||||
#include "at86rf230.h"
|
#include "at86rf230.h"
|
||||||
#include "atspi/ep0.h"
|
|
||||||
#include "atspi.h"
|
#include "atspi.h"
|
||||||
|
#include "misctxrx.h"
|
||||||
|
|
||||||
|
|
||||||
static struct timeval t0;
|
static struct timeval t0;
|
||||||
|
static volatile int run = 1;
|
||||||
|
|
||||||
|
|
||||||
static void sweep(struct atspi_dsc *dsc)
|
static void sweep(struct atspi_dsc *dsc)
|
||||||
@ -31,7 +33,8 @@ static void sweep(struct atspi_dsc *dsc)
|
|||||||
for (chan = 11; chan <= 26; chan++) {
|
for (chan = 11; chan <= 26; chan++) {
|
||||||
atspi_reg_write(dsc, REG_PHY_CC_CCA, chan);
|
atspi_reg_write(dsc, REG_PHY_CC_CCA, chan);
|
||||||
/* 150 us, according to AVR2001 section 3.5 */
|
/* 150 us, according to AVR2001 section 3.5 */
|
||||||
usleep(1000);
|
wait_for_interrupt(dsc, IRQ_PLL_LOCK, IRQ_PLL_LOCK, 10, 20);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* No need to explicitly wait for the PPL lock - going USB-SPI
|
* No need to explicitly wait for the PPL lock - going USB-SPI
|
||||||
* is pretty slow, leaving the transceiver plenty of time.
|
* is pretty slow, leaving the transceiver plenty of time.
|
||||||
@ -49,9 +52,15 @@ static void sweep(struct atspi_dsc *dsc)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void die(int sig)
|
||||||
|
{
|
||||||
|
run = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static void usage(const char *name)
|
static void usage(const char *name)
|
||||||
{
|
{
|
||||||
fprintf(stderr, "%s sweeps \n", name);
|
fprintf(stderr, "usage: %s sweeps \n", name);
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -68,22 +77,25 @@ int main(int argc, const char **argv)
|
|||||||
if (*end)
|
if (*end)
|
||||||
usage(*argv);
|
usage(*argv);
|
||||||
|
|
||||||
|
signal(SIGINT, die);
|
||||||
|
|
||||||
dsc = atspi_open();
|
dsc = atspi_open();
|
||||||
if (!dsc)
|
if (!dsc)
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
atspi_reg_write(dsc, REG_TRX_STATE, TRX_CMD_TRX_OFF);
|
atspi_reg_write(dsc, REG_TRX_STATE, TRX_CMD_TRX_OFF);
|
||||||
/*
|
|
||||||
* No need to explicitly wait for things to stabilize - going USB-SPI
|
|
||||||
* is pretty slow, leaving the transceiver more than enough time.
|
|
||||||
*/
|
|
||||||
atspi_reg_write(dsc, REG_TRX_STATE, TRX_CMD_RX_ON);
|
atspi_reg_write(dsc, REG_TRX_STATE, TRX_CMD_RX_ON);
|
||||||
|
/*
|
||||||
|
* We'll wait for the PLL lock after selecting the channel.
|
||||||
|
*/
|
||||||
|
|
||||||
gettimeofday(&t0, NULL);
|
gettimeofday(&t0, NULL);
|
||||||
for (i = 0; i != sweeps; i++)
|
for (i = 0; run && i != sweeps; i++)
|
||||||
sweep(dsc);
|
sweep(dsc);
|
||||||
|
|
||||||
atspi_reg_write(dsc, REG_TRX_STATE, TRX_CMD_TRX_OFF);
|
atspi_reg_write(dsc, REG_TRX_STATE, TRX_CMD_TRX_OFF);
|
||||||
|
|
||||||
|
atspi_close(dsc);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user