diff options
Diffstat (limited to 'robot')
| -rw-r--r-- | robot/sercomm.c | 42 | ||||
| -rw-r--r-- | robot/sim.c | 29 | ||||
| -rw-r--r-- | robot/tests/mcfg.bin | bin | 0 -> 11 bytes | 
3 files changed, 26 insertions, 45 deletions
| diff --git a/robot/sercomm.c b/robot/sercomm.c index 9e40b0e..293e3c6 100644 --- a/robot/sercomm.c +++ b/robot/sercomm.c @@ -47,8 +47,8 @@ void w2_sercomm_append_msg(w2_s_bin *data) {  	g_w2_sercomm_index = next_index;  } -void w2_scmd_ping_rx(w2_s_bin *data) { -	w2_s_cmd_ping_rx *message = malloc(w2_scmd_length(data->data, data->bytes)); +void w2_cmd_ping_rx(w2_s_bin *data) { +	w2_s_cmd_ping_rx *message = malloc(w2_cmd_sizeof(data->data, data->bytes));  	memcpy(message, data->data, data->bytes);  	size_t return_size				 = sizeof(w2_s_cmd_ping_tx); @@ -65,34 +65,34 @@ void w2_scmd_ping_rx(w2_s_bin *data) {  	free(return_message_bin);  } -void w2_scmd_mode_rx(w2_s_bin *data) { return; } +void w2_cmd_mode_rx(w2_s_bin *data) { return; } -void w2_scmd_sped_rx(w2_s_bin *data) { return; } +void w2_cmd_sped_rx(w2_s_bin *data) { return; } -void w2_scmd_dirc_rx(w2_s_bin *data) { return; } +void w2_cmd_dirc_rx(w2_s_bin *data) { return; } -void w2_scmd_cord_rx(w2_s_bin *data) { return; } +void w2_cmd_cord_rx(w2_s_bin *data) { return; } -void w2_scmd_bomd_rx(w2_s_bin *data) { return; } +void w2_cmd_bomd_rx(w2_s_bin *data) { return; } -void w2_scmd_sres_rx(w2_s_bin *data) { return; } +void w2_cmd_sres_rx(w2_s_bin *data) { return; } -void w2_scmd_mcfg_rx(w2_s_bin *data) { return; } +void w2_cmd_mcfg_rx(w2_s_bin *data) { return; } -void w2_scmd_sens_rx(w2_s_bin *data) { return; } +void w2_cmd_sens_rx(w2_s_bin *data) { return; } -void w2_scmd_info_rx(w2_s_bin *data) { return; } +void w2_cmd_info_rx(w2_s_bin *data) { return; } -void w2_scmd_disp_rx(w2_s_bin *data) { return; } +void w2_cmd_disp_rx(w2_s_bin *data) { return; } -void w2_scmd_play_rx(w2_s_bin *data) { return; } +void w2_cmd_play_rx(w2_s_bin *data) { return; } -void w2_scmd_cled_rx(w2_s_bin *data) { return; } +void w2_cmd_cled_rx(w2_s_bin *data) { return; } -void w2_scmd_ping_tx(w2_s_bin *data) {} -void w2_scmd_expt_tx(w2_s_bin *data) {} -void w2_scmd_mode_tx(w2_s_bin *data) {} -void w2_scmd_cord_tx(w2_s_bin *data) {} -void w2_scmd_bomd_tx(w2_s_bin *data) {} -void w2_scmd_sens_tx(w2_s_bin *data) {} -void w2_scmd_info_tx(w2_s_bin *data) {} +void w2_cmd_ping_tx(w2_s_bin *data) {} +void w2_cmd_expt_tx(w2_s_bin *data) {} +void w2_cmd_mode_tx(w2_s_bin *data) {} +void w2_cmd_cord_tx(w2_s_bin *data) {} +void w2_cmd_bomd_tx(w2_s_bin *data) {} +void w2_cmd_sens_tx(w2_s_bin *data) {} +void w2_cmd_info_tx(w2_s_bin *data) {} diff --git a/robot/sim.c b/robot/sim.c index 57e0ef5..0cde6a0 100644 --- a/robot/sim.c +++ b/robot/sim.c @@ -38,7 +38,6 @@ static const char* const W2_CMD_DIRECTIONS[] = {  void time_reset() {  	simprintfunc("time_reset", "");  	clock_gettime(CLOCK_MONOTONIC, &reference_time); -	return;  }  unsigned long get_ms() { @@ -51,27 +50,22 @@ unsigned long get_ms() {  void red_led(unsigned char on) {  	simprintfunc("red_led", "%i", on); -	return;  }  void green_led(unsigned char on) {  	simprintfunc("green_led", "%i", on); -	return;  }  void clear() {  	simprintfunc("clear", ""); -	return;  }  void play(const char* melody) {  	simprintfunc("play", "\"%s\"", melody); -	return;  }  void serial_set_baud_rate(unsigned int rate) {  	simprintfunc("serial_set_baud_rate", "%u", rate); -	return;  }  void serial_send(char* message, unsigned int length) { @@ -81,25 +75,16 @@ void serial_send(char* message, unsigned int length) {  		return;  	}  	if (!DBG_ENABLE_PRINTFUNC) return; +  	simprintfunc("serial_send", "<see below>, %u", length); -	unsigned int bytes = 0; -	simprintf(""); -	for (unsigned int byte = 0; byte < length; byte++) { -		if (bytes > DBG_BYTES_PER_LINE) { -			bytes = 0; -			printf("\n"); -			simprintf(""); -		} -		printf("%02x ", message[byte] & 0xff); -		bytes++; -	} -	printf("\n"); -	return; + +	w2_s_bin *bin = w2_bin_s_alloc(length, (uint8_t*) message); +	w2_sim_print_serial(bin); +	free(bin);  }  void serial_receive_ring(char* buffer, unsigned char size) {  	simprintfunc("serial_receive_ring", "0x%016lx, %u", (unsigned long) buffer, size); -	return;  }  unsigned char serial_get_received_bytes() { @@ -118,16 +103,12 @@ void w2_sim_setup(int argc, char **argv) {  	term.c_cc[VTIME] = 0;  	term.c_cc[VMIN] = 0;  	tcsetattr(STDIN_FILENO, 0, &term); - -	return;  }  void w2_sim_cycle_begin() {  	// read bytes from stdin  	while(read(STDIN_FILENO, (g_w2_serial_buffer + sizeof(char) * g_w2_serial_buffer_head), 1) > 0)  		g_w2_serial_buffer_head = (g_w2_serial_buffer_head + 1) % W2_SERIAL_READ_BUFFER_SIZE; - -	return;  }  void w2_sim_print_serial(w2_s_bin *data) { diff --git a/robot/tests/mcfg.bin b/robot/tests/mcfg.binBinary files differ new file mode 100644 index 0000000..a43ecf8 --- /dev/null +++ b/robot/tests/mcfg.bin |