Commit 592ef9fb authored by H Hartley Sweeten's avatar H Hartley Sweeten Committed by Greg Kroah-Hartman

staging: comedi: ni_tio: fix ni_tio_insn_config()

The (*insn_config) functions are supposed to return an errno or the number
of 'data' values used for the instruction (insn->n). Currently this function
returns an errno or 0. Fix the function to work like the core expects.
Signed-off-by: default avatarH Hartley Sweeten <hsweeten@visionengravers.com>
Reviewed-by: default avatarIan Abbott <abbotti@mev.co.uk>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 475ea1ed
...@@ -1295,15 +1295,18 @@ int ni_tio_insn_config(struct comedi_device *dev, ...@@ -1295,15 +1295,18 @@ int ni_tio_insn_config(struct comedi_device *dev,
struct ni_gpct *counter = s->private; struct ni_gpct *counter = s->private;
unsigned int cidx = counter->counter_index; unsigned int cidx = counter->counter_index;
unsigned int status; unsigned int status;
int ret = 0;
switch (data[0]) { switch (data[0]) {
case INSN_CONFIG_SET_COUNTER_MODE: case INSN_CONFIG_SET_COUNTER_MODE:
return ni_tio_set_counter_mode(counter, data[1]); ret = ni_tio_set_counter_mode(counter, data[1]);
break;
case INSN_CONFIG_ARM: case INSN_CONFIG_ARM:
return ni_tio_arm(counter, true, data[1]); ret = ni_tio_arm(counter, true, data[1]);
break;
case INSN_CONFIG_DISARM: case INSN_CONFIG_DISARM:
ni_tio_arm(counter, false, 0); ret = ni_tio_arm(counter, false, 0);
return 0; break;
case INSN_CONFIG_GET_COUNTER_STATUS: case INSN_CONFIG_GET_COUNTER_STATUS:
data[1] = 0; data[1] = 0;
status = ni_tio_read(counter, NITIO_SHARED_STATUS_REG(cidx)); status = ni_tio_read(counter, NITIO_SHARED_STATUS_REG(cidx));
...@@ -1313,25 +1316,29 @@ int ni_tio_insn_config(struct comedi_device *dev, ...@@ -1313,25 +1316,29 @@ int ni_tio_insn_config(struct comedi_device *dev,
data[1] |= COMEDI_COUNTER_COUNTING; data[1] |= COMEDI_COUNTER_COUNTING;
} }
data[2] = COMEDI_COUNTER_ARMED | COMEDI_COUNTER_COUNTING; data[2] = COMEDI_COUNTER_ARMED | COMEDI_COUNTER_COUNTING;
return 0; break;
case INSN_CONFIG_SET_CLOCK_SRC: case INSN_CONFIG_SET_CLOCK_SRC:
return ni_tio_set_clock_src(counter, data[1], data[2]); ret = ni_tio_set_clock_src(counter, data[1], data[2]);
break;
case INSN_CONFIG_GET_CLOCK_SRC: case INSN_CONFIG_GET_CLOCK_SRC:
ni_tio_get_clock_src(counter, &data[1], &data[2]); ni_tio_get_clock_src(counter, &data[1], &data[2]);
return 0; break;
case INSN_CONFIG_SET_GATE_SRC: case INSN_CONFIG_SET_GATE_SRC:
return ni_tio_set_gate_src(counter, data[1], data[2]); ret = ni_tio_set_gate_src(counter, data[1], data[2]);
break;
case INSN_CONFIG_GET_GATE_SRC: case INSN_CONFIG_GET_GATE_SRC:
return ni_tio_get_gate_src(counter, data[1], &data[2]); ret = ni_tio_get_gate_src(counter, data[1], &data[2]);
break;
case INSN_CONFIG_SET_OTHER_SRC: case INSN_CONFIG_SET_OTHER_SRC:
return ni_tio_set_other_src(counter, data[1], data[2]); ret = ni_tio_set_other_src(counter, data[1], data[2]);
break;
case INSN_CONFIG_RESET: case INSN_CONFIG_RESET:
ni_tio_reset_count_and_disarm(counter); ni_tio_reset_count_and_disarm(counter);
return 0;
default:
break; break;
default:
return -EINVAL;
} }
return -EINVAL; return ret ? ret : insn->n;
} }
EXPORT_SYMBOL_GPL(ni_tio_insn_config); EXPORT_SYMBOL_GPL(ni_tio_insn_config);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment