staging: comedi: adl_pci7x3x: fix digital output on PCI-7230
authorIan Abbott <abbotti@mev.co.uk>
Tue, 11 Aug 2015 12:05:10 +0000 (13:05 +0100)
committerSasha Levin <sasha.levin@oracle.com>
Wed, 28 Oct 2015 02:14:38 +0000 (22:14 -0400)
commit51935aeef6c9b82ee82d37c5dc5d9244a379b5d1
tree56a356f83f14f76444cd6d912ef9672c522834fa
parentb2ec1ef6b08b8c5b29b5ee88a7e2b84215bc457c
staging: comedi: adl_pci7x3x: fix digital output on PCI-7230

[ Upstream commit ad83dbd974feb2e2a8cc071a1d28782bd4d2c70e ]

The "adl_pci7x3x" driver replaced the "adl_pci7230" and "adl_pci7432"
drivers in commits 8f567c373c4b ("staging: comedi: new adl_pci7x3x
driver") and 657f77d173d3 ("staging: comedi: remove adl_pci7230 and
adl_pci7432 drivers").  Although the new driver code agrees with the
user manuals for the respective boards, digital outputs stopped working
on the PCI-7230.  This has 16 digital output channels and the previous
adl_pci7230 driver shifted the 16 bit output state left by 16 bits
before writing to the hardware register.  The new adl_pci7x3x driver
doesn't do that.  Fix it in `adl_pci7x3x_do_insn_bits()` by checking
for the special case of the subdevice having only 16 channels and
duplicating the 16 bit output state into both halves of the 32-bit
register.  That should work both for what the board actually does and
for what the user manual says it should do.

Fixes: 8f567c373c4b ("staging: comedi: new adl_pci7x3x driver")
Signed-off-by: Ian Abbott <abbotti@mev.co.uk>
Cc: <stable@vger.kernel.org> # 3.13+, needs backporting for 3.7 to 3.12
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Sasha Levin <sasha.levin@oracle.com>
drivers/staging/comedi/drivers/adl_pci7x3x.c