Add struct sr_session parameter to all session source backends.
This commit is contained in:
parent
85b69c2b64
commit
102f123966
|
@ -249,7 +249,8 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
|
|
||||||
/* Poll every 100ms, or whenever some data comes in. */
|
/* Poll every 100ms, or whenever some data comes in. */
|
||||||
serial = sdi->conn;
|
serial = sdi->conn;
|
||||||
serial_source_add(serial, G_IO_IN, 100, agdmm_receive_data, (void *)sdi);
|
serial_source_add(sdi->session, serial, G_IO_IN, 100,
|
||||||
|
agdmm_receive_data, (void *)sdi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -259,7 +259,8 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi,
|
||||||
std_session_send_df_header(cb_data, LOG_PREFIX);
|
std_session_send_df_header(cb_data, LOG_PREFIX);
|
||||||
|
|
||||||
/* Poll every 50ms, or whenever some data comes in. */
|
/* Poll every 50ms, or whenever some data comes in. */
|
||||||
serial_source_add(serial, G_IO_IN, 50, appa_55ii_receive_data, (void *)sdi);
|
serial_source_add(sdi->session, serial, G_IO_IN, 50,
|
||||||
|
appa_55ii_receive_data, (void *)sdi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1005,7 +1005,7 @@ static void sigma_decode_dram_cluster(struct sigma_dram_cluster *dram_cluster,
|
||||||
*/
|
*/
|
||||||
if ((i == 1023) || (ts == (tsdiff - EVENTS_PER_CLUSTER))) {
|
if ((i == 1023) || (ts == (tsdiff - EVENTS_PER_CLUSTER))) {
|
||||||
logic.length = (i + 1) * logic.unitsize;
|
logic.length = (i + 1) * logic.unitsize;
|
||||||
sr_session_send(devc->cb_data, &packet);
|
sr_session_send(sdi, &packet);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1033,14 +1033,14 @@ static void sigma_decode_dram_cluster(struct sigma_dram_cluster *dram_cluster,
|
||||||
if (trigger_offset > 0) {
|
if (trigger_offset > 0) {
|
||||||
packet.type = SR_DF_LOGIC;
|
packet.type = SR_DF_LOGIC;
|
||||||
logic.length = trigger_offset * logic.unitsize;
|
logic.length = trigger_offset * logic.unitsize;
|
||||||
sr_session_send(devc->cb_data, &packet);
|
sr_session_send(sdi, &packet);
|
||||||
events_in_cluster -= trigger_offset;
|
events_in_cluster -= trigger_offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Only send trigger if explicitly enabled. */
|
/* Only send trigger if explicitly enabled. */
|
||||||
if (devc->use_triggers) {
|
if (devc->use_triggers) {
|
||||||
packet.type = SR_DF_TRIGGER;
|
packet.type = SR_DF_TRIGGER;
|
||||||
sr_session_send(devc->cb_data, &packet);
|
sr_session_send(sdi, &packet);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1048,7 +1048,7 @@ static void sigma_decode_dram_cluster(struct sigma_dram_cluster *dram_cluster,
|
||||||
packet.type = SR_DF_LOGIC;
|
packet.type = SR_DF_LOGIC;
|
||||||
logic.length = events_in_cluster * logic.unitsize;
|
logic.length = events_in_cluster * logic.unitsize;
|
||||||
logic.data = samples + (trigger_offset * logic.unitsize);
|
logic.data = samples + (trigger_offset * logic.unitsize);
|
||||||
sr_session_send(devc->cb_data, &packet);
|
sr_session_send(sdi, &packet);
|
||||||
}
|
}
|
||||||
|
|
||||||
ss->lastsample =
|
ss->lastsample =
|
||||||
|
@ -1069,10 +1069,9 @@ static void sigma_decode_dram_cluster(struct sigma_dram_cluster *dram_cluster,
|
||||||
static int decode_chunk_ts(struct sigma_dram_line *dram_line,
|
static int decode_chunk_ts(struct sigma_dram_line *dram_line,
|
||||||
uint16_t events_in_line,
|
uint16_t events_in_line,
|
||||||
uint32_t trigger_event,
|
uint32_t trigger_event,
|
||||||
void *cb_data)
|
struct sr_dev_inst *sdi)
|
||||||
{
|
{
|
||||||
struct sigma_dram_cluster *dram_cluster;
|
struct sigma_dram_cluster *dram_cluster;
|
||||||
struct sr_dev_inst *sdi = cb_data;
|
|
||||||
struct dev_context *devc = sdi->priv;
|
struct dev_context *devc = sdi->priv;
|
||||||
unsigned int clusters_in_line =
|
unsigned int clusters_in_line =
|
||||||
(events_in_line + (EVENTS_PER_CLUSTER - 1)) / EVENTS_PER_CLUSTER;
|
(events_in_line + (EVENTS_PER_CLUSTER - 1)) / EVENTS_PER_CLUSTER;
|
||||||
|
@ -1510,10 +1509,10 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
devc->cb_data = cb_data;
|
devc->cb_data = cb_data;
|
||||||
|
|
||||||
/* Send header packet to the session bus. */
|
/* Send header packet to the session bus. */
|
||||||
std_session_send_df_header(cb_data, LOG_PREFIX);
|
std_session_send_df_header(sdi, LOG_PREFIX);
|
||||||
|
|
||||||
/* Add capture source. */
|
/* Add capture source. */
|
||||||
sr_source_add(0, G_IO_IN, 10, receive_data, (void *)sdi);
|
sr_session_source_add(sdi->session, 0, G_IO_IN, 10, receive_data, (void *)sdi);
|
||||||
|
|
||||||
devc->state.state = SIGMA_CAPTURE;
|
devc->state.state = SIGMA_CAPTURE;
|
||||||
|
|
||||||
|
@ -1529,7 +1528,7 @@ static int dev_acquisition_stop(struct sr_dev_inst *sdi, void *cb_data)
|
||||||
devc = sdi->priv;
|
devc = sdi->priv;
|
||||||
devc->state.state = SIGMA_IDLE;
|
devc->state.state = SIGMA_IDLE;
|
||||||
|
|
||||||
sr_source_remove(0);
|
sr_session_source_remove(sdi->session, 0);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -470,7 +470,8 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi,
|
||||||
devc->acquisition_running = TRUE;
|
devc->acquisition_running = TRUE;
|
||||||
|
|
||||||
serial = sdi->conn;
|
serial = sdi->conn;
|
||||||
serial_source_add(serial, G_IO_IN, 50, atten_pps3xxx_receive_data, (void *)sdi);
|
serial_source_add(sdi->session, serial, G_IO_IN, 50,
|
||||||
|
atten_pps3xxx_receive_data, (void *)sdi);
|
||||||
std_session_send_df_header(cb_data, LOG_PREFIX);
|
std_session_send_df_header(cb_data, LOG_PREFIX);
|
||||||
|
|
||||||
/* Send a "channel" configuration packet now. */
|
/* Send a "channel" configuration packet now. */
|
||||||
|
|
|
@ -153,7 +153,7 @@ SR_PRIV int atten_pps3xxx_receive_data(int fd, int revents, void *cb_data)
|
||||||
if (devc->acquisition_running)
|
if (devc->acquisition_running)
|
||||||
send_config(sdi);
|
send_config(sdi);
|
||||||
else {
|
else {
|
||||||
serial_source_remove(serial);
|
serial_source_remove(sdi->session, serial);
|
||||||
packet.type = SR_DF_END;
|
packet.type = SR_DF_END;
|
||||||
sr_session_send(sdi, &packet);
|
sr_session_send(sdi, &packet);
|
||||||
}
|
}
|
||||||
|
|
|
@ -261,17 +261,19 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi,
|
||||||
{
|
{
|
||||||
struct dev_context *devc;
|
struct dev_context *devc;
|
||||||
|
|
||||||
|
(void)cb_data;
|
||||||
|
|
||||||
if (sdi->status != SR_ST_ACTIVE)
|
if (sdi->status != SR_ST_ACTIVE)
|
||||||
return SR_ERR_DEV_CLOSED;
|
return SR_ERR_DEV_CLOSED;
|
||||||
|
|
||||||
devc = sdi->priv;
|
devc = sdi->priv;
|
||||||
devc->session_cb_data = cb_data;
|
|
||||||
devc->start_time = g_get_monotonic_time();
|
devc->start_time = g_get_monotonic_time();
|
||||||
|
|
||||||
/* Send header packet to the session bus. */
|
/* Send header packet to the session bus. */
|
||||||
std_session_send_df_header(cb_data, LOG_PREFIX);
|
std_session_send_df_header(sdi, LOG_PREFIX);
|
||||||
|
|
||||||
sr_source_add(0, 0, 10, brymen_bm86x_receive_data, (void *)sdi);
|
sr_session_source_add(sdi->session, 0, 0, 10,
|
||||||
|
brymen_bm86x_receive_data, (void *)sdi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
@ -280,14 +282,16 @@ static int dev_acquisition_stop(struct sr_dev_inst *sdi, void *cb_data)
|
||||||
{
|
{
|
||||||
struct sr_datafeed_packet packet;
|
struct sr_datafeed_packet packet;
|
||||||
|
|
||||||
|
(void)cb_data;
|
||||||
|
|
||||||
if (sdi->status != SR_ST_ACTIVE)
|
if (sdi->status != SR_ST_ACTIVE)
|
||||||
return SR_ERR_DEV_CLOSED;
|
return SR_ERR_DEV_CLOSED;
|
||||||
|
|
||||||
/* Send end packet to the session bus. */
|
/* Send end packet to the session bus. */
|
||||||
packet.type = SR_DF_END;
|
packet.type = SR_DF_END;
|
||||||
sr_session_send(cb_data, &packet);
|
sr_session_send(sdi, &packet);
|
||||||
|
|
||||||
sr_source_remove(0);
|
sr_session_source_remove(sdi->session, 0);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -211,7 +211,7 @@ static void brymen_bm86x_handle_packet(const struct sr_dev_inst *sdi,
|
||||||
analog[0].channels = g_slist_append(NULL, sdi->channels->data);
|
analog[0].channels = g_slist_append(NULL, sdi->channels->data);
|
||||||
packet.type = SR_DF_ANALOG;
|
packet.type = SR_DF_ANALOG;
|
||||||
packet.payload = &analog[0];
|
packet.payload = &analog[0];
|
||||||
sr_session_send(devc->session_cb_data, &packet);
|
sr_session_send(sdi, &packet);
|
||||||
g_slist_free(analog[0].channels);
|
g_slist_free(analog[0].channels);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -222,7 +222,7 @@ static void brymen_bm86x_handle_packet(const struct sr_dev_inst *sdi,
|
||||||
analog[1].channels = g_slist_append(NULL, sdi->channels->next->data);
|
analog[1].channels = g_slist_append(NULL, sdi->channels->next->data);
|
||||||
packet.type = SR_DF_ANALOG;
|
packet.type = SR_DF_ANALOG;
|
||||||
packet.payload = &analog[1];
|
packet.payload = &analog[1];
|
||||||
sr_session_send(devc->session_cb_data, &packet);
|
sr_session_send(sdi, &packet);
|
||||||
g_slist_free(analog[1].channels);
|
g_slist_free(analog[1].channels);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -32,7 +32,6 @@ struct dev_context {
|
||||||
/* Acquisition settings */
|
/* Acquisition settings */
|
||||||
uint64_t limit_samples; /**< The sampling limit (in number of samples).*/
|
uint64_t limit_samples; /**< The sampling limit (in number of samples).*/
|
||||||
uint64_t limit_msec; /**< The time limit (in milliseconds). */
|
uint64_t limit_msec; /**< The time limit (in milliseconds). */
|
||||||
void *session_cb_data; /**< Opaque pointer passed in by the frontend. */
|
|
||||||
|
|
||||||
/* Operational state */
|
/* Operational state */
|
||||||
int detached_kernel_driver;/**< Whether kernel driver was detached or not */
|
int detached_kernel_driver;/**< Whether kernel driver was detached or not */
|
||||||
|
|
|
@ -230,7 +230,7 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
|
|
||||||
/* Poll every 50ms, or whenever some data comes in. */
|
/* Poll every 50ms, or whenever some data comes in. */
|
||||||
serial = sdi->conn;
|
serial = sdi->conn;
|
||||||
serial_source_add(serial, G_IO_IN, 50,
|
serial_source_add(sdi->session, serial, G_IO_IN, 50,
|
||||||
brymen_dmm_receive_data, (void *)sdi);
|
brymen_dmm_receive_data, (void *)sdi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
|
|
|
@ -397,8 +397,8 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
|
|
||||||
/* Poll every 100ms, or whenever some data comes in. */
|
/* Poll every 100ms, or whenever some data comes in. */
|
||||||
serial = sdi->conn;
|
serial = sdi->conn;
|
||||||
serial_source_add(serial, G_IO_IN, 150, cem_dt_885x_receive_data,
|
serial_source_add(sdi->session, serial, G_IO_IN, 150,
|
||||||
(void *)sdi);
|
cem_dt_885x_receive_data, (void *)sdi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -231,7 +231,7 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi,
|
||||||
|
|
||||||
/* Poll every 500ms, or whenever some data comes in. */
|
/* Poll every 500ms, or whenever some data comes in. */
|
||||||
serial = sdi->conn;
|
serial = sdi->conn;
|
||||||
serial_source_add(serial, G_IO_IN, 500,
|
serial_source_add(sdi->session, serial, G_IO_IN, 500,
|
||||||
center_devs[idx].receive_data, (void *)sdi);
|
center_devs[idx].receive_data, (void *)sdi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
|
|
|
@ -507,7 +507,7 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
devc->cb_data = cb_data;
|
devc->cb_data = cb_data;
|
||||||
|
|
||||||
/* Send header packet to the session bus. */
|
/* Send header packet to the session bus. */
|
||||||
std_session_send_df_header(cb_data, LOG_PREFIX);
|
std_session_send_df_header(sdi, LOG_PREFIX);
|
||||||
|
|
||||||
/* Time when we should be done (for detecting trigger timeouts). */
|
/* Time when we should be done (for detecting trigger timeouts). */
|
||||||
devc->done = (devc->divcount + 1) * devc->prof->trigger_constant +
|
devc->done = (devc->divcount + 1) * devc->prof->trigger_constant +
|
||||||
|
@ -516,7 +516,7 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
devc->trigger_found = 0;
|
devc->trigger_found = 0;
|
||||||
|
|
||||||
/* Hook up a dummy handler to receive data from the device. */
|
/* Hook up a dummy handler to receive data from the device. */
|
||||||
sr_source_add(-1, G_IO_IN, 0, receive_data, (void *)sdi);
|
sr_session_source_add(sdi->session, -1, G_IO_IN, 0, receive_data, (void *)sdi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
@ -525,15 +525,15 @@ static int dev_acquisition_stop(struct sr_dev_inst *sdi, void *cb_data)
|
||||||
{
|
{
|
||||||
struct sr_datafeed_packet packet;
|
struct sr_datafeed_packet packet;
|
||||||
|
|
||||||
(void)sdi;
|
(void)cb_data;
|
||||||
|
|
||||||
sr_dbg("Stopping acquisition.");
|
sr_dbg("Stopping acquisition.");
|
||||||
sr_source_remove(-1);
|
sr_session_source_remove(sdi->session, -1);
|
||||||
|
|
||||||
/* Send end packet to the session bus. */
|
/* Send end packet to the session bus. */
|
||||||
sr_dbg("Sending SR_DF_END.");
|
sr_dbg("Sending SR_DF_END.");
|
||||||
packet.type = SR_DF_END;
|
packet.type = SR_DF_END;
|
||||||
sr_session_send(cb_data, &packet);
|
sr_session_send(sdi, &packet);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -209,8 +209,8 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
|
|
||||||
/* Poll every 150ms, or whenever some data comes in. */
|
/* Poll every 150ms, or whenever some data comes in. */
|
||||||
serial = sdi->conn;
|
serial = sdi->conn;
|
||||||
serial_source_add(serial, G_IO_IN, 150, colead_slm_receive_data,
|
serial_source_add(sdi->session, serial, G_IO_IN, 150,
|
||||||
(void *)sdi);
|
colead_slm_receive_data, (void *)sdi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -216,10 +216,11 @@ SR_PRIV int sr_scpi_open(struct sr_scpi_dev_inst *scpi)
|
||||||
* @return SR_OK upon success, SR_ERR_ARG upon invalid arguments, or
|
* @return SR_OK upon success, SR_ERR_ARG upon invalid arguments, or
|
||||||
* SR_ERR_MALLOC upon memory allocation errors.
|
* SR_ERR_MALLOC upon memory allocation errors.
|
||||||
*/
|
*/
|
||||||
SR_PRIV int sr_scpi_source_add(struct sr_scpi_dev_inst *scpi, int events,
|
SR_PRIV int sr_scpi_source_add(struct sr_session *session,
|
||||||
int timeout, sr_receive_data_callback cb, void *cb_data)
|
struct sr_scpi_dev_inst *scpi, int events, int timeout,
|
||||||
|
sr_receive_data_callback cb, void *cb_data)
|
||||||
{
|
{
|
||||||
return scpi->source_add(scpi->priv, events, timeout, cb, cb_data);
|
return scpi->source_add(session, scpi->priv, events, timeout, cb, cb_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -231,9 +232,10 @@ SR_PRIV int sr_scpi_source_add(struct sr_scpi_dev_inst *scpi, int events,
|
||||||
* SR_ERR_MALLOC upon memory allocation errors, SR_ERR_BUG upon
|
* SR_ERR_MALLOC upon memory allocation errors, SR_ERR_BUG upon
|
||||||
* internal errors.
|
* internal errors.
|
||||||
*/
|
*/
|
||||||
SR_PRIV int sr_scpi_source_remove(struct sr_scpi_dev_inst *scpi)
|
SR_PRIV int sr_scpi_source_remove(struct sr_session *session,
|
||||||
|
struct sr_scpi_dev_inst *scpi)
|
||||||
{
|
{
|
||||||
return scpi->source_remove(scpi->priv);
|
return scpi->source_remove(session, scpi->priv);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -102,21 +102,21 @@ static int scpi_serial_open(void *priv)
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int scpi_serial_source_add(void *priv, int events, int timeout,
|
static int scpi_serial_source_add(struct sr_session *session, void *priv,
|
||||||
sr_receive_data_callback cb, void *cb_data)
|
int events, int timeout, sr_receive_data_callback cb, void *cb_data)
|
||||||
{
|
{
|
||||||
struct scpi_serial *sscpi = priv;
|
struct scpi_serial *sscpi = priv;
|
||||||
struct sr_serial_dev_inst *serial = sscpi->serial;
|
struct sr_serial_dev_inst *serial = sscpi->serial;
|
||||||
|
|
||||||
return serial_source_add(serial, events, timeout, cb, cb_data);
|
return serial_source_add(session, serial, events, timeout, cb, cb_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int scpi_serial_source_remove(void *priv)
|
static int scpi_serial_source_remove(struct sr_session *session, void *priv)
|
||||||
{
|
{
|
||||||
struct scpi_serial *sscpi = priv;
|
struct scpi_serial *sscpi = priv;
|
||||||
struct sr_serial_dev_inst *serial = sscpi->serial;
|
struct sr_serial_dev_inst *serial = sscpi->serial;
|
||||||
|
|
||||||
return serial_source_remove(serial);
|
return serial_source_remove(session, serial);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int scpi_serial_send(void *priv, const char *command)
|
static int scpi_serial_send(void *priv, const char *command)
|
||||||
|
|
|
@ -115,19 +115,20 @@ static int scpi_tcp_open(void *priv)
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int scpi_tcp_source_add(void *priv, int events, int timeout,
|
static int scpi_tcp_source_add(struct sr_session *session, void *priv,
|
||||||
sr_receive_data_callback cb, void *cb_data)
|
int events, int timeout, sr_receive_data_callback cb, void *cb_data)
|
||||||
{
|
{
|
||||||
struct scpi_tcp *tcp = priv;
|
struct scpi_tcp *tcp = priv;
|
||||||
|
|
||||||
return sr_source_add(tcp->socket, events, timeout, cb, cb_data);
|
return sr_session_source_add(session, tcp->socket, events, timeout,
|
||||||
|
cb, cb_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int scpi_tcp_source_remove(void *priv)
|
static int scpi_tcp_source_remove(struct sr_session *session, void *priv)
|
||||||
{
|
{
|
||||||
struct scpi_tcp *tcp = priv;
|
struct scpi_tcp *tcp = priv;
|
||||||
|
|
||||||
return sr_source_remove(tcp->socket);
|
return sr_session_source_remove(session, tcp->socket);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int scpi_tcp_send(void *priv, const char *command)
|
static int scpi_tcp_send(void *priv, const char *command)
|
||||||
|
|
|
@ -316,18 +316,20 @@ static int scpi_usbtmc_libusb_open(void *priv)
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int scpi_usbtmc_libusb_source_add(void *priv, int events, int timeout,
|
static int scpi_usbtmc_libusb_source_add(struct sr_session *session,
|
||||||
sr_receive_data_callback cb, void *cb_data)
|
void *priv, int events, int timeout, sr_receive_data_callback cb,
|
||||||
|
void *cb_data)
|
||||||
{
|
{
|
||||||
struct scpi_usbtmc_libusb *uscpi = priv;
|
struct scpi_usbtmc_libusb *uscpi = priv;
|
||||||
(void)events;
|
(void)events;
|
||||||
return usb_source_add(uscpi->ctx, timeout, cb, cb_data);
|
return usb_source_add(session, uscpi->ctx, timeout, cb, cb_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int scpi_usbtmc_libusb_source_remove(void *priv)
|
static int scpi_usbtmc_libusb_source_remove(struct sr_session *session,
|
||||||
|
void *priv)
|
||||||
{
|
{
|
||||||
struct scpi_usbtmc_libusb *uscpi = priv;
|
struct scpi_usbtmc_libusb *uscpi = priv;
|
||||||
return usb_source_remove(uscpi->ctx);
|
return usb_source_remove(session, uscpi->ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void usbtmc_bulk_out_header_write(void *header, uint8_t MsgID,
|
static void usbtmc_bulk_out_header_write(void *header, uint8_t MsgID,
|
||||||
|
|
|
@ -67,20 +67,20 @@ static int scpi_visa_open(void *priv)
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int scpi_visa_source_add(void *priv, int events, int timeout,
|
static int scpi_visa_source_add(struct sr_session *session, void *priv,
|
||||||
sr_receive_data_callback cb, void *cb_data)
|
int events, int timeout, sr_receive_data_callback cb, void *cb_data)
|
||||||
{
|
{
|
||||||
(void) priv;
|
(void) priv;
|
||||||
|
|
||||||
/* Hook up a dummy handler to receive data from the device. */
|
/* Hook up a dummy handler to receive data from the device. */
|
||||||
return sr_source_add(-1, events, timeout, cb, cb_data);
|
return sr_session_source_add(session, -1, events, timeout, cb, cb_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int scpi_visa_source_remove(void *priv)
|
static int scpi_visa_source_remove(struct sr_session *session, void *priv)
|
||||||
{
|
{
|
||||||
(void) priv;
|
(void) priv;
|
||||||
|
|
||||||
return sr_source_remove(-1);
|
return sr_session_source_remove(session, -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int scpi_visa_send(void *priv, const char *command)
|
static int scpi_visa_send(void *priv, const char *command)
|
||||||
|
|
|
@ -91,20 +91,20 @@ static int scpi_vxi_open(void *priv)
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int scpi_vxi_source_add(void *priv, int events, int timeout,
|
static int scpi_vxi_source_add(struct sr_session *session, void *priv,
|
||||||
sr_receive_data_callback cb, void *cb_data)
|
int events, int timeout, sr_receive_data_callback cb, void *cb_data)
|
||||||
{
|
{
|
||||||
(void)priv;
|
(void)priv;
|
||||||
|
|
||||||
/* Hook up a dummy handler to receive data from the device. */
|
/* Hook up a dummy handler to receive data from the device. */
|
||||||
return sr_source_add(-1, events, timeout, cb, cb_data);
|
return sr_session_source_add(session, -1, events, timeout, cb, cb_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int scpi_vxi_source_remove(void *priv)
|
static int scpi_vxi_source_remove(struct sr_session *session, void *priv)
|
||||||
{
|
{
|
||||||
(void)priv;
|
(void)priv;
|
||||||
|
|
||||||
return sr_source_remove(-1);
|
return sr_session_source_remove(session, -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Operation Flags */
|
/* Operation Flags */
|
||||||
|
|
|
@ -708,8 +708,9 @@ typedef HANDLE event_handle;
|
||||||
typedef int event_handle;
|
typedef int event_handle;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
SR_PRIV int serial_source_add(struct sr_serial_dev_inst *serial, int events,
|
SR_PRIV int serial_source_add(struct sr_session *session,
|
||||||
int timeout, sr_receive_data_callback cb, void *cb_data)
|
struct sr_serial_dev_inst *serial, int events, int timeout,
|
||||||
|
sr_receive_data_callback cb, void *cb_data)
|
||||||
{
|
{
|
||||||
enum sp_event mask = 0;
|
enum sp_event mask = 0;
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
@ -744,7 +745,7 @@ SR_PRIV int serial_source_add(struct sr_serial_dev_inst *serial, int events,
|
||||||
if (mask & SP_EVENT_ERROR)
|
if (mask & SP_EVENT_ERROR)
|
||||||
serial->pollfds[i].events |= G_IO_ERR;
|
serial->pollfds[i].events |= G_IO_ERR;
|
||||||
|
|
||||||
if (sr_source_add_pollfd(&serial->pollfds[i],
|
if (sr_session_source_add_pollfd(session, &serial->pollfds[i],
|
||||||
timeout, cb, cb_data) != SR_OK)
|
timeout, cb, cb_data) != SR_OK)
|
||||||
return SR_ERR;
|
return SR_ERR;
|
||||||
}
|
}
|
||||||
|
@ -752,12 +753,13 @@ SR_PRIV int serial_source_add(struct sr_serial_dev_inst *serial, int events,
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
SR_PRIV int serial_source_remove(struct sr_serial_dev_inst *serial)
|
SR_PRIV int serial_source_remove(struct sr_session *session,
|
||||||
|
struct sr_serial_dev_inst *serial)
|
||||||
{
|
{
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
|
||||||
for (i = 0; i < serial->event_set->count; i++)
|
for (i = 0; i < serial->event_set->count; i++)
|
||||||
if (sr_source_remove_pollfd(&serial->pollfds[i]) != SR_OK)
|
if (sr_session_source_remove_pollfd(session, &serial->pollfds[i]) != SR_OK)
|
||||||
return SR_ERR;
|
return SR_ERR;
|
||||||
|
|
||||||
g_free(serial->pollfds);
|
g_free(serial->pollfds);
|
||||||
|
|
|
@ -209,8 +209,8 @@ static int usb_callback(int fd, int revents, void *cb_data)
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
SR_PRIV int usb_source_add(struct sr_context *ctx, int timeout,
|
SR_PRIV int usb_source_add(struct sr_session *session, struct sr_context *ctx,
|
||||||
sr_receive_data_callback cb, void *cb_data)
|
int timeout, sr_receive_data_callback cb, void *cb_data)
|
||||||
{
|
{
|
||||||
if (ctx->usb_source_present) {
|
if (ctx->usb_source_present) {
|
||||||
sr_err("A USB event source is already present.");
|
sr_err("A USB event source is already present.");
|
||||||
|
@ -226,14 +226,16 @@ SR_PRIV int usb_source_add(struct sr_context *ctx, int timeout,
|
||||||
ctx->usb_pollfd.events = G_IO_IN;
|
ctx->usb_pollfd.events = G_IO_IN;
|
||||||
ctx->usb_cb = cb;
|
ctx->usb_cb = cb;
|
||||||
ctx->usb_cb_data = cb_data;
|
ctx->usb_cb_data = cb_data;
|
||||||
sr_session_source_add_pollfd(&ctx->usb_pollfd, timeout, usb_callback, ctx);
|
sr_session_source_add_pollfd(session, &ctx->usb_pollfd, timeout,
|
||||||
|
usb_callback, ctx);
|
||||||
#else
|
#else
|
||||||
const struct libusb_pollfd **lupfd;
|
const struct libusb_pollfd **lupfd;
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
|
||||||
lupfd = libusb_get_pollfds(ctx->libusb_ctx);
|
lupfd = libusb_get_pollfds(ctx->libusb_ctx);
|
||||||
for (i = 0; lupfd[i]; i++)
|
for (i = 0; lupfd[i]; i++)
|
||||||
sr_source_add(lupfd[i]->fd, lupfd[i]->events, timeout, cb, cb_data);
|
sr_session_source_add(session, lupfd[i]->fd, lupfd[i]->events,
|
||||||
|
timeout, cb, cb_data);
|
||||||
free(lupfd);
|
free(lupfd);
|
||||||
#endif
|
#endif
|
||||||
ctx->usb_source_present = TRUE;
|
ctx->usb_source_present = TRUE;
|
||||||
|
@ -241,7 +243,7 @@ SR_PRIV int usb_source_add(struct sr_context *ctx, int timeout,
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
SR_PRIV int usb_source_remove(struct sr_context *ctx)
|
SR_PRIV int usb_source_remove(struct sr_session *session, struct sr_context *ctx)
|
||||||
{
|
{
|
||||||
if (!ctx->usb_source_present)
|
if (!ctx->usb_source_present)
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
|
@ -252,7 +254,7 @@ SR_PRIV int usb_source_remove(struct sr_context *ctx)
|
||||||
libusb_unlock_events(ctx->libusb_ctx);
|
libusb_unlock_events(ctx->libusb_ctx);
|
||||||
g_thread_join(ctx->usb_thread);
|
g_thread_join(ctx->usb_thread);
|
||||||
g_mutex_clear(&ctx->usb_mutex);
|
g_mutex_clear(&ctx->usb_mutex);
|
||||||
sr_session_source_remove_pollfd(&ctx->usb_pollfd);
|
sr_session_source_remove_pollfd(session, &ctx->usb_pollfd);
|
||||||
CloseHandle(ctx->usb_event);
|
CloseHandle(ctx->usb_event);
|
||||||
#else
|
#else
|
||||||
const struct libusb_pollfd **lupfd;
|
const struct libusb_pollfd **lupfd;
|
||||||
|
@ -260,7 +262,7 @@ SR_PRIV int usb_source_remove(struct sr_context *ctx)
|
||||||
|
|
||||||
lupfd = libusb_get_pollfds(ctx->libusb_ctx);
|
lupfd = libusb_get_pollfds(ctx->libusb_ctx);
|
||||||
for (i = 0; lupfd[i]; i++)
|
for (i = 0; lupfd[i]; i++)
|
||||||
sr_source_remove(lupfd[i]->fd);
|
sr_session_source_remove(session, lupfd[i]->fd);
|
||||||
free(lupfd);
|
free(lupfd);
|
||||||
#endif
|
#endif
|
||||||
ctx->usb_source_present = FALSE;
|
ctx->usb_source_present = FALSE;
|
||||||
|
|
|
@ -692,6 +692,8 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
GSList *l;
|
GSList *l;
|
||||||
struct dev_context *devc;
|
struct dev_context *devc;
|
||||||
|
|
||||||
|
(void)cb_data;
|
||||||
|
|
||||||
if (sdi->status != SR_ST_ACTIVE)
|
if (sdi->status != SR_ST_ACTIVE)
|
||||||
return SR_ERR_DEV_CLOSED;
|
return SR_ERR_DEV_CLOSED;
|
||||||
|
|
||||||
|
@ -726,11 +728,11 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
/* Make channels to unbuffered. */
|
/* Make channels to unbuffered. */
|
||||||
g_io_channel_set_buffered(devc->channel, FALSE);
|
g_io_channel_set_buffered(devc->channel, FALSE);
|
||||||
|
|
||||||
sr_source_add_channel(devc->channel, G_IO_IN | G_IO_ERR,
|
sr_session_source_add_channel(sdi->session, devc->channel, G_IO_IN | G_IO_ERR,
|
||||||
40, prepare_data, (void *)sdi);
|
40, prepare_data, (void *)sdi);
|
||||||
|
|
||||||
/* Send header packet to the session bus. */
|
/* Send header packet to the session bus. */
|
||||||
std_session_send_df_header(cb_data, LOG_PREFIX);
|
std_session_send_df_header(sdi, LOG_PREFIX);
|
||||||
|
|
||||||
/* We use this timestamp to decide how many more samples to send. */
|
/* We use this timestamp to decide how many more samples to send. */
|
||||||
devc->starttime = g_get_monotonic_time();
|
devc->starttime = g_get_monotonic_time();
|
||||||
|
@ -748,7 +750,7 @@ static int dev_acquisition_stop(struct sr_dev_inst *sdi, void *cb_data)
|
||||||
devc = sdi->priv;
|
devc = sdi->priv;
|
||||||
sr_dbg("Stopping acquisition.");
|
sr_dbg("Stopping acquisition.");
|
||||||
|
|
||||||
sr_source_remove_channel(devc->channel);
|
sr_session_source_remove_channel(sdi->session, devc->channel);
|
||||||
g_io_channel_shutdown(devc->channel, FALSE, NULL);
|
g_io_channel_shutdown(devc->channel, FALSE, NULL);
|
||||||
g_io_channel_unref(devc->channel);
|
g_io_channel_unref(devc->channel);
|
||||||
devc->channel = NULL;
|
devc->channel = NULL;
|
||||||
|
|
|
@ -283,7 +283,8 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
|
|
||||||
/* Poll every 100ms, or whenever some data comes in. */
|
/* Poll every 100ms, or whenever some data comes in. */
|
||||||
serial = sdi->conn;
|
serial = sdi->conn;
|
||||||
serial_source_add(serial, G_IO_IN, 50, fluke_receive_data, (void *)sdi);
|
serial_source_add(sdi->session, serial, G_IO_IN, 50,
|
||||||
|
fluke_receive_data, (void *)sdi);
|
||||||
|
|
||||||
if (serial_write(serial, "QM\r", 3) == -1) {
|
if (serial_write(serial, "QM\r", 3) == -1) {
|
||||||
sr_err("Unable to send QM: %s.", strerror(errno));
|
sr_err("Unable to send QM: %s.", strerror(errno));
|
||||||
|
|
|
@ -576,7 +576,7 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
|
|
||||||
devc->ctx = drvc->sr_ctx;
|
devc->ctx = drvc->sr_ctx;
|
||||||
|
|
||||||
usb_source_add(devc->ctx, timeout, receive_data, NULL);
|
usb_source_add(sdi->session, devc->ctx, timeout, receive_data, NULL);
|
||||||
|
|
||||||
/* Send header packet to the session bus. */
|
/* Send header packet to the session bus. */
|
||||||
std_session_send_df_header(cb_data, LOG_PREFIX);
|
std_session_send_df_header(cb_data, LOG_PREFIX);
|
||||||
|
|
|
@ -328,16 +328,19 @@ SR_PRIV void fx2lafw_abort_acquisition(struct dev_context *devc)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void finish_acquisition(struct dev_context *devc)
|
static void finish_acquisition(struct sr_dev_inst *sdi)
|
||||||
{
|
{
|
||||||
struct sr_datafeed_packet packet;
|
struct sr_datafeed_packet packet;
|
||||||
|
struct dev_context *devc;
|
||||||
|
|
||||||
|
devc = sdi->priv;
|
||||||
|
|
||||||
/* Terminate session. */
|
/* Terminate session. */
|
||||||
packet.type = SR_DF_END;
|
packet.type = SR_DF_END;
|
||||||
sr_session_send(devc->cb_data, &packet);
|
sr_session_send(sdi, &packet);
|
||||||
|
|
||||||
/* Remove fds from polling. */
|
/* Remove fds from polling. */
|
||||||
usb_source_remove(devc->ctx);
|
usb_source_remove(sdi->session, devc->ctx);
|
||||||
|
|
||||||
devc->num_transfers = 0;
|
devc->num_transfers = 0;
|
||||||
g_free(devc->transfers);
|
g_free(devc->transfers);
|
||||||
|
@ -370,7 +373,7 @@ static void free_transfer(struct libusb_transfer *transfer)
|
||||||
|
|
||||||
devc->submitted_transfers--;
|
devc->submitted_transfers--;
|
||||||
if (devc->submitted_transfers == 0)
|
if (devc->submitted_transfers == 0)
|
||||||
finish_acquisition(devc);
|
finish_acquisition(sdi);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void resubmit_transfer(struct libusb_transfer *transfer)
|
static void resubmit_transfer(struct libusb_transfer *transfer)
|
||||||
|
|
|
@ -529,8 +529,8 @@ static int dev_acquisition_start_1x_2x_rs232(const struct sr_dev_inst *sdi,
|
||||||
|
|
||||||
/* Poll every 40ms, or whenever some data comes in. */
|
/* Poll every 40ms, or whenever some data comes in. */
|
||||||
serial = sdi->conn;
|
serial = sdi->conn;
|
||||||
serial_source_add(serial, G_IO_IN, 40, gmc_mh_1x_2x_receive_data,
|
serial_source_add(sdi->session, serial, G_IO_IN, 40,
|
||||||
(void *)sdi);
|
gmc_mh_1x_2x_receive_data, (void *)sdi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
@ -560,8 +560,8 @@ static int dev_acquisition_start_2x_bd232(const struct sr_dev_inst *sdi,
|
||||||
|
|
||||||
/* Poll every 40ms, or whenever some data comes in. */
|
/* Poll every 40ms, or whenever some data comes in. */
|
||||||
serial = sdi->conn;
|
serial = sdi->conn;
|
||||||
serial_source_add(serial, G_IO_IN, 40, gmc_mh_2x_receive_data,
|
serial_source_add(sdi->session, serial, G_IO_IN, 40,
|
||||||
(void *)sdi);
|
gmc_mh_2x_receive_data, (void *)sdi);
|
||||||
|
|
||||||
/* Send start message */
|
/* Send start message */
|
||||||
return req_meas14(sdi);
|
return req_meas14(sdi);
|
||||||
|
|
|
@ -749,7 +749,8 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
return SR_ERR;
|
return SR_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
sr_scpi_source_add(scpi, G_IO_IN, 50, hmo_receive_data, (void *)sdi);
|
sr_scpi_source_add(sdi->session, scpi, G_IO_IN, 50,
|
||||||
|
hmo_receive_data, (void *)sdi);
|
||||||
|
|
||||||
/* Send header packet to the session bus. */
|
/* Send header packet to the session bus. */
|
||||||
std_session_send_df_header(cb_data, LOG_PREFIX);
|
std_session_send_df_header(cb_data, LOG_PREFIX);
|
||||||
|
@ -780,7 +781,7 @@ static int dev_acquisition_stop(struct sr_dev_inst *sdi, void *cb_data)
|
||||||
g_slist_free(devc->enabled_channels);
|
g_slist_free(devc->enabled_channels);
|
||||||
devc->enabled_channels = NULL;
|
devc->enabled_channels = NULL;
|
||||||
scpi = sdi->conn;
|
scpi = sdi->conn;
|
||||||
sr_scpi_source_remove(scpi);
|
sr_scpi_source_remove(sdi->session, scpi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -822,7 +822,7 @@ static int handle_event(int fd, int revents, void *cb_data)
|
||||||
* TODO: Doesn't really cancel pending transfers so they might
|
* TODO: Doesn't really cancel pending transfers so they might
|
||||||
* come in after SR_DF_END is sent.
|
* come in after SR_DF_END is sent.
|
||||||
*/
|
*/
|
||||||
usb_source_remove(drvc->sr_ctx);
|
usb_source_remove(sdi->session, drvc->sr_ctx);
|
||||||
|
|
||||||
packet.type = SR_DF_END;
|
packet.type = SR_DF_END;
|
||||||
sr_session_send(sdi, &packet);
|
sr_session_send(sdi, &packet);
|
||||||
|
@ -933,7 +933,7 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
return SR_ERR;
|
return SR_ERR;
|
||||||
|
|
||||||
devc->dev_state = CAPTURE;
|
devc->dev_state = CAPTURE;
|
||||||
usb_source_add(drvc->sr_ctx, TICK, handle_event, (void *)sdi);
|
usb_source_add(sdi->session, drvc->sr_ctx, TICK, handle_event, (void *)sdi);
|
||||||
|
|
||||||
/* Send header packet to the session bus. */
|
/* Send header packet to the session bus. */
|
||||||
std_session_send_df_header(cb_data, LOG_PREFIX);
|
std_session_send_df_header(cb_data, LOG_PREFIX);
|
||||||
|
|
|
@ -490,7 +490,8 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
return SR_ERR;
|
return SR_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
usb_source_add(drvc->sr_ctx, 100, ikalogic_scanalogic2_receive_data, (void *)sdi);
|
usb_source_add(sdi->session, drvc->sr_ctx, 100,
|
||||||
|
ikalogic_scanalogic2_receive_data, (void *)sdi);
|
||||||
|
|
||||||
sr_dbg("Acquisition started successfully.");
|
sr_dbg("Acquisition started successfully.");
|
||||||
|
|
||||||
|
|
|
@ -33,7 +33,7 @@ static void stop_acquisition(struct sr_dev_inst *sdi)
|
||||||
devc = sdi->priv;
|
devc = sdi->priv;
|
||||||
|
|
||||||
/* Remove USB file descriptors from polling. */
|
/* Remove USB file descriptors from polling. */
|
||||||
usb_source_remove(drvc->sr_ctx);
|
usb_source_remove(sdi->session, drvc->sr_ctx);
|
||||||
|
|
||||||
packet.type = SR_DF_END;
|
packet.type = SR_DF_END;
|
||||||
sr_session_send(devc->cb_data, &packet);
|
sr_session_send(devc->cb_data, &packet);
|
||||||
|
@ -50,7 +50,7 @@ static void abort_acquisition(struct sr_dev_inst *sdi)
|
||||||
devc = sdi->priv;
|
devc = sdi->priv;
|
||||||
|
|
||||||
/* Remove USB file descriptors from polling. */
|
/* Remove USB file descriptors from polling. */
|
||||||
usb_source_remove(drvc->sr_ctx);
|
usb_source_remove(sdi->session, drvc->sr_ctx);
|
||||||
|
|
||||||
packet.type = SR_DF_END;
|
packet.type = SR_DF_END;
|
||||||
sr_session_send(devc->cb_data, &packet);
|
sr_session_send(devc->cb_data, &packet);
|
||||||
|
|
|
@ -393,10 +393,10 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
/* Send header packet to the session bus. */
|
/* Send header packet to the session bus. */
|
||||||
std_session_send_df_header(cb_data, LOG_PREFIX);
|
std_session_send_df_header(sdi, LOG_PREFIX);
|
||||||
|
|
||||||
/* Hook up a dummy handler to receive data from the device. */
|
/* Hook up a dummy handler to receive data from the device. */
|
||||||
sr_source_add(-1, G_IO_IN, 0, scanaplus_receive_data, (void *)sdi);
|
sr_session_source_add(sdi->session, -1, G_IO_IN, 0, scanaplus_receive_data, (void *)sdi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
@ -405,15 +405,15 @@ static int dev_acquisition_stop(struct sr_dev_inst *sdi, void *cb_data)
|
||||||
{
|
{
|
||||||
struct sr_datafeed_packet packet;
|
struct sr_datafeed_packet packet;
|
||||||
|
|
||||||
(void)sdi;
|
(void)cb_data;
|
||||||
|
|
||||||
sr_dbg("Stopping acquisition.");
|
sr_dbg("Stopping acquisition.");
|
||||||
sr_source_remove(-1);
|
sr_session_source_remove(sdi->session, -1);
|
||||||
|
|
||||||
/* Send end packet to the session bus. */
|
/* Send end packet to the session bus. */
|
||||||
sr_dbg("Sending SR_DF_END.");
|
sr_dbg("Sending SR_DF_END.");
|
||||||
packet.type = SR_DF_END;
|
packet.type = SR_DF_END;
|
||||||
sr_session_send(cb_data, &packet);
|
sr_session_send(sdi, &packet);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -489,7 +489,7 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi,
|
||||||
if (!(devc->xfer = libusb_alloc_transfer(0)))
|
if (!(devc->xfer = libusb_alloc_transfer(0)))
|
||||||
return SR_ERR;
|
return SR_ERR;
|
||||||
|
|
||||||
usb_source_add(drvc->sr_ctx, 10,
|
usb_source_add(sdi->session, drvc->sr_ctx, 10,
|
||||||
kecheng_kc_330b_handle_events, (void *)sdi);
|
kecheng_kc_330b_handle_events, (void *)sdi);
|
||||||
|
|
||||||
if (devc->data_source == DATA_SOURCE_LIVE) {
|
if (devc->data_source == DATA_SOURCE_LIVE) {
|
||||||
|
|
|
@ -51,7 +51,7 @@ SR_PRIV int kecheng_kc_330b_handle_events(int fd, int revents, void *cb_data)
|
||||||
|
|
||||||
if (sdi->status == SR_ST_STOPPING) {
|
if (sdi->status == SR_ST_STOPPING) {
|
||||||
libusb_free_transfer(devc->xfer);
|
libusb_free_transfer(devc->xfer);
|
||||||
usb_source_remove(drvc->sr_ctx);
|
usb_source_remove(sdi->session, drvc->sr_ctx);
|
||||||
packet.type = SR_DF_END;
|
packet.type = SR_DF_END;
|
||||||
sr_session_send(cb_data, &packet);
|
sr_session_send(cb_data, &packet);
|
||||||
sdi->status = SR_ST_ACTIVE;
|
sdi->status = SR_ST_ACTIVE;
|
||||||
|
|
|
@ -434,7 +434,8 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
devc->log_size = xfer_in->buffer[1] + (xfer_in->buffer[2] << 8);
|
devc->log_size = xfer_in->buffer[1] + (xfer_in->buffer[2] << 8);
|
||||||
libusb_free_transfer(xfer_out);
|
libusb_free_transfer(xfer_out);
|
||||||
|
|
||||||
usb_source_add(drvc->sr_ctx, 100, lascar_el_usb_handle_events, (void *)sdi);
|
usb_source_add(sdi->session, drvc->sr_ctx, 100,
|
||||||
|
lascar_el_usb_handle_events, (void *)sdi);
|
||||||
|
|
||||||
buf = g_try_malloc(4096);
|
buf = g_try_malloc(4096);
|
||||||
libusb_fill_bulk_transfer(xfer_in, usb->devhdl, LASCAR_EP_IN,
|
libusb_fill_bulk_transfer(xfer_in, usb->devhdl, LASCAR_EP_IN,
|
||||||
|
|
|
@ -499,7 +499,7 @@ SR_PRIV int lascar_el_usb_handle_events(int fd, int revents, void *cb_data)
|
||||||
sdi = cb_data;
|
sdi = cb_data;
|
||||||
|
|
||||||
if (sdi->status == SR_ST_STOPPING) {
|
if (sdi->status == SR_ST_STOPPING) {
|
||||||
usb_source_remove(drvc->sr_ctx);
|
usb_source_remove(sdi->session, drvc->sr_ctx);
|
||||||
|
|
||||||
packet.type = SR_DF_END;
|
packet.type = SR_DF_END;
|
||||||
sr_session_send(cb_data, &packet);
|
sr_session_send(cb_data, &packet);
|
||||||
|
|
|
@ -461,7 +461,8 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
/* Our first channel is analog, the other 8 are of type 'logic'. */
|
/* Our first channel is analog, the other 8 are of type 'logic'. */
|
||||||
/* TODO. */
|
/* TODO. */
|
||||||
|
|
||||||
serial_source_add(devc->serial, G_IO_IN, -1, mso_receive_data, cb_data);
|
serial_source_add(sdi->session, devc->serial, G_IO_IN, -1,
|
||||||
|
mso_receive_data, cb_data);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -294,7 +294,7 @@ SR_PRIV void stop_acquisition(const struct sr_dev_inst *sdi)
|
||||||
struct dev_context *devc;
|
struct dev_context *devc;
|
||||||
|
|
||||||
devc = sdi->priv;
|
devc = sdi->priv;
|
||||||
serial_source_remove(devc->serial);
|
serial_source_remove(sdi->session, devc->serial);
|
||||||
|
|
||||||
/* Terminate session */
|
/* Terminate session */
|
||||||
packet.type = SR_DF_END;
|
packet.type = SR_DF_END;
|
||||||
|
|
|
@ -398,7 +398,8 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
|
|
||||||
/* Poll every 10ms, or whenever some data comes in. */
|
/* Poll every 10ms, or whenever some data comes in. */
|
||||||
serial = sdi->conn;
|
serial = sdi->conn;
|
||||||
serial_source_add(serial, G_IO_IN, 10, hcs_receive_data, (void *)sdi);
|
serial_source_add(sdi->session, serial, G_IO_IN, 10,
|
||||||
|
hcs_receive_data, (void *)sdi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -233,7 +233,7 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi,
|
||||||
|
|
||||||
/* Poll every 100ms, or whenever some data comes in. */
|
/* Poll every 100ms, or whenever some data comes in. */
|
||||||
serial = sdi->conn;
|
serial = sdi->conn;
|
||||||
serial_source_add(serial, G_IO_IN, 100,
|
serial_source_add(sdi->session, serial, G_IO_IN, 100,
|
||||||
mic_devs[idx].receive_data, (void *)sdi);
|
mic_devs[idx].receive_data, (void *)sdi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
|
|
|
@ -814,7 +814,8 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi,
|
||||||
devc->acq_running = TRUE;
|
devc->acq_running = TRUE;
|
||||||
|
|
||||||
serial = sdi->conn;
|
serial = sdi->conn;
|
||||||
serial_source_add(serial, G_IO_IN, 50, motech_lps_30x_receive_data, (void *)sdi);
|
serial_source_add(sdi->session, serial, G_IO_IN, 50,
|
||||||
|
motech_lps_30x_receive_data, (void *)sdi);
|
||||||
std_session_send_df_header(cb_data, LOG_PREFIX);
|
std_session_send_df_header(cb_data, LOG_PREFIX);
|
||||||
|
|
||||||
/* Start timer, if required. */
|
/* Start timer, if required. */
|
||||||
|
|
|
@ -317,8 +317,8 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi,
|
||||||
|
|
||||||
/* Poll every 100ms, or whenever some data comes in. */
|
/* Poll every 100ms, or whenever some data comes in. */
|
||||||
serial = sdi->conn;
|
serial = sdi->conn;
|
||||||
serial_source_add(serial, G_IO_IN, 100, norma_dmm_receive_data,
|
serial_source_add(sdi->session, serial, G_IO_IN, 100,
|
||||||
(void *)sdi);
|
norma_dmm_receive_data, (void *)sdi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -565,7 +565,8 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi,
|
||||||
/* Send header packet to the session bus. */
|
/* Send header packet to the session bus. */
|
||||||
std_session_send_df_header(cb_data, LOG_PREFIX);
|
std_session_send_df_header(cb_data, LOG_PREFIX);
|
||||||
|
|
||||||
serial_source_add(serial, G_IO_IN, -1, ols_receive_data, cb_data);
|
serial_source_add(sdi->session, serial, G_IO_IN, -1,
|
||||||
|
ols_receive_data, cb_data);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -318,7 +318,7 @@ SR_PRIV void abort_acquisition(const struct sr_dev_inst *sdi)
|
||||||
struct sr_serial_dev_inst *serial;
|
struct sr_serial_dev_inst *serial;
|
||||||
|
|
||||||
serial = sdi->conn;
|
serial = sdi->conn;
|
||||||
serial_source_remove(serial);
|
serial_source_remove(sdi->session, serial);
|
||||||
|
|
||||||
/* Terminate session */
|
/* Terminate session */
|
||||||
packet.type = SR_DF_END;
|
packet.type = SR_DF_END;
|
||||||
|
@ -350,8 +350,9 @@ SR_PRIV int ols_receive_data(int fd, int revents, void *cb_data)
|
||||||
* longer than it takes to send a byte, that means it's
|
* longer than it takes to send a byte, that means it's
|
||||||
* finished. We'll double that to 30ms to be sure...
|
* finished. We'll double that to 30ms to be sure...
|
||||||
*/
|
*/
|
||||||
serial_source_remove(serial);
|
serial_source_remove(sdi->session, serial);
|
||||||
serial_source_add(serial, G_IO_IN, 30, ols_receive_data, cb_data);
|
serial_source_add(sdi->session, serial, G_IO_IN, 30,
|
||||||
|
ols_receive_data, cb_data);
|
||||||
devc->raw_sample_buf = g_try_malloc(devc->limit_samples * 4);
|
devc->raw_sample_buf = g_try_malloc(devc->limit_samples * 4);
|
||||||
if (!devc->raw_sample_buf) {
|
if (!devc->raw_sample_buf) {
|
||||||
sr_err("Sample buffer malloc failed.");
|
sr_err("Sample buffer malloc failed.");
|
||||||
|
|
|
@ -970,7 +970,8 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
if (rigol_ds_config_set(sdi, ":RUN") != SR_OK)
|
if (rigol_ds_config_set(sdi, ":RUN") != SR_OK)
|
||||||
return SR_ERR;
|
return SR_ERR;
|
||||||
|
|
||||||
sr_scpi_source_add(scpi, G_IO_IN, 50, rigol_ds_receive, (void *)sdi);
|
sr_scpi_source_add(sdi->session, scpi, G_IO_IN, 50,
|
||||||
|
rigol_ds_receive, (void *)sdi);
|
||||||
|
|
||||||
/* Send header packet to the session bus. */
|
/* Send header packet to the session bus. */
|
||||||
std_session_send_df_header(cb_data, LOG_PREFIX);
|
std_session_send_df_header(cb_data, LOG_PREFIX);
|
||||||
|
@ -1014,7 +1015,7 @@ static int dev_acquisition_stop(struct sr_dev_inst *sdi, void *cb_data)
|
||||||
devc->enabled_analog_channels = NULL;
|
devc->enabled_analog_channels = NULL;
|
||||||
devc->enabled_digital_channels = NULL;
|
devc->enabled_digital_channels = NULL;
|
||||||
scpi = sdi->conn;
|
scpi = sdi->conn;
|
||||||
sr_scpi_source_remove(scpi);
|
sr_scpi_source_remove(sdi->session, scpi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -773,7 +773,7 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
transfer = libusb_alloc_transfer(0);
|
transfer = libusb_alloc_transfer(0);
|
||||||
libusb_fill_bulk_transfer(transfer, usb->devhdl,
|
libusb_fill_bulk_transfer(transfer, usb->devhdl,
|
||||||
2 | LIBUSB_ENDPOINT_IN, buf, size,
|
2 | LIBUSB_ENDPOINT_IN, buf, size,
|
||||||
logic16_receive_transfer, devc, timeout);
|
logic16_receive_transfer, (void *)sdi, timeout);
|
||||||
if ((ret = libusb_submit_transfer(transfer)) != 0) {
|
if ((ret = libusb_submit_transfer(transfer)) != 0) {
|
||||||
sr_err("Failed to submit transfer: %s.",
|
sr_err("Failed to submit transfer: %s.",
|
||||||
libusb_error_name(ret));
|
libusb_error_name(ret));
|
||||||
|
@ -788,7 +788,7 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
|
|
||||||
devc->ctx = drvc->sr_ctx;
|
devc->ctx = drvc->sr_ctx;
|
||||||
|
|
||||||
usb_source_add(devc->ctx, timeout, receive_data, (void *)sdi);
|
usb_source_add(sdi->session, devc->ctx, timeout, receive_data, (void *)sdi);
|
||||||
|
|
||||||
/* Send header packet to the session bus. */
|
/* Send header packet to the session bus. */
|
||||||
std_session_send_df_header(cb_data, LOG_PREFIX);
|
std_session_send_df_header(cb_data, LOG_PREFIX);
|
||||||
|
|
|
@ -576,16 +576,19 @@ SR_PRIV int logic16_init_device(const struct sr_dev_inst *sdi)
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void finish_acquisition(struct dev_context *devc)
|
static void finish_acquisition(struct sr_dev_inst *sdi)
|
||||||
{
|
{
|
||||||
struct sr_datafeed_packet packet;
|
struct sr_datafeed_packet packet;
|
||||||
|
struct dev_context *devc;
|
||||||
|
|
||||||
|
devc = sdi->priv;
|
||||||
|
|
||||||
/* Terminate session. */
|
/* Terminate session. */
|
||||||
packet.type = SR_DF_END;
|
packet.type = SR_DF_END;
|
||||||
sr_session_send(devc->cb_data, &packet);
|
sr_session_send(devc->cb_data, &packet);
|
||||||
|
|
||||||
/* Remove fds from polling. */
|
/* Remove fds from polling. */
|
||||||
usb_source_remove(devc->ctx);
|
usb_source_remove(sdi->session, devc->ctx);
|
||||||
|
|
||||||
devc->num_transfers = 0;
|
devc->num_transfers = 0;
|
||||||
g_free(devc->transfers);
|
g_free(devc->transfers);
|
||||||
|
@ -598,10 +601,12 @@ static void finish_acquisition(struct dev_context *devc)
|
||||||
|
|
||||||
static void free_transfer(struct libusb_transfer *transfer)
|
static void free_transfer(struct libusb_transfer *transfer)
|
||||||
{
|
{
|
||||||
|
struct sr_dev_inst *sdi;
|
||||||
struct dev_context *devc;
|
struct dev_context *devc;
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
|
||||||
devc = transfer->user_data;
|
sdi = transfer->user_data;
|
||||||
|
devc = sdi->priv;
|
||||||
|
|
||||||
g_free(transfer->buffer);
|
g_free(transfer->buffer);
|
||||||
transfer->buffer = NULL;
|
transfer->buffer = NULL;
|
||||||
|
@ -616,7 +621,7 @@ static void free_transfer(struct libusb_transfer *transfer)
|
||||||
|
|
||||||
devc->submitted_transfers--;
|
devc->submitted_transfers--;
|
||||||
if (devc->submitted_transfers == 0)
|
if (devc->submitted_transfers == 0)
|
||||||
finish_acquisition(devc);
|
finish_acquisition(sdi);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void resubmit_transfer(struct libusb_transfer *transfer)
|
static void resubmit_transfer(struct libusb_transfer *transfer)
|
||||||
|
@ -679,11 +684,13 @@ SR_PRIV void logic16_receive_transfer(struct libusb_transfer *transfer)
|
||||||
gboolean packet_has_error = FALSE;
|
gboolean packet_has_error = FALSE;
|
||||||
struct sr_datafeed_packet packet;
|
struct sr_datafeed_packet packet;
|
||||||
struct sr_datafeed_logic logic;
|
struct sr_datafeed_logic logic;
|
||||||
|
struct sr_dev_inst *sdi;
|
||||||
struct dev_context *devc;
|
struct dev_context *devc;
|
||||||
size_t new_samples, num_samples;
|
size_t new_samples, num_samples;
|
||||||
int trigger_offset;
|
int trigger_offset;
|
||||||
|
|
||||||
devc = transfer->user_data;
|
sdi = transfer->user_data;
|
||||||
|
devc = sdi->priv;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If acquisition has already ended, just free any queued up
|
* If acquisition has already ended, just free any queued up
|
||||||
|
|
|
@ -543,7 +543,7 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi,
|
||||||
|
|
||||||
/* Poll every 50ms, or whenever some data comes in. */
|
/* Poll every 50ms, or whenever some data comes in. */
|
||||||
serial = sdi->conn;
|
serial = sdi->conn;
|
||||||
serial_source_add(serial, G_IO_IN, 50,
|
serial_source_add(sdi->session, serial, G_IO_IN, 50,
|
||||||
dmms[dmm].receive_data, (void *)sdi);
|
dmms[dmm].receive_data, (void *)sdi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
|
|
|
@ -537,7 +537,7 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
lwla_free_acquisition_state(acq);
|
lwla_free_acquisition_state(acq);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
usb_source_add(drvc->sr_ctx, 100, &lwla_receive_data,
|
usb_source_add(sdi->session, drvc->sr_ctx, 100, &lwla_receive_data,
|
||||||
(struct sr_dev_inst *)sdi);
|
(struct sr_dev_inst *)sdi);
|
||||||
|
|
||||||
sr_info("Waiting for data.");
|
sr_info("Waiting for data.");
|
||||||
|
|
|
@ -587,7 +587,7 @@ static void end_acquisition(struct sr_dev_inst *sdi)
|
||||||
devc->state = STATE_IDLE;
|
devc->state = STATE_IDLE;
|
||||||
|
|
||||||
/* Remove USB file descriptors from polling. */
|
/* Remove USB file descriptors from polling. */
|
||||||
usb_source_remove(drvc->sr_ctx);
|
usb_source_remove(sdi->session, drvc->sr_ctx);
|
||||||
|
|
||||||
packet.type = SR_DF_END;
|
packet.type = SR_DF_END;
|
||||||
sr_session_send(sdi, &packet);
|
sr_session_send(sdi, &packet);
|
||||||
|
|
|
@ -257,7 +257,8 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
std_session_send_df_header(cb_data, LOG_PREFIX);
|
std_session_send_df_header(cb_data, LOG_PREFIX);
|
||||||
|
|
||||||
/* Poll every 50ms, or whenever some data comes in. */
|
/* Poll every 50ms, or whenever some data comes in. */
|
||||||
serial_source_add(serial, G_IO_IN, 50, teleinfo_receive_data, (void *)sdi);
|
serial_source_add(sdi->session, serial, G_IO_IN, 50,
|
||||||
|
teleinfo_receive_data, (void *)sdi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -430,7 +430,7 @@ static int handle_events(int fd, int revents, void *cb_data)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (sdi->status == SR_ST_STOPPING) {
|
if (sdi->status == SR_ST_STOPPING) {
|
||||||
usb_source_remove(drvc->sr_ctx);
|
usb_source_remove(sdi->session, drvc->sr_ctx);
|
||||||
|
|
||||||
dev_close(sdi);
|
dev_close(sdi);
|
||||||
|
|
||||||
|
@ -473,7 +473,8 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
/* Send header packet to the session bus. */
|
/* Send header packet to the session bus. */
|
||||||
std_session_send_df_header(cb_data, LOG_PREFIX);
|
std_session_send_df_header(cb_data, LOG_PREFIX);
|
||||||
|
|
||||||
usb_source_add(drvc->sr_ctx, 100, handle_events, (void *)sdi);
|
usb_source_add(sdi->session, drvc->sr_ctx, 100,
|
||||||
|
handle_events, (void *)sdi);
|
||||||
|
|
||||||
if (testo_set_serial_params(usb) != SR_OK)
|
if (testo_set_serial_params(usb) != SR_OK)
|
||||||
return SR_ERR;
|
return SR_ERR;
|
||||||
|
|
|
@ -192,7 +192,7 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi,
|
||||||
|
|
||||||
/* Poll every 500ms, or whenever some data comes in. */
|
/* Poll every 500ms, or whenever some data comes in. */
|
||||||
serial = sdi->conn;
|
serial = sdi->conn;
|
||||||
serial_source_add(serial, G_IO_IN, 500,
|
serial_source_add(sdi->session, serial, G_IO_IN, 500,
|
||||||
tondaj_sl_814_receive_data, (void *)sdi);
|
tondaj_sl_814_receive_data, (void *)sdi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
|
|
|
@ -338,9 +338,9 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi,
|
||||||
devc->starttime = g_get_monotonic_time();
|
devc->starttime = g_get_monotonic_time();
|
||||||
|
|
||||||
/* Send header packet to the session bus. */
|
/* Send header packet to the session bus. */
|
||||||
std_session_send_df_header(cb_data, LOG_PREFIX);
|
std_session_send_df_header(sdi, LOG_PREFIX);
|
||||||
|
|
||||||
sr_source_add(0, 0, 10 /* poll_timeout */,
|
sr_session_source_add(sdi->session, 0, 0, 10 /* poll_timeout */,
|
||||||
udmms[dmm].receive_data, (void *)sdi);
|
udmms[dmm].receive_data, (void *)sdi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
|
@ -350,17 +350,16 @@ static int dev_acquisition_stop(struct sr_dev_inst *sdi, void *cb_data)
|
||||||
{
|
{
|
||||||
struct sr_datafeed_packet packet;
|
struct sr_datafeed_packet packet;
|
||||||
|
|
||||||
(void)sdi;
|
(void)cb_data;
|
||||||
|
|
||||||
sr_dbg("Stopping acquisition.");
|
sr_dbg("Stopping acquisition.");
|
||||||
|
|
||||||
/* Send end packet to the session bus. */
|
/* Send end packet to the session bus. */
|
||||||
sr_dbg("Sending SR_DF_END.");
|
sr_dbg("Sending SR_DF_END.");
|
||||||
packet.type = SR_DF_END;
|
packet.type = SR_DF_END;
|
||||||
sr_session_send(cb_data, &packet);
|
sr_session_send(sdi, &packet);
|
||||||
|
|
||||||
/* TODO? */
|
sr_session_source_remove(sdi->session, 0);
|
||||||
sr_source_remove(0);
|
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -345,7 +345,8 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi,
|
||||||
return SR_ERR;
|
return SR_ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
usb_source_add(drvc->sr_ctx, 10, uni_t_ut32x_handle_events, (void *)sdi);
|
usb_source_add(sdi->session, drvc->sr_ctx, 10,
|
||||||
|
uni_t_ut32x_handle_events, (void *)sdi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -217,7 +217,7 @@ SR_PRIV int uni_t_ut32x_handle_events(int fd, int revents, void *cb_data)
|
||||||
NULL);
|
NULL);
|
||||||
|
|
||||||
if (sdi->status == SR_ST_STOPPING) {
|
if (sdi->status == SR_ST_STOPPING) {
|
||||||
usb_source_remove(drvc->sr_ctx);
|
usb_source_remove(sdi->session, drvc->sr_ctx);
|
||||||
packet.type = SR_DF_END;
|
packet.type = SR_DF_END;
|
||||||
sr_session_send(cb_data, &packet);
|
sr_session_send(cb_data, &packet);
|
||||||
|
|
||||||
|
|
|
@ -348,7 +348,7 @@ static int handle_events(int fd, int revents, void *cb_data)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (sdi->status == SR_ST_STOPPING) {
|
if (sdi->status == SR_ST_STOPPING) {
|
||||||
usb_source_remove(drvc->sr_ctx);
|
usb_source_remove(sdi->session, drvc->sr_ctx);
|
||||||
|
|
||||||
dev_close(sdi);
|
dev_close(sdi);
|
||||||
|
|
||||||
|
@ -387,7 +387,8 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
/* Send header packet to the session bus. */
|
/* Send header packet to the session bus. */
|
||||||
std_session_send_df_header(cb_data, LOG_PREFIX);
|
std_session_send_df_header(cb_data, LOG_PREFIX);
|
||||||
|
|
||||||
usb_source_add(drvc->sr_ctx, 100, handle_events, (void *)sdi);
|
usb_source_add(sdi->session, drvc->sr_ctx, 100,
|
||||||
|
handle_events, (void *)sdi);
|
||||||
|
|
||||||
buf = g_try_malloc(DMM_DATA_SIZE);
|
buf = g_try_malloc(DMM_DATA_SIZE);
|
||||||
transfer = libusb_alloc_transfer(0);
|
transfer = libusb_alloc_transfer(0);
|
||||||
|
|
|
@ -393,9 +393,11 @@ SR_PRIV int serial_stream_detect(struct sr_serial_dev_inst *serial,
|
||||||
uint64_t timeout_ms, int baudrate);
|
uint64_t timeout_ms, int baudrate);
|
||||||
SR_PRIV int sr_serial_extract_options(GSList *options, const char **serial_device,
|
SR_PRIV int sr_serial_extract_options(GSList *options, const char **serial_device,
|
||||||
const char **serial_options);
|
const char **serial_options);
|
||||||
SR_PRIV int serial_source_add(struct sr_serial_dev_inst *serial, int events,
|
SR_PRIV int serial_source_add(struct sr_session *session,
|
||||||
int timeout, sr_receive_data_callback cb, void *cb_data);
|
struct sr_serial_dev_inst *serial, int events, int timeout,
|
||||||
SR_PRIV int serial_source_remove(struct sr_serial_dev_inst *serial);
|
sr_receive_data_callback cb, void *cb_data);
|
||||||
|
SR_PRIV int serial_source_remove(struct sr_session *session,
|
||||||
|
struct sr_serial_dev_inst *serial);
|
||||||
SR_PRIV GSList *sr_serial_find_usb(uint16_t vendor_id, uint16_t product_id);
|
SR_PRIV GSList *sr_serial_find_usb(uint16_t vendor_id, uint16_t product_id);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -414,9 +416,9 @@ SR_PRIV int ezusb_upload_firmware(libusb_device *dev, int configuration,
|
||||||
#ifdef HAVE_LIBUSB_1_0
|
#ifdef HAVE_LIBUSB_1_0
|
||||||
SR_PRIV GSList *sr_usb_find(libusb_context *usb_ctx, const char *conn);
|
SR_PRIV GSList *sr_usb_find(libusb_context *usb_ctx, const char *conn);
|
||||||
SR_PRIV int sr_usb_open(libusb_context *usb_ctx, struct sr_usb_dev_inst *usb);
|
SR_PRIV int sr_usb_open(libusb_context *usb_ctx, struct sr_usb_dev_inst *usb);
|
||||||
SR_PRIV int usb_source_add(struct sr_context *ctx, int timeout,
|
SR_PRIV int usb_source_add(struct sr_session *session, struct sr_context *ctx,
|
||||||
sr_receive_data_callback cb, void *cb_data);
|
int timeout, sr_receive_data_callback cb, void *cb_data);
|
||||||
SR_PRIV int usb_source_remove(struct sr_context *ctx);
|
SR_PRIV int usb_source_remove(struct sr_session *session, struct sr_context *ctx);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*--- hardware/common/scpi.c ------------------------------------------------*/
|
/*--- hardware/common/scpi.c ------------------------------------------------*/
|
||||||
|
@ -465,9 +467,9 @@ struct sr_scpi_dev_inst {
|
||||||
int (*dev_inst_new)(void *priv, struct drv_context *drvc,
|
int (*dev_inst_new)(void *priv, struct drv_context *drvc,
|
||||||
const char *resource, char **params, const char *serialcomm);
|
const char *resource, char **params, const char *serialcomm);
|
||||||
int (*open)(void *priv);
|
int (*open)(void *priv);
|
||||||
int (*source_add)(void *priv, int events,
|
int (*source_add)(struct sr_session *session, void *priv, int events,
|
||||||
int timeout, sr_receive_data_callback cb, void *cb_data);
|
int timeout, sr_receive_data_callback cb, void *cb_data);
|
||||||
int (*source_remove)(void *priv);
|
int (*source_remove)(struct sr_session *session, void *priv);
|
||||||
int (*send)(void *priv, const char *command);
|
int (*send)(void *priv, const char *command);
|
||||||
int (*read_begin)(void *priv);
|
int (*read_begin)(void *priv);
|
||||||
int (*read_data)(void *priv, char *buf, int maxlen);
|
int (*read_data)(void *priv, char *buf, int maxlen);
|
||||||
|
@ -482,9 +484,11 @@ SR_PRIV GSList *sr_scpi_scan(struct drv_context *drvc, GSList *options,
|
||||||
SR_PRIV struct sr_scpi_dev_inst *scpi_dev_inst_new(struct drv_context *drvc,
|
SR_PRIV struct sr_scpi_dev_inst *scpi_dev_inst_new(struct drv_context *drvc,
|
||||||
const char *resource, const char *serialcomm);
|
const char *resource, const char *serialcomm);
|
||||||
SR_PRIV int sr_scpi_open(struct sr_scpi_dev_inst *scpi);
|
SR_PRIV int sr_scpi_open(struct sr_scpi_dev_inst *scpi);
|
||||||
SR_PRIV int sr_scpi_source_add(struct sr_scpi_dev_inst *scpi, int events,
|
SR_PRIV int sr_scpi_source_add(struct sr_session *session,
|
||||||
int timeout, sr_receive_data_callback cb, void *cb_data);
|
struct sr_scpi_dev_inst *scpi, int events, int timeout,
|
||||||
SR_PRIV int sr_scpi_source_remove(struct sr_scpi_dev_inst *scpi);
|
sr_receive_data_callback cb, void *cb_data);
|
||||||
|
SR_PRIV int sr_scpi_source_remove(struct sr_session *session,
|
||||||
|
struct sr_scpi_dev_inst *scpi);
|
||||||
SR_PRIV int sr_scpi_send(struct sr_scpi_dev_inst *scpi,
|
SR_PRIV int sr_scpi_send(struct sr_scpi_dev_inst *scpi,
|
||||||
const char *format, ...);
|
const char *format, ...);
|
||||||
SR_PRIV int sr_scpi_send_variadic(struct sr_scpi_dev_inst *scpi,
|
SR_PRIV int sr_scpi_send_variadic(struct sr_scpi_dev_inst *scpi,
|
||||||
|
|
20
session.c
20
session.c
|
@ -673,10 +673,9 @@ SR_PRIV int sr_session_send(const struct sr_dev_inst *sdi,
|
||||||
* @retval SR_ERR_ARG Invalid argument.
|
* @retval SR_ERR_ARG Invalid argument.
|
||||||
* @retval SR_ERR_MALLOC Memory allocation error.
|
* @retval SR_ERR_MALLOC Memory allocation error.
|
||||||
*/
|
*/
|
||||||
static int _sr_session_source_add(GPollFD *pollfd, int timeout,
|
static int _sr_session_source_add(struct sr_session *session, GPollFD *pollfd,
|
||||||
sr_receive_data_callback cb, void *cb_data, gintptr poll_object)
|
int timeout, sr_receive_data_callback cb, void *cb_data, gintptr poll_object)
|
||||||
{
|
{
|
||||||
struct sr_session *session = sr_current_session;
|
|
||||||
struct source *new_sources, *s;
|
struct source *new_sources, *s;
|
||||||
GPollFD *new_pollfds;
|
GPollFD *new_pollfds;
|
||||||
|
|
||||||
|
@ -742,7 +741,7 @@ SR_API int sr_session_source_add(struct sr_session *session, int fd,
|
||||||
p.fd = fd;
|
p.fd = fd;
|
||||||
p.events = events;
|
p.events = events;
|
||||||
|
|
||||||
return _sr_session_source_add(&p, timeout, cb, cb_data, (gintptr)fd);
|
return _sr_session_source_add(session, &p, timeout, cb, cb_data, (gintptr)fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -765,7 +764,7 @@ SR_API int sr_session_source_add_pollfd(struct sr_session *session,
|
||||||
{
|
{
|
||||||
(void) session;
|
(void) session;
|
||||||
|
|
||||||
return _sr_session_source_add(pollfd, timeout, cb,
|
return _sr_session_source_add(session, pollfd, timeout, cb,
|
||||||
cb_data, (gintptr)pollfd);
|
cb_data, (gintptr)pollfd);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -799,7 +798,7 @@ SR_API int sr_session_source_add_channel(struct sr_session *session,
|
||||||
p.events = events;
|
p.events = events;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return _sr_session_source_add(&p, timeout, cb, cb_data, (gintptr)channel);
|
return _sr_session_source_add(session, &p, timeout, cb, cb_data, (gintptr)channel);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -814,9 +813,8 @@ SR_API int sr_session_source_add_channel(struct sr_session *session,
|
||||||
* @retval SR_ERR_MALLOC Memory allocation error
|
* @retval SR_ERR_MALLOC Memory allocation error
|
||||||
* @retval SR_ERR_BUG Internal error
|
* @retval SR_ERR_BUG Internal error
|
||||||
*/
|
*/
|
||||||
static int _sr_session_source_remove(gintptr poll_object)
|
static int _sr_session_source_remove(struct sr_session *session, gintptr poll_object)
|
||||||
{
|
{
|
||||||
struct sr_session *session = sr_current_session;
|
|
||||||
struct source *new_sources;
|
struct source *new_sources;
|
||||||
GPollFD *new_pollfds;
|
GPollFD *new_pollfds;
|
||||||
unsigned int old;
|
unsigned int old;
|
||||||
|
@ -878,7 +876,7 @@ SR_API int sr_session_source_remove(struct sr_session *session, int fd)
|
||||||
{
|
{
|
||||||
(void) session;
|
(void) session;
|
||||||
|
|
||||||
return _sr_session_source_remove((gintptr)fd);
|
return _sr_session_source_remove(session, (gintptr)fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -897,7 +895,7 @@ SR_API int sr_session_source_remove_pollfd(struct sr_session *session,
|
||||||
{
|
{
|
||||||
(void) session;
|
(void) session;
|
||||||
|
|
||||||
return _sr_session_source_remove((gintptr)pollfd);
|
return _sr_session_source_remove(session, (gintptr)pollfd);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -917,7 +915,7 @@ SR_API int sr_session_source_remove_channel(struct sr_session *session,
|
||||||
{
|
{
|
||||||
(void) session;
|
(void) session;
|
||||||
|
|
||||||
return _sr_session_source_remove((gintptr)channel);
|
return _sr_session_source_remove(session, (gintptr)channel);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** @} */
|
/** @} */
|
||||||
|
|
|
@ -33,6 +33,9 @@
|
||||||
#define CHUNKSIZE (512 * 1024)
|
#define CHUNKSIZE (512 * 1024)
|
||||||
/** @endcond */
|
/** @endcond */
|
||||||
|
|
||||||
|
SR_PRIV struct sr_dev_driver session_driver_info;
|
||||||
|
static struct sr_dev_driver *di = &session_driver_info;
|
||||||
|
|
||||||
struct session_vdev {
|
struct session_vdev {
|
||||||
char *sessionfile;
|
char *sessionfile;
|
||||||
char *capturefile;
|
char *capturefile;
|
||||||
|
@ -46,15 +49,12 @@ struct session_vdev {
|
||||||
gboolean finished;
|
gboolean finished;
|
||||||
};
|
};
|
||||||
|
|
||||||
static GSList *dev_insts = NULL;
|
|
||||||
static const int hwcaps[] = {
|
static const int hwcaps[] = {
|
||||||
SR_CONF_CAPTUREFILE,
|
SR_CONF_CAPTUREFILE,
|
||||||
SR_CONF_CAPTURE_UNITSIZE,
|
SR_CONF_CAPTURE_UNITSIZE,
|
||||||
SR_CONF_SAMPLERATE,
|
SR_CONF_SAMPLERATE,
|
||||||
};
|
};
|
||||||
|
|
||||||
extern struct sr_session *sr_current_session;
|
|
||||||
|
|
||||||
static int receive_data(int fd, int revents, void *cb_data)
|
static int receive_data(int fd, int revents, void *cb_data)
|
||||||
{
|
{
|
||||||
struct sr_dev_inst *sdi;
|
struct sr_dev_inst *sdi;
|
||||||
|
@ -62,7 +62,6 @@ static int receive_data(int fd, int revents, void *cb_data)
|
||||||
struct sr_datafeed_packet packet;
|
struct sr_datafeed_packet packet;
|
||||||
struct sr_datafeed_logic logic;
|
struct sr_datafeed_logic logic;
|
||||||
struct zip_stat zs;
|
struct zip_stat zs;
|
||||||
GSList *l;
|
|
||||||
int ret, got_data;
|
int ret, got_data;
|
||||||
char capturefile[16];
|
char capturefile[16];
|
||||||
void *buf;
|
void *buf;
|
||||||
|
@ -70,14 +69,10 @@ static int receive_data(int fd, int revents, void *cb_data)
|
||||||
(void)fd;
|
(void)fd;
|
||||||
(void)revents;
|
(void)revents;
|
||||||
|
|
||||||
|
sdi = cb_data;
|
||||||
got_data = FALSE;
|
got_data = FALSE;
|
||||||
for (l = dev_insts; l; l = l->next) {
|
|
||||||
sdi = l->data;
|
|
||||||
vdev = sdi->priv;
|
vdev = sdi->priv;
|
||||||
if (vdev->finished)
|
if (!vdev->finished) {
|
||||||
/* Already done with this instance. */
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (!vdev->capfile) {
|
if (!vdev->capfile) {
|
||||||
/* No capture file opened yet, or finished with the last
|
/* No capture file opened yet, or finished with the last
|
||||||
* chunked one. */
|
* chunked one. */
|
||||||
|
@ -118,7 +113,7 @@ static int receive_data(int fd, int revents, void *cb_data)
|
||||||
} else {
|
} else {
|
||||||
/* We got all the chunks, finish up. */
|
/* We got all the chunks, finish up. */
|
||||||
vdev->finished = TRUE;
|
vdev->finished = TRUE;
|
||||||
continue;
|
return TRUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -141,7 +136,7 @@ static int receive_data(int fd, int revents, void *cb_data)
|
||||||
logic.unitsize = vdev->unitsize;
|
logic.unitsize = vdev->unitsize;
|
||||||
logic.data = buf;
|
logic.data = buf;
|
||||||
vdev->bytes_read += ret;
|
vdev->bytes_read += ret;
|
||||||
sr_session_send(cb_data, &packet);
|
sr_session_send(sdi, &packet);
|
||||||
} else {
|
} else {
|
||||||
/* done with this capture file */
|
/* done with this capture file */
|
||||||
zip_fclose(vdev->capfile);
|
zip_fclose(vdev->capfile);
|
||||||
|
@ -161,8 +156,8 @@ static int receive_data(int fd, int revents, void *cb_data)
|
||||||
|
|
||||||
if (!got_data) {
|
if (!got_data) {
|
||||||
packet.type = SR_DF_END;
|
packet.type = SR_DF_END;
|
||||||
sr_session_send(cb_data, &packet);
|
sr_session_send(sdi, &packet);
|
||||||
sr_session_source_remove(sr_current_session, -1);
|
sr_session_source_remove(sdi->session, -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
@ -172,30 +167,32 @@ static int receive_data(int fd, int revents, void *cb_data)
|
||||||
|
|
||||||
static int init(struct sr_context *sr_ctx)
|
static int init(struct sr_context *sr_ctx)
|
||||||
{
|
{
|
||||||
(void)sr_ctx;
|
return std_init(sr_ctx, di, LOG_PREFIX);
|
||||||
|
|
||||||
return SR_OK;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int dev_clear(void)
|
static int dev_clear(void)
|
||||||
{
|
{
|
||||||
|
struct drv_context *drvc;
|
||||||
GSList *l;
|
GSList *l;
|
||||||
|
|
||||||
for (l = dev_insts; l; l = l->next)
|
drvc = di->priv;
|
||||||
|
for (l = drvc->instances; l; l = l->next)
|
||||||
sr_dev_inst_free(l->data);
|
sr_dev_inst_free(l->data);
|
||||||
g_slist_free(dev_insts);
|
g_slist_free(drvc->instances);
|
||||||
dev_insts = NULL;
|
drvc->instances = NULL;
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int dev_open(struct sr_dev_inst *sdi)
|
static int dev_open(struct sr_dev_inst *sdi)
|
||||||
{
|
{
|
||||||
|
struct drv_context *drvc;
|
||||||
struct session_vdev *vdev;
|
struct session_vdev *vdev;
|
||||||
|
|
||||||
vdev = g_try_malloc0(sizeof(struct session_vdev));
|
drvc = di->priv;
|
||||||
|
vdev = g_malloc0(sizeof(struct session_vdev));
|
||||||
sdi->priv = vdev;
|
sdi->priv = vdev;
|
||||||
dev_insts = g_slist_append(dev_insts, sdi);
|
drvc->instances = g_slist_append(drvc->instances, sdi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
@ -294,8 +291,9 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
struct session_vdev *vdev;
|
struct session_vdev *vdev;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
vdev = sdi->priv;
|
(void)cb_data;
|
||||||
|
|
||||||
|
vdev = sdi->priv;
|
||||||
vdev->bytes_read = 0;
|
vdev->bytes_read = 0;
|
||||||
vdev->cur_chunk = 0;
|
vdev->cur_chunk = 0;
|
||||||
vdev->finished = FALSE;
|
vdev->finished = FALSE;
|
||||||
|
@ -310,10 +308,10 @@ static int dev_acquisition_start(const struct sr_dev_inst *sdi, void *cb_data)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Send header packet to the session bus. */
|
/* Send header packet to the session bus. */
|
||||||
std_session_send_df_header(cb_data, LOG_PREFIX);
|
std_session_send_df_header(sdi, LOG_PREFIX);
|
||||||
|
|
||||||
/* freewheeling source */
|
/* freewheeling source */
|
||||||
sr_session_source_add(sr_current_session, -1, 0, 0, receive_data, cb_data);
|
sr_session_source_add(sdi->session, -1, 0, 0, receive_data, (void *)sdi);
|
||||||
|
|
||||||
return SR_OK;
|
return SR_OK;
|
||||||
}
|
}
|
||||||
|
|
2
std.c
2
std.c
|
@ -200,7 +200,7 @@ SR_PRIV int std_serial_dev_acquisition_stop(struct sr_dev_inst *sdi,
|
||||||
|
|
||||||
sr_dbg("%s: Stopping acquisition.", prefix);
|
sr_dbg("%s: Stopping acquisition.", prefix);
|
||||||
|
|
||||||
if ((ret = serial_source_remove(serial)) < 0) {
|
if ((ret = serial_source_remove(sdi->session, serial)) < 0) {
|
||||||
sr_err("%s: Failed to remove source: %d.", prefix, ret);
|
sr_err("%s: Failed to remove source: %d.", prefix, ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue