]> git.baikalelectronics.ru Git - kernel.git/commitdiff
serial: exar: Fix GPIO configuration for Sealevel cards based on XR17V35X
authorMatthew Howell <matthew.howell@sealevel.com>
Wed, 22 Jul 2020 20:11:24 +0000 (16:11 -0400)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 24 Jul 2020 08:58:14 +0000 (10:58 +0200)
Sealevel XR17V35X based devices are inoperable on kernel versions
4.11 and above due to a change in the GPIO preconfiguration introduced in
commit
ff3ca0ae31b. This patch fixes this by preconfiguring the GPIO on Sealevel
cards to the value (0x00) used prior to commit ff3ca0ae31b

With GPIOs preconfigured as per commit ff3ca0ae31b all ports on
Sealevel XR17V35X based devices become stuck in high impedance
mode, regardless of dip-switch or software configuration. This
causes the device to become effectively unusable. This patch (in
various forms) has been distributed to our customers and no issues
related to it have been reported.

Fixes: ff3ca0ae31b8 ("serial: exar: Preconfigure xr17v35x MPIOs as output")
Signed-off-by: Matthew Howell <matthew.howell@sealevel.com>
Link: https://lore.kernel.org/r/alpine.DEB.2.21.2007221605270.13247@tstest-VirtualBox
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/tty/serial/8250/8250_exar.c

index ddb6aeb76dc53a8c41ca5d9f7833ce2eefea400f..04b9af7ed94153dac7e045bce7d8e11132f3e057 100644 (file)
@@ -326,7 +326,17 @@ static void setup_gpio(struct pci_dev *pcidev, u8 __iomem *p)
         * devices will export them as GPIOs, so we pre-configure them safely
         * as inputs.
         */
-       u8 dir = pcidev->vendor == PCI_VENDOR_ID_EXAR ? 0xff : 0x00;
+
+       u8 dir = 0x00;
+
+       if  ((pcidev->vendor == PCI_VENDOR_ID_EXAR) &&
+               (pcidev->subsystem_vendor != PCI_VENDOR_ID_SEALEVEL)) {
+               // Configure GPIO as inputs for Commtech adapters
+               dir = 0xff;
+       } else {
+               // Configure GPIO as outputs for SeaLevel adapters
+               dir = 0x00;
+       }
 
        writeb(0x00, p + UART_EXAR_MPIOINT_7_0);
        writeb(0x00, p + UART_EXAR_MPIOLVL_7_0);