mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-27 02:35:23 +07:00
staging: comedi: usbduxsigma: use comedi_async 'scans_done' to detect AO EOA
Remove the private data member 'ao_sample_count' and use the comedi_async 'scans_done' member to detect the analog output end-of-acquisition. Signed-off-by: H Hartley Sweeten <hsweeten@visionengravers.com> Reviewed-by: Ian Abbott <abbotti@mev.co.uk> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
88340999de
commit
4b8ffac385
@ -166,7 +166,6 @@ struct usbduxsigma_private {
|
|||||||
|
|
||||||
/* number of samples to acquire */
|
/* number of samples to acquire */
|
||||||
int ai_sample_count;
|
int ai_sample_count;
|
||||||
int ao_sample_count;
|
|
||||||
/* time between samples in units of the timer */
|
/* time between samples in units of the timer */
|
||||||
unsigned int ai_timer;
|
unsigned int ai_timer;
|
||||||
unsigned int ao_timer;
|
unsigned int ao_timer;
|
||||||
@ -358,13 +357,11 @@ static void usbduxsigma_ao_handle_urb(struct comedi_device *dev,
|
|||||||
if (devpriv->ao_counter == 0) {
|
if (devpriv->ao_counter == 0) {
|
||||||
devpriv->ao_counter = devpriv->ao_timer;
|
devpriv->ao_counter = devpriv->ao_timer;
|
||||||
|
|
||||||
if (cmd->stop_src == TRIG_COUNT) {
|
if (cmd->stop_src == TRIG_COUNT &&
|
||||||
devpriv->ao_sample_count--;
|
async->scans_done >= cmd->stop_arg) {
|
||||||
if (devpriv->ao_sample_count < 0) {
|
|
||||||
async->events |= COMEDI_CB_EOA;
|
async->events |= COMEDI_CB_EOA;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/* transmit data to the USB bus */
|
/* transmit data to the USB bus */
|
||||||
datap = urb->transfer_buffer;
|
datap = urb->transfer_buffer;
|
||||||
@ -952,25 +949,6 @@ static int usbduxsigma_ao_cmdtest(struct comedi_device *dev,
|
|||||||
if (devpriv->ao_timer < 1)
|
if (devpriv->ao_timer < 1)
|
||||||
err |= -EINVAL;
|
err |= -EINVAL;
|
||||||
|
|
||||||
if (cmd->stop_src == TRIG_COUNT) {
|
|
||||||
/* not continuous, use counter */
|
|
||||||
if (high_speed) {
|
|
||||||
/* high speed also scans everything at once */
|
|
||||||
devpriv->ao_sample_count = cmd->stop_arg *
|
|
||||||
cmd->scan_end_arg;
|
|
||||||
} else {
|
|
||||||
/*
|
|
||||||
* There's no scan as the scan has been
|
|
||||||
* handled inside the FX2. Data arrives as
|
|
||||||
* one packet.
|
|
||||||
*/
|
|
||||||
devpriv->ao_sample_count = cmd->stop_arg;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
/* continuous acquisition */
|
|
||||||
devpriv->ao_sample_count = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (err)
|
if (err)
|
||||||
return 4;
|
return 4;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user