tx works
This commit is contained in:
		
							parent
							
								
									da75d0a2a0
								
							
						
					
					
						commit
						ddba2120e1
					
				| @ -70,8 +70,10 @@ bool adc_read(ADC_Data_t* out_data) | ||||
| 	); | ||||
| 	if (ret == ESP_OK) | ||||
| 	{ | ||||
| 		for (int i=0; i<6; i++) { | ||||
| 			out_data->value[i] = data[i].type2.data; | ||||
| 		for (uint8_t i=0; i<3; i++) { | ||||
| 			for (uint8_t ii=0; ii<2; ii++) { | ||||
| 				out_data->value[i][ii] = data[i*2 + ii].type2.data; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 	return (ret == ESP_OK); | ||||
|  | ||||
| @ -5,7 +5,7 @@ | ||||
| #include <stdbool.h> | ||||
| 
 | ||||
| typedef struct { | ||||
| 	uint16_t value[6]; | ||||
| 	uint16_t value[3][2]; | ||||
| } ADC_Data_t; | ||||
| 
 | ||||
| void adc_init(); | ||||
|  | ||||
| @ -19,7 +19,7 @@ | ||||
| #include "ws.h" | ||||
| #if TARGET == TARGET_TX | ||||
| #include "led.h" | ||||
| // #include "adc.h"
 | ||||
| #include "adc.h" | ||||
| #endif | ||||
| 
 | ||||
| bool volatile running = true; | ||||
| @ -116,9 +116,8 @@ void app_main() { | ||||
| 	servo_init(); | ||||
| 
 | ||||
| 	wifiInit(); | ||||
| #if TARGET == TARGET_TX | ||||
| 	// adc_init();
 | ||||
| #endif | ||||
| 	bool adc_inited = false; | ||||
| 	uint8_t adc_counter = 0; | ||||
| 
 | ||||
| 	running = true; | ||||
| 
 | ||||
| @ -189,49 +188,94 @@ void app_main() { | ||||
| 
 | ||||
| #if TARGET == TARGET_TX | ||||
|       case STATE_WIFI_CONNECTED: | ||||
| 			switch (WSStates[WS_conn_proc]) | ||||
| 			if (!adc_inited) | ||||
| 			{ | ||||
| 				case STATE_WS_CONNECTING: | ||||
| 					ws_client[WS_conn_proc] = ws_connect(WS_URL, BoatId + WS_conn_proc, WS_DEV_CODE_CLIENT); | ||||
| 					WSStates[WS_conn_proc] = STATE_WS_WAIT_CONNECTION; | ||||
| 					LOG_I("main: websocket %d: connecting", WS_conn_proc); | ||||
| 					break; | ||||
| 				case STATE_WS_WAIT_CONNECTION: | ||||
| 					if (ws_client[WS_conn_proc]->connected) | ||||
| 					{ | ||||
| 						cli_ws_client[WS_conn_proc] = CLI_init((CLI_charOutFn)&charOut_ws[WS_conn_proc], cmdList); | ||||
| 						cli_ws_client[WS_conn_proc].echo = false; | ||||
| 						MainState = STATE_IDEL; | ||||
| 						LOG_I("main: websocket %d: connected", WS_conn_proc); | ||||
| 					} | ||||
| 					break; | ||||
| 
 | ||||
| 				case STATE_IDEL: | ||||
| 				case STATE_DRIVING: | ||||
| 					if (!ws_client[WS_conn_proc]->connected) | ||||
| 					{ | ||||
| 						CLI_deinit(&cli_ws_client[WS_conn_proc]); | ||||
| 						MainState = STATE_WS_WAIT_CONNECTION; | ||||
| 					} | ||||
| 
 | ||||
| 					while ((charIn = ws_getchar(ws_client[WS_conn_proc])) != 255) | ||||
| 					{ | ||||
| 						CLI_charIn(&cli_ws_client[WS_conn_proc], charIn); | ||||
| 					} | ||||
| 					ws_sendData(ws_client[WS_conn_proc]); | ||||
| 					break; | ||||
| 				adc_init(); | ||||
| 				adc_inited = true; | ||||
| 			} | ||||
| 			ADC_Data_t adc_data; | ||||
| 			bool adc_data_valid = false; | ||||
| 			if (adc_read(&adc_data)) | ||||
| 			{ | ||||
| 				adc_counter++; | ||||
| 				if (adc_counter >= 20) | ||||
| 				{ | ||||
| 					// LOG_D("ADC_DATA: %d, %d, %d, %d, %d, %d", adc_data.value[0], adc_data.value[1], adc_data.value[2], adc_data.value[3], adc_data.value[4], adc_data.value[5]);
 | ||||
| 					adc_data_valid = true; | ||||
| 					adc_counter = 0; | ||||
| 				} | ||||
| 			} | ||||
| 			// WS_conn_proc++;
 | ||||
| 			// if (WS_conn_proc >= 3)
 | ||||
| 			// {
 | ||||
| 			// 	WS_conn_proc = 0;
 | ||||
| 			// }
 | ||||
| 
 | ||||
| 			// ADC_Data_t data;
 | ||||
| 			// if (adc_read(&data))
 | ||||
| 			// {
 | ||||
| 			// 	LOG_D("ADC_DATA: %d, %d, %d, %d, %d, %d", data.value[0], data.value[1], data.value[2], data.value[3], data.value[4], data.value[5]);
 | ||||
| 			// }
 | ||||
| 			for (WS_conn_proc = 0; WS_conn_proc <3; WS_conn_proc++) | ||||
| 			{ | ||||
| 				switch (WSStates[WS_conn_proc]) | ||||
| 				{ | ||||
| 					case STATE_WS_CONNECTING: | ||||
| 						LOG_I("main: websocket %d: connecting", WS_conn_proc); | ||||
| 						ws_client[WS_conn_proc] = ws_connect(WS_URL, BoatId + WS_conn_proc, WS_DEV_CODE_CLIENT); | ||||
| 						WSStates[WS_conn_proc] = STATE_WS_WAIT_CONNECTION; | ||||
| 						break; | ||||
| 					case STATE_WS_WAIT_CONNECTION: | ||||
| 						if (ws_client[WS_conn_proc]->connected) | ||||
| 						{ | ||||
| 							LOG_I("main: websocket %d: connected", WS_conn_proc); | ||||
| 							WSStates[WS_conn_proc] = STATE_IDEL; | ||||
| 						} | ||||
| 						break; | ||||
| 
 | ||||
| 					case STATE_IDEL: | ||||
| 					   if (adc_data_valid) | ||||
| 						{ | ||||
| 							char cmd[100]; | ||||
| 							snprintf(&cmd[0], 100, "%04u;ctrl;%04u", | ||||
| 								ws_client[WS_conn_proc]->id, | ||||
| 								ws_client[WS_conn_proc]->id | ||||
| 							); | ||||
| 							ws_sendString(ws_client[WS_conn_proc], &cmd[0]); | ||||
| 						} | ||||
| 					case STATE_DRIVING: | ||||
| 						if (!ws_client[WS_conn_proc]->connected) | ||||
| 						{ | ||||
| 							WSStates[WS_conn_proc] = STATE_WS_WAIT_CONNECTION; | ||||
| 						} | ||||
| 
 | ||||
| 						char ws_resp[10]; | ||||
| 						uint16_t ws_resp_len; | ||||
| 						while ((ws_resp_len = ws_getstr(ws_client[WS_conn_proc], 10, &ws_resp[0])) > 0) | ||||
| 						{ | ||||
| 							LOG_D("main: websocket %d: resv: %.*s", WS_conn_proc, ws_resp_len, ws_resp); | ||||
| 							if (ws_resp_len == 4) | ||||
| 							{ | ||||
| 								ws_resp[4] = 0; | ||||
| 								if (strcmp(&ws_resp[0], "FAIL") == 0) | ||||
| 								{ | ||||
| 									WSStates[WS_conn_proc] = STATE_IDEL; | ||||
| 								} | ||||
| 							} | ||||
| 							else if (ws_resp_len == 2) | ||||
| 							{ | ||||
| 								ws_resp[2] = 0; | ||||
| 								if (strcmp(&ws_resp[0], "OK") == 0) | ||||
| 								{ | ||||
| 									WSStates[WS_conn_proc] = STATE_DRIVING; | ||||
| 								} | ||||
| 							} | ||||
| 						} | ||||
| 
 | ||||
| 						if ((WSStates[WS_conn_proc] == STATE_DRIVING) && adc_data_valid) | ||||
| 						{ | ||||
| 							char ctrl_cmd[100]; | ||||
| 							snprintf(&ctrl_cmd[0], 100, "%04u;d;%u,%u", | ||||
| 								ws_client[WS_conn_proc]->id, | ||||
| 								adc_data.value[WS_conn_proc][0] >> 4, | ||||
| 								adc_data.value[WS_conn_proc][1] >> 4 | ||||
| 							); | ||||
| 							ws_sendString(ws_client[WS_conn_proc], &ctrl_cmd[0]); | ||||
| 						} | ||||
| 
 | ||||
| 						break; | ||||
| 				} | ||||
| 			} | ||||
| 			break; | ||||
| #elif TARGET == TARGET_RX | ||||
| 			case STATE_WS_CONNECTING: | ||||
|  | ||||
| @ -16,12 +16,12 @@ static void ws_event_handler(void* handler_args, esp_event_base_t base, int32_t | ||||
| 	{ | ||||
| 		case WEBSOCKET_EVENT_CONNECTED: | ||||
| 			LOG_I("ws_event_handler: connected"); | ||||
| 			client->connected = true; | ||||
| 
 | ||||
| 			char str[100]; | ||||
| 			snprintf(&str[0], 100, "%04u;%04u;" BOAT_NAME "\n", client->id, client->dev_code); | ||||
| 			esp_websocket_client_send_text(client->handle, &str[0], strlen(str), 1000); | ||||
| 
 | ||||
| 			client->connected = true; | ||||
| 			break; | ||||
| 		case WEBSOCKET_EVENT_DISCONNECTED: | ||||
| 			LOG_W("ws_event_handler: disconnected"); | ||||
| @ -105,6 +105,9 @@ static void ws_event_handler(void* handler_args, esp_event_base_t base, int32_t | ||||
| 					LOG_E("ws_event_handler: captured as transport's socket errno %d",  data->error_handle.esp_transport_sock_errno); | ||||
| 			} | ||||
| 			break; | ||||
| 		case WEBSOCKET_EVENT_BEFORE_CONNECT: | ||||
| 			LOG_D("ws_event_handler: event before connect fired"); | ||||
| 			break; | ||||
| 		default: | ||||
| 			LOG_D("ws_event_handler: a unkown event happened: %d", event_id); | ||||
| 			break; | ||||
| @ -138,7 +141,7 @@ int ws_getchar(ws_client_t client) | ||||
| 	if (client->rxBuffer_rp != client->rxBuffer_wp) | ||||
| 	{ | ||||
| 		out = client->rxBuffer[client->rxBuffer_rp]; | ||||
|       client->rxBuffer_rp++; | ||||
| 		client->rxBuffer_rp++; | ||||
| 		if (client->rxBuffer_rp >= WS_RX_BUFFER_LEN) | ||||
| 		{ | ||||
| 			client->rxBuffer_rp = 0; | ||||
| @ -147,6 +150,47 @@ int ws_getchar(ws_client_t client) | ||||
| 	return out; | ||||
| } | ||||
| 
 | ||||
| int ws_getstr(ws_client_t client, uint16_t max_size, char *str) | ||||
| { | ||||
| 	uint16_t out = 0; | ||||
| 	if (client->rxBuffer_rp != client->rxBuffer_wp) | ||||
| 	{ | ||||
| 		out = WS_RX_BUFFER_LEN + client->rxBuffer_wp - client->rxBuffer_rp; | ||||
| 		if (out > WS_RX_BUFFER_LEN) | ||||
| 		{ | ||||
| 			out -= WS_RX_BUFFER_LEN; | ||||
| 		} | ||||
| 		if (out > max_size) | ||||
| 		{ | ||||
| 			out = max_size; | ||||
| 		} | ||||
| 
 | ||||
| 		if (client->rxBuffer_rp < client->rxBuffer_wp) | ||||
| 		{ | ||||
| 			memcpy(str, &client->rxBuffer[client->rxBuffer_rp], out); | ||||
| 		} | ||||
| 		else | ||||
| 		{ | ||||
| 			uint16_t sizeUntilEnd = WS_RX_BUFFER_LEN - client->rxBuffer_rp; | ||||
| 			if (sizeUntilEnd >= out) | ||||
| 			{ | ||||
| 				memcpy(str, &client->rxBuffer[client->rxBuffer_rp], out); | ||||
| 			} | ||||
| 			else | ||||
| 			{ | ||||
| 				memcpy(str, &client->rxBuffer[client->rxBuffer_rp], sizeUntilEnd); | ||||
| 				memcpy(str + sizeUntilEnd, &client->rxBuffer[0], out - sizeUntilEnd); | ||||
| 			} | ||||
| 		} | ||||
| 		client->rxBuffer_rp += out; | ||||
| 		if (client->rxBuffer_rp >= WS_RX_BUFFER_LEN) | ||||
| 		{ | ||||
| 			client->rxBuffer_rp -= WS_RX_BUFFER_LEN; | ||||
| 		} | ||||
| 	} | ||||
| 	return out; | ||||
| } | ||||
| 
 | ||||
| void ws_putchar(ws_client_t client, char c) | ||||
| { | ||||
| 	if (client->txBuffer_wp == WS_TX_BUFFER_LEN) | ||||
| @ -173,3 +217,8 @@ void ws_sendData(ws_client_t client) | ||||
| 		client->txBuffer_wp = 0; | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| void ws_sendString(ws_client_t client, const char *str) | ||||
| { | ||||
| 	esp_websocket_client_send_text(client->handle, str, strlen(str), 1000 * portTICK_PERIOD_MS); | ||||
| } | ||||
|  | ||||
| @ -25,7 +25,9 @@ typedef ws_client_data_t* ws_client_t; | ||||
| 
 | ||||
| ws_client_t ws_connect(char *url, uint16_t id, uint16_t dev_code); | ||||
| int ws_getchar(ws_client_t client); | ||||
| int ws_getstr(ws_client_t client, uint16_t max_len, char *str); | ||||
| void ws_putchar(ws_client_t client, char c); | ||||
| void ws_sendData(ws_client_t client); | ||||
| void ws_sendString(ws_client_t client, const char *str); | ||||
| 
 | ||||
| #endif | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user