Commit adb2653b authored by Manikanta Maddireddy's avatar Manikanta Maddireddy Committed by Lorenzo Pieralisi

PCI: tegra: Add AFI_PEX2_CTRL reg offset as part of SoC struct

Tegra186 and Tegra30 have three PCIe root ports. AFI_PEX2_CTRL register
is defined for third root port. Offset of this register in Tegra186 is
different from Tegra30, so add the offset as part of SoC data structure.
Signed-off-by: default avatarManikanta Maddireddy <mmaddireddy@nvidia.com>
Signed-off-by: default avatarLorenzo Pieralisi <lorenzo.pieralisi@arm.com>
Acked-by: default avatarThierry Reding <treding@nvidia.com>
parent c894121d
...@@ -168,7 +168,6 @@ ...@@ -168,7 +168,6 @@
#define AFI_PEX0_CTRL 0x110 #define AFI_PEX0_CTRL 0x110
#define AFI_PEX1_CTRL 0x118 #define AFI_PEX1_CTRL 0x118
#define AFI_PEX2_CTRL 0x128
#define AFI_PEX_CTRL_RST (1 << 0) #define AFI_PEX_CTRL_RST (1 << 0)
#define AFI_PEX_CTRL_CLKREQ_EN (1 << 1) #define AFI_PEX_CTRL_CLKREQ_EN (1 << 1)
#define AFI_PEX_CTRL_REFCLK_EN (1 << 3) #define AFI_PEX_CTRL_REFCLK_EN (1 << 3)
...@@ -307,6 +306,7 @@ struct tegra_pcie_soc { ...@@ -307,6 +306,7 @@ struct tegra_pcie_soc {
unsigned int num_ports; unsigned int num_ports;
const struct tegra_pcie_port_soc *ports; const struct tegra_pcie_port_soc *ports;
unsigned int msi_base_shift; unsigned int msi_base_shift;
unsigned long afi_pex2_ctrl;
u32 pads_pll_ctl; u32 pads_pll_ctl;
u32 tx_ref_sel; u32 tx_ref_sel;
u32 pads_refclk_cfg0; u32 pads_refclk_cfg0;
...@@ -517,6 +517,7 @@ static struct pci_ops tegra_pcie_ops = { ...@@ -517,6 +517,7 @@ static struct pci_ops tegra_pcie_ops = {
static unsigned long tegra_pcie_port_get_pex_ctrl(struct tegra_pcie_port *port) static unsigned long tegra_pcie_port_get_pex_ctrl(struct tegra_pcie_port *port)
{ {
const struct tegra_pcie_soc *soc = port->pcie->soc;
unsigned long ret = 0; unsigned long ret = 0;
switch (port->index) { switch (port->index) {
...@@ -529,7 +530,7 @@ static unsigned long tegra_pcie_port_get_pex_ctrl(struct tegra_pcie_port *port) ...@@ -529,7 +530,7 @@ static unsigned long tegra_pcie_port_get_pex_ctrl(struct tegra_pcie_port *port)
break; break;
case 2: case 2:
ret = AFI_PEX2_CTRL; ret = soc->afi_pex2_ctrl;
break; break;
} }
...@@ -2449,6 +2450,7 @@ static const struct tegra_pcie_soc tegra20_pcie = { ...@@ -2449,6 +2450,7 @@ static const struct tegra_pcie_soc tegra20_pcie = {
.num_ports = 2, .num_ports = 2,
.ports = tegra20_pcie_ports, .ports = tegra20_pcie_ports,
.msi_base_shift = 0, .msi_base_shift = 0,
.afi_pex2_ctrl = 0x128,
.pads_pll_ctl = PADS_PLL_CTL_TEGRA20, .pads_pll_ctl = PADS_PLL_CTL_TEGRA20,
.tx_ref_sel = PADS_PLL_CTL_TXCLKREF_DIV10, .tx_ref_sel = PADS_PLL_CTL_TXCLKREF_DIV10,
.pads_refclk_cfg0 = 0xfa5cfa5c, .pads_refclk_cfg0 = 0xfa5cfa5c,
...@@ -2566,6 +2568,7 @@ static const struct tegra_pcie_soc tegra186_pcie = { ...@@ -2566,6 +2568,7 @@ static const struct tegra_pcie_soc tegra186_pcie = {
.num_ports = 3, .num_ports = 3,
.ports = tegra186_pcie_ports, .ports = tegra186_pcie_ports,
.msi_base_shift = 8, .msi_base_shift = 8,
.afi_pex2_ctrl = 0x19c,
.pads_pll_ctl = PADS_PLL_CTL_TEGRA30, .pads_pll_ctl = PADS_PLL_CTL_TEGRA30,
.tx_ref_sel = PADS_PLL_CTL_TXCLKREF_BUF_EN, .tx_ref_sel = PADS_PLL_CTL_TXCLKREF_BUF_EN,
.pads_refclk_cfg0 = 0x80b880b8, .pads_refclk_cfg0 = 0x80b880b8,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment