1
0
mirror of git://projects.qi-hardware.com/ben-wpan.git synced 2024-11-26 12:45:21 +02:00

tools/: added interrupt_wait support to atnet and atrf-proxy (untested)

- atrf-proxy/PROTOCOL: WAIT is now implemented and takes a timeout
  argument
- atrf-proxy/atrf-proxy.c (cmd_more): implemented WAIT command using
  atrf_interrupt_wait
- lib/atnet.c (atnet_interrupt_wait, atnet_driver): added
  interrupt_wait (using WAIT)
This commit is contained in:
Werner Almesberger 2011-06-20 17:42:48 -03:00
parent b0dd5ced20
commit 668d8c61cf
3 changed files with 38 additions and 4 deletions

View File

@ -60,8 +60,8 @@ POLL
+0|1 +0|1
-message -message
WAIT WAIT timeout_ms
+0|1 +value
-message -message
@ -84,8 +84,9 @@ The device is implicitly opened when establishing a TCP session. The
device is implicitly closed when closing the TCP session. device is implicitly closed when closing the TCP session.
Asynchrous interrupt notification (not implemented yet) Asynchrous interrupt notification
--------------------------------- ---------------------------------
The WAIT command is not answered until an interrupt or another command is The WAIT command is not answered until an interrupt or another command is
received. WAIT returns the interrupt status, just like POLL. received. WAIT returns the value of the IRQ_STATUS register. If WAIT
times out before receiving an interrupt, it returns 0.

View File

@ -168,6 +168,18 @@ static int cmd_more(struct atrf_dsc *dsc, struct netio *netio, const char *cmd)
return netio_printf(netio, "-I/O error\n"); return netio_printf(netio, "-I/O error\n");
return netio_printf(netio, "+0x%02x\n", res); return netio_printf(netio, "+0x%02x\n", res);
} }
if (!strcasecmp(cmd, "wait")) {
uint8_t res;
if (!n)
n = 1;
res = atrf_interrupt_wait(dsc, n);
if (atrf_error(dsc))
return netio_printf(netio, "-I/O error\n");
if (res < 0)
return netio_printf(netio, "-not supported\n");
return netio_printf(netio, "+0x%02x\n", res);
}
if (!strcasecmp(cmd, "getram")) { if (!strcasecmp(cmd, "getram")) {
uint8_t res; uint8_t res;

View File

@ -463,6 +463,26 @@ static int atnet_interrupt(void *handle)
} }
int atnet_interrupt_wait(void *handle, int timeout_ms)
{
struct atnet_dsc *dsc = handle;
unsigned long value;
char *end;
if (dsc->error)
return 0;
if (dialog(dsc, "WAIT %d", timeout_ms) < 0)
return 0;
value = strtoul(dsc->reply+1, &end, 0);
if (*end || value > 1) {
fprintf(stderr, "invalid response \"%s\"\n", dsc->reply+1);
dsc->error = 1;
return 0;
}
return value;
}
/* ----- CLKM handling ----------------------------------------------------- */ /* ----- CLKM handling ----------------------------------------------------- */
@ -496,4 +516,5 @@ struct atrf_driver atnet_driver = {
.sram_write = atnet_sram_write, .sram_write = atnet_sram_write,
.sram_read = atnet_sram_read, .sram_read = atnet_sram_read,
.interrupt = atnet_interrupt, .interrupt = atnet_interrupt,
.interrupt_wait = atnet_interrupt_wait,
}; };