On 09/05/2014 01:54 PM, Arnd Bergmann wrote:
On Friday 05 September 2014 13:39:42 Murali Karicheri wrote:
+
/* enable RC mode in devcfg */
val = readl(reg_p);
- val&= ~PCIE_MODE_MASK;
- val |= PCIE_RC_MODE;
+ port_id<<= 1;
+ val&= ~(PCIE_MODE_MASK<< port_id);
+ val |= (PCIE_RC_MODE<< port_id);
writel(val, reg_p);
+ devm_iounmap(dev, reg_p);
+ devm_release_mem_region(dev, res->start, resource_size(res));
This looks like it's a shared register of some sort that doesn't
really belong into the registers of a particular port. Could it
be that it's actually for the PHY?
Arnd
Arnd,
This a shared device configuration register between the two ports the
desciption states it is bootstrap configuration of the PCIe module as
Endpoint or Root complex and Not Phy. Hope below text will help.
Table 3-23 Device Configuration Register (DEVCFG)
PCIESSMODE[1:0] 00b PCIESSMODE is used to control the
functionality of PCIESS module out of
reset. This MMR output is connected to
DEVTYPE input of PCIESS
(Changes from
Nysh) : Note that in Nysh this value came
from a bootstrap pin.
00 : Endpoint
01 : Legacy Endpoint
10 : Rootcomplex
11 : Reserved
PCIESS_1_MODE[1:0
]
00b PCIESSMODE is used to control the
functionality of PCIE_1 module out of
reset. This MMR output is connected to
DEVTYPE input of PCIE_1
00 : Endpoint
01 : Legacy Endpoint
10 : Rootcomplex
11 : Reserv
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/