added some comments

master
Ondřej Hruška 7 years ago
parent 96b1e11e55
commit 9e183920fc
Signed by: MightyPork
GPG Key ID: 2C5FD5035250423D
  1. 42
      gex/gex_client.c
  2. 11
      gex/gex_client.h

@ -43,7 +43,7 @@ static TF_Result unit_report_lst(TinyFrame *tf, TF_Msg *msg)
uint8_t callsign = msg->data[0]; uint8_t callsign = msg->data[0];
uint8_t rpt_type = msg->data[1]; uint8_t rpt_type = msg->data[1];
struct gex_unit *lu = gex_find_unit_by_callsign(gex, callsign); GexUnit *lu = gex_find_unit_by_callsign(gex, callsign);
GexMsg gexMsg = { GexMsg gexMsg = {
.payload = (uint8_t *) (msg->data + 2), .payload = (uint8_t *) (msg->data + 2),
@ -69,19 +69,20 @@ static TF_Result list_units_lst(TinyFrame *tf, TF_Msg *msg)
gex_destroy_unit_lookup(gex); gex_destroy_unit_lookup(gex);
// Parse the payload
PayloadParser pp = pp_start((uint8_t*)msg->data, msg->len, NULL); PayloadParser pp = pp_start((uint8_t*)msg->data, msg->len, NULL);
uint8_t count = pp_u8(&pp); uint8_t count = pp_u8(&pp);
char buf[20]; char buf[20];
char buf2[20]; char buf2[20];
struct gex_unit *tail = NULL; GexUnit *tail = NULL;
for(int i = 0; i < count; i++) { for(int i = 0; i < count; i++) {
uint8_t callsign = pp_u8(&pp); uint8_t callsign = pp_u8(&pp);
pp_string(&pp, buf, 20); pp_string(&pp, buf, 20);
pp_string(&pp, buf2, 20); pp_string(&pp, buf2, 20);
fprintf(stderr, "- Found unit \"%s\" (type %s) @ callsign %d\n", buf, buf2, callsign); fprintf(stderr, "- Found unit \"%s\" (type %s) @ callsign %d\n", buf, buf2, callsign);
// append // append a unit instance
struct gex_unit *lu = malloc(sizeof(struct gex_unit)); GexUnit *lu = malloc(sizeof(GexUnit));
lu->next = NULL; lu->next = NULL;
lu->type = strdup(buf2); lu->type = strdup(buf2);
lu->name = strdup(buf); lu->name = strdup(buf);
@ -100,16 +101,18 @@ static TF_Result list_units_lst(TinyFrame *tf, TF_Msg *msg)
} }
/** Bind report listener */ /** Bind report listener */
void GEX_OnReport(GexClient *gex, GexUnit *unit, GexEventListener lst) void GEX_SetUnitReportListener(GexUnit *unit, GexEventListener lst)
{ {
if (!unit) { unit->report_handler = lst;
gex->fallback_report_handler = lst; }
}
else { /** Bind report listener */
unit->report_handler = lst; void GEX_SetDefaultReportListener(GexClient *gex, GexEventListener lst)
} {
gex->fallback_report_handler = lst;
} }
/** Get raw TinyFrame instance */
TinyFrame *GEX_GetTF(GexClient *gex) TinyFrame *GEX_GetTF(GexClient *gex)
{ {
return gex->tf; return gex->tf;
@ -159,7 +162,9 @@ GexClient *GEX_Init(const char *device, uint32_t timeout_ms)
// --- Test connectivity --- // --- Test connectivity ---
fprintf(stderr, "Testing connection...\n"); fprintf(stderr, "Testing connection...\n");
TF_QuerySimple(gex->tf, MSG_PING, /*pld*/ NULL, 0, /*cb*/ connectivity_check_lst, 0); TF_QuerySimple(gex->tf, MSG_PING,
NULL, 0,
connectivity_check_lst, 0);
GEX_Poll(gex); GEX_Poll(gex);
if (!gex->connected) { if (!gex->connected) {
@ -170,7 +175,9 @@ GexClient *GEX_Init(const char *device, uint32_t timeout_ms)
// --- populate callsign look-up table --- // --- populate callsign look-up table ---
fprintf(stderr, "Loading available units info...\n"); fprintf(stderr, "Loading available units info...\n");
TF_QuerySimple(gex->tf, MSG_LIST_UNITS, /*pld*/ NULL, 0, /*cb*/ list_units_lst, 0); TF_QuerySimple(gex->tf, MSG_LIST_UNITS,
NULL, 0,
list_units_lst, 0);
GEX_Poll(gex); GEX_Poll(gex);
// Bind the catch-all event handler. Will be re-distributed to individual unit listeners if needed. // Bind the catch-all event handler. Will be re-distributed to individual unit listeners if needed.
@ -192,31 +199,40 @@ void GEX_Poll(GexClient *gex)
int cycle = 0; int cycle = 0;
do { do {
// The first read is blocking up to a timeout and waits for data
if (first) serial_shouldwait(gex->acm_fd, gex->ser_timeout); if (first) serial_shouldwait(gex->acm_fd, gex->ser_timeout);
ssize_t len = read(gex->acm_fd, pollbuffer, TF_MAX_PAYLOAD_RX); ssize_t len = read(gex->acm_fd, pollbuffer, TF_MAX_PAYLOAD_RX);
if (first) { if (first) {
// Following reads are non-blocking and just grab data from the system buffer
serial_noblock(gex->acm_fd); serial_noblock(gex->acm_fd);
first = false; first = false;
} }
// abort on error
if (len < 0) { if (len < 0) {
fprintf(stderr, "ERROR %d in GEX Poll: %s\n", errno, strerror(errno)); fprintf(stderr, "ERROR %d in GEX Poll: %s\n", errno, strerror(errno));
break; break;
} }
else { else {
// nothing received?
if (len == 0) { if (len == 0) {
// keep trying to read we have a reason to expect more data
if (gex->tf->state != 0) { if (gex->tf->state != 0) {
if (cycle < MAX_RETRIES) { if (cycle < MAX_RETRIES) {
// start a new cycle, setting 'first' to use a blocking read
cycle++; cycle++;
first=true; first=true;
} else { } else {
// tries exhausted
break; break;
} }
} else { } else {
// nothing more received and TF is in the base state, we're done.
break; break;
} }
} }
else { else {
// process the received data
TF_Accept(gex->tf, pollbuffer, (size_t) len); TF_Accept(gex->tf, pollbuffer, (size_t) len);
} }
} }

@ -20,11 +20,18 @@
* a spontaneous report is received. If no known unit matched the report, * a spontaneous report is received. If no known unit matched the report,
* a dummy unit is provided to avoid NULL access. * a dummy unit is provided to avoid NULL access.
* *
* @param unit - the handled unit
* @param lst - the listener
*/
void GEX_SetUnitReportListener(GexUnit *unit, GexEventListener lst);
/**
* Bind a defualt report listener (used if a report is not handled by any unit report listener).
*
* @param gex - client * @param gex - client
* @param unit - the handled unit, NULL to bind a fallback listener (fallback may receive events from all unhandled units)
* @param lst - the listener * @param lst - the listener
*/ */
void GEX_OnReport(GexClient *gex, GexUnit *unit, GexEventListener lst); void GEX_SetDefaultReportListener(GexClient *gex, GexEventListener lst);
TinyFrame *GEX_GetTF(GexClient *gex); TinyFrame *GEX_GetTF(GexClient *gex);

Loading…
Cancel
Save