X-Git-Url: http://git.droids-corp.org/?p=protos%2Fxbee-avr.git;a=blobdiff_plain;f=commands.c;h=10b62cc0feababd678c8a89414befca09cbee76d;hp=df76f478b3807ff4dc8c55c87616cc54175c76e9;hb=58822b8f01bbc479c273d2c440e6415c754cba9e;hpb=8a9ba904e4215b92930a6d71c06c97514bcc6688 diff --git a/commands.c b/commands.c index df76f47..10b62cc 100644 --- a/commands.c +++ b/commands.c @@ -56,7 +56,7 @@ extern const parse_inst_t PROGMEM cmd_log; extern const parse_inst_t PROGMEM cmd_log_show; extern const parse_inst_t PROGMEM cmd_log_type; extern const parse_inst_t PROGMEM cmd_stack_space; -extern const parse_inst_t PROGMEM cmd_scheduler; +extern const parse_inst_t PROGMEM cmd_callout; static int monitor_period_ms = 1000; static int monitor_running = 0; @@ -119,7 +119,7 @@ static void range_cb(struct callout_mgr *cm, if (range_cur_count == 0) { range_running = 0; - return; + callout_stop(cm, clt); } callout_reschedule(cm, clt, range_period_ms); @@ -741,7 +741,8 @@ static void cmd_range_parsed(void *parsed_result, void *data) } range_cur_count = range_count; callout_init(&range_event, range_cb, NULL, 0); - callout_schedule(&cm, &range_event, 0); /* immediate */ + callout_schedule(&xbeeboard.mainloop_cm, + &range_event, 0); /* immediate */ range_running = 1; } else if (!strcmp(res->action, "end")) { @@ -750,7 +751,7 @@ static void cmd_range_parsed(void *parsed_result, void *data) return; } range_running = 0; - callout_stop(&cm, &range_event); + callout_stop(&xbeeboard.mainloop_cm, &range_event); } } @@ -990,7 +991,8 @@ static void cmd_monitor_parsed(void *parsed_result, void *data) return; } callout_init(&monitor_event, monitor_cb, NULL, 0); - callout_schedule(&cm, &monitor_event, 0); /* immediate */ + callout_schedule(&xbeeboard.mainloop_cm, + &monitor_event, 0); /* immediate */ monitor_running = 1; monitor_current = LIST_FIRST(&xbee_monitor_list); printf_P(PSTR("monitor cb: %S %s\r\n"), @@ -1004,7 +1006,7 @@ static void cmd_monitor_parsed(void *parsed_result, void *data) return; } monitor_running = 0; - callout_stop(&cm, &monitor_event); + callout_stop(&xbeeboard.mainloop_cm, &monitor_event); } } @@ -1167,7 +1169,7 @@ static void cmd_monitor_del_parsed(void *parsed_result, void *data) monitor_count --; if (monitor_count == 0) { printf_P(PSTR("Disable monitoring, no more event\r\n")); - callout_stop(&cm, &monitor_event); + callout_stop(&xbeeboard.mainloop_cm, &monitor_event); monitor_running = 0; return; } @@ -1245,6 +1247,11 @@ static void cmd_raw_parsed(void *parsed_result, void *data) { (void)parsed_result; (void)data; + + if (range_running || monitor_running) { + printf_P(PSTR("stop running range or monitor first\r\n")); + return; + } printf_P(PSTR("switched to raw mode, CTRL-D to exit\r\n")); rdline_stop(&xbeeboard.rdl); /* don't display prompt when return */ xbee_raw = 1; @@ -1892,7 +1899,7 @@ const parse_ctx_t PROGMEM main_ctx[] = { &cmd_log_show, &cmd_log_type, &cmd_stack_space, - &cmd_scheduler, + &cmd_callout, &cmd_help, &cmd_neigh_del, &cmd_neigh_add,