Library for the PsiSwarm Robot - Version 0.7

Dependents:   PsiSwarm_V7_Blank

Fork of PsiSwarmLibrary by James Hilder

Committer:
jah128
Date:
Sat Oct 15 13:51:39 2016 +0000
Revision:
6:b340a527add9
Parent:
5:3cdd1a37cdd7
Added Apache license to files

Who changed what in which revision?

UserRevisionLine numberNew contents of line
jah128 0:d6269d17c8cf 1 /* University of York Robotics Laboratory PsiSwarm Library: Serial Control Source File
jah128 6:b340a527add9 2 *
jah128 6:b340a527add9 3 * Copyright 2016 University of York
jah128 6:b340a527add9 4 *
jah128 6:b340a527add9 5 * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License.
jah128 6:b340a527add9 6 * You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
jah128 6:b340a527add9 7 * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS
jah128 6:b340a527add9 8 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
jah128 6:b340a527add9 9 * See the License for the specific language governing permissions and limitations under the License.
jah128 0:d6269d17c8cf 10 *
jah128 0:d6269d17c8cf 11 * File: serial.cpp
jah128 0:d6269d17c8cf 12 *
jah128 0:d6269d17c8cf 13 * (C) Dept. Electronics & Computer Science, University of York
jah128 0:d6269d17c8cf 14 * James Hilder, Alan Millard, Alexander Horsfield, Homero Elizondo, Jon Timmis
jah128 0:d6269d17c8cf 15 *
jah128 5:3cdd1a37cdd7 16 * PsiSwarm Library Version: 0.7
jah128 0:d6269d17c8cf 17 *
jah128 5:3cdd1a37cdd7 18 * October 2016
jah128 0:d6269d17c8cf 19 *
jah128 0:d6269d17c8cf 20 *
jah128 0:d6269d17c8cf 21 */
jah128 0:d6269d17c8cf 22
jah128 0:d6269d17c8cf 23 #include "psiswarm.h"
jah128 0:d6269d17c8cf 24
jah128 0:d6269d17c8cf 25 static float command_timeout_period = 0.1f; //If a complete command message is not received in 0.1s then consider it a user message
jah128 0:d6269d17c8cf 26 char pc_command_message_started = 0;
jah128 0:d6269d17c8cf 27 char pc_command_message_byte = 0;
jah128 0:d6269d17c8cf 28 char pc_command_message[3];
jah128 0:d6269d17c8cf 29 char bt_command_message_started = 0;
jah128 0:d6269d17c8cf 30 char bt_command_message_byte = 0;
jah128 0:d6269d17c8cf 31 char bt_command_message[3];
jah128 0:d6269d17c8cf 32
jah128 0:d6269d17c8cf 33 char allow_commands = 1;
jah128 0:d6269d17c8cf 34 char allow_requests = 1;
jah128 2:c6986ee3c7c5 35 char file_transfer_state = 0;
jah128 0:d6269d17c8cf 36
jah128 2:c6986ee3c7c5 37 int block_size = 88; // The data block size for file transfer
jah128 2:c6986ee3c7c5 38 char data_block[89]; // Stores the data block to write for Bluetooth file transfer
jah128 2:c6986ee3c7c5 39 int data_written; // Stores if partial data has been written to a file
jah128 2:c6986ee3c7c5 40 int file_length; // Stores the file length for a Bluetooth file transfer
jah128 2:c6986ee3c7c5 41 int final_block; // Stores the index of the final data block for a Bluetooth file transfer
jah128 2:c6986ee3c7c5 42 int block_index; // Stores the current block index for a Bluetooth file transfer
jah128 2:c6986ee3c7c5 43 char filename [21]; // Stores the filename for a Bluetooth file transfer
jah128 1:060690a934a9 44
jah128 1:060690a934a9 45 Timeout ft_timeout;
jah128 0:d6269d17c8cf 46 Timeout pc_command_timeout;
jah128 0:d6269d17c8cf 47 Timeout bt_command_timeout;
jah128 0:d6269d17c8cf 48
jah128 0:d6269d17c8cf 49 // A predefined message structure for command messages is as follows:
jah128 0:d6269d17c8cf 50 // [Byte 0][Byte 1][Byte 2][Byte 3][Byte 4]
jah128 0:d6269d17c8cf 51 // Byte 0 and Byte 4 must be equal to COMMAND_MESSAGE_BYTE [in psiswarm.h] or message is treated as a user message
jah128 0:d6269d17c8cf 52
jah128 0:d6269d17c8cf 53
jah128 0:d6269d17c8cf 54
jah128 0:d6269d17c8cf 55
jah128 1:060690a934a9 56 void IF_start_file_transfer_mode()
jah128 1:060690a934a9 57 {
jah128 1:060690a934a9 58 display.clear_display();
jah128 1:060690a934a9 59 display.set_position(0,0);
jah128 1:060690a934a9 60 display.write_string("FILE TRANSFER");
jah128 1:060690a934a9 61 display.set_position(1,0);
jah128 1:060690a934a9 62 display.write_string("MODE...");
jah128 2:c6986ee3c7c5 63 data_written = 0;
jah128 1:060690a934a9 64 file_transfer_mode = 1;
jah128 1:060690a934a9 65 file_transfer_state = 0;
jah128 1:060690a934a9 66 file_length = 0;
jah128 1:060690a934a9 67 user_code_restore_mode = user_code_running;
jah128 1:060690a934a9 68 user_code_running = 0;
jah128 1:060690a934a9 69 ft_timeout.attach(IF_file_transfer_timeout,2.0);
jah128 1:060690a934a9 70 }
jah128 1:060690a934a9 71
jah128 1:060690a934a9 72
jah128 1:060690a934a9 73 void IF_invalid_transfer(void)
jah128 1:060690a934a9 74 {
jah128 1:060690a934a9 75 debug("File transfer failed\n");
jah128 2:c6986ee3c7c5 76 if(data_written == 1){
jah128 2:c6986ee3c7c5 77 debug("Deleting corrupted file\n");
jah128 2:c6986ee3c7c5 78 remove(filename);
jah128 2:c6986ee3c7c5 79 }
jah128 1:060690a934a9 80 display.clear_display();
jah128 1:060690a934a9 81 display.set_position(0,0);
jah128 1:060690a934a9 82 display.write_string("TRANSFER FAILED");
jah128 1:060690a934a9 83 wait(0.5);
jah128 1:060690a934a9 84 IF_end_file_transfer_mode();
jah128 1:060690a934a9 85 }
jah128 1:060690a934a9 86
jah128 1:060690a934a9 87 void IF_file_transfer_timeout(void)
jah128 1:060690a934a9 88 {
jah128 1:060690a934a9 89 debug("File transfer failed: timeout\n");
jah128 1:060690a934a9 90 display.clear_display();
jah128 1:060690a934a9 91 display.set_position(0,0);
jah128 1:060690a934a9 92 display.write_string("TRANSFER TIMEOUT");
jah128 1:060690a934a9 93 wait(0.5);
jah128 1:060690a934a9 94 IF_end_file_transfer_mode();
jah128 1:060690a934a9 95 }
jah128 1:060690a934a9 96
jah128 1:060690a934a9 97 void IF_end_file_transfer_mode(void)
jah128 1:060690a934a9 98 {
jah128 1:060690a934a9 99 display.clear_display();
jah128 1:060690a934a9 100 file_transfer_mode = 0;
jah128 1:060690a934a9 101 user_code_running = user_code_restore_mode;
jah128 1:060690a934a9 102 }
jah128 1:060690a934a9 103
jah128 0:d6269d17c8cf 104
jah128 0:d6269d17c8cf 105 void IF_handle_file_transfer_serial_message(char * message, char length, char interface)
jah128 0:d6269d17c8cf 106 {
jah128 0:d6269d17c8cf 107 // Code for handling a serial (Bluetooth) message when in file-transfer mode
jah128 0:d6269d17c8cf 108 //
jah128 0:d6269d17c8cf 109 // message = pointer to message char array
jah128 0:d6269d17c8cf 110 // length = length of message
jah128 0:d6269d17c8cf 111 // interface = 0 for PC serial connection, 1 for Bluetooth [NB only Bluetooth used for file transfer in this version]
jah128 0:d6269d17c8cf 112
jah128 2:c6986ee3c7c5 113 if(file_transfer_state < 2)debug("FTM Message:%.*s [%d]\n",length,message,length);
jah128 2:c6986ee3c7c5 114 else debug("FTM data block received (%d bytes)\n",length);
jah128 1:060690a934a9 115 int expected_size;
jah128 1:060690a934a9 116 // The first byte in EVERY message received should be 33; if it isn't, abort the transfer
jah128 1:060690a934a9 117 if(message[0] != 33) {
jah128 1:060690a934a9 118 IF_invalid_transfer();
jah128 1:060690a934a9 119 } else {
jah128 1:060690a934a9 120 switch(file_transfer_state) {
jah128 1:060690a934a9 121 case 0: //First message received is the target filename
jah128 1:060690a934a9 122 //The filenames cannot be more that 8.3 characters long (FAT12 format)
jah128 1:060690a934a9 123 if(length == 1 || length > 13) IF_invalid_transfer();
jah128 1:060690a934a9 124 else {
jah128 2:c6986ee3c7c5 125 strcpy(filename, "/local/");
jah128 2:c6986ee3c7c5 126 strncat(filename, message + 1, length - 1);
jah128 2:c6986ee3c7c5 127 debug("Target filename:%s\n",filename);
jah128 1:060690a934a9 128 //Send acknowledge ("FN")
jah128 1:060690a934a9 129 ft_timeout.detach();
jah128 1:060690a934a9 130 ft_timeout.attach(IF_file_transfer_timeout,2.0);
jah128 1:060690a934a9 131 bt.printf("%c%c%s",RESPONSE_MESSAGE_BYTE,2,"FN");
jah128 1:060690a934a9 132 file_transfer_state = 1;
jah128 1:060690a934a9 133 }
jah128 1:060690a934a9 134 break;
jah128 1:060690a934a9 135 case 1: //Second message is the length of the file in bytes
jah128 1:060690a934a9 136 //Length is encoded as a 3-byte value
jah128 1:060690a934a9 137 if(length != 4) IF_invalid_transfer();
jah128 1:060690a934a9 138 else {
jah128 1:060690a934a9 139 file_length = (message[1]) * 256;
jah128 1:060690a934a9 140 file_length += (message[2]);
jah128 1:060690a934a9 141 file_length *= 256;
jah128 1:060690a934a9 142 file_length += message[3];
jah128 1:060690a934a9 143 file_transfer_state = 2;
jah128 1:060690a934a9 144 display.clear_display();
jah128 1:060690a934a9 145 char display_message[17];
jah128 1:060690a934a9 146 sprintf(display_message,"F:%s",filename);
jah128 1:060690a934a9 147 display.set_position(0,0);
jah128 1:060690a934a9 148 display.write_string(display_message);
jah128 1:060690a934a9 149 display.set_position(1,0);
jah128 1:060690a934a9 150 sprintf(display_message,"S:%d b",file_length);
jah128 1:060690a934a9 151 display.write_string(display_message);
jah128 1:060690a934a9 152 block_index = 0;
jah128 1:060690a934a9 153 //Work out how many blocks the file will be sent in (size = block_size, tested at 100 bytes)
jah128 1:060690a934a9 154 //Allocate memory for the file up to a limit of 16 blocks; larger files will be split across
jah128 1:060690a934a9 155 //multiple blocks....
jah128 1:060690a934a9 156 final_block = file_length / block_size;
jah128 1:060690a934a9 157 if(file_length % block_size != 0) final_block ++;
jah128 2:c6986ee3c7c5 158 //int target_size = file_length;
jah128 2:c6986ee3c7c5 159 //if(file_length > (block_size * 16)) target_size = block_size * 16;
jah128 2:c6986ee3c7c5 160 //file_data = (char *) malloc(target_size);
jah128 2:c6986ee3c7c5 161 debug("File size %d bytes (%d blocks of %d bytes)\n",file_length,final_block,block_size);
jah128 1:060690a934a9 162 ft_timeout.detach();
jah128 1:060690a934a9 163 ft_timeout.attach(IF_file_transfer_timeout,1.0);
jah128 1:060690a934a9 164 //Send acknowledge (size of file)
jah128 1:060690a934a9 165 bt.printf("%c%c%c%c%c",RESPONSE_MESSAGE_BYTE,3,message[1],message[2],message[3]);
jah128 1:060690a934a9 166 }
jah128 1:060690a934a9 167 break;
jah128 1:060690a934a9 168 case 2:
jah128 1:060690a934a9 169 block_index ++;
jah128 2:c6986ee3c7c5 170 display.clear_display();
jah128 2:c6986ee3c7c5 171 display.set_position(0,0);
jah128 2:c6986ee3c7c5 172 display.write_string("FILE TRANSFER");
jah128 2:c6986ee3c7c5 173 display.set_position(1,0);
jah128 2:c6986ee3c7c5 174 char details_string[17];
jah128 2:c6986ee3c7c5 175 sprintf(details_string,"BLOCK %d OF %d",block_index,final_block);
jah128 2:c6986ee3c7c5 176 display.write_string(details_string);
jah128 2:c6986ee3c7c5 177 expected_size = block_size;
jah128 1:060690a934a9 178 if(block_index == final_block) expected_size = file_length % block_size;
jah128 1:060690a934a9 179 if(expected_size == 0) expected_size = block_size;
jah128 1:060690a934a9 180 if(length!=expected_size + 1){
jah128 1:060690a934a9 181 // Unexpected length
jah128 2:c6986ee3c7c5 182 debug("File data unexpected length in packet %d (%d bytes received, %d bytes expected)\n",block_index,length-1,expected_size);
jah128 1:060690a934a9 183 }else{
jah128 2:c6986ee3c7c5 184 char transfer_mode[2]={'a'};
jah128 2:c6986ee3c7c5 185 if(block_index == 1){
jah128 2:c6986ee3c7c5 186 transfer_mode[0]='w';
jah128 2:c6986ee3c7c5 187 }
jah128 2:c6986ee3c7c5 188 FILE *fp = fopen(filename,transfer_mode);
jah128 2:c6986ee3c7c5 189 //strncpy(data_block,message+1,length);
jah128 2:c6986ee3c7c5 190 //data_block[length]=0;
jah128 2:c6986ee3c7c5 191 //fprintf(fp,data_block);
jah128 2:c6986ee3c7c5 192 int bytes_written;
jah128 2:c6986ee3c7c5 193 bytes_written = fwrite(message+1,expected_size,1,fp);
jah128 2:c6986ee3c7c5 194 fclose(fp);
jah128 2:c6986ee3c7c5 195 if(data_written == false && bytes_written > 0) data_written = true;
jah128 2:c6986ee3c7c5 196 debug("Bytes written: %d\n",expected_size * bytes_written);
jah128 2:c6986ee3c7c5 197 if(block_index < final_block){
jah128 2:c6986ee3c7c5 198 debug("Message packet %d received and written\n",block_index);
jah128 2:c6986ee3c7c5 199 //Send acknowledge ("D")
jah128 1:060690a934a9 200 ft_timeout.detach();
jah128 1:060690a934a9 201 ft_timeout.attach(IF_file_transfer_timeout,1.0);
jah128 2:c6986ee3c7c5 202 bt.printf("%c%c%s",RESPONSE_MESSAGE_BYTE,1,"D");
jah128 2:c6986ee3c7c5 203 }
jah128 2:c6986ee3c7c5 204 else{
jah128 2:c6986ee3c7c5 205 //Last data block written
jah128 2:c6986ee3c7c5 206 //[Put file checking code here]
jah128 2:c6986ee3c7c5 207 //Send acknowledge ("P");
jah128 2:c6986ee3c7c5 208 bt.printf("%c%c%s",RESPONSE_MESSAGE_BYTE,1,"F");
jah128 2:c6986ee3c7c5 209 ft_timeout.detach();
jah128 2:c6986ee3c7c5 210 debug("File transfer completed successfully\n");
jah128 2:c6986ee3c7c5 211 wait(0.25);
jah128 2:c6986ee3c7c5 212 //Calculate CRC16 value for file
jah128 2:c6986ee3c7c5 213 IF_calculateCRC16(file_length);
jah128 2:c6986ee3c7c5 214
jah128 2:c6986ee3c7c5 215 display.clear_display();
jah128 2:c6986ee3c7c5 216 display.write_string("FILE TRANSFER");
jah128 2:c6986ee3c7c5 217 display.set_position(1,0);
jah128 2:c6986ee3c7c5 218 display.write_string("COMPLETE");
jah128 2:c6986ee3c7c5 219 wait(1);
jah128 2:c6986ee3c7c5 220 debug("File transfer mode ended\n");
jah128 2:c6986ee3c7c5 221 IF_end_file_transfer_mode();
jah128 2:c6986ee3c7c5 222 }
jah128 1:060690a934a9 223 }
jah128 2:c6986ee3c7c5 224 break;
jah128 1:060690a934a9 225 }
jah128 1:060690a934a9 226 }
jah128 0:d6269d17c8cf 227 }
jah128 0:d6269d17c8cf 228
jah128 0:d6269d17c8cf 229
jah128 0:d6269d17c8cf 230 void IF_handle_user_serial_message(char * message, char length, char interface)
jah128 0:d6269d17c8cf 231 {
jah128 0:d6269d17c8cf 232 char buffer[255];
jah128 0:d6269d17c8cf 233 sprintf(buffer,message,length);
jah128 0:d6269d17c8cf 234 for(int i=0; i<length; i++) {
jah128 0:d6269d17c8cf 235 buffer[i]=message[i];
jah128 0:d6269d17c8cf 236 }
jah128 0:d6269d17c8cf 237 buffer[length]=0;
jah128 0:d6269d17c8cf 238 // if(interface) debug("Received BT message:%s [%d chars]\n",buffer,length);
jah128 0:d6269d17c8cf 239 // else debug("Received USB message:%s [%d chars]\n",buffer,length);
jah128 0:d6269d17c8cf 240 handle_user_serial_message(message,length,interface);
jah128 0:d6269d17c8cf 241 }
jah128 0:d6269d17c8cf 242
jah128 0:d6269d17c8cf 243 void IF_handle_command_serial_message(char message[3], char interface)
jah128 0:d6269d17c8cf 244 {
jah128 0:d6269d17c8cf 245 char iface [4];
jah128 0:d6269d17c8cf 246 if(interface) strcpy(iface,"BT");
jah128 0:d6269d17c8cf 247 else strcpy(iface,"USB");
jah128 0:d6269d17c8cf 248 char command [26];
jah128 0:d6269d17c8cf 249 char subcommand[30];
jah128 0:d6269d17c8cf 250 float dec;
jah128 0:d6269d17c8cf 251 float l_dec;
jah128 0:d6269d17c8cf 252 float r_dec;
jah128 0:d6269d17c8cf 253 int irp_delay;
jah128 0:d6269d17c8cf 254 char colour_string[7];
jah128 0:d6269d17c8cf 255 char ret_message[50];
jah128 0:d6269d17c8cf 256 char send_message = 0;
jah128 0:d6269d17c8cf 257 char command_status = 0;
jah128 0:d6269d17c8cf 258 // command_status values:
jah128 0:d6269d17c8cf 259 // 0 - unrecognised command
jah128 0:d6269d17c8cf 260 // 1 - command actioned
jah128 0:d6269d17c8cf 261 // 2 - command blocked
jah128 0:d6269d17c8cf 262 // 3 - invalid parameters
jah128 0:d6269d17c8cf 263
jah128 0:d6269d17c8cf 264 subcommand[0]=0;
jah128 0:d6269d17c8cf 265 command[0]=0;
jah128 0:d6269d17c8cf 266 switch(message[0]) {
jah128 0:d6269d17c8cf 267
jah128 0:d6269d17c8cf 268 // MOTOR COMMANDS
jah128 0:d6269d17c8cf 269
jah128 0:d6269d17c8cf 270 case 1:
jah128 0:d6269d17c8cf 271 strcpy(command,"SET LEFT MOTOR");
jah128 0:d6269d17c8cf 272 dec = IF_decode_float(message[1],message[2]);
jah128 0:d6269d17c8cf 273 sprintf(subcommand,"%1.5f",dec);
jah128 0:d6269d17c8cf 274 if(allow_commands) {
jah128 0:d6269d17c8cf 275 command_status = 1;
jah128 0:d6269d17c8cf 276 set_left_motor_speed(dec);
jah128 0:d6269d17c8cf 277 } else command_status = 2;
jah128 0:d6269d17c8cf 278 break;
jah128 0:d6269d17c8cf 279 case 2:
jah128 0:d6269d17c8cf 280 strcpy(command,"SET RIGHT MOTOR");
jah128 0:d6269d17c8cf 281 dec = IF_decode_float(message[1],message[2]);
jah128 0:d6269d17c8cf 282 sprintf(subcommand,"%1.5f",dec);
jah128 0:d6269d17c8cf 283 if(allow_commands) {
jah128 0:d6269d17c8cf 284 set_right_motor_speed(dec);
jah128 0:d6269d17c8cf 285 command_status = 1;
jah128 0:d6269d17c8cf 286 } else command_status = 2;
jah128 0:d6269d17c8cf 287 break;
jah128 0:d6269d17c8cf 288 case 3:
jah128 0:d6269d17c8cf 289 strcpy(command,"SET BOTH MOTORS");
jah128 0:d6269d17c8cf 290 dec = IF_decode_float(message[1],message[2]);
jah128 0:d6269d17c8cf 291 sprintf(subcommand,"%1.5f",dec);
jah128 0:d6269d17c8cf 292 if(allow_commands) {
jah128 0:d6269d17c8cf 293 command_status = 1;
jah128 0:d6269d17c8cf 294 forward(dec);
jah128 0:d6269d17c8cf 295 } else command_status = 2;
jah128 0:d6269d17c8cf 296 break;
jah128 0:d6269d17c8cf 297 case 4:
jah128 0:d6269d17c8cf 298 strcpy(command,"BRAKE LEFT MOTOR");
jah128 0:d6269d17c8cf 299 sprintf(subcommand,"");
jah128 0:d6269d17c8cf 300 if(allow_commands) {
jah128 0:d6269d17c8cf 301 command_status = 1;
jah128 0:d6269d17c8cf 302 brake_left_motor();
jah128 0:d6269d17c8cf 303 } else command_status = 2;
jah128 0:d6269d17c8cf 304 break;
jah128 0:d6269d17c8cf 305 case 5:
jah128 0:d6269d17c8cf 306 strcpy(command,"BRAKE RIGHT MOTOR");
jah128 0:d6269d17c8cf 307 sprintf(subcommand,"");
jah128 0:d6269d17c8cf 308 if(allow_commands) {
jah128 0:d6269d17c8cf 309 command_status = 1;
jah128 0:d6269d17c8cf 310 brake_right_motor();
jah128 0:d6269d17c8cf 311 } else command_status = 2;
jah128 0:d6269d17c8cf 312 break;
jah128 0:d6269d17c8cf 313 case 6:
jah128 0:d6269d17c8cf 314 strcpy(command,"BRAKE BOTH MOTORS");
jah128 0:d6269d17c8cf 315 sprintf(subcommand,"");
jah128 0:d6269d17c8cf 316 if(allow_commands) {
jah128 0:d6269d17c8cf 317 command_status = 1;
jah128 0:d6269d17c8cf 318 brake();
jah128 0:d6269d17c8cf 319 } else command_status = 2;
jah128 0:d6269d17c8cf 320 break;
jah128 0:d6269d17c8cf 321 case 7:
jah128 0:d6269d17c8cf 322 strcpy(command,"STOP BOTH MOTORS");
jah128 0:d6269d17c8cf 323 sprintf(subcommand,"");
jah128 0:d6269d17c8cf 324 if(allow_commands) {
jah128 0:d6269d17c8cf 325 command_status = 1;
jah128 0:d6269d17c8cf 326 stop();
jah128 0:d6269d17c8cf 327 } else command_status = 2;
jah128 0:d6269d17c8cf 328 break;
jah128 0:d6269d17c8cf 329 case 8:
jah128 0:d6269d17c8cf 330 strcpy(command,"TURN ON SPOT");
jah128 0:d6269d17c8cf 331 dec = IF_decode_float(message[1],message[2]);
jah128 0:d6269d17c8cf 332 sprintf(subcommand,"%1.5f",dec);
jah128 0:d6269d17c8cf 333 if(allow_commands) {
jah128 0:d6269d17c8cf 334 command_status = 1;
jah128 0:d6269d17c8cf 335 turn(dec);
jah128 0:d6269d17c8cf 336 } else command_status = 2;
jah128 0:d6269d17c8cf 337 break;
jah128 0:d6269d17c8cf 338 case 9:
jah128 0:d6269d17c8cf 339 strcpy(command,"SET EACH MOTOR");
jah128 0:d6269d17c8cf 340 l_dec = IF_decode_float(message[1]);
jah128 0:d6269d17c8cf 341 r_dec = IF_decode_float(message[2]);
jah128 0:d6269d17c8cf 342 sprintf(subcommand,"L=%1.3f R=%1.3f",l_dec,r_dec);
jah128 0:d6269d17c8cf 343 if(allow_commands) {
jah128 0:d6269d17c8cf 344 command_status = 1;
jah128 0:d6269d17c8cf 345 set_left_motor_speed(l_dec);
jah128 0:d6269d17c8cf 346 set_right_motor_speed(r_dec);
jah128 0:d6269d17c8cf 347 } else command_status = 2;
jah128 0:d6269d17c8cf 348 break;
jah128 0:d6269d17c8cf 349 // LED COMMANDS
jah128 0:d6269d17c8cf 350
jah128 0:d6269d17c8cf 351 case 10:
jah128 0:d6269d17c8cf 352 strcpy(command,"SET LED STATES");
jah128 0:d6269d17c8cf 353 sprintf(subcommand,"G:%s R:%s",IF_char_to_binary_char(message[1]), IF_char_to_binary_char(message[2]));
jah128 0:d6269d17c8cf 354 if(allow_commands) {
jah128 0:d6269d17c8cf 355 command_status = 1;
jah128 0:d6269d17c8cf 356 set_leds(message[1],message[2]);
jah128 0:d6269d17c8cf 357 } else command_status = 2;
jah128 0:d6269d17c8cf 358 break;
jah128 0:d6269d17c8cf 359 case 11:
jah128 0:d6269d17c8cf 360 strcpy(command,"SET RED LED STATES");
jah128 0:d6269d17c8cf 361 sprintf(subcommand,"%s",IF_char_to_binary_char(message[1]));
jah128 0:d6269d17c8cf 362 if(allow_commands) {
jah128 0:d6269d17c8cf 363 command_status = 1;
jah128 0:d6269d17c8cf 364 set_red_leds(message[1]);
jah128 0:d6269d17c8cf 365 } else command_status = 2;
jah128 0:d6269d17c8cf 366 break;
jah128 0:d6269d17c8cf 367 case 12:
jah128 0:d6269d17c8cf 368 strcpy(command,"SET GREEN LED STATES");
jah128 0:d6269d17c8cf 369 sprintf(subcommand,"%s",IF_char_to_binary_char(message[1]));
jah128 0:d6269d17c8cf 370 if(allow_commands) {
jah128 0:d6269d17c8cf 371 command_status = 1;
jah128 0:d6269d17c8cf 372 set_green_leds(message[1]);
jah128 0:d6269d17c8cf 373 } else command_status = 2;
jah128 0:d6269d17c8cf 374 break;
jah128 0:d6269d17c8cf 375 case 13:
jah128 0:d6269d17c8cf 376 strcpy(command,"SET LED");
jah128 0:d6269d17c8cf 377 switch(message[2]) {
jah128 0:d6269d17c8cf 378 case 1:
jah128 0:d6269d17c8cf 379 strcpy(colour_string,"RED");
jah128 0:d6269d17c8cf 380 break;
jah128 0:d6269d17c8cf 381 case 2:
jah128 0:d6269d17c8cf 382 strcpy(colour_string,"GREEN");
jah128 0:d6269d17c8cf 383 break;
jah128 0:d6269d17c8cf 384 case 3:
jah128 0:d6269d17c8cf 385 strcpy(colour_string,"BOTH");
jah128 0:d6269d17c8cf 386 break;
jah128 0:d6269d17c8cf 387 case 0:
jah128 0:d6269d17c8cf 388 strcpy(colour_string,"OFF");
jah128 0:d6269d17c8cf 389 break;
jah128 0:d6269d17c8cf 390 }
jah128 0:d6269d17c8cf 391 if(message[1] < 8 && message[2] < 4) {
jah128 0:d6269d17c8cf 392 sprintf(subcommand,"%d %s",message[1],colour_string);
jah128 0:d6269d17c8cf 393 if(allow_commands) {
jah128 0:d6269d17c8cf 394 command_status = 1;
jah128 0:d6269d17c8cf 395 set_led(message[1],message[2]);
jah128 0:d6269d17c8cf 396 } else command_status = 2;
jah128 0:d6269d17c8cf 397 } else {
jah128 0:d6269d17c8cf 398 sprintf(subcommand,"[INVALID CODE]");
jah128 0:d6269d17c8cf 399 command_status = 3;
jah128 0:d6269d17c8cf 400 }
jah128 0:d6269d17c8cf 401 break;
jah128 0:d6269d17c8cf 402 case 14:
jah128 0:d6269d17c8cf 403 strcpy(command,"SET CENTER LED STATE");
jah128 0:d6269d17c8cf 404 switch(message[1]) {
jah128 0:d6269d17c8cf 405 case 1:
jah128 0:d6269d17c8cf 406 strcpy(colour_string,"RED");
jah128 0:d6269d17c8cf 407 break;
jah128 0:d6269d17c8cf 408 case 2:
jah128 0:d6269d17c8cf 409 strcpy(colour_string,"GREEN");
jah128 0:d6269d17c8cf 410 break;
jah128 0:d6269d17c8cf 411 case 3:
jah128 0:d6269d17c8cf 412 strcpy(colour_string,"BOTH");
jah128 0:d6269d17c8cf 413 break;
jah128 0:d6269d17c8cf 414 case 0:
jah128 0:d6269d17c8cf 415 strcpy(colour_string,"OFF");
jah128 0:d6269d17c8cf 416 break;
jah128 0:d6269d17c8cf 417 }
jah128 0:d6269d17c8cf 418 if(message[1] < 4) {
jah128 0:d6269d17c8cf 419 sprintf(subcommand,"%s",colour_string);
jah128 0:d6269d17c8cf 420 if(allow_commands) {
jah128 0:d6269d17c8cf 421 command_status = 1;
jah128 0:d6269d17c8cf 422 set_center_led(message[1]);
jah128 0:d6269d17c8cf 423 } else command_status = 2;
jah128 0:d6269d17c8cf 424 } else {
jah128 0:d6269d17c8cf 425 sprintf(subcommand,"[INVALID CODE]");
jah128 0:d6269d17c8cf 426 command_status = 3;
jah128 0:d6269d17c8cf 427 }
jah128 0:d6269d17c8cf 428 break;
jah128 0:d6269d17c8cf 429 case 15:
jah128 0:d6269d17c8cf 430 strcpy(command,"SET C.LED BRIGHTNESS");
jah128 0:d6269d17c8cf 431 dec = IF_decode_unsigned_float(message[1],message[2]);
jah128 0:d6269d17c8cf 432 sprintf(subcommand,"%1.5f",dec);
jah128 0:d6269d17c8cf 433 if(allow_commands) {
jah128 0:d6269d17c8cf 434 command_status = 1;
jah128 0:d6269d17c8cf 435 set_center_led_brightness(dec);
jah128 0:d6269d17c8cf 436 } else command_status = 2;
jah128 0:d6269d17c8cf 437 break;
jah128 0:d6269d17c8cf 438 case 16:
jah128 0:d6269d17c8cf 439 strcpy(command,"SET MBED LEDS");
jah128 0:d6269d17c8cf 440 sprintf(subcommand,"%s",IF_nibble_to_binary_char(message[1]));
jah128 0:d6269d17c8cf 441 if(allow_commands) {
jah128 0:d6269d17c8cf 442 command_status = 1;
jah128 0:d6269d17c8cf 443 mbed_led1 = (message[1] & 128) >> 7;
jah128 0:d6269d17c8cf 444 mbed_led2 = (message[1] & 64) >> 6;
jah128 0:d6269d17c8cf 445 mbed_led3 = (message[1] & 32) >> 5;
jah128 0:d6269d17c8cf 446 mbed_led4 = (message[1] & 16) >> 4;
jah128 0:d6269d17c8cf 447 } else command_status = 2;
jah128 0:d6269d17c8cf 448 break;
jah128 0:d6269d17c8cf 449 case 17:
jah128 0:d6269d17c8cf 450 strcpy(command,"BLINK OUTER LEDS");
jah128 0:d6269d17c8cf 451 dec = IF_decode_unsigned_float(message[1],message[2]);
jah128 0:d6269d17c8cf 452 sprintf(subcommand,"FOR %1.5fS",dec);
jah128 0:d6269d17c8cf 453 if(allow_commands) {
jah128 0:d6269d17c8cf 454 command_status = 1;
jah128 0:d6269d17c8cf 455 blink_leds(dec);
jah128 0:d6269d17c8cf 456 } else command_status = 2;
jah128 0:d6269d17c8cf 457 break;
jah128 0:d6269d17c8cf 458 case 18:
jah128 0:d6269d17c8cf 459 strcpy(command,"SET BASE LED STATE");
jah128 0:d6269d17c8cf 460 switch(message[1]) {
jah128 0:d6269d17c8cf 461 case 1:
jah128 0:d6269d17c8cf 462 strcpy(subcommand,"ON");
jah128 0:d6269d17c8cf 463 break;
jah128 0:d6269d17c8cf 464 case 0:
jah128 0:d6269d17c8cf 465 strcpy(subcommand,"OFF");
jah128 0:d6269d17c8cf 466 break;
jah128 0:d6269d17c8cf 467 }
jah128 0:d6269d17c8cf 468 //Function not yet implemented
jah128 0:d6269d17c8cf 469 break;
jah128 0:d6269d17c8cf 470 case 19:
jah128 0:d6269d17c8cf 471 strcpy(command,"SET CENTER LED ");
jah128 0:d6269d17c8cf 472 switch(message[1]) {
jah128 0:d6269d17c8cf 473 case 1:
jah128 0:d6269d17c8cf 474 strcpy(colour_string,"RED");
jah128 0:d6269d17c8cf 475 break;
jah128 0:d6269d17c8cf 476 case 2:
jah128 0:d6269d17c8cf 477 strcpy(colour_string,"GREEN");
jah128 0:d6269d17c8cf 478 break;
jah128 0:d6269d17c8cf 479 case 3:
jah128 0:d6269d17c8cf 480 strcpy(colour_string,"BOTH");
jah128 0:d6269d17c8cf 481 break;
jah128 0:d6269d17c8cf 482 case 0:
jah128 0:d6269d17c8cf 483 strcpy(colour_string,"OFF");
jah128 0:d6269d17c8cf 484 break;
jah128 0:d6269d17c8cf 485 }
jah128 0:d6269d17c8cf 486 dec = IF_decode_unsigned_float(message[2]);
jah128 0:d6269d17c8cf 487 sprintf(subcommand,"%s @ %1.5f brightness",colour_string,dec);
jah128 0:d6269d17c8cf 488 if(allow_commands) {
jah128 0:d6269d17c8cf 489 command_status = 1;
jah128 0:d6269d17c8cf 490 set_center_led(message[1],dec);
jah128 0:d6269d17c8cf 491 } else command_status = 2;
jah128 0:d6269d17c8cf 492 break;
jah128 0:d6269d17c8cf 493
jah128 0:d6269d17c8cf 494 // DISPLAY COMMANDS
jah128 0:d6269d17c8cf 495
jah128 0:d6269d17c8cf 496 case 20:
jah128 0:d6269d17c8cf 497 strcpy(command,"SET DISPLAY ");
jah128 0:d6269d17c8cf 498 switch(message[1]) {
jah128 0:d6269d17c8cf 499 case 0:
jah128 0:d6269d17c8cf 500 strcpy(subcommand,"CLEAR");
jah128 0:d6269d17c8cf 501 if(allow_commands) {
jah128 0:d6269d17c8cf 502 command_status = 1;
jah128 0:d6269d17c8cf 503 display.clear_display();
jah128 0:d6269d17c8cf 504 } else command_status = 2;
jah128 0:d6269d17c8cf 505 break;
jah128 0:d6269d17c8cf 506 case 1:
jah128 0:d6269d17c8cf 507 strcpy(subcommand,"MESSAGE 1");
jah128 0:d6269d17c8cf 508 if(allow_commands) {
jah128 0:d6269d17c8cf 509 command_status = 1;
jah128 0:d6269d17c8cf 510 display.clear_display();
jah128 0:d6269d17c8cf 511 display.home();
jah128 0:d6269d17c8cf 512 display.write_string("PC CONNECTION");
jah128 0:d6269d17c8cf 513 display.set_position(1,0);
jah128 0:d6269d17c8cf 514 display.write_string("STARTED");
jah128 0:d6269d17c8cf 515 } else command_status = 2;
jah128 0:d6269d17c8cf 516 break;
jah128 0:d6269d17c8cf 517 case 2:
jah128 0:d6269d17c8cf 518 strcpy(subcommand,"MESSAGE 2");
jah128 0:d6269d17c8cf 519 if(allow_commands) {
jah128 0:d6269d17c8cf 520 command_status = 1;
jah128 0:d6269d17c8cf 521 display.clear_display();
jah128 0:d6269d17c8cf 522 display.home();
jah128 0:d6269d17c8cf 523 display.write_string("PC CONNECTION");
jah128 0:d6269d17c8cf 524 display.set_position(1,0);
jah128 0:d6269d17c8cf 525 display.write_string("TERMINATED");
jah128 0:d6269d17c8cf 526 } else command_status = 2;
jah128 0:d6269d17c8cf 527 break;
jah128 0:d6269d17c8cf 528 case 3:
jah128 0:d6269d17c8cf 529 strcpy(subcommand,"MESSAGE 3");
jah128 0:d6269d17c8cf 530 if(allow_commands) {
jah128 0:d6269d17c8cf 531 command_status = 1;
jah128 0:d6269d17c8cf 532 display.clear_display();
jah128 0:d6269d17c8cf 533 display.home();
jah128 0:d6269d17c8cf 534 display.write_string("ANDROID DEVICE");
jah128 0:d6269d17c8cf 535 display.set_position(1,0);
jah128 0:d6269d17c8cf 536 display.write_string("CONNECTED");
jah128 0:d6269d17c8cf 537 } else command_status = 2;
jah128 0:d6269d17c8cf 538 break;
jah128 0:d6269d17c8cf 539 case 4:
jah128 0:d6269d17c8cf 540 strcpy(subcommand,"MESSAGE 4");
jah128 0:d6269d17c8cf 541 if(allow_commands) {
jah128 0:d6269d17c8cf 542 command_status = 1;
jah128 0:d6269d17c8cf 543 display.clear_display();
jah128 0:d6269d17c8cf 544 display.home();
jah128 0:d6269d17c8cf 545 display.write_string("ANDROID DEVICE");
jah128 0:d6269d17c8cf 546 display.set_position(1,0);
jah128 0:d6269d17c8cf 547 display.write_string("DISCONNECTED");
jah128 0:d6269d17c8cf 548 } else command_status = 2;
jah128 0:d6269d17c8cf 549 break;
jah128 3:7c0d1f581757 550 case 5:
jah128 3:7c0d1f581757 551 strcpy(subcommand,"MESSAGE 5");
jah128 3:7c0d1f581757 552 if(allow_commands) {
jah128 3:7c0d1f581757 553 command_status = 1;
jah128 3:7c0d1f581757 554 display.clear_display();
jah128 3:7c0d1f581757 555 display.home();
jah128 3:7c0d1f581757 556 display.write_string("PSI CONSOLE");
jah128 3:7c0d1f581757 557 display.set_position(1,0);
jah128 3:7c0d1f581757 558 display.write_string("CONNECTED");
jah128 3:7c0d1f581757 559 } else command_status = 2;
jah128 3:7c0d1f581757 560 break;
jah128 3:7c0d1f581757 561 case 6:
jah128 3:7c0d1f581757 562 strcpy(subcommand,"MESSAGE 6");
jah128 3:7c0d1f581757 563 if(allow_commands) {
jah128 3:7c0d1f581757 564 command_status = 1;
jah128 3:7c0d1f581757 565 display.clear_display();
jah128 3:7c0d1f581757 566 display.home();
jah128 3:7c0d1f581757 567 display.write_string("PSI CONSOLE");
jah128 3:7c0d1f581757 568 display.set_position(1,0);
jah128 3:7c0d1f581757 569 display.write_string("DISCONNECTED");
jah128 3:7c0d1f581757 570 } else command_status = 2;
jah128 3:7c0d1f581757 571 break;
jah128 0:d6269d17c8cf 572 }
jah128 0:d6269d17c8cf 573 break;
jah128 0:d6269d17c8cf 574 case 21:
jah128 0:d6269d17c8cf 575 strcpy(command,"SET CURSOR ");
jah128 0:d6269d17c8cf 576 if(message[1] < 2 && message[2] < 16) {
jah128 0:d6269d17c8cf 577 sprintf(subcommand,"[%d,%d]",message[1],message[2]);
jah128 0:d6269d17c8cf 578 if(allow_commands) {
jah128 0:d6269d17c8cf 579 display.set_position(message[1],message[2]);
jah128 0:d6269d17c8cf 580 } else command_status = 2;
jah128 0:d6269d17c8cf 581 } else {
jah128 0:d6269d17c8cf 582 sprintf(subcommand,"[INVALID]");
jah128 0:d6269d17c8cf 583 command_status = 3;
jah128 0:d6269d17c8cf 584 }
jah128 0:d6269d17c8cf 585 break;
jah128 0:d6269d17c8cf 586 case 22:
jah128 0:d6269d17c8cf 587 strcpy(command,"PRINT CHARACTERS ");
jah128 0:d6269d17c8cf 588 char print_message[2];
jah128 0:d6269d17c8cf 589 print_message[0]=message[1];
jah128 0:d6269d17c8cf 590 print_message[1]=message[2];
jah128 0:d6269d17c8cf 591 sprintf(subcommand,"[%c,%c]",message[1],message[2]);
jah128 0:d6269d17c8cf 592 if(allow_commands) {
jah128 0:d6269d17c8cf 593 display.write_string(print_message,2);
jah128 0:d6269d17c8cf 594 } else command_status = 2;
jah128 0:d6269d17c8cf 595 break;
jah128 0:d6269d17c8cf 596 case 23:
jah128 0:d6269d17c8cf 597 strcpy(command,"SET DISPLAY B.NESS");
jah128 0:d6269d17c8cf 598 dec = IF_decode_unsigned_float(message[1],message[2]);
jah128 0:d6269d17c8cf 599 sprintf(subcommand,"%1.5f",dec);
jah128 0:d6269d17c8cf 600 if(allow_commands) {
jah128 0:d6269d17c8cf 601 command_status = 1;
jah128 0:d6269d17c8cf 602 display.set_backlight_brightness(dec);
jah128 0:d6269d17c8cf 603 } else command_status = 2;
jah128 0:d6269d17c8cf 604 break;
jah128 0:d6269d17c8cf 605
jah128 0:d6269d17c8cf 606 case 30:
jah128 0:d6269d17c8cf 607 strcpy(command,"SET DEBUG MODE");
jah128 0:d6269d17c8cf 608 switch(message[1]) {
jah128 0:d6269d17c8cf 609 case 1:
jah128 0:d6269d17c8cf 610 strcpy(subcommand,"ON");
jah128 0:d6269d17c8cf 611 break;
jah128 0:d6269d17c8cf 612 case 0:
jah128 0:d6269d17c8cf 613 strcpy(subcommand,"OFF");
jah128 0:d6269d17c8cf 614 break;
jah128 0:d6269d17c8cf 615 }
jah128 0:d6269d17c8cf 616 if(message[2] & 1) strcat (subcommand,"-PC");
jah128 0:d6269d17c8cf 617 if(message[2] & 2) strcat (subcommand,"-BT");
jah128 0:d6269d17c8cf 618 if(message[2] & 4) strcat (subcommand,"-DISP");
jah128 0:d6269d17c8cf 619 if(allow_commands) {
jah128 0:d6269d17c8cf 620 command_status = 1;
jah128 0:d6269d17c8cf 621 debug_mode = message[1];
jah128 0:d6269d17c8cf 622 debug_output = message[2];
jah128 0:d6269d17c8cf 623 } else command_status = 2;
jah128 0:d6269d17c8cf 624 break;
jah128 0:d6269d17c8cf 625 case 31:
jah128 0:d6269d17c8cf 626 strcpy(command,"SET DEMO MODE");
jah128 0:d6269d17c8cf 627 switch(message[1] % 2) {
jah128 0:d6269d17c8cf 628 case 1:
jah128 0:d6269d17c8cf 629 strcpy(subcommand,"ON");
jah128 0:d6269d17c8cf 630 break;
jah128 0:d6269d17c8cf 631 case 0:
jah128 0:d6269d17c8cf 632 strcpy(subcommand,"OFF");
jah128 0:d6269d17c8cf 633 break;
jah128 0:d6269d17c8cf 634 }
jah128 0:d6269d17c8cf 635 if(allow_commands) {
jah128 0:d6269d17c8cf 636 command_status = 1;
jah128 0:d6269d17c8cf 637 demo_on = message[1] % 2;
jah128 0:d6269d17c8cf 638 if(demo_on == 1) {
jah128 0:d6269d17c8cf 639 user_code_restore_mode = user_code_running;
jah128 0:d6269d17c8cf 640 user_code_running = 0;
jah128 0:d6269d17c8cf 641 } else {
jah128 0:d6269d17c8cf 642 user_code_running = user_code_restore_mode;
jah128 0:d6269d17c8cf 643 }
jah128 0:d6269d17c8cf 644 } else command_status = 2;
jah128 0:d6269d17c8cf 645 break;
jah128 0:d6269d17c8cf 646 case 32:
jah128 0:d6269d17c8cf 647 strcpy(command,"SET USER CODE");
jah128 0:d6269d17c8cf 648 switch(message[1] % 2) {
jah128 0:d6269d17c8cf 649 case 1:
jah128 0:d6269d17c8cf 650 strcpy(subcommand,"ON");
jah128 0:d6269d17c8cf 651 break;
jah128 0:d6269d17c8cf 652 case 0:
jah128 0:d6269d17c8cf 653 strcpy(subcommand,"OFF");
jah128 0:d6269d17c8cf 654 break;
jah128 0:d6269d17c8cf 655 }
jah128 0:d6269d17c8cf 656 if(allow_commands) {
jah128 0:d6269d17c8cf 657 command_status = 1;
jah128 0:d6269d17c8cf 658 user_code_running = message[1] % 2;
jah128 0:d6269d17c8cf 659 } else command_status = 2;
jah128 0:d6269d17c8cf 660 break;
jah128 0:d6269d17c8cf 661 case 33:
jah128 0:d6269d17c8cf 662 strcpy(command,"PAUSE USER CODE");
jah128 0:d6269d17c8cf 663 dec = IF_decode_unsigned_float(message[1],message[2]) * 10;
jah128 0:d6269d17c8cf 664 sprintf(subcommand,"FOR %2.3fS",dec);
jah128 0:d6269d17c8cf 665 if(allow_commands) {
jah128 0:d6269d17c8cf 666 command_status = 1;
jah128 0:d6269d17c8cf 667 pause_user_code(dec);
jah128 0:d6269d17c8cf 668 } else command_status = 2;
jah128 0:d6269d17c8cf 669 break;
jah128 0:d6269d17c8cf 670
jah128 0:d6269d17c8cf 671 case 34:
jah128 0:d6269d17c8cf 672 strcpy(command,"RESET ENCODERS");
jah128 0:d6269d17c8cf 673 if(allow_commands) {
jah128 0:d6269d17c8cf 674 command_status = 1;
jah128 0:d6269d17c8cf 675 reset_encoders();
jah128 0:d6269d17c8cf 676 } else command_status = 2;
jah128 0:d6269d17c8cf 677 break;
jah128 0:d6269d17c8cf 678
jah128 0:d6269d17c8cf 679 case 35:
jah128 0:d6269d17c8cf 680 strcpy(command,"SET ALLOW COMMANDS");
jah128 0:d6269d17c8cf 681 switch(message[1] % 2) {
jah128 0:d6269d17c8cf 682 case 1:
jah128 0:d6269d17c8cf 683 strcpy(subcommand,"ON");
jah128 0:d6269d17c8cf 684 break;
jah128 0:d6269d17c8cf 685 case 0:
jah128 0:d6269d17c8cf 686 strcpy(subcommand,"OFF");
jah128 0:d6269d17c8cf 687 break;
jah128 0:d6269d17c8cf 688 }
jah128 0:d6269d17c8cf 689 allow_commands = message[1] % 2;
jah128 0:d6269d17c8cf 690 command_status = 1;
jah128 0:d6269d17c8cf 691 break;
jah128 0:d6269d17c8cf 692
jah128 0:d6269d17c8cf 693 case 36:
jah128 0:d6269d17c8cf 694 irp_delay = (message[1] << 8) + message[2];
jah128 0:d6269d17c8cf 695 sprintf(command,"SET IR PULSE DELAY %d MS",irp_delay);
jah128 0:d6269d17c8cf 696 if(allow_commands) {
jah128 0:d6269d17c8cf 697 command_status = 1;
jah128 0:d6269d17c8cf 698 ir_pulse_delay = irp_delay;
jah128 0:d6269d17c8cf 699 } else command_status = 2;
jah128 0:d6269d17c8cf 700 break;
jah128 0:d6269d17c8cf 701 case 37:
jah128 0:d6269d17c8cf 702 irp_delay = (message[1] << 8) + message[2];
jah128 0:d6269d17c8cf 703 sprintf(command,"SET BASE IR PULSE DELAY %d MS",irp_delay);
jah128 0:d6269d17c8cf 704 if(allow_commands) {
jah128 0:d6269d17c8cf 705 command_status = 1;
jah128 0:d6269d17c8cf 706 base_ir_pulse_delay = irp_delay;
jah128 0:d6269d17c8cf 707 } else command_status = 2;
jah128 0:d6269d17c8cf 708 break;
jah128 0:d6269d17c8cf 709
jah128 0:d6269d17c8cf 710 // MOTOR REQUESTS
jah128 0:d6269d17c8cf 711 case 40:
jah128 0:d6269d17c8cf 712 strcpy(command,"GET LEFT MOTOR SPEED");
jah128 0:d6269d17c8cf 713 sprintf(ret_message,"%1.5f",motor_left_speed);
jah128 0:d6269d17c8cf 714 send_message = 1;
jah128 0:d6269d17c8cf 715 break;
jah128 0:d6269d17c8cf 716
jah128 0:d6269d17c8cf 717 case 41:
jah128 0:d6269d17c8cf 718 strcpy(command,"GET RIGHT MOTOR SPEED");
jah128 0:d6269d17c8cf 719 sprintf(ret_message,"%1.5f",motor_right_speed);
jah128 0:d6269d17c8cf 720 send_message = 1;
jah128 0:d6269d17c8cf 721 break;
jah128 0:d6269d17c8cf 722 case 42:
jah128 0:d6269d17c8cf 723 strcpy(command,"GET BRAKE STATES");
jah128 0:d6269d17c8cf 724 sprintf(ret_message,"%d,%d",motor_left_brake,motor_right_brake);
jah128 0:d6269d17c8cf 725 send_message = 1;
jah128 0:d6269d17c8cf 726 break;
jah128 0:d6269d17c8cf 727 case 43:
jah128 0:d6269d17c8cf 728 strcpy(command,"GET MOTOR STATES");
jah128 0:d6269d17c8cf 729 //sprintf(ret_message,"%d,%d",motor_left_brake,motor_right_brake);
jah128 0:d6269d17c8cf 730 send_message = 1;
jah128 0:d6269d17c8cf 731 break;
jah128 0:d6269d17c8cf 732 case 44:
jah128 0:d6269d17c8cf 733 strcpy(command,"GET ENCODERS");
jah128 0:d6269d17c8cf 734 sprintf(ret_message,"%d,%d",left_encoder,right_encoder);
jah128 0:d6269d17c8cf 735 send_message = 1;
jah128 0:d6269d17c8cf 736 break;
jah128 0:d6269d17c8cf 737
jah128 0:d6269d17c8cf 738 // LED REQUESTS
jah128 0:d6269d17c8cf 739 case 50:
jah128 0:d6269d17c8cf 740 strcpy(command,"GET LED STATES");
jah128 0:d6269d17c8cf 741 sprintf(ret_message,"%04x",get_led_states());
jah128 0:d6269d17c8cf 742 send_message = 1;
jah128 0:d6269d17c8cf 743 break;
jah128 0:d6269d17c8cf 744
jah128 0:d6269d17c8cf 745 // GENERAL REQUESTS
jah128 0:d6269d17c8cf 746 case 60:
jah128 0:d6269d17c8cf 747 strcpy(command,"GET SOFTWARE VERSION");
jah128 0:d6269d17c8cf 748 sprintf(ret_message,"%1.2f",SOFTWARE_VERSION_CODE);
jah128 0:d6269d17c8cf 749 send_message = 1;
jah128 0:d6269d17c8cf 750 break;
jah128 0:d6269d17c8cf 751
jah128 0:d6269d17c8cf 752 case 61:
jah128 0:d6269d17c8cf 753 strcpy(command,"GET UPTIME");
jah128 0:d6269d17c8cf 754 sprintf(ret_message,"%6.2f",get_uptime());
jah128 0:d6269d17c8cf 755 send_message = 1;
jah128 0:d6269d17c8cf 756 break;
jah128 0:d6269d17c8cf 757
jah128 0:d6269d17c8cf 758 case 62:
jah128 0:d6269d17c8cf 759 strcpy(command,"GET ID");
jah128 0:d6269d17c8cf 760 sprintf(ret_message,"%d",robot_id);
jah128 0:d6269d17c8cf 761 send_message = 1;
jah128 0:d6269d17c8cf 762 break;
jah128 0:d6269d17c8cf 763
jah128 0:d6269d17c8cf 764 case 63:
jah128 0:d6269d17c8cf 765 strcpy(command,"GET SWITCH BYTE");
jah128 0:d6269d17c8cf 766 sprintf(ret_message,"%02x",switch_byte);
jah128 0:d6269d17c8cf 767 send_message = 1;
jah128 0:d6269d17c8cf 768 break;
jah128 0:d6269d17c8cf 769 case 64:
jah128 0:d6269d17c8cf 770 strcpy(command,"GET USER CODE");
jah128 0:d6269d17c8cf 771 sprintf(ret_message,"%d",user_code_running);
jah128 0:d6269d17c8cf 772 send_message = 1;
jah128 0:d6269d17c8cf 773 break;
jah128 0:d6269d17c8cf 774 case 65:
jah128 0:d6269d17c8cf 775 strcpy(command,"GET RESPONSE STRING");
jah128 0:d6269d17c8cf 776 sprintf(ret_message,"PSI");
jah128 0:d6269d17c8cf 777 send_message = 1;
jah128 0:d6269d17c8cf 778 break;
jah128 0:d6269d17c8cf 779 case 66:
jah128 0:d6269d17c8cf 780 strcpy(command,"GET PROGRAM NAME");
jah128 0:d6269d17c8cf 781 sprintf(ret_message,"%s",program_name);
jah128 0:d6269d17c8cf 782 send_message = 1;
jah128 0:d6269d17c8cf 783 break;
jah128 0:d6269d17c8cf 784 case 67:
jah128 0:d6269d17c8cf 785 strcpy(command,"GET AUTHOR NAME");
jah128 0:d6269d17c8cf 786 sprintf(ret_message,"%s",author_name);
jah128 0:d6269d17c8cf 787 send_message = 1;
jah128 0:d6269d17c8cf 788 break;
jah128 0:d6269d17c8cf 789 case 68:
jah128 0:d6269d17c8cf 790 strcpy(command,"GET DEBUG MODE");
jah128 0:d6269d17c8cf 791 sprintf(ret_message,"%1d%1d",debug_mode,debug_output);
jah128 0:d6269d17c8cf 792 send_message = 1;
jah128 0:d6269d17c8cf 793 break;
jah128 0:d6269d17c8cf 794 case 69:
jah128 0:d6269d17c8cf 795 strcpy(command,"GET SYSTEM WARNINGS");
jah128 0:d6269d17c8cf 796 sprintf(ret_message,"%d",system_warnings);
jah128 0:d6269d17c8cf 797 send_message = 1;
jah128 0:d6269d17c8cf 798 break;
jah128 0:d6269d17c8cf 799
jah128 0:d6269d17c8cf 800
jah128 0:d6269d17c8cf 801 // Sensors
jah128 0:d6269d17c8cf 802 case 80:
jah128 0:d6269d17c8cf 803 strcpy(command,"STORE BG. IR VALUES");
jah128 0:d6269d17c8cf 804 if(allow_commands) {
jah128 0:d6269d17c8cf 805 command_status = 1;
jah128 0:d6269d17c8cf 806 store_background_raw_ir_values();
jah128 0:d6269d17c8cf 807 } else command_status = 2;
jah128 0:d6269d17c8cf 808 break;
jah128 0:d6269d17c8cf 809 case 81:
jah128 0:d6269d17c8cf 810 strcpy(command,"STORE IL. IR VALUES");
jah128 0:d6269d17c8cf 811 if(allow_commands) {
jah128 0:d6269d17c8cf 812 command_status = 1;
jah128 0:d6269d17c8cf 813 store_illuminated_raw_ir_values();
jah128 0:d6269d17c8cf 814 } else command_status = 2;
jah128 0:d6269d17c8cf 815 break;
jah128 0:d6269d17c8cf 816 case 82:
jah128 0:d6269d17c8cf 817 strcpy(command,"STORE IR VALUES");
jah128 0:d6269d17c8cf 818 if(allow_commands) {
jah128 0:d6269d17c8cf 819 command_status = 1;
jah128 0:d6269d17c8cf 820 store_ir_values();
jah128 0:d6269d17c8cf 821 } else command_status = 2;
jah128 0:d6269d17c8cf 822 break;
jah128 0:d6269d17c8cf 823 case 83:
jah128 0:d6269d17c8cf 824 strcpy(command,"STORE BG BASE IR VALUES");
jah128 0:d6269d17c8cf 825 if(allow_commands) {
jah128 0:d6269d17c8cf 826 command_status = 1;
jah128 0:d6269d17c8cf 827 store_background_base_ir_values();
jah128 0:d6269d17c8cf 828 } else command_status = 2;
jah128 0:d6269d17c8cf 829 break;
jah128 0:d6269d17c8cf 830 case 84:
jah128 0:d6269d17c8cf 831 strcpy(command,"STORE IL. BASE IR VALUES");
jah128 0:d6269d17c8cf 832 if(allow_commands) {
jah128 0:d6269d17c8cf 833 command_status = 1;
jah128 0:d6269d17c8cf 834 store_illuminated_base_ir_values();
jah128 0:d6269d17c8cf 835 } else command_status = 2;
jah128 0:d6269d17c8cf 836 break;
jah128 0:d6269d17c8cf 837 case 85:
jah128 0:d6269d17c8cf 838 strcpy(command,"STORE BASE IR VALUES");
jah128 0:d6269d17c8cf 839 if(allow_commands) {
jah128 0:d6269d17c8cf 840 command_status = 1;
jah128 0:d6269d17c8cf 841 store_base_ir_values();
jah128 0:d6269d17c8cf 842 } else command_status = 2;
jah128 0:d6269d17c8cf 843 break;
jah128 0:d6269d17c8cf 844 case 86:
jah128 0:d6269d17c8cf 845 strcpy(command,"STORE ALL IR VALUES");
jah128 0:d6269d17c8cf 846 if(allow_commands) {
jah128 0:d6269d17c8cf 847 command_status = 1;
jah128 0:d6269d17c8cf 848 store_ir_values();
jah128 0:d6269d17c8cf 849 store_base_ir_values();
jah128 0:d6269d17c8cf 850 } else command_status = 2;
jah128 0:d6269d17c8cf 851 break;
jah128 0:d6269d17c8cf 852 case 90:
jah128 0:d6269d17c8cf 853 sprintf(command,"%s %d","GET BG IR VALUE",message[1]);
jah128 0:d6269d17c8cf 854 sprintf(ret_message,"%d",get_background_raw_ir_value(message[1]));
jah128 0:d6269d17c8cf 855 send_message = 1;
jah128 0:d6269d17c8cf 856 break;
jah128 0:d6269d17c8cf 857 case 91:
jah128 0:d6269d17c8cf 858 sprintf(command,"%s %d","GET IL IR VALUE",message[1]);
jah128 0:d6269d17c8cf 859 sprintf(ret_message,"%d",get_illuminated_raw_ir_value(message[1]));
jah128 0:d6269d17c8cf 860 send_message = 1;
jah128 0:d6269d17c8cf 861 break;
jah128 0:d6269d17c8cf 862 case 92:
jah128 0:d6269d17c8cf 863 strcpy(command,"GET BG IR VALUES");
jah128 0:d6269d17c8cf 864 sprintf(ret_message,"%03X%03X%03X%03X%03X%03X%03X%03X",get_background_raw_ir_value(0),get_background_raw_ir_value(1),get_background_raw_ir_value(2),get_background_raw_ir_value(3),get_background_raw_ir_value(4),get_background_raw_ir_value(5),get_background_raw_ir_value(6),get_background_raw_ir_value(7));
jah128 0:d6269d17c8cf 865 send_message = 1;
jah128 0:d6269d17c8cf 866 break;
jah128 0:d6269d17c8cf 867 case 93:
jah128 0:d6269d17c8cf 868 strcpy(command,"GET ILLUMINATED IR VALUES");
jah128 0:d6269d17c8cf 869 sprintf(ret_message,"%03X%03X%03X%03X%03X%03X%03X%03X",get_illuminated_raw_ir_value(0),get_illuminated_raw_ir_value(1),get_illuminated_raw_ir_value(2),get_illuminated_raw_ir_value(3),get_illuminated_raw_ir_value(4),get_illuminated_raw_ir_value(5),get_illuminated_raw_ir_value(6),get_illuminated_raw_ir_value(7));
jah128 0:d6269d17c8cf 870 send_message = 1;
jah128 0:d6269d17c8cf 871 break;
jah128 0:d6269d17c8cf 872 case 94:
jah128 0:d6269d17c8cf 873 sprintf(command,"%s %d","GET BG BASE IR VALUE",message[1]);
jah128 0:d6269d17c8cf 874 sprintf(ret_message,"%d",get_background_base_ir_value(message[1]));
jah128 0:d6269d17c8cf 875 send_message = 1;
jah128 0:d6269d17c8cf 876 break;
jah128 0:d6269d17c8cf 877 case 95:
jah128 0:d6269d17c8cf 878 sprintf(command,"%s %d","GET IL BASE IR VALUE",message[1]);
jah128 0:d6269d17c8cf 879 sprintf(ret_message,"%d",get_illuminated_base_ir_value(message[1]));
jah128 0:d6269d17c8cf 880 send_message = 1;
jah128 0:d6269d17c8cf 881 break;
jah128 0:d6269d17c8cf 882 case 96:
jah128 0:d6269d17c8cf 883 strcpy(command,"GET BG BASE IR VALUES");
jah128 0:d6269d17c8cf 884 sprintf(ret_message,"%03X%03X%03X%03X%03X",get_background_base_ir_value(0),get_background_base_ir_value(1),get_background_base_ir_value(2),get_background_base_ir_value(3),get_background_base_ir_value(4));
jah128 0:d6269d17c8cf 885 send_message = 1;
jah128 0:d6269d17c8cf 886 break;
jah128 0:d6269d17c8cf 887 case 97:
jah128 0:d6269d17c8cf 888 strcpy(command,"GET IL BASE IR VALUES");
jah128 0:d6269d17c8cf 889 sprintf(ret_message,"%03X%03X%03X%03X%03X",get_illuminated_base_ir_value(0),get_illuminated_base_ir_value(1),get_illuminated_base_ir_value(2),get_illuminated_base_ir_value(3),get_illuminated_base_ir_value(4));
jah128 0:d6269d17c8cf 890 send_message = 1;
jah128 0:d6269d17c8cf 891 break;
jah128 2:c6986ee3c7c5 892 case 98:
jah128 2:c6986ee3c7c5 893 strcpy(command,"CALCULATE BASE IR VALUES");
jah128 2:c6986ee3c7c5 894 sprintf(ret_message,"%03X%03X%03X%03X%03X",calculate_base_ir_value(0),calculate_base_ir_value(1),calculate_base_ir_value(2),calculate_base_ir_value(3),calculate_base_ir_value(4));
jah128 2:c6986ee3c7c5 895 send_message = 1;
jah128 2:c6986ee3c7c5 896 break;
jah128 2:c6986ee3c7c5 897 case 99:
jah128 2:c6986ee3c7c5 898 strcpy(command,"CALCULATE SIDE IR VALUES");
jah128 2:c6986ee3c7c5 899 sprintf(ret_message,"%03X%03X%03X%03X%03X%03X%03X%03X",calculate_side_ir_value(0),calculate_side_ir_value(1),calculate_side_ir_value(2),calculate_side_ir_value(3),calculate_side_ir_value(4),calculate_side_ir_value(5),calculate_side_ir_value(6),calculate_side_ir_value(7));
jah128 2:c6986ee3c7c5 900 send_message = 1;
jah128 2:c6986ee3c7c5 901 break;
jah128 0:d6269d17c8cf 902 case 100:
jah128 0:d6269d17c8cf 903 strcpy(command,"START FILE TRANSFER MODE");
jah128 0:d6269d17c8cf 904 if(allow_commands) {
jah128 0:d6269d17c8cf 905 command_status = 1;
jah128 1:060690a934a9 906 IF_start_file_transfer_mode();
jah128 0:d6269d17c8cf 907 sprintf(ret_message,"OK");
jah128 0:d6269d17c8cf 908 send_message = 1;
jah128 0:d6269d17c8cf 909 } else command_status = 2;
jah128 0:d6269d17c8cf 910 break;
jah128 3:7c0d1f581757 911 case 110:
jah128 3:7c0d1f581757 912 strcpy(command,"GET FIRMWARE VERSION");
jah128 3:7c0d1f581757 913 sprintf(ret_message,"%1.2f",firmware_version);
jah128 3:7c0d1f581757 914 send_message = 1;
jah128 3:7c0d1f581757 915 break;
jah128 3:7c0d1f581757 916 case 111:
jah128 3:7c0d1f581757 917 strcpy(command,"GET SERIAL NUMBER");
jah128 3:7c0d1f581757 918 sprintf(ret_message,"%2.3f",serial_number);
jah128 3:7c0d1f581757 919 send_message = 1;
jah128 3:7c0d1f581757 920 break;
jah128 3:7c0d1f581757 921 case 112:
jah128 3:7c0d1f581757 922 strcpy(command,"GET HAS SIDE IR");
jah128 3:7c0d1f581757 923 sprintf(ret_message,"%d",has_side_ir);
jah128 3:7c0d1f581757 924 send_message = 1;
jah128 3:7c0d1f581757 925 break;
jah128 3:7c0d1f581757 926 case 113:
jah128 3:7c0d1f581757 927 strcpy(command,"GET HAS BASE IR");
jah128 3:7c0d1f581757 928 sprintf(ret_message,"%d",has_base_ir);
jah128 3:7c0d1f581757 929 send_message = 1;
jah128 3:7c0d1f581757 930 break;
jah128 3:7c0d1f581757 931 case 114:
jah128 3:7c0d1f581757 932 strcpy(command,"GET HAS ENCODERS");
jah128 3:7c0d1f581757 933 sprintf(ret_message,"%d",has_wheel_encoders);
jah128 3:7c0d1f581757 934 send_message = 1;
jah128 3:7c0d1f581757 935 break;
jah128 3:7c0d1f581757 936 case 115:
jah128 3:7c0d1f581757 937 strcpy(command,"GET HAS AUDIO");
jah128 3:7c0d1f581757 938 sprintf(ret_message,"%d",has_audio_pic);
jah128 3:7c0d1f581757 939 send_message = 1;
jah128 3:7c0d1f581757 940 break;
jah128 3:7c0d1f581757 941 case 116:
jah128 3:7c0d1f581757 942 strcpy(command,"GET HAS RECHARGING");
jah128 3:7c0d1f581757 943 sprintf(ret_message,"%d",has_recharging_circuit);
jah128 3:7c0d1f581757 944 send_message = 1;
jah128 3:7c0d1f581757 945 break;
jah128 3:7c0d1f581757 946 case 117:
jah128 3:7c0d1f581757 947 strcpy(command,"GET HAS COMPASS");
jah128 3:7c0d1f581757 948 sprintf(ret_message,"%d",has_compass);
jah128 3:7c0d1f581757 949 send_message = 1;
jah128 3:7c0d1f581757 950 break;
jah128 3:7c0d1f581757 951 case 118:
jah128 3:7c0d1f581757 952 strcpy(command,"GET HAS ULTRASONIC");
jah128 3:7c0d1f581757 953 sprintf(ret_message,"%d",has_ultrasonic_sensor);
jah128 3:7c0d1f581757 954 send_message = 1;
jah128 3:7c0d1f581757 955 break;
jah128 3:7c0d1f581757 956 case 119:
jah128 3:7c0d1f581757 957 strcpy(command,"GET HAS TEMPERATURE");
jah128 3:7c0d1f581757 958 sprintf(ret_message,"%d",has_temperature_sensor);
jah128 3:7c0d1f581757 959 send_message = 1;
jah128 3:7c0d1f581757 960 break;
jah128 3:7c0d1f581757 961 case 120:
jah128 3:7c0d1f581757 962 strcpy(command,"GET HAS BASE COLOUR");
jah128 3:7c0d1f581757 963 sprintf(ret_message,"%d",has_base_colour_sensor);
jah128 3:7c0d1f581757 964 send_message = 1;
jah128 3:7c0d1f581757 965 break;
jah128 3:7c0d1f581757 966 case 121:
jah128 3:7c0d1f581757 967 strcpy(command,"GET HAS TOP COLOUR");
jah128 3:7c0d1f581757 968 sprintf(ret_message,"%d",has_top_colour_sensor);
jah128 3:7c0d1f581757 969 send_message = 1;
jah128 3:7c0d1f581757 970 break;
jah128 3:7c0d1f581757 971 case 122:
jah128 3:7c0d1f581757 972 strcpy(command,"GET HAS RADIO");
jah128 3:7c0d1f581757 973 sprintf(ret_message,"%d",has_433_radio);
jah128 3:7c0d1f581757 974 send_message = 1;
jah128 3:7c0d1f581757 975 break;
jah128 3:7c0d1f581757 976 case 123:
jah128 3:7c0d1f581757 977 strcpy(command,"GET FIRMWARE H-DESC");
jah128 3:7c0d1f581757 978 char byte0 = 0;
jah128 3:7c0d1f581757 979 char byte1 = 1;
jah128 3:7c0d1f581757 980 if(has_side_ir)byte0+=128;
jah128 3:7c0d1f581757 981 if(has_base_ir)byte0+=64;
jah128 3:7c0d1f581757 982 if(has_wheel_encoders)byte0+=32;
jah128 3:7c0d1f581757 983 if(has_audio_pic)byte0+=16;
jah128 3:7c0d1f581757 984 if(has_recharging_circuit)byte0+=8;
jah128 3:7c0d1f581757 985 if(has_compass)byte0+=4;
jah128 3:7c0d1f581757 986 if(has_ultrasonic_sensor)byte0+=2;
jah128 3:7c0d1f581757 987 if(has_temperature_sensor)byte0+=1;
jah128 3:7c0d1f581757 988 if(has_base_colour_sensor)byte1+=128;
jah128 3:7c0d1f581757 989 if(has_top_colour_sensor)byte1+=64;
jah128 3:7c0d1f581757 990 if(has_433_radio)byte1+=32;
jah128 3:7c0d1f581757 991 sprintf(ret_message,"%c%c",byte0,byte1);
jah128 3:7c0d1f581757 992 send_message = 1;
jah128 3:7c0d1f581757 993 break;
jah128 3:7c0d1f581757 994 case 124:
jah128 3:7c0d1f581757 995 strcpy(command,"GET PCB VERSION");
jah128 3:7c0d1f581757 996 sprintf(ret_message,"%1.2f",pcb_version);
jah128 3:7c0d1f581757 997 send_message = 1;
jah128 3:7c0d1f581757 998 break;
jah128 0:d6269d17c8cf 999 }
jah128 0:d6269d17c8cf 1000
jah128 0:d6269d17c8cf 1001
jah128 0:d6269d17c8cf 1002 if(send_message) {
jah128 0:d6269d17c8cf 1003 char message_length = strlen(ret_message);
jah128 0:d6269d17c8cf 1004 switch(interface) {
jah128 0:d6269d17c8cf 1005 case 0:
jah128 0:d6269d17c8cf 1006 pc.printf("%c%c%s",RESPONSE_MESSAGE_BYTE,message_length,ret_message);
jah128 0:d6269d17c8cf 1007 break;
jah128 0:d6269d17c8cf 1008 case 1:
jah128 0:d6269d17c8cf 1009 bt.printf("%c%c%s",RESPONSE_MESSAGE_BYTE,message_length,ret_message);
jah128 0:d6269d17c8cf 1010 break;
jah128 0:d6269d17c8cf 1011 }
jah128 0:d6269d17c8cf 1012 debug("Received %s request message: %s %s [%02x%02x%02x]\nReply: %s [%d ch]\n",iface, command, subcommand,message[0],message[1],message[2],ret_message,message_length);
jah128 0:d6269d17c8cf 1013 } else {
jah128 0:d6269d17c8cf 1014 switch(interface) {
jah128 0:d6269d17c8cf 1015 case 0:
jah128 0:d6269d17c8cf 1016 pc.printf("%c%c",ACKNOWLEDGE_MESSAGE_BYTE,command_status);
jah128 0:d6269d17c8cf 1017 break;
jah128 0:d6269d17c8cf 1018 case 1:
jah128 0:d6269d17c8cf 1019 bt.printf("%c%c",ACKNOWLEDGE_MESSAGE_BYTE,command_status);
jah128 0:d6269d17c8cf 1020 break;
jah128 0:d6269d17c8cf 1021 }
jah128 0:d6269d17c8cf 1022 switch(command_status) {
jah128 0:d6269d17c8cf 1023 case 0:
jah128 0:d6269d17c8cf 1024 debug("Unrecognised %s command message [%02x%02x%02x]\n",iface,message[0],message[1],message[2]);
jah128 0:d6269d17c8cf 1025 break;
jah128 0:d6269d17c8cf 1026 case 1:
jah128 0:d6269d17c8cf 1027 debug("Actioned %s command message:%s %s [%02x%02x%02x]\n",iface, command, subcommand,message[0],message[1],message[2]);
jah128 0:d6269d17c8cf 1028 break;
jah128 0:d6269d17c8cf 1029 case 2:
jah128 0:d6269d17c8cf 1030 debug("Blocked %s command message:%s %s [%02x%02x%02x]\n",iface, command, subcommand,message[0],message[1],message[2]);
jah128 0:d6269d17c8cf 1031 break;
jah128 0:d6269d17c8cf 1032 case 3:
jah128 0:d6269d17c8cf 1033 debug("Invalid %s command message:%s %s [%02x%02x%02x]\n",iface, command, subcommand,message[0],message[1],message[2]);
jah128 0:d6269d17c8cf 1034 break;
jah128 0:d6269d17c8cf 1035 }
jah128 0:d6269d17c8cf 1036 }
jah128 0:d6269d17c8cf 1037 }
jah128 0:d6269d17c8cf 1038
jah128 0:d6269d17c8cf 1039 char * IF_nibble_to_binary_char(char in)
jah128 0:d6269d17c8cf 1040 {
jah128 0:d6269d17c8cf 1041 char * ret = (char*)malloc(sizeof(char)*5);
jah128 0:d6269d17c8cf 1042 for(int i=0; i<4; i++) {
jah128 0:d6269d17c8cf 1043 if(in & (128 >> i)) ret[i]='1';
jah128 0:d6269d17c8cf 1044 else ret[i]='0';
jah128 0:d6269d17c8cf 1045 }
jah128 0:d6269d17c8cf 1046 ret[4]=0;
jah128 0:d6269d17c8cf 1047 return ret;
jah128 0:d6269d17c8cf 1048 }
jah128 0:d6269d17c8cf 1049
jah128 0:d6269d17c8cf 1050 char * IF_char_to_binary_char(char in)
jah128 0:d6269d17c8cf 1051 {
jah128 0:d6269d17c8cf 1052 char * ret = (char*)malloc(sizeof(char)*9);
jah128 0:d6269d17c8cf 1053 for(int i=0; i<8; i++) {
jah128 0:d6269d17c8cf 1054 if(in & (128 >> i)) ret[i]='1';
jah128 0:d6269d17c8cf 1055 else ret[i]='0';
jah128 0:d6269d17c8cf 1056 }
jah128 0:d6269d17c8cf 1057 ret[8]=0;
jah128 0:d6269d17c8cf 1058 return ret;
jah128 0:d6269d17c8cf 1059 }
jah128 0:d6269d17c8cf 1060
jah128 0:d6269d17c8cf 1061 float IF_decode_unsigned_float(char byte0, char byte1)
jah128 0:d6269d17c8cf 1062 {
jah128 0:d6269d17c8cf 1063 unsigned short sval = (byte0) << 8;
jah128 0:d6269d17c8cf 1064 sval += byte1;
jah128 0:d6269d17c8cf 1065 float scaled = sval / 65535.0f;
jah128 0:d6269d17c8cf 1066 return scaled;
jah128 0:d6269d17c8cf 1067 }
jah128 0:d6269d17c8cf 1068
jah128 0:d6269d17c8cf 1069 float IF_decode_float(char byte0, char byte1)
jah128 0:d6269d17c8cf 1070 {
jah128 0:d6269d17c8cf 1071 // MSB is byte 0 is sign, rest is linear spread between 0 and 1
jah128 0:d6269d17c8cf 1072 char sign = byte0 / 128;
jah128 0:d6269d17c8cf 1073 short sval = (byte0 % 128) << 8;
jah128 0:d6269d17c8cf 1074 sval += byte1;
jah128 0:d6269d17c8cf 1075 float scaled = sval / 32767.0f;
jah128 0:d6269d17c8cf 1076 if(sign == 0) scaled = 0-scaled;
jah128 0:d6269d17c8cf 1077 return scaled;
jah128 0:d6269d17c8cf 1078 }
jah128 0:d6269d17c8cf 1079
jah128 0:d6269d17c8cf 1080 float IF_decode_unsigned_float(char byte0)
jah128 0:d6269d17c8cf 1081 {
jah128 0:d6269d17c8cf 1082 unsigned short sval = (byte0);
jah128 0:d6269d17c8cf 1083 float scaled = sval / 255.0f;
jah128 0:d6269d17c8cf 1084 return scaled;
jah128 0:d6269d17c8cf 1085 }
jah128 0:d6269d17c8cf 1086
jah128 0:d6269d17c8cf 1087 float IF_decode_float(char byte0)
jah128 0:d6269d17c8cf 1088 {
jah128 0:d6269d17c8cf 1089 // MSB is byte 0 is sign, rest is linear spread between 0 and 1
jah128 0:d6269d17c8cf 1090 char sign = byte0 / 128;
jah128 0:d6269d17c8cf 1091 short sval = (byte0 % 128);
jah128 0:d6269d17c8cf 1092 float scaled = sval / 127.0f;
jah128 0:d6269d17c8cf 1093 if(sign == 0) scaled = 0-scaled;
jah128 0:d6269d17c8cf 1094 return scaled;
jah128 0:d6269d17c8cf 1095 }
jah128 0:d6269d17c8cf 1096
jah128 0:d6269d17c8cf 1097 void IF_setup_serial_interfaces()
jah128 0:d6269d17c8cf 1098 {
jah128 0:d6269d17c8cf 1099 if(ENABLE_PC_SERIAL) {
jah128 0:d6269d17c8cf 1100 pc.baud(PC_BAUD);
jah128 0:d6269d17c8cf 1101 pc.attach(&IF_pc_rx_callback, Serial::RxIrq);
jah128 0:d6269d17c8cf 1102 }
jah128 0:d6269d17c8cf 1103 if(ENABLE_BLUETOOTH) {
jah128 0:d6269d17c8cf 1104 bt.baud(BLUETOOTH_BAUD);
jah128 0:d6269d17c8cf 1105 bt.attach(&IF_bt_rx_callback, Serial::RxIrq);
jah128 0:d6269d17c8cf 1106 }
jah128 0:d6269d17c8cf 1107 }
jah128 0:d6269d17c8cf 1108
jah128 0:d6269d17c8cf 1109 void IF_pc_rx_command_timeout()
jah128 0:d6269d17c8cf 1110 {
jah128 0:d6269d17c8cf 1111 char message_array[6];
jah128 0:d6269d17c8cf 1112 char length = 1 + pc_command_message_byte;
jah128 0:d6269d17c8cf 1113 pc_command_message_started = 0;
jah128 0:d6269d17c8cf 1114 message_array[0] = COMMAND_MESSAGE_BYTE;
jah128 0:d6269d17c8cf 1115 for(int k=0; k<pc_command_message_byte; k++) {
jah128 0:d6269d17c8cf 1116 message_array[k+1] = pc_command_message[k];
jah128 0:d6269d17c8cf 1117 }
jah128 0:d6269d17c8cf 1118 IF_handle_user_serial_message(message_array, length, 0);
jah128 0:d6269d17c8cf 1119 }
jah128 0:d6269d17c8cf 1120
jah128 0:d6269d17c8cf 1121 void IF_bt_rx_command_timeout()
jah128 0:d6269d17c8cf 1122 {
jah128 0:d6269d17c8cf 1123 char message_array[6];
jah128 0:d6269d17c8cf 1124 char length = 1 + bt_command_message_byte;
jah128 0:d6269d17c8cf 1125 bt_command_message_started = 0;
jah128 0:d6269d17c8cf 1126 message_array[0] = COMMAND_MESSAGE_BYTE;
jah128 0:d6269d17c8cf 1127 for(int k=0; k<bt_command_message_byte; k++) {
jah128 0:d6269d17c8cf 1128 message_array[k+1] = bt_command_message[k];
jah128 0:d6269d17c8cf 1129 }
jah128 0:d6269d17c8cf 1130 IF_handle_user_serial_message(message_array, length, 1);
jah128 0:d6269d17c8cf 1131 }
jah128 0:d6269d17c8cf 1132
jah128 0:d6269d17c8cf 1133 void IF_pc_rx_callback()
jah128 0:d6269d17c8cf 1134 {
jah128 0:d6269d17c8cf 1135 int count = 0;
jah128 0:d6269d17c8cf 1136 char message_array[255];
jah128 0:d6269d17c8cf 1137
jah128 0:d6269d17c8cf 1138 while(pc.readable()) {
jah128 0:d6269d17c8cf 1139 char tc = pc.getc();
jah128 0:d6269d17c8cf 1140 message_array[count] = tc;
jah128 0:d6269d17c8cf 1141 count ++;
jah128 0:d6269d17c8cf 1142 if(pc_command_message_started == 1) {
jah128 0:d6269d17c8cf 1143 if(pc_command_message_byte == 3) {
jah128 0:d6269d17c8cf 1144 pc_command_timeout.detach();
jah128 0:d6269d17c8cf 1145 if(tc == COMMAND_MESSAGE_BYTE) {
jah128 0:d6269d17c8cf 1146 // A complete command message succesfully received, call handler
jah128 0:d6269d17c8cf 1147 pc_command_message_started = 0;
jah128 0:d6269d17c8cf 1148 count = 0;
jah128 0:d6269d17c8cf 1149 IF_handle_command_serial_message(pc_command_message , 0);
jah128 0:d6269d17c8cf 1150 } else {
jah128 0:d6269d17c8cf 1151 // Message is not a valid command message as 5th byte is not correct; treat whole message as a user message
jah128 0:d6269d17c8cf 1152 pc_command_message_started = 0;
jah128 0:d6269d17c8cf 1153 message_array[0] = COMMAND_MESSAGE_BYTE;
jah128 0:d6269d17c8cf 1154 message_array[1] = pc_command_message[0];
jah128 0:d6269d17c8cf 1155 message_array[2] = pc_command_message[1];
jah128 0:d6269d17c8cf 1156 message_array[3] = pc_command_message[2];
jah128 0:d6269d17c8cf 1157 message_array[4] = tc;
jah128 0:d6269d17c8cf 1158 count = 5;
jah128 0:d6269d17c8cf 1159 }
jah128 0:d6269d17c8cf 1160 } else {
jah128 0:d6269d17c8cf 1161 pc_command_message[pc_command_message_byte] = tc;
jah128 0:d6269d17c8cf 1162 pc_command_message_byte ++;
jah128 0:d6269d17c8cf 1163 }
jah128 0:d6269d17c8cf 1164 } else {
jah128 0:d6269d17c8cf 1165 if(count == 1) {
jah128 0:d6269d17c8cf 1166 if(tc == COMMAND_MESSAGE_BYTE) {
jah128 0:d6269d17c8cf 1167 pc_command_timeout.attach(&IF_pc_rx_command_timeout,command_timeout_period);
jah128 0:d6269d17c8cf 1168 pc_command_message_started = 1;
jah128 0:d6269d17c8cf 1169 pc_command_message_byte = 0;
jah128 0:d6269d17c8cf 1170
jah128 0:d6269d17c8cf 1171 }
jah128 0:d6269d17c8cf 1172 }
jah128 0:d6269d17c8cf 1173 }
jah128 0:d6269d17c8cf 1174 }
jah128 0:d6269d17c8cf 1175 if(!pc_command_message_started && count>0) IF_handle_user_serial_message(message_array, count, 0);
jah128 0:d6269d17c8cf 1176 }
jah128 0:d6269d17c8cf 1177
jah128 0:d6269d17c8cf 1178 Timeout bt_message_timeout;
jah128 0:d6269d17c8cf 1179 static float bt_message_timeout_period = 0.001; // 1 millisecond
jah128 0:d6269d17c8cf 1180 char bt_buffer[255];
jah128 0:d6269d17c8cf 1181 int bt_buffer_index = 0;
jah128 0:d6269d17c8cf 1182
jah128 0:d6269d17c8cf 1183 void IF_bt_message_timeout()
jah128 0:d6269d17c8cf 1184 {
jah128 0:d6269d17c8cf 1185 char buffer[255];
jah128 0:d6269d17c8cf 1186
jah128 0:d6269d17c8cf 1187 sprintf(buffer, bt_buffer, bt_buffer_index);
jah128 0:d6269d17c8cf 1188 buffer[bt_buffer_index] = 0;
jah128 0:d6269d17c8cf 1189 if(file_transfer_mode == 1) {
jah128 0:d6269d17c8cf 1190 IF_handle_file_transfer_serial_message(bt_buffer, bt_buffer_index, 1);
jah128 0:d6269d17c8cf 1191 } else {
jah128 0:d6269d17c8cf 1192 // debug("BT message timeout: %s [%d chars]\n", buffer, bt_buffer_index);
jah128 0:d6269d17c8cf 1193 if(bt_buffer_index == 5 && buffer[0] == COMMAND_MESSAGE_BYTE && buffer[4] == COMMAND_MESSAGE_BYTE) {
jah128 0:d6269d17c8cf 1194 bt_command_message[0] = buffer[1];
jah128 0:d6269d17c8cf 1195 bt_command_message[1] = buffer[2];
jah128 0:d6269d17c8cf 1196 bt_command_message[2] = buffer[3];
jah128 0:d6269d17c8cf 1197 IF_handle_command_serial_message(bt_command_message , 1);
jah128 0:d6269d17c8cf 1198 } else IF_handle_user_serial_message(bt_buffer, bt_buffer_index, 1);
jah128 0:d6269d17c8cf 1199 }
jah128 0:d6269d17c8cf 1200 bt_buffer_index = 0;
jah128 0:d6269d17c8cf 1201 }
jah128 0:d6269d17c8cf 1202
jah128 0:d6269d17c8cf 1203
jah128 3:7c0d1f581757 1204 //void IF_bt_rx_callback()
jah128 3:7c0d1f581757 1205 //{
jah128 3:7c0d1f581757 1206 // while(bt.readable()) {
jah128 3:7c0d1f581757 1207 // char byte = bt.getc();
jah128 3:7c0d1f581757 1208 //
jah128 3:7c0d1f581757 1209 // bt_buffer[bt_buffer_index] = byte;
jah128 3:7c0d1f581757 1210 // bt_buffer_index++;
jah128 3:7c0d1f581757 1211 // }
jah128 3:7c0d1f581757 1212 //
jah128 3:7c0d1f581757 1213 // bt_message_timeout.attach(&IF_bt_message_timeout, bt_message_timeout_period);
jah128 3:7c0d1f581757 1214 //}
jah128 0:d6269d17c8cf 1215
jah128 0:d6269d17c8cf 1216
jah128 2:c6986ee3c7c5 1217 void IF_set_filename(char * filename_in){
jah128 2:c6986ee3c7c5 1218 strcpy(filename,filename_in);
jah128 2:c6986ee3c7c5 1219 }
jah128 2:c6986ee3c7c5 1220
jah128 2:c6986ee3c7c5 1221 unsigned short IF_calculateCRC16(int file_length){
jah128 2:c6986ee3c7c5 1222 unsigned short crc16table[256] = {
jah128 2:c6986ee3c7c5 1223 0x0000, 0x8005, 0x800F, 0x000A, 0x801B, 0x001E, 0x0014, 0x8011,
jah128 2:c6986ee3c7c5 1224 0x8033, 0x0036, 0x003C, 0x8039, 0x0028, 0x802D, 0x8027, 0x0022,
jah128 2:c6986ee3c7c5 1225 0x8063, 0x0066, 0x006C, 0x8069, 0x0078, 0x807D, 0x8077, 0x0072,
jah128 2:c6986ee3c7c5 1226 0x0050, 0x8055, 0x805F, 0x005A, 0x804B, 0x004E, 0x0044, 0x8041,
jah128 2:c6986ee3c7c5 1227 0x80C3, 0x00C6, 0x00CC, 0x80C9, 0x00D8, 0x80DD, 0x80D7, 0x00D2,
jah128 2:c6986ee3c7c5 1228 0x00F0, 0x80F5, 0x80FF, 0x00FA, 0x80EB, 0x00EE, 0x00E4, 0x80E1,
jah128 2:c6986ee3c7c5 1229 0x00A0, 0x80A5, 0x80AF, 0x00AA, 0x80BB, 0x00BE, 0x00B4, 0x80B1,
jah128 2:c6986ee3c7c5 1230 0x8093, 0x0096, 0x009C, 0x8099, 0x0088, 0x808D, 0x8087, 0x0082,
jah128 2:c6986ee3c7c5 1231 0x8183, 0x0186, 0x018C, 0x8189, 0x0198, 0x819D, 0x8197, 0x0192,
jah128 2:c6986ee3c7c5 1232 0x01B0, 0x81B5, 0x81BF, 0x01BA, 0x81AB, 0x01AE, 0x01A4, 0x81A1,
jah128 2:c6986ee3c7c5 1233 0x01E0, 0x81E5, 0x81EF, 0x01EA, 0x81FB, 0x01FE, 0x01F4, 0x81F1,
jah128 2:c6986ee3c7c5 1234 0x81D3, 0x01D6, 0x01DC, 0x81D9, 0x01C8, 0x81CD, 0x81C7, 0x01C2,
jah128 2:c6986ee3c7c5 1235 0x0140, 0x8145, 0x814F, 0x014A, 0x815B, 0x015E, 0x0154, 0x8151,
jah128 2:c6986ee3c7c5 1236 0x8173, 0x0176, 0x017C, 0x8179, 0x0168, 0x816D, 0x8167, 0x0162,
jah128 2:c6986ee3c7c5 1237 0x8123, 0x0126, 0x012C, 0x8129, 0x0138, 0x813D, 0x8137, 0x0132,
jah128 2:c6986ee3c7c5 1238 0x0110, 0x8115, 0x811F, 0x011A, 0x810B, 0x010E, 0x0104, 0x8101,
jah128 2:c6986ee3c7c5 1239 0x8303, 0x0306, 0x030C, 0x8309, 0x0318, 0x831D, 0x8317, 0x0312,
jah128 2:c6986ee3c7c5 1240 0x0330, 0x8335, 0x833F, 0x033A, 0x832B, 0x032E, 0x0324, 0x8321,
jah128 2:c6986ee3c7c5 1241 0x0360, 0x8365, 0x836F, 0x036A, 0x837B, 0x037E, 0x0374, 0x8371,
jah128 2:c6986ee3c7c5 1242 0x8353, 0x0356, 0x035C, 0x8359, 0x0348, 0x834D, 0x8347, 0x0342,
jah128 2:c6986ee3c7c5 1243 0x03C0, 0x83C5, 0x83CF, 0x03CA, 0x83DB, 0x03DE, 0x03D4, 0x83D1,
jah128 2:c6986ee3c7c5 1244 0x83F3, 0x03F6, 0x03FC, 0x83F9, 0x03E8, 0x83ED, 0x83E7, 0x03E2,
jah128 2:c6986ee3c7c5 1245 0x83A3, 0x03A6, 0x03AC, 0x83A9, 0x03B8, 0x83BD, 0x83B7, 0x03B2,
jah128 2:c6986ee3c7c5 1246 0x0390, 0x8395, 0x839F, 0x039A, 0x838B, 0x038E, 0x0384, 0x8381,
jah128 2:c6986ee3c7c5 1247 0x0280, 0x8285, 0x828F, 0x028A, 0x829B, 0x029E, 0x0294, 0x8291,
jah128 2:c6986ee3c7c5 1248 0x82B3, 0x02B6, 0x02BC, 0x82B9, 0x02A8, 0x82AD, 0x82A7, 0x02A2,
jah128 2:c6986ee3c7c5 1249 0x82E3, 0x02E6, 0x02EC, 0x82E9, 0x02F8, 0x82FD, 0x82F7, 0x02F2,
jah128 2:c6986ee3c7c5 1250 0x02D0, 0x82D5, 0x82DF, 0x02DA, 0x82CB, 0x02CE, 0x02C4, 0x82C1,
jah128 2:c6986ee3c7c5 1251 0x8243, 0x0246, 0x024C, 0x8249, 0x0258, 0x825D, 0x8257, 0x0252,
jah128 2:c6986ee3c7c5 1252 0x0270, 0x8275, 0x827F, 0x027A, 0x826B, 0x026E, 0x0264, 0x8261,
jah128 2:c6986ee3c7c5 1253 0x0220, 0x8225, 0x822F, 0x022A, 0x823B, 0x023E, 0x0234, 0x8231,
jah128 2:c6986ee3c7c5 1254 0x8213, 0x0216, 0x021C, 0x8219, 0x0208, 0x820D, 0x8207, 0x0202};
jah128 2:c6986ee3c7c5 1255
jah128 2:c6986ee3c7c5 1256 //Opens, reads and calculates the CRC16 value for file pointed to by filename
jah128 2:c6986ee3c7c5 1257 unsigned short crc_value = 0;
jah128 2:c6986ee3c7c5 1258 FILE *fp = fopen(filename,"r");
jah128 2:c6986ee3c7c5 1259 char * buffer;
jah128 2:c6986ee3c7c5 1260 int limit = 512;
jah128 2:c6986ee3c7c5 1261 if(file_length < 512) limit = file_length;
jah128 2:c6986ee3c7c5 1262 buffer = (char*) malloc (sizeof(char)*limit);
jah128 2:c6986ee3c7c5 1263 int blocks = 1;
jah128 2:c6986ee3c7c5 1264 if(file_length > limit) blocks += file_length / limit;
jah128 2:c6986ee3c7c5 1265 for(int i=0;i<blocks;i++){
jah128 2:c6986ee3c7c5 1266 //Determine size of this block
jah128 2:c6986ee3c7c5 1267 int blocksize = limit;
jah128 2:c6986ee3c7c5 1268 if(i == blocks-1){
jah128 2:c6986ee3c7c5 1269 if((file_length % limit) != 0) blocksize = file_length % limit;
jah128 2:c6986ee3c7c5 1270 }
jah128 2:c6986ee3c7c5 1271 debug("Calculating %d bytes of CRC data...\n",blocksize);
jah128 2:c6986ee3c7c5 1272 int result;
jah128 2:c6986ee3c7c5 1273 result = fread(buffer,1,blocksize,fp);
jah128 2:c6986ee3c7c5 1274 debug("Data read: %d\n",result);
jah128 2:c6986ee3c7c5 1275 for(int j=0;j<blocksize;j++){
jah128 2:c6986ee3c7c5 1276 int subindex = ((crc_value>>8)^*(char *)(buffer[j]))&0x00FF;
jah128 2:c6986ee3c7c5 1277 //debug("J:%d Subindex:%d\n",j,subindex);
jah128 2:c6986ee3c7c5 1278 unsigned short table_value = crc16table[subindex];
jah128 2:c6986ee3c7c5 1279 crc_value=(crc_value<<8)^table_value;
jah128 2:c6986ee3c7c5 1280 }
jah128 2:c6986ee3c7c5 1281 }
jah128 2:c6986ee3c7c5 1282 fclose(fp);
jah128 2:c6986ee3c7c5 1283 debug("CRC Calculated: %x\n",crc_value);
jah128 2:c6986ee3c7c5 1284 return crc_value;
jah128 2:c6986ee3c7c5 1285 }
jah128 2:c6986ee3c7c5 1286
jah128 3:7c0d1f581757 1287 void IF_bt_rx_callback()
jah128 3:7c0d1f581757 1288 {
jah128 3:7c0d1f581757 1289 int count = 0;
jah128 3:7c0d1f581757 1290 char message_array[255];
jah128 3:7c0d1f581757 1291
jah128 3:7c0d1f581757 1292 wait_ms(500); // Wait 0.5ms to allow a complete message to arrive before atttempting to process it
jah128 3:7c0d1f581757 1293
jah128 3:7c0d1f581757 1294 while(bt.readable()) {
jah128 3:7c0d1f581757 1295 char tc = bt.getc();
jah128 3:7c0d1f581757 1296 message_array[count] = tc;
jah128 3:7c0d1f581757 1297 count ++;
jah128 3:7c0d1f581757 1298 if(bt_command_message_started == 1) {
jah128 3:7c0d1f581757 1299 if(bt_command_message_byte == 3) {
jah128 3:7c0d1f581757 1300 bt_command_timeout.detach();
jah128 3:7c0d1f581757 1301 if(tc == COMMAND_MESSAGE_BYTE) {
jah128 3:7c0d1f581757 1302 // A complete command message succesfully received, call handler
jah128 3:7c0d1f581757 1303 bt_command_message_started = 0;
jah128 3:7c0d1f581757 1304 count = 0;
jah128 3:7c0d1f581757 1305 IF_handle_command_serial_message(bt_command_message , 1);
jah128 3:7c0d1f581757 1306 } else {
jah128 3:7c0d1f581757 1307 // Message is not a valid command message as 5th byte is not correct; treat whole message as a user message
jah128 3:7c0d1f581757 1308 bt_command_message_started = 0;
jah128 3:7c0d1f581757 1309 message_array[0] = COMMAND_MESSAGE_BYTE;
jah128 3:7c0d1f581757 1310 message_array[1] = bt_command_message[0];
jah128 3:7c0d1f581757 1311 message_array[2] = bt_command_message[1];
jah128 3:7c0d1f581757 1312 message_array[3] = bt_command_message[2];
jah128 3:7c0d1f581757 1313 message_array[4] = tc;
jah128 3:7c0d1f581757 1314 count = 5;
jah128 3:7c0d1f581757 1315 }
jah128 3:7c0d1f581757 1316 } else {
jah128 3:7c0d1f581757 1317 bt_command_timeout.attach(&IF_bt_rx_command_timeout,command_timeout_period);
jah128 3:7c0d1f581757 1318 bt_command_message[bt_command_message_byte] = tc;
jah128 3:7c0d1f581757 1319 bt_command_message_byte ++;
jah128 3:7c0d1f581757 1320 }
jah128 3:7c0d1f581757 1321 } else {
jah128 3:7c0d1f581757 1322 if(count == 1) {
jah128 3:7c0d1f581757 1323 if(tc == COMMAND_MESSAGE_BYTE) {
jah128 3:7c0d1f581757 1324 bt_command_message_started = 1;
jah128 3:7c0d1f581757 1325 bt_command_message_byte = 0;
jah128 3:7c0d1f581757 1326
jah128 3:7c0d1f581757 1327 }
jah128 3:7c0d1f581757 1328 }
jah128 3:7c0d1f581757 1329 }
jah128 3:7c0d1f581757 1330 }
jah128 3:7c0d1f581757 1331 if(!bt_command_message_started && count>0) IF_handle_user_serial_message(message_array, count, 1);
jah128 3:7c0d1f581757 1332 }