2 * Copyright © 2012 Keith Packard <keithp@keithp.com>
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; either version 2 of the License, or
7 * (at your option) any later version.
9 * This program is distributed in the hope that it will be useful, but
10 * WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * General Public License for more details.
14 * You should have received a copy of the GNU General Public License along
15 * with this program; if not, write to the Free Software Foundation, Inc.,
16 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
21 #include <ao_lco_cmd.h>
22 #include <ao_lco_func.h>
23 #include <ao_radio_cmac.h>
25 #ifndef HAS_STATIC_TEST
26 #define HAS_STATIC_TEST 1
29 static uint16_t lco_box;
30 static uint8_t lco_channels;
31 static uint16_t tick_offset;
36 lco_box = ao_cmd_decimal();
37 lco_channels = ao_cmd_hex();
40 static struct ao_pad_query ao_pad_query;
41 static uint16_t tick_offset;
47 int8_t r = AO_RADIO_CMAC_OK;
49 for (i = 0; i < 10; i++) {
50 printf ("."); flush();
51 r = ao_lco_query(lco_box, &ao_pad_query, &tick_offset);
52 if (r == AO_RADIO_CMAC_OK)
55 printf("\n"); flush();
62 ao_lco_arm(lco_box, lco_channels, tick_offset);
66 lco_ignite(uint8_t cmd)
78 if (ao_cmd_status != ao_cmd_success)
82 case AO_RADIO_CMAC_OK:
83 switch (ao_pad_query.arm_status) {
84 case AO_PAD_ARM_STATUS_ARMED:
87 case AO_PAD_ARM_STATUS_DISARMED:
90 case AO_PAD_ARM_STATUS_UNKNOWN:
95 for (c = 0; c < AO_PAD_MAX_CHANNELS; c++) {
96 if (ao_pad_query.channels & (1 << c)) {
97 printf (" pad %d ", c);
98 switch (ao_pad_query.igniter_status[c]) {
102 case AO_PAD_IGNITER_STATUS_NO_IGNITER_RELAY_OPEN:
103 printf("bad-open, ");
105 case AO_PAD_IGNITER_STATUS_GOOD_IGNITER_RELAY_OPEN:
106 printf("good-igniter, ");
108 case AO_PAD_IGNITER_STATUS_NO_IGNITER_RELAY_CLOSED:
109 printf("bad-closed, ");
114 printf("Rssi: %d\n", ao_radio_cmac_rssi);
117 printf("Error %d\n", r);
130 secs = ao_cmd_decimal();
131 if (ao_cmd_status != ao_cmd_success)
134 if (r != AO_RADIO_CMAC_OK) {
135 printf("query failed %d\n", r);
139 for (i = 0; i < 4; i++) {
140 printf("arm %d\n", i); flush();
144 secs = secs * 10 - 5;
147 for (i = 0; i < secs; i++) {
148 printf("fire %d\n", i); flush();
149 lco_ignite(AO_PAD_FIRE);
150 ao_delay(AO_MS_TO_TICKS(100));
163 secs = ao_cmd_decimal();
164 if (ao_cmd_status != ao_cmd_success)
167 if (r != AO_RADIO_CMAC_OK) {
168 printf("query failed %d\n", r);
172 for (i = 0; i < 4; i++) {
173 printf("arm %d\n", i); flush();
177 secs = secs * 10 - 5;
180 for (i = 0; i < secs; i++) {
181 printf("fire %d\n", i); flush();
182 lco_ignite(AO_PAD_STATIC);
183 ao_delay(AO_MS_TO_TICKS(100));
195 if (r != AO_RADIO_CMAC_OK) {
196 printf("query failed %d\n", r);
199 for (i = 0; i < 4; i++)
208 for (i = 0; i < 4; i++)
209 lco_ignite(AO_PAD_FIRE);
215 lco_endstatic_cmd(void)
217 lco_ignite(AO_PAD_ENDSTATIC);
221 static const struct ao_cmds ao_lco_cmds[] = {
222 { lco_report_cmd, "l <box> <channel>\0Get remote status" },
223 { lco_fire_cmd, "F <box> <channel> <secs>\0Fire remote igniters" },
225 { lco_static_cmd, "S <box> <channel> <secs>\0Initiate static test" },
226 { lco_endstatic_cmd, "D\0End static test (and download someday)" },
228 { lco_arm_cmd, "a <box> <channel>\0Arm remote igniter" },
229 { lco_ignite_cmd, "i <box> <channel>\0Pulse remote igniter" },
234 ao_lco_cmd_init(void)
236 ao_cmd_register(&ao_lco_cmds[0]);