Erick / Mbed 2 deprecated ICE_BLE_TEST

Dependencies:   NaturalTinyShell_ice libmDot-12Sept mbed-rtos mbed

Fork of ICE by Erick

Committer:
jmarkel44
Date:
Fri Sep 09 21:20:26 2016 +0000
Revision:
43:62de0e05ab6b
Parent:
42:c703a60993b1
Child:
44:c73f2ca79669
added wildcard to cmd_rm (rm *);

Who changed what in which revision?

UserRevisionLine numberNew contents of line
jmarkel44 0:65cfa4873284 1 /*
jmarkel44 0:65cfa4873284 2 * ===============================================================
jmarkel44 0:65cfa4873284 3 * Natural Tiny Shell (NT-Shell) Application example.
jmarkel44 0:65cfa4873284 4 * Version 0.0.6
jmarkel44 0:65cfa4873284 5 * ===============================================================
jmarkel44 0:65cfa4873284 6 * Copyright (c) 2010-2011 Shinichiro Nakamura
jmarkel44 0:65cfa4873284 7 *
jmarkel44 0:65cfa4873284 8 * Permission is hereby granted, free of charge, to any person
jmarkel44 0:65cfa4873284 9 * obtaining a copy of this software and associated documentation
jmarkel44 0:65cfa4873284 10 * files (the "Software"), to deal in the Software without
jmarkel44 0:65cfa4873284 11 * restriction, including without limitation the rights to use,
jmarkel44 0:65cfa4873284 12 * copy, modify, merge, publish, distribute, sublicense, and/or
jmarkel44 0:65cfa4873284 13 * sell copies of the Software, and to permit persons to whom the
jmarkel44 0:65cfa4873284 14 * Software is furnished to do so, subject to the following
jmarkel44 0:65cfa4873284 15 * conditions:
jmarkel44 0:65cfa4873284 16 *
jmarkel44 0:65cfa4873284 17 * The above copyright notice and this permission notice shall be
jmarkel44 0:65cfa4873284 18 * included in all copies or substantial portions of the Software.
jmarkel44 0:65cfa4873284 19 *
jmarkel44 0:65cfa4873284 20 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
jmarkel44 0:65cfa4873284 21 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
jmarkel44 0:65cfa4873284 22 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
jmarkel44 0:65cfa4873284 23 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
jmarkel44 0:65cfa4873284 24 * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
jmarkel44 0:65cfa4873284 25 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
jmarkel44 0:65cfa4873284 26 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
jmarkel44 0:65cfa4873284 27 * OTHER DEALINGS IN THE SOFTWARE.
jmarkel44 0:65cfa4873284 28 * ===============================================================
jmarkel44 0:65cfa4873284 29 */
jmarkel44 0:65cfa4873284 30
jmarkel44 0:65cfa4873284 31 #include "cmd.h"
jmarkel44 0:65cfa4873284 32 #include <mbed.h>
jmarkel44 36:f240f5a6d0ed 33 #include <utility>
jmarkel44 0:65cfa4873284 34 #include "ntshell.h"
jmarkel44 0:65cfa4873284 35 #include "ntopt.h"
jmarkel44 0:65cfa4873284 36 #include "global.h"
jmarkel44 0:65cfa4873284 37 #include "ConfigurationHandler.h"
jmarkel44 3:8ea4db957749 38 #include "mDot.h"
jmarkel44 34:f345fdec711d 39 #include "rtos.h"
jmarkel44 0:65cfa4873284 40
jmarkel44 0:65cfa4873284 41 Serial serial(USBTX, USBRX);
jmarkel44 0:65cfa4873284 42 ntshell_t ntshell;
jmarkel44 0:65cfa4873284 43
jmarkel44 14:cc916fa8dd11 44 extern mDot *GLOBAL_mdot;
jmarkel44 14:cc916fa8dd11 45
jmarkel44 0:65cfa4873284 46 typedef struct {
jmarkel44 0:65cfa4873284 47 char *command; // command (from shell)
jmarkel44 0:65cfa4873284 48 char *description; // descrption
jmarkel44 0:65cfa4873284 49 void (*func)(int argc, char **argv); // callback function
jmarkel44 0:65cfa4873284 50 } command_table_t;
jmarkel44 0:65cfa4873284 51
jmarkel44 0:65cfa4873284 52 // see cmd.h
jmarkel44 0:65cfa4873284 53 const command_table_t cmdlist[] = {
jmarkel44 0:65cfa4873284 54 {"?", "help command", cmd_help },
jmarkel44 0:65cfa4873284 55 {"create", "create a control", cmd_create },
jmarkel44 0:65cfa4873284 56 {"destroy", "destroy a control", cmd_destroy },
jmarkel44 36:f240f5a6d0ed 57 {"ccf", "create a test control file", cmd_ccf },
jmarkel44 37:7e6986b77f01 58 {"cif", "create a test input file", cmd_cif },
jmarkel44 37:7e6986b77f01 59 {"cof", "create a test output file", cmd_cof },
jmarkel44 0:65cfa4873284 60 {"heap", "show heap statistics", cmd_heap },
jmarkel44 0:65cfa4873284 61 {"help", "help command", cmd_help },
jmarkel44 36:f240f5a6d0ed 62 {"log-level", "get/set mDot log level", cmd_logLevel },
jmarkel44 14:cc916fa8dd11 63 {"ls", "list user files", cmd_ls },
jmarkel44 0:65cfa4873284 64 {"modify", "modify a control", cmd_modify },
jmarkel44 0:65cfa4873284 65 {"reset", "reset the controller", cmd_reset },
jmarkel44 35:6235ef67faa1 66 {"reset-stats", "reset current mDot statistics", cmd_resetStats },
jmarkel44 14:cc916fa8dd11 67 {"rm", "remove a user file", cmd_rm },
jmarkel44 35:6235ef67faa1 68 {"rssi-stats", "get current rssi stats", cmd_rssiStats },
jmarkel44 35:6235ef67faa1 69 {"show-controls", "display active controls", cmd_ShowControls },
jmarkel44 35:6235ef67faa1 70 {"snr-stats", "get current SNR stats", cmd_snrStats },
jmarkel44 36:f240f5a6d0ed 71 {"stack", "get thread stack usage stats", cmd_stack },
jmarkel44 18:9cf694a764c0 72 {"stats", "get current mDot statistics", cmd_stats },
jmarkel44 0:65cfa4873284 73 {NULL, NULL, NULL}
jmarkel44 0:65cfa4873284 74 };
jmarkel44 0:65cfa4873284 75
jmarkel44 0:65cfa4873284 76 int func_read(char *buf, int cnt);
jmarkel44 0:65cfa4873284 77 int func_write(const char *buf, int cnt);
jmarkel44 0:65cfa4873284 78 int func_cb_ntshell(const char *text);
jmarkel44 0:65cfa4873284 79 void func_cb_ntopt(int argc, char **argv);
jmarkel44 0:65cfa4873284 80
jmarkel44 0:65cfa4873284 81 /**
jmarkel44 0:65cfa4873284 82 * Serial read function.
jmarkel44 0:65cfa4873284 83 */
jmarkel44 0:65cfa4873284 84 int func_read(char *buf, int cnt)
jmarkel44 0:65cfa4873284 85 {
jmarkel44 0:65cfa4873284 86 for (int i = 0; i < cnt; i++) {
jmarkel44 0:65cfa4873284 87 buf[i] = serial.getc();
jmarkel44 0:65cfa4873284 88 }
jmarkel44 0:65cfa4873284 89 return 0;
jmarkel44 0:65cfa4873284 90 }
jmarkel44 0:65cfa4873284 91
jmarkel44 0:65cfa4873284 92 /**
jmarkel44 0:65cfa4873284 93 * Serial write function.
jmarkel44 0:65cfa4873284 94 */
jmarkel44 0:65cfa4873284 95 int func_write(const char *buf, int cnt)
jmarkel44 0:65cfa4873284 96 {
jmarkel44 0:65cfa4873284 97 for (int i = 0; i < cnt; i++) {
jmarkel44 0:65cfa4873284 98 serial.putc(buf[i]);
jmarkel44 0:65cfa4873284 99 }
jmarkel44 0:65cfa4873284 100 return 0;
jmarkel44 0:65cfa4873284 101 }
jmarkel44 0:65cfa4873284 102
jmarkel44 0:65cfa4873284 103 /**
jmarkel44 0:65cfa4873284 104 * Callback function for ntshell module.
jmarkel44 0:65cfa4873284 105 */
jmarkel44 0:65cfa4873284 106 int func_cb_ntshell(const char *text)
jmarkel44 0:65cfa4873284 107 {
jmarkel44 0:65cfa4873284 108 return ntopt_parse(text, func_cb_ntopt);
jmarkel44 0:65cfa4873284 109 }
jmarkel44 0:65cfa4873284 110
jmarkel44 0:65cfa4873284 111 /**
jmarkel44 0:65cfa4873284 112 * Callback function for ntopt module.
jmarkel44 0:65cfa4873284 113 */
jmarkel44 0:65cfa4873284 114 void func_cb_ntopt(int argc, char **argv)
jmarkel44 0:65cfa4873284 115 {
jmarkel44 0:65cfa4873284 116 if (argc == 0) {
jmarkel44 0:65cfa4873284 117 return;
jmarkel44 0:65cfa4873284 118 }
jmarkel44 0:65cfa4873284 119 int execnt = 0;
jmarkel44 0:65cfa4873284 120 const command_table_t *p = &cmdlist[0];
jmarkel44 0:65cfa4873284 121 while (p->command != NULL) {
jmarkel44 0:65cfa4873284 122 if (strcmp(argv[0], p->command) == 0) {
jmarkel44 0:65cfa4873284 123 p->func(argc, argv);
jmarkel44 0:65cfa4873284 124 execnt++;
jmarkel44 0:65cfa4873284 125 }
jmarkel44 0:65cfa4873284 126 p++;
jmarkel44 0:65cfa4873284 127 }
jmarkel44 0:65cfa4873284 128 if (execnt == 0) {
jmarkel44 0:65cfa4873284 129 printf("Command not found.\r\n");
jmarkel44 0:65cfa4873284 130 }
jmarkel44 0:65cfa4873284 131 wait_ms(250);
jmarkel44 0:65cfa4873284 132 }
jmarkel44 0:65cfa4873284 133
jmarkel44 0:65cfa4873284 134 /************************* callback functions *******************************/
jmarkel44 35:6235ef67faa1 135
jmarkel44 35:6235ef67faa1 136 /*****************************************************************************
jmarkel44 35:6235ef67faa1 137 * Function: cmd_help
jmarkel44 35:6235ef67faa1 138 * Description: displays the list of commands available
jmarkel44 35:6235ef67faa1 139 *
jmarkel44 35:6235ef67faa1 140 * @param argc (not used)
jmarkel44 35:6235ef67faa1 141 * @param argv (not used)
jmarkel44 35:6235ef67faa1 142 * @return none
jmarkel44 35:6235ef67faa1 143 *****************************************************************************/
jmarkel44 0:65cfa4873284 144 void cmd_help(int argc, char **argv)
jmarkel44 0:65cfa4873284 145 {
jmarkel44 0:65cfa4873284 146 UNUSED(argc);
jmarkel44 0:65cfa4873284 147 UNUSED(argv);
jmarkel44 0:65cfa4873284 148
jmarkel44 0:65cfa4873284 149 const command_table_t *tblPtr = cmdlist;
jmarkel44 0:65cfa4873284 150
jmarkel44 0:65cfa4873284 151 while (tblPtr->command) {
jmarkel44 0:65cfa4873284 152 printf("\r%-32s:\t%s\n", tblPtr->command, tblPtr->description);
jmarkel44 0:65cfa4873284 153 tblPtr++;
jmarkel44 0:65cfa4873284 154 }
jmarkel44 0:65cfa4873284 155 printf("\r\n");
jmarkel44 0:65cfa4873284 156 }
jmarkel44 0:65cfa4873284 157
jmarkel44 36:f240f5a6d0ed 158
jmarkel44 36:f240f5a6d0ed 159 /*****************************************************************************
jmarkel44 36:f240f5a6d0ed 160 * Function: cmd_logLevel
davidjhoward 41:e8946fc01ea4 161 * Description: get or set the current log-level
jmarkel44 36:f240f5a6d0ed 162 *
jmarkel44 36:f240f5a6d0ed 163 * @param argc (not used)
jmarkel44 36:f240f5a6d0ed 164 * @param argv (not used)
jmarkel44 36:f240f5a6d0ed 165 * @return none
jmarkel44 36:f240f5a6d0ed 166 *****************************************************************************/
jmarkel44 36:f240f5a6d0ed 167 void cmd_logLevel(int argc, char **argv)
jmarkel44 36:f240f5a6d0ed 168 {
jmarkel44 36:f240f5a6d0ed 169 uint8_t logLevel = 0;
davidjhoward 41:e8946fc01ea4 170
davidjhoward 41:e8946fc01ea4 171 const char *mapper[] = { "NONE",
davidjhoward 41:e8946fc01ea4 172 "FATAL",
davidjhoward 41:e8946fc01ea4 173 "ERROR",
davidjhoward 41:e8946fc01ea4 174 "WARNING",
davidjhoward 41:e8946fc01ea4 175 "INFO",
davidjhoward 41:e8946fc01ea4 176 "DEBUG",
davidjhoward 41:e8946fc01ea4 177 "TRACE"
davidjhoward 41:e8946fc01ea4 178 };
davidjhoward 41:e8946fc01ea4 179
jmarkel44 36:f240f5a6d0ed 180 if ( argc == 1 ) {
davidjhoward 41:e8946fc01ea4 181 printf("\r current log-level set to %s\r\n",
davidjhoward 41:e8946fc01ea4 182 mapper[GLOBAL_mdot->getLogLevel()]);
jmarkel44 36:f240f5a6d0ed 183 goto usage;
jmarkel44 36:f240f5a6d0ed 184 }
jmarkel44 36:f240f5a6d0ed 185
jmarkel44 36:f240f5a6d0ed 186 if ( argc != 2 ) {
jmarkel44 36:f240f5a6d0ed 187 usage:
jmarkel44 36:f240f5a6d0ed 188 printf("\rusage: log-level [0-6]\n");
jmarkel44 36:f240f5a6d0ed 189 printf("\r 0 = NONE\n");
jmarkel44 36:f240f5a6d0ed 190 printf("\r 1 = FATAL\n");
jmarkel44 36:f240f5a6d0ed 191 printf("\r 2 = ERROR\n");
jmarkel44 36:f240f5a6d0ed 192 printf("\r 3 = WARNING\n");
jmarkel44 36:f240f5a6d0ed 193 printf("\r 4 = INFO\n");
jmarkel44 36:f240f5a6d0ed 194 printf("\r 5 = DEBUG\n");
jmarkel44 36:f240f5a6d0ed 195 printf("\r 6 = TRACE\r\n");
jmarkel44 36:f240f5a6d0ed 196 return;
jmarkel44 36:f240f5a6d0ed 197 }
davidjhoward 41:e8946fc01ea4 198
jmarkel44 36:f240f5a6d0ed 199 logLevel = atoi(argv[1]);
davidjhoward 41:e8946fc01ea4 200 if ( logLevel > 6 )
jmarkel44 36:f240f5a6d0ed 201 goto usage;
davidjhoward 41:e8946fc01ea4 202
davidjhoward 41:e8946fc01ea4 203 // reassign the log level
jmarkel44 36:f240f5a6d0ed 204 printf("...setting log-level to %s\r\n", mapper[logLevel]);
davidjhoward 41:e8946fc01ea4 205 GLOBAL_mdot->setLogLevel(logLevel);
jmarkel44 36:f240f5a6d0ed 206 printf("\r\n");
jmarkel44 36:f240f5a6d0ed 207 }
jmarkel44 36:f240f5a6d0ed 208
jmarkel44 35:6235ef67faa1 209 /*****************************************************************************
jmarkel44 35:6235ef67faa1 210 * Function: cmd_ls
jmarkel44 36:f240f5a6d0ed 211 * Description: list the user files on flash
jmarkel44 35:6235ef67faa1 212 *
jmarkel44 35:6235ef67faa1 213 * @param argc (not used)
jmarkel44 35:6235ef67faa1 214 * @param argv (not used)
jmarkel44 35:6235ef67faa1 215 * @return none
jmarkel44 35:6235ef67faa1 216 *****************************************************************************/
jmarkel44 14:cc916fa8dd11 217 void cmd_ls(int argc, char **argv)
jmarkel44 14:cc916fa8dd11 218 {
jmarkel44 35:6235ef67faa1 219 UNUSED(argc);
jmarkel44 35:6235ef67faa1 220 UNUSED(argv);
jmarkel44 36:f240f5a6d0ed 221
jmarkel44 14:cc916fa8dd11 222 vector<mDot::mdot_file> userFiles;
jmarkel44 14:cc916fa8dd11 223 userFiles = GLOBAL_mdot->listUserFiles();
jmarkel44 14:cc916fa8dd11 224 vector<mDot::mdot_file>::iterator pos;
jmarkel44 18:9cf694a764c0 225
jmarkel44 14:cc916fa8dd11 226 for ( pos = userFiles.begin(); pos != userFiles.end(); ++pos ) {
jmarkel44 14:cc916fa8dd11 227 printf("\r %-33s %d\n", pos->name, pos->size);
jmarkel44 14:cc916fa8dd11 228 }
jmarkel44 14:cc916fa8dd11 229 printf("\r\n");
jmarkel44 14:cc916fa8dd11 230 }
jmarkel44 14:cc916fa8dd11 231
jmarkel44 35:6235ef67faa1 232 /*****************************************************************************
jmarkel44 35:6235ef67faa1 233 * Function: cmd_ShowControls
jmarkel44 36:f240f5a6d0ed 234 * Description: show active controls
jmarkel44 35:6235ef67faa1 235 *
jmarkel44 35:6235ef67faa1 236 * @param argc (not used)
jmarkel44 35:6235ef67faa1 237 * @param argv (not used)
jmarkel44 35:6235ef67faa1 238 * @return none
jmarkel44 35:6235ef67faa1 239 *****************************************************************************/
jmarkel44 0:65cfa4873284 240 void cmd_ShowControls(int argc, char **argv)
jmarkel44 0:65cfa4873284 241 {
jmarkel44 0:65cfa4873284 242 UNUSED(argc);
jmarkel44 0:65cfa4873284 243 UNUSED(argv);
jmarkel44 12:ea87887ca7ad 244 ConfigurationHandler_showControls();
jmarkel44 18:9cf694a764c0 245 printf("\r\n");
jmarkel44 18:9cf694a764c0 246
jmarkel44 0:65cfa4873284 247 }
jmarkel44 0:65cfa4873284 248
jmarkel44 35:6235ef67faa1 249 /*****************************************************************************
jmarkel44 35:6235ef67faa1 250 * Function: cmd_reset
jmarkel44 36:f240f5a6d0ed 251 * Description: reset the cpu
jmarkel44 35:6235ef67faa1 252 *
jmarkel44 35:6235ef67faa1 253 * @param argc (not used)
jmarkel44 35:6235ef67faa1 254 * @param argv (not used)
jmarkel44 35:6235ef67faa1 255 * @return none
jmarkel44 35:6235ef67faa1 256 *****************************************************************************/
jmarkel44 0:65cfa4873284 257 void cmd_reset(int argc, char **argv)
jmarkel44 0:65cfa4873284 258 {
jmarkel44 0:65cfa4873284 259 UNUSED(argc);
jmarkel44 0:65cfa4873284 260 UNUSED(argv);
jmarkel44 18:9cf694a764c0 261 GLOBAL_mdot->resetCpu();
jmarkel44 0:65cfa4873284 262 }
jmarkel44 0:65cfa4873284 263
jmarkel44 35:6235ef67faa1 264 /*****************************************************************************
jmarkel44 35:6235ef67faa1 265 * Function: cmd_rm
jmarkel44 35:6235ef67faa1 266 * Description: removes a user file from flash
jmarkel44 35:6235ef67faa1 267 *
jmarkel44 35:6235ef67faa1 268 * @param argc-> number of args
jmarkel44 36:f240f5a6d0ed 269 * @param argv-> filename
jmarkel44 35:6235ef67faa1 270 * @return none
jmarkel44 35:6235ef67faa1 271 *****************************************************************************/
jmarkel44 14:cc916fa8dd11 272 void cmd_rm(int argc, char **argv)
jmarkel44 14:cc916fa8dd11 273 {
jmarkel44 18:9cf694a764c0 274 UNUSED(argc);
jmarkel44 14:cc916fa8dd11 275 UNUSED(argv);
jmarkel44 18:9cf694a764c0 276
jmarkel44 14:cc916fa8dd11 277 if ( argc != 2 ) {
jmarkel44 14:cc916fa8dd11 278 printf("\rusage: rm <filename>\n");
jmarkel44 14:cc916fa8dd11 279 return;
jmarkel44 14:cc916fa8dd11 280 }
jmarkel44 43:62de0e05ab6b 281 if ( strcmp(argv[1], "*") == 0 ) {
jmarkel44 43:62de0e05ab6b 282 vector<mDot::mdot_file> userFiles;
jmarkel44 43:62de0e05ab6b 283 userFiles = GLOBAL_mdot->listUserFiles();
jmarkel44 43:62de0e05ab6b 284 vector<mDot::mdot_file>::iterator pos;
jmarkel44 43:62de0e05ab6b 285 for ( pos = userFiles.begin(); pos != userFiles.end(); ++pos ) {
jmarkel44 43:62de0e05ab6b 286 GLOBAL_mdot->deleteUserFile(pos->name);
jmarkel44 43:62de0e05ab6b 287 }
jmarkel44 43:62de0e05ab6b 288 } else {
jmarkel44 43:62de0e05ab6b 289 GLOBAL_mdot->deleteUserFile(argv[1]);
jmarkel44 43:62de0e05ab6b 290 }
jmarkel44 14:cc916fa8dd11 291 }
jmarkel44 18:9cf694a764c0 292
jmarkel44 35:6235ef67faa1 293 /*****************************************************************************
jmarkel44 35:6235ef67faa1 294 * Function: cmd_create
jmarkel44 36:f240f5a6d0ed 295 * Description: create a control
jmarkel44 35:6235ef67faa1 296 *
jmarkel44 35:6235ef67faa1 297 * @param argc-> number of args
jmarkel44 35:6235ef67faa1 298 * @param argv-> control name, control type
jmarkel44 35:6235ef67faa1 299 * @return none
jmarkel44 35:6235ef67faa1 300 *****************************************************************************/
jmarkel44 0:65cfa4873284 301 void cmd_create(int argc, char **argv)
jmarkel44 0:65cfa4873284 302 {
jmarkel44 0:65cfa4873284 303 if ( argc != 3 ) {
jmarkel44 0:65cfa4873284 304 printf("\r\nusage: create [controlName] [controlType]\n");
jmarkel44 18:9cf694a764c0 305 printf("\rcontrolType-> 0=timer, 1=PID, 2=setpoint, 3=composite, 4=manual\r\n");
jmarkel44 0:65cfa4873284 306 return;
jmarkel44 0:65cfa4873284 307 }
jmarkel44 0:65cfa4873284 308 // send a message to the configuration handler to create the control
jmarkel44 0:65cfa4873284 309 Message_t *msg = MailBox.alloc();
jmarkel44 0:65cfa4873284 310 memset(msg, 0, sizeof(Message_t));
jmarkel44 0:65cfa4873284 311 msg->action = ACTION_CREATE;
jmarkel44 0:65cfa4873284 312 msg->control = (Control_t) atoi(argv[2]);
jmarkel44 0:65cfa4873284 313 strncpy(msg->controlFile, argv[1], sizeof(msg->controlFile)-1);
jmarkel44 0:65cfa4873284 314
jmarkel44 0:65cfa4873284 315 printf("%s: Sending a create request for control %s type = %u\r\n",
jmarkel44 0:65cfa4873284 316 __func__, msg->controlFile, msg->control);
jmarkel44 0:65cfa4873284 317
jmarkel44 0:65cfa4873284 318 MailBox.put(msg);
jmarkel44 18:9cf694a764c0 319 printf("\r\n");
jmarkel44 0:65cfa4873284 320 return;
jmarkel44 0:65cfa4873284 321 }
jmarkel44 0:65cfa4873284 322
jmarkel44 35:6235ef67faa1 323 /*****************************************************************************
jmarkel44 35:6235ef67faa1 324 * Function: cmd_destroy
jmarkel44 36:f240f5a6d0ed 325 * Description: reset the cpu
jmarkel44 35:6235ef67faa1 326 *
jmarkel44 35:6235ef67faa1 327 * @param argc-> number of arguments
jmarkel44 36:f240f5a6d0ed 328 * @param argv-> control name, control type
jmarkel44 35:6235ef67faa1 329 * @return none
jmarkel44 35:6235ef67faa1 330 *****************************************************************************/
jmarkel44 0:65cfa4873284 331 void cmd_destroy(int argc, char **argv)
jmarkel44 0:65cfa4873284 332 {
jmarkel44 12:ea87887ca7ad 333 if ( argc != 3 ) {
jmarkel44 12:ea87887ca7ad 334 printf("\r\nusage: destroy [controlName] [controlType]\n");
jmarkel44 18:9cf694a764c0 335 printf("\rcontrolType-> 0=timer, 1=PID, 2=setpoint, 3=composite, 4=manual\r\n");
jmarkel44 0:65cfa4873284 336 return;
jmarkel44 0:65cfa4873284 337 }
jmarkel44 0:65cfa4873284 338
jmarkel44 0:65cfa4873284 339 // send a message to the configuration handler to destroy the control
jmarkel44 0:65cfa4873284 340 Message_t *msg = MailBox.alloc();
jmarkel44 0:65cfa4873284 341 memset(msg, 0, sizeof(Message_t));
jmarkel44 0:65cfa4873284 342 msg->action = ACTION_DESTROY;
jmarkel44 12:ea87887ca7ad 343 msg->control = (Control_t) atoi(argv[2]);
jmarkel44 0:65cfa4873284 344 strncpy(msg->controlFile, argv[1], sizeof(msg->controlFile)-1);
jmarkel44 0:65cfa4873284 345
jmarkel44 0:65cfa4873284 346 printf("%s: Sending a destroy request for control %s\r\n",
jmarkel44 0:65cfa4873284 347 __func__, msg->controlFile);
jmarkel44 0:65cfa4873284 348
jmarkel44 0:65cfa4873284 349 MailBox.put(msg);
jmarkel44 18:9cf694a764c0 350 printf("\r\n");
jmarkel44 0:65cfa4873284 351 return;
jmarkel44 0:65cfa4873284 352 }
jmarkel44 0:65cfa4873284 353
jmarkel44 35:6235ef67faa1 354 /*****************************************************************************
jmarkel44 35:6235ef67faa1 355 * Function: cmd_ccf
jmarkel44 37:7e6986b77f01 356 * Description: create control file
jmarkel44 35:6235ef67faa1 357 *
jmarkel44 35:6235ef67faa1 358 * @param argc-> number of args
jmarkel44 36:f240f5a6d0ed 359 * @param argv-> filename
jmarkel44 35:6235ef67faa1 360 * @return none
jmarkel44 35:6235ef67faa1 361 *****************************************************************************/
jmarkel44 36:f240f5a6d0ed 362 void cmd_ccf(int argc, char **argv)
jmarkel44 18:9cf694a764c0 363 {
jmarkel44 18:9cf694a764c0 364 if ( argc != 2 ) {
jmarkel44 36:f240f5a6d0ed 365 printf("\rusage: ccf <filename>\r\n");
jmarkel44 18:9cf694a764c0 366 return;
jmarkel44 18:9cf694a764c0 367 }
jmarkel44 36:f240f5a6d0ed 368
jmarkel44 18:9cf694a764c0 369 char data_buf[1024];
jmarkel44 36:f240f5a6d0ed 370 snprintf(data_buf, sizeof(data_buf),
jmarkel44 36:f240f5a6d0ed 371 "{ "
jmarkel44 37:7e6986b77f01 372 "\"id\": \"SP\", "
jmarkel44 37:7e6986b77f01 373 "\"name\": \"TRASAR\", "
jmarkel44 37:7e6986b77f01 374 "\"priority\": \"800\", "
jmarkel44 37:7e6986b77f01 375 "\"input\": \"i_tra01\", "
jmarkel44 37:7e6986b77f01 376 "\"output\": \"o_r05\", "
jmarkel44 37:7e6986b77f01 377 "\"prodfact\": \"100\", "
jmarkel44 37:7e6986b77f01 378 "\"halert\": \"115\", "
jmarkel44 37:7e6986b77f01 379 "\"lalert\": \"85\", "
jmarkel44 37:7e6986b77f01 380 "\"hfs\": \"130\", "
jmarkel44 37:7e6986b77f01 381 "\"lfs\": \"70\", "
jmarkel44 37:7e6986b77f01 382 "\"tol\": \"5\" } "
jmarkel44 36:f240f5a6d0ed 383 );
jmarkel44 18:9cf694a764c0 384
jmarkel44 18:9cf694a764c0 385 bool status = GLOBAL_mdot->saveUserFile(argv[1], (void *)data_buf, 1024);
jmarkel44 18:9cf694a764c0 386 if( status != true ) {
jmarkel44 18:9cf694a764c0 387 logInfo("(%d)save file failed, status=%d", __LINE__, status);
jmarkel44 18:9cf694a764c0 388 }
jmarkel44 18:9cf694a764c0 389 }
jmarkel44 18:9cf694a764c0 390
jmarkel44 35:6235ef67faa1 391 /*****************************************************************************
jmarkel44 37:7e6986b77f01 392 * Function: cmd_cif
jmarkel44 37:7e6986b77f01 393 * Description: create input file
jmarkel44 37:7e6986b77f01 394 *
jmarkel44 37:7e6986b77f01 395 * @param argc-> number of args
jmarkel44 37:7e6986b77f01 396 * @param argv-> filename
jmarkel44 37:7e6986b77f01 397 * @return none
jmarkel44 37:7e6986b77f01 398 *****************************************************************************/
jmarkel44 37:7e6986b77f01 399 void cmd_cif(int argc, char **argv)
jmarkel44 37:7e6986b77f01 400 {
jmarkel44 37:7e6986b77f01 401 if ( argc != 2 ) {
jmarkel44 37:7e6986b77f01 402 printf("\rusage: cif <filename>\r\n");
jmarkel44 37:7e6986b77f01 403 return;
jmarkel44 37:7e6986b77f01 404 }
jmarkel44 37:7e6986b77f01 405
jmarkel44 37:7e6986b77f01 406 char data_buf[1024];
jmarkel44 37:7e6986b77f01 407 snprintf(data_buf, sizeof(data_buf),
jmarkel44 37:7e6986b77f01 408 "{ "
davidjhoward 41:e8946fc01ea4 409 "\"id\": \"i_tra01\", "
jmarkel44 37:7e6986b77f01 410 "\"name\": \"TRASAR\", "
jmarkel44 37:7e6986b77f01 411 "\"units\": \"PPM\", "
jmarkel44 37:7e6986b77f01 412 "\"min\": \"0\", "
jmarkel44 37:7e6986b77f01 413 "\"max\": \"300\", "
davidjhoward 41:e8946fc01ea4 414 "\"node\": \"1\", "
davidjhoward 41:e8946fc01ea4 415 "\"reg\": \"9\", "
jmarkel44 37:7e6986b77f01 416 "\"rtype\": \"1\", "
jmarkel44 37:7e6986b77f01 417 "\"type\": \"16\", "
davidjhoward 41:e8946fc01ea4 418 "\"size\": \"2\", "
davidjhoward 41:e8946fc01ea4 419 "\"order\": \"2\", "
davidjhoward 41:e8946fc01ea4 420 "\"rfreq\": \"5\", "
jmarkel44 37:7e6986b77f01 421 "\"fmt\": \"%%.2f\" } "
jmarkel44 37:7e6986b77f01 422 );
jmarkel44 37:7e6986b77f01 423
jmarkel44 37:7e6986b77f01 424 bool status = GLOBAL_mdot->saveUserFile(argv[1], (void *)data_buf, 1024);
jmarkel44 37:7e6986b77f01 425 if( status != true ) {
jmarkel44 37:7e6986b77f01 426 logInfo("(%d)save file failed, status=%d", __LINE__, status);
jmarkel44 37:7e6986b77f01 427 }
davidjhoward 41:e8946fc01ea4 428
davidjhoward 42:c703a60993b1 429 logInfo("Sending Mail To ModbusMasterMailBox, filename=%s", argv[1]);
davidjhoward 41:e8946fc01ea4 430 Message_t *mail = ModbusMasterMailBox.alloc();
davidjhoward 41:e8946fc01ea4 431 mail->action = ACTION_READ_FILE;
davidjhoward 41:e8946fc01ea4 432 strncpy( mail->controlFile, argv[1], (sizeof(mail->controlFile)-1));
davidjhoward 41:e8946fc01ea4 433 ModbusMasterMailBox.put(mail);
jmarkel44 37:7e6986b77f01 434 }
jmarkel44 37:7e6986b77f01 435
jmarkel44 37:7e6986b77f01 436 /*****************************************************************************
jmarkel44 37:7e6986b77f01 437 * Function: cmd_cof
jmarkel44 37:7e6986b77f01 438 * Description: create output file
jmarkel44 37:7e6986b77f01 439 *
jmarkel44 37:7e6986b77f01 440 * @param argc-> number of args
jmarkel44 37:7e6986b77f01 441 * @param argv-> filename
jmarkel44 37:7e6986b77f01 442 * @return none
jmarkel44 37:7e6986b77f01 443 *****************************************************************************/
jmarkel44 37:7e6986b77f01 444 void cmd_cof(int argc, char **argv)
jmarkel44 37:7e6986b77f01 445 {
jmarkel44 37:7e6986b77f01 446 if ( argc != 2 ) {
jmarkel44 37:7e6986b77f01 447 printf("\rusage: cof <filename>\r\n");
jmarkel44 37:7e6986b77f01 448 return;
jmarkel44 37:7e6986b77f01 449 }
jmarkel44 37:7e6986b77f01 450
jmarkel44 37:7e6986b77f01 451 char data_buf[1024];
jmarkel44 37:7e6986b77f01 452 snprintf(data_buf, sizeof(data_buf),
jmarkel44 37:7e6986b77f01 453 "{ "
davidjhoward 41:e8946fc01ea4 454 "\"id\": \"o_r05\", "
davidjhoward 41:e8946fc01ea4 455 "\"name\": \"Relay 5\", "
jmarkel44 37:7e6986b77f01 456 "\"min\": \"0\", "
jmarkel44 37:7e6986b77f01 457 "\"max\": \"300\", "
jmarkel44 37:7e6986b77f01 458 "\"node\": \"20\", "
jmarkel44 37:7e6986b77f01 459 "\"reg\": \"21\", "
jmarkel44 37:7e6986b77f01 460 "\"rtype\": \"1\", "
jmarkel44 37:7e6986b77f01 461 "\"type\": \"16\", "
jmarkel44 37:7e6986b77f01 462 "\"fmt\": \"%%.2f\", "
jmarkel44 37:7e6986b77f01 463 "\"toperiod\": \"0\", "
jmarkel44 37:7e6986b77f01 464 "\"scalelo\": \"0\", "
jmarkel44 37:7e6986b77f01 465 "\"scalehi\": \"100\" }"
davidjhoward 41:e8946fc01ea4 466 );
jmarkel44 37:7e6986b77f01 467
jmarkel44 37:7e6986b77f01 468 bool status = GLOBAL_mdot->saveUserFile(argv[1], (void *)data_buf, 1024);
jmarkel44 37:7e6986b77f01 469 if( status != true ) {
jmarkel44 37:7e6986b77f01 470 logInfo("(%d)save file failed, status=%d", __LINE__, status);
jmarkel44 37:7e6986b77f01 471 }
jmarkel44 43:62de0e05ab6b 472
davidjhoward 42:c703a60993b1 473 logInfo("Sending Mail To ModbusMasterMailBox, filename=%s", argv[1]);
davidjhoward 41:e8946fc01ea4 474 Message_t *mail = ModbusMasterMailBox.alloc();
davidjhoward 41:e8946fc01ea4 475 mail->action = ACTION_READ_FILE;
davidjhoward 41:e8946fc01ea4 476 strncpy( mail->controlFile, argv[1], (sizeof(mail->controlFile)-1));
davidjhoward 41:e8946fc01ea4 477 ModbusMasterMailBox.put(mail);
jmarkel44 37:7e6986b77f01 478 }
jmarkel44 37:7e6986b77f01 479
jmarkel44 37:7e6986b77f01 480 /*****************************************************************************
jmarkel44 35:6235ef67faa1 481 * Function: cmd_heap
jmarkel44 35:6235ef67faa1 482 * Description: display heap statistics
jmarkel44 35:6235ef67faa1 483 *
jmarkel44 35:6235ef67faa1 484 * @param argc (not used)
jmarkel44 35:6235ef67faa1 485 * @param argv (not used)
jmarkel44 35:6235ef67faa1 486 * @return none
jmarkel44 35:6235ef67faa1 487 *****************************************************************************/
jmarkel44 0:65cfa4873284 488 void cmd_heap(int argc, char **argv)
jmarkel44 0:65cfa4873284 489 {
jmarkel44 0:65cfa4873284 490 UNUSED(argc), UNUSED(argv);
jmarkel44 0:65cfa4873284 491 __heapstats((__heapprt)fprintf,stderr); // print initial free heap size
jmarkel44 0:65cfa4873284 492 }
jmarkel44 0:65cfa4873284 493
jmarkel44 35:6235ef67faa1 494 /*****************************************************************************
jmarkel44 35:6235ef67faa1 495 * Function: cmd_modify
jmarkel44 36:f240f5a6d0ed 496 * Description: modify an active control
jmarkel44 35:6235ef67faa1 497 *
jmarkel44 35:6235ef67faa1 498 * @param argc (not used)
jmarkel44 35:6235ef67faa1 499 * @param argv (not used)
jmarkel44 35:6235ef67faa1 500 * @return none
jmarkel44 35:6235ef67faa1 501 *****************************************************************************/
jmarkel44 0:65cfa4873284 502 void cmd_modify(int argc, char **argv)
jmarkel44 0:65cfa4873284 503 {
jmarkel44 0:65cfa4873284 504 // stubbed
jmarkel44 3:8ea4db957749 505 printf("\rNot yet implemented.\n");
jmarkel44 0:65cfa4873284 506 return;
jmarkel44 0:65cfa4873284 507 }
jmarkel44 0:65cfa4873284 508
jmarkel44 35:6235ef67faa1 509 /*****************************************************************************
jmarkel44 35:6235ef67faa1 510 * Function: cmd_stats
jmarkel44 35:6235ef67faa1 511 * Description: display mDot stats
jmarkel44 35:6235ef67faa1 512 *
jmarkel44 35:6235ef67faa1 513 * @param argc (not used)
jmarkel44 35:6235ef67faa1 514 * @param argv (not used)
jmarkel44 35:6235ef67faa1 515 * @return none
jmarkel44 35:6235ef67faa1 516 *****************************************************************************/
jmarkel44 18:9cf694a764c0 517 void cmd_stats(int argc, char **argv)
jmarkel44 18:9cf694a764c0 518 {
jmarkel44 35:6235ef67faa1 519 UNUSED(argc);
jmarkel44 35:6235ef67faa1 520 UNUSED(argv);
jmarkel44 36:f240f5a6d0ed 521
jmarkel44 18:9cf694a764c0 522 mDot::mdot_stats stats = GLOBAL_mdot->getStats();
jmarkel44 0:65cfa4873284 523
jmarkel44 18:9cf694a764c0 524 printf("\r Up: %u\n", stats.Up);
jmarkel44 18:9cf694a764c0 525 printf("\r Down: %u\n", stats.Down);
jmarkel44 18:9cf694a764c0 526 printf("\r Joins: %u\n", stats.Joins);
jmarkel44 18:9cf694a764c0 527 printf("\r JoinFails: %u\n", stats.JoinFails);
jmarkel44 18:9cf694a764c0 528 printf("\r MissedAcks: %u\n", stats.MissedAcks);
jmarkel44 18:9cf694a764c0 529 printf("\r CRCErrors: %u\n", stats.CRCErrors);
jmarkel44 18:9cf694a764c0 530
jmarkel44 18:9cf694a764c0 531 printf("\r\n");
jmarkel44 18:9cf694a764c0 532 }
jmarkel44 18:9cf694a764c0 533
jmarkel44 35:6235ef67faa1 534 /*****************************************************************************
jmarkel44 35:6235ef67faa1 535 * Function: cmd_resetStats
jmarkel44 35:6235ef67faa1 536 * Description: resets the mDot stats
jmarkel44 35:6235ef67faa1 537 *
jmarkel44 35:6235ef67faa1 538 * @param argc (not used)
jmarkel44 35:6235ef67faa1 539 * @param argv (not used)
jmarkel44 35:6235ef67faa1 540 * @return none
jmarkel44 35:6235ef67faa1 541 *****************************************************************************/
jmarkel44 18:9cf694a764c0 542 void cmd_resetStats(int argc, char **argv)
jmarkel44 18:9cf694a764c0 543 {
jmarkel44 35:6235ef67faa1 544 UNUSED(argc);
jmarkel44 35:6235ef67faa1 545 UNUSED(argv);
jmarkel44 36:f240f5a6d0ed 546
jmarkel44 18:9cf694a764c0 547 GLOBAL_mdot->resetStats();
jmarkel44 18:9cf694a764c0 548 }
jmarkel44 0:65cfa4873284 549
jmarkel44 35:6235ef67faa1 550 /*****************************************************************************
jmarkel44 35:6235ef67faa1 551 * Function: cmd_rssiStats
jmarkel44 36:f240f5a6d0ed 552 * Description: displays mDot RSSI statistics
jmarkel44 35:6235ef67faa1 553 *
jmarkel44 35:6235ef67faa1 554 * @param argc (not used)
jmarkel44 35:6235ef67faa1 555 * @param argv (not used)
jmarkel44 35:6235ef67faa1 556 * @return none
jmarkel44 35:6235ef67faa1 557 *****************************************************************************/
jmarkel44 18:9cf694a764c0 558 void cmd_rssiStats(int argc, char **argv)
jmarkel44 18:9cf694a764c0 559 {
jmarkel44 35:6235ef67faa1 560 UNUSED(argc);
jmarkel44 35:6235ef67faa1 561 UNUSED(argv);
jmarkel44 36:f240f5a6d0ed 562
jmarkel44 18:9cf694a764c0 563 mDot::rssi_stats s = GLOBAL_mdot->getRssiStats();
jmarkel44 0:65cfa4873284 564
jmarkel44 18:9cf694a764c0 565 printf("\r Last: %d dB\n", s.last);
jmarkel44 18:9cf694a764c0 566 printf("\r Min: %d dB\n", s.min);
jmarkel44 18:9cf694a764c0 567 printf("\r Max: %d dB\n", s.max);
jmarkel44 18:9cf694a764c0 568 printf("\r Avg: %d dB\n", s.avg);
jmarkel44 18:9cf694a764c0 569
jmarkel44 18:9cf694a764c0 570 printf("\r\n");
jmarkel44 18:9cf694a764c0 571 }
jmarkel44 18:9cf694a764c0 572
jmarkel44 35:6235ef67faa1 573 /*****************************************************************************
jmarkel44 35:6235ef67faa1 574 * Function: cmd_snrStats
jmarkel44 35:6235ef67faa1 575 * Description: displays signal-to-noise ratio stats
jmarkel44 35:6235ef67faa1 576 *
jmarkel44 35:6235ef67faa1 577 * @param argc (not used)
jmarkel44 35:6235ef67faa1 578 * @param argv (not used)
jmarkel44 35:6235ef67faa1 579 * @return none
jmarkel44 35:6235ef67faa1 580 *****************************************************************************/
jmarkel44 18:9cf694a764c0 581 void cmd_snrStats(int argc, char **argv)
jmarkel44 18:9cf694a764c0 582 {
jmarkel44 18:9cf694a764c0 583 mDot::snr_stats s = GLOBAL_mdot->getSnrStats();
jmarkel44 18:9cf694a764c0 584
jmarkel44 18:9cf694a764c0 585 printf("\r Last: %d cB\n", s.last);
jmarkel44 18:9cf694a764c0 586 printf("\r Min: %d cB\n", s.min);
jmarkel44 18:9cf694a764c0 587 printf("\r Max: %d cB\n", s.max);
jmarkel44 18:9cf694a764c0 588 printf("\r Avg: %d cB\n", s.avg);
jmarkel44 18:9cf694a764c0 589
jmarkel44 18:9cf694a764c0 590 printf("\r\n");
jmarkel44 18:9cf694a764c0 591 }
jmarkel44 34:f345fdec711d 592
jmarkel44 35:6235ef67faa1 593 /*****************************************************************************
jmarkel44 35:6235ef67faa1 594 * Function: cmd_stack
jmarkel44 36:f240f5a6d0ed 595 * Description: display thread stack statisics
jmarkel44 35:6235ef67faa1 596 *
jmarkel44 35:6235ef67faa1 597 * @param argc (not used)
jmarkel44 35:6235ef67faa1 598 * @param argv (not used)
jmarkel44 35:6235ef67faa1 599 * @return none
jmarkel44 35:6235ef67faa1 600 *****************************************************************************/
jmarkel44 34:f345fdec711d 601 void cmd_stack(int argc, char **argv)
jmarkel44 34:f345fdec711d 602 {
jmarkel44 36:f240f5a6d0ed 603 vector<pair<string, Thread*> > taskList;
jmarkel44 36:f240f5a6d0ed 604
jmarkel44 36:f240f5a6d0ed 605 //simply add your task to the list...
jmarkel44 36:f240f5a6d0ed 606 taskList.push_back(make_pair((string)"AnalyticsLogger", GLOBAL_analyticsLogger_thread));
jmarkel44 36:f240f5a6d0ed 607 taskList.push_back(make_pair((string)"BLEHandler", GLOBAL_BLE_thread));
jmarkel44 36:f240f5a6d0ed 608 taskList.push_back(make_pair((string)"CloudDataHandler", GLOBAL_CDH_thread));
jmarkel44 36:f240f5a6d0ed 609 taskList.push_back(make_pair((string)"ConfigHandler", GLOBAL_configHandler_thread));
jmarkel44 36:f240f5a6d0ed 610 taskList.push_back(make_pair((string)"ControlTask", GLOBAL_controlTask_thread));
jmarkel44 36:f240f5a6d0ed 611 taskList.push_back(make_pair((string)"ModbusMaster", GLOBAL_modbusMaster_thread));
jmarkel44 36:f240f5a6d0ed 612
jmarkel44 36:f240f5a6d0ed 613 for ( vector<pair<string, Thread*> >::iterator pos = taskList.begin();
jmarkel44 36:f240f5a6d0ed 614 pos != taskList.end(); ++ pos) {
jmarkel44 36:f240f5a6d0ed 615 printf("\r %-32s size/free/used/max = %u/%u/%u/%u\n",
davidjhoward 41:e8946fc01ea4 616 pos->first.c_str(),
davidjhoward 41:e8946fc01ea4 617 pos->second->stack_size(),
davidjhoward 41:e8946fc01ea4 618 pos->second->free_stack(),
davidjhoward 41:e8946fc01ea4 619 pos->second->used_stack(),
davidjhoward 41:e8946fc01ea4 620 pos->second->max_stack());
jmarkel44 34:f345fdec711d 621 }
jmarkel44 36:f240f5a6d0ed 622
jmarkel44 34:f345fdec711d 623 printf("\r\n");
jmarkel44 34:f345fdec711d 624 }