Make two connections for SDK and device

refactor
PgSocks 2 years ago
parent 51b8897d38
commit 0cec23f7f7

@ -147,7 +147,7 @@ union Request {
union Response { union Response {
struct Header header; struct Header header;
struct SetSdkConnectionResp sdkconn; struct SetSdkConnectionResp sdkconn;
struct SetSdkModeReq sdkmode; struct SetSdkModeResp sdkmode;
struct SetSystemLedResp led; struct SetSystemLedResp led;
struct SetWheelSpeedResp wheel; struct SetWheelSpeedResp wheel;
}; };

@ -8,7 +8,8 @@ struct Client {
int16_t seq; int16_t seq;
struct Connection* connection; struct Connection* sdk_conn;
struct Connection* dev_conn;
}; };

@ -11,6 +11,7 @@
#include <arpa/inet.h> #include <arpa/inet.h>
#include <string.h> #include <string.h>
#include <fcntl.h> #include <fcntl.h>
#include <stdio.h>
struct Connection { struct Connection {
int sockfd; int sockfd;
@ -21,27 +22,52 @@ struct Connection {
inline inline
static static
struct Connection* struct Connection*
connection_new() connection_new(unsigned int source_port, const char* source_ip, unsigned int dest_port, const char* dest_ip)
{ {
struct Connection* conn = malloc(sizeof(struct Connection)); struct Connection* conn = malloc(sizeof(struct Connection));
memset(conn, 0, sizeof(struct Connection)); memset(conn, 0, sizeof(struct Connection));
// Request a UDP socket // Request a UDP socket
conn->sockfd = socket(AF_INET, SOCK_DGRAM, 0); conn->sockfd = socket(AF_INET, SOCK_DGRAM, 0);
if(source_port && source_ip) {
struct sockaddr_in loc_addr;
loc_addr.sin_family = AF_INET;
loc_addr.sin_port = htons(source_port);
loc_addr.sin_addr.s_addr = inet_addr(source_ip);
if(bind(conn->sockfd, (struct sockaddr*)&loc_addr, sizeof(loc_addr)) < 0)
{
perror("unable to bind local port");
exit(EXIT_FAILURE);
}
}
// Make the socket non-blocking // Make the socket non-blocking
int flags = fcntl(conn->sockfd, F_GETFL); int flags = fcntl(conn->sockfd, F_GETFL);
fcntl(conn->sockfd, F_SETFL, flags | O_NONBLOCK); fcntl(conn->sockfd, F_SETFL, flags | O_NONBLOCK);
// Set the address of the drone // Set the address of the drone
memset(&conn->remote_addr, 0, sizeof(conn->remote_addr));
conn->addrlen = sizeof(conn->remote_addr); conn->addrlen = sizeof(conn->remote_addr);
conn->remote_addr.sin_family = AF_INET; conn->remote_addr.sin_family = AF_INET;
conn->remote_addr.sin_port = htons(30030); conn->remote_addr.sin_port = htons(dest_port);
conn->remote_addr.sin_addr.s_addr = inet_addr("192.168.2.1"); conn->remote_addr.sin_addr.s_addr = inet_addr(dest_ip);
return conn; return conn;
} }
inline
static
void
connection_set_remote(struct Connection* conn, unsigned int dest_port, const char* dest_ip)
{
// Set the address of the drone
conn->addrlen = sizeof(conn->remote_addr);
conn->remote_addr.sin_family = AF_INET;
conn->remote_addr.sin_port = htons(dest_port);
conn->remote_addr.sin_addr.s_addr = inet_addr(dest_ip);
}
static static
inline inline
void void

@ -28,6 +28,6 @@ set_system_led (
req.led.t2 = t2; req.led.t2 = t2;
req_finalize(session, 0x3F, SET_SYSTEM_LED_CMDID, sizeof(struct SetSystemLedReq), &req); req_finalize(session, 0x3F, SET_SYSTEM_LED_CMDID, sizeof(struct SetSystemLedReq), &req);
req_send(session->connection, &req, sizeof(struct SetSystemLedReq)); req_send(session->dev_conn, &req, sizeof(struct SetSystemLedReq));
} }

@ -17,5 +17,5 @@ set_sdk_connection(
req.sdkconn.ip_address = ip_address; req.sdkconn.ip_address = ip_address;
req.sdkconn.port = port; req.sdkconn.port = port;
req_finalize(session, 0x3F, SET_SDK_CONNECTION_CMDID, sizeof(struct SetSdkConnectionReq), &req); req_finalize(session, 0x3F, SET_SDK_CONNECTION_CMDID, sizeof(struct SetSdkConnectionReq), &req);
req_send(session->connection, &req, sizeof(struct SetSdkConnectionReq)); req_send(session->sdk_conn, &req, sizeof(struct SetSdkConnectionReq));
} }

@ -9,5 +9,5 @@ set_sdk_mode(
union Request req = {0}; union Request req = {0};
req.sdkmode.enable = enable; req.sdkmode.enable = enable;
req_finalize(session, 0x3F, SET_SDK_MODE_CMDID, sizeof(struct SetSdkModeReq), &req); req_finalize(session, 0x3F, SET_SDK_MODE_CMDID, sizeof(struct SetSdkModeReq), &req);
req_send(session->connection, &req, sizeof(struct SetSdkModeReq)); req_send(session->dev_conn, &req, sizeof(struct SetSdkModeReq));
} }

@ -15,5 +15,5 @@ set_wheel_speed (
req.wheel.wheel_speed[2] = w3; req.wheel.wheel_speed[2] = w3;
req.wheel.wheel_speed[3] = w4; req.wheel.wheel_speed[3] = w4;
req_finalize(session, 0x3F, SET_WHEEL_SPEED_CMDID, sizeof(struct SetWheelSpeedReq), &req); req_finalize(session, 0x3F, SET_WHEEL_SPEED_CMDID, sizeof(struct SetWheelSpeedReq), &req);
req_send(session->connection, &req, sizeof(struct SetWheelSpeedReq)); req_send(session->sdk_conn, &req, sizeof(struct SetWheelSpeedReq));
} }

@ -20,19 +20,22 @@ Client client_new() {
} }
void client_connect(Client client) { void client_connect(Client client) {
client->connection = connection_new(); client->sdk_conn = connection_new(0, 0, 30030, "192.168.2.1");
client->dev_conn = connection_new(10010, "192.168.2.24", 20020, "192.168.2.1");
set_sdk_connection(client, CONNECTION_WIFI_AP, 0, 10010); set_sdk_connection(client, CONNECTION_WIFI_AP, 0, 10010);
} }
void poll_message(Client client, union Message* resp) { void poll_message(Client client, union Message* resp) {
memset(resp, 0, sizeof(union Message));
// Poll for messages // Poll for messages
static struct timeval timeout = {0, 0}; static struct timeval timeout = {0, 0};
fd_set read_fds; fd_set read_fds;
FD_ZERO(&read_fds); FD_ZERO(&read_fds);
FD_SET(client->connection->sockfd, &read_fds); FD_SET(client->sdk_conn->sockfd, &read_fds);
int result = select(client->connection->sockfd + 1, &read_fds, NULL, NULL, NULL); int result = select(client->sdk_conn->sockfd + 1, &read_fds, NULL, NULL, NULL);
// Check for socket polling errors // Check for socket polling errors
if(result < 0) { if(result < 0) {
@ -47,8 +50,7 @@ void poll_message(Client client, union Message* resp) {
} }
// Read a message from the socket // Read a message from the socket
// TODO: Use union to make all messages same size int recvb = recvfrom(client->sdk_conn->sockfd, resp, sizeof(union Message), 0, (struct sockaddr*)&client->sdk_conn->remote_addr, &client->sdk_conn->addrlen);
int recvb = recvfrom(client->connection->sockfd, resp, sizeof(union Message), 0, (struct sockaddr*)&client->connection->remote_addr, &client->connection->addrlen);
// Check for socket read errors // Check for socket read errors
if(recvb < 0) { if(recvb < 0) {

Loading…
Cancel
Save