X-Git-Url: http://sigrok.org/gitweb/?a=blobdiff_plain;f=hardware%2Fdemo%2Fdemo.c;h=560d1be3c5d99da52c5d950f810716a475e58fce;hb=d5a669a9e0319531595a8a45b6c21f0c316a24f1;hp=248ee11eabb53756dd3c697ff221f080448b7ce7;hpb=0e94d524c19fe89c564243421d37c17818f87631;p=libsigrok.git diff --git a/hardware/demo/demo.c b/hardware/demo/demo.c index 248ee11e..560d1be3 100644 --- a/hardware/demo/demo.c +++ b/hardware/demo/demo.c @@ -79,7 +79,7 @@ struct dev_context { GIOChannel *channels[2]; uint8_t sample_generator; uint64_t samples_counter; - void *session_dev_id; + void *cb_data; int64_t starttime; }; @@ -371,7 +371,7 @@ static int receive_data(int fd, int revents, void *cb_data) logic.length = sending_now; logic.unitsize = 1; logic.data = buf; - sr_session_send(devc->session_dev_id, &packet); + sr_session_send(devc->cb_data, &packet); devc->samples_counter += sending_now; } @@ -387,14 +387,10 @@ static int receive_data(int fd, int revents, void *cb_data) static int hw_dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data) { - struct sr_datafeed_packet *packet; - struct sr_datafeed_header *header; struct dev_context *devc; (void)sdi; - sr_dbg("Starting acquisition."); - /* TODO: 'devc' is never g_free()'d? */ if (!(devc = g_try_malloc(sizeof(struct dev_context)))) { sr_err("%s: devc malloc failed", __func__); @@ -402,7 +398,7 @@ static int hw_dev_acquisition_start(const struct sr_dev_inst *sdi, } devc->sample_generator = default_pattern; - devc->session_dev_id = cb_data; + devc->cb_data = cb_data; devc->samples_counter = 0; /* @@ -434,28 +430,12 @@ static int hw_dev_acquisition_start(const struct sr_dev_inst *sdi, sr_session_source_add_channel(devc->channels[0], G_IO_IN | G_IO_ERR, 40, receive_data, devc); - if (!(packet = g_try_malloc(sizeof(struct sr_datafeed_packet)))) { - sr_err("%s: packet malloc failed", __func__); - return SR_ERR_MALLOC; - } - - if (!(header = g_try_malloc(sizeof(struct sr_datafeed_header)))) { - sr_err("%s: header malloc failed", __func__); - return SR_ERR_MALLOC; - } - - packet->type = SR_DF_HEADER; - packet->payload = header; - header->feed_version = 1; - gettimeofday(&header->starttime, NULL); - sr_session_send(devc->session_dev_id, packet); + /* Send header packet to the session bus. */ + std_session_send_df_header(cb_data, DRIVER_LOG_DOMAIN); /* We use this timestamp to decide how many more samples to send. */ devc->starttime = g_get_monotonic_time(); - g_free(header); - g_free(packet); - return SR_OK; } @@ -475,7 +455,7 @@ static int hw_dev_acquisition_stop(struct sr_dev_inst *sdi, void *cb_data) /* Send last packet. */ packet.type = SR_DF_END; - sr_session_send(devc->session_dev_id, &packet); + sr_session_send(devc->cb_data, &packet); return SR_OK; }