CNS3xxx: Fix PCIe read size limit.
authorKrzysztof Hałasa <khalasa@piap.pl>
Tue, 16 Sep 2014 10:37:16 +0000 (12:37 +0200)
committerArnd Bergmann <arnd@arndb.de>
Thu, 25 Sep 2014 21:35:01 +0000 (23:35 +0200)
Max_Read_Request_Size is 3 bits wide, not 2 bits.
Also fix the message.

Signed-off-by: Krzysztof Hałasa <khalasa@piap.pl>
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
arch/arm/mach-cns3xxx/pcie.c

index fbfe852..45d6bd0 100644 (file)
@@ -299,12 +299,15 @@ static void __init cns3xxx_pcie_hw_init(struct cns3xxx_pcie *cnspci)
        devfn = PCI_DEVFN(0, 0);
        pos = pci_bus_find_capability(&bus, devfn, PCI_CAP_ID_EXP);
        pci_bus_read_config_word(&bus, devfn, pos + PCI_EXP_DEVCTL, &dc);
-       dc &= ~(0x3 << 12);     /* Clear Device Control Register [14:12] */
-       pci_bus_write_config_word(&bus, devfn, pos + PCI_EXP_DEVCTL, dc);
-       pci_bus_read_config_word(&bus, devfn, pos + PCI_EXP_DEVCTL, &dc);
-       if (!(dc & (0x3 << 12)))
-               pr_info("PCIe: Set Device Max_Read_Request_Size to 128 byte\n");
-
+       if (dc & PCI_EXP_DEVCTL_READRQ) {
+               dc &= ~PCI_EXP_DEVCTL_READRQ;
+               pci_bus_write_config_word(&bus, devfn, pos + PCI_EXP_DEVCTL, dc);
+               pci_bus_read_config_word(&bus, devfn, pos + PCI_EXP_DEVCTL, &dc);
+               if (dc & PCI_EXP_DEVCTL_READRQ)
+                       pr_warn("PCIe: Unable to set device Max_Read_Request_Size\n");
+               else
+                       pr_info("PCIe: Max_Read_Request_Size set to 128 bytes\n");
+       }
        /* Disable PCIe0 Interrupt Mask INTA to INTD */
        __raw_writel(~0x3FFF, MISC_PCIE_INT_MASK(port));
 }