staging: comedi: ni_mio_common: create device-global access to tio

Adds tio sub-devices of ni_mio_common supported hardware to the
implementation of test_route, connect_route, disconnect_route.  This change
delegates the actual functionality to the ni_tio module.

Signed-off-by: Spencer E. Olson <olsonse@umich.edu>
Reviewed-by: Ian Abbott <abbotti@mev.co.uk>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
Spencer E. Olson 2018-10-03 14:56:09 -06:00 committed by Greg Kroah-Hartman
parent 347e244884
commit 713ebc5939
1 changed files with 11 additions and 0 deletions

View File

@ -5644,6 +5644,8 @@ static int get_output_select_source(int dest, struct comedi_device *dev)
/* there are only two g_out outputs. */ /* there are only two g_out outputs. */
return -EINVAL; return -EINVAL;
reg = ni_get_gout_routing(dest, dev); reg = ni_get_gout_routing(dest, dev);
} else if (channel_is_ctr(dest)) {
reg = ni_tio_get_routing(devpriv->counter_dev, dest);
} else { } else {
dev_dbg(dev->class_dev, "%s: unhandled destination (%d) queried\n", dev_dbg(dev->class_dev, "%s: unhandled destination (%d) queried\n",
__func__, dest); __func__, dest);
@ -5732,6 +5734,13 @@ static int connect_route(unsigned int src, unsigned int dest,
return -EINVAL; return -EINVAL;
if (ni_set_gout_routing(src, dest, dev)) if (ni_set_gout_routing(src, dest, dev))
return -EINVAL; return -EINVAL;
} else if (channel_is_ctr(dest)) {
/*
* we are adding back the channel modifier info to set
* invert/edge info passed by the user
*/
ni_tio_set_routing(devpriv->counter_dev, dest,
reg | (src & ~CR_CHAN(-1)));
} else { } else {
return -EINVAL; return -EINVAL;
} }
@ -5790,6 +5799,8 @@ static int disconnect_route(unsigned int src, unsigned int dest,
/* there are only two g_out outputs. */ /* there are only two g_out outputs. */
return -EINVAL; return -EINVAL;
reg = ni_disable_gout_routing(dest, dev); reg = ni_disable_gout_routing(dest, dev);
} else if (channel_is_ctr(dest)) {
ni_tio_unset_routing(devpriv->counter_dev, dest);
} else { } else {
return -EINVAL; return -EINVAL;
} }