MIPS: Malta: Enable magic multipliers for Super I/O UARTs
authorMaciej W. Rozycki <macro@orcam.me.uk>
Thu, 10 Jun 2021 18:38:48 +0000 (20:38 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 16 Jun 2021 07:20:29 +0000 (09:20 +0200)
The SMSC FDC37M817 Super I/O chip has a configuration feature that lets
it support special UART divisor values of 32770 and 32769 for bit rates
of 230400 and 460800 bits per second respectively.  Our 8250 driver core
provides support for these special divisors via the UPF_MAGIC_MULTIPLIER
flag, and YAMON firmware unconditionally configures the Super I/O chip
with these divisors enabled as well, so all we need to do in platform
setup for these bit rates to work is to set the flag.

Signed-off-by: Maciej W. Rozycki <macro@orcam.me.uk>
Link: https://lore.kernel.org/r/alpine.DEB.2.21.2105182249380.3032@angie.orcam.me.uk
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
arch/mips/mti-malta/malta-platform.c

index 11e9527c6e441034be9865523678e61d48cbf127..ee7471984fe76bb5e09dab34683ac3ba73a76e72 100644 (file)
@@ -33,7 +33,8 @@
        .irq            = int,                                          \
        .uartclk        = 1843200,                                      \
        .iotype         = UPIO_PORT,                                    \
-       .flags          = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST,            \
+       .flags          = UPF_BOOT_AUTOCONF | UPF_SKIP_TEST |           \
+                         UPF_MAGIC_MULTIPLIER,                         \
        .regshift       = 0,                                            \
 }