Skip to content

Commit 90eb421

Browse files
committed
Merge branch 'pci/controller/rockchip'
- Drop unused PCIe Message routing and code definitions (Hans Zhang) - Use standard PCIe config register definitions instead of rockchip-specific redefinitions (Geraldo Nascimento) - Set Target Link Speed to 5.0 GT/s before retraining so we have a chance to train at a higher speed (Geraldo Nascimento) * pci/controller/rockchip: PCI: rockchip: Set Target Link Speed to 5.0 GT/s before retraining PCI: rockchip: Use standard PCIe definitions PCI: rockchip: Remove redundant PCIe message routing definitions
2 parents 81b3be6 + 114b06e commit 90eb421

File tree

3 files changed

+30
-49
lines changed

3 files changed

+30
-49
lines changed

drivers/pci/controller/pcie-rockchip-ep.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -518,9 +518,9 @@ static void rockchip_pcie_ep_retrain_link(struct rockchip_pcie *rockchip)
518518
{
519519
u32 status;
520520

521-
status = rockchip_pcie_read(rockchip, PCIE_EP_CONFIG_LCS);
521+
status = rockchip_pcie_read(rockchip, PCIE_EP_CONFIG_BASE + PCI_EXP_LNKCTL);
522522
status |= PCI_EXP_LNKCTL_RL;
523-
rockchip_pcie_write(rockchip, status, PCIE_EP_CONFIG_LCS);
523+
rockchip_pcie_write(rockchip, status, PCIE_EP_CONFIG_BASE + PCI_EXP_LNKCTL);
524524
}
525525

526526
static bool rockchip_pcie_ep_link_up(struct rockchip_pcie *rockchip)

drivers/pci/controller/pcie-rockchip-host.c

Lines changed: 27 additions & 22 deletions
Original file line numberDiff line numberDiff line change
@@ -11,6 +11,7 @@
1111
* ARM PCI Host generic driver.
1212
*/
1313

14+
#include <linux/bitfield.h>
1415
#include <linux/bitrev.h>
1516
#include <linux/clk.h>
1617
#include <linux/delay.h>
@@ -40,18 +41,18 @@ static void rockchip_pcie_enable_bw_int(struct rockchip_pcie *rockchip)
4041
{
4142
u32 status;
4243

43-
status = rockchip_pcie_read(rockchip, PCIE_RC_CONFIG_LCS);
44+
status = rockchip_pcie_read(rockchip, PCIE_RC_CONFIG_CR + PCI_EXP_LNKCTL);
4445
status |= (PCI_EXP_LNKCTL_LBMIE | PCI_EXP_LNKCTL_LABIE);
45-
rockchip_pcie_write(rockchip, status, PCIE_RC_CONFIG_LCS);
46+
rockchip_pcie_write(rockchip, status, PCIE_RC_CONFIG_CR + PCI_EXP_LNKCTL);
4647
}
4748

4849
static void rockchip_pcie_clr_bw_int(struct rockchip_pcie *rockchip)
4950
{
5051
u32 status;
5152

52-
status = rockchip_pcie_read(rockchip, PCIE_RC_CONFIG_LCS);
53+
status = rockchip_pcie_read(rockchip, PCIE_RC_CONFIG_CR + PCI_EXP_LNKCTL);
5354
status |= (PCI_EXP_LNKSTA_LBMS | PCI_EXP_LNKSTA_LABS) << 16;
54-
rockchip_pcie_write(rockchip, status, PCIE_RC_CONFIG_LCS);
55+
rockchip_pcie_write(rockchip, status, PCIE_RC_CONFIG_CR + PCI_EXP_LNKCTL);
5556
}
5657

5758
static void rockchip_pcie_update_txcredit_mui(struct rockchip_pcie *rockchip)
@@ -269,7 +270,7 @@ static void rockchip_pcie_set_power_limit(struct rockchip_pcie *rockchip)
269270
scale = 3; /* 0.001x */
270271
curr = curr / 1000; /* convert to mA */
271272
power = (curr * 3300) / 1000; /* milliwatt */
272-
while (power > PCIE_RC_CONFIG_DCR_CSPL_LIMIT) {
273+
while (power > FIELD_MAX(PCI_EXP_DEVCAP_PWR_VAL)) {
273274
if (!scale) {
274275
dev_warn(rockchip->dev, "invalid power supply\n");
275276
return;
@@ -278,10 +279,10 @@ static void rockchip_pcie_set_power_limit(struct rockchip_pcie *rockchip)
278279
power = power / 10;
279280
}
280281

281-
status = rockchip_pcie_read(rockchip, PCIE_RC_CONFIG_DCR);
282-
status |= (power << PCIE_RC_CONFIG_DCR_CSPL_SHIFT) |
283-
(scale << PCIE_RC_CONFIG_DCR_CPLS_SHIFT);
284-
rockchip_pcie_write(rockchip, status, PCIE_RC_CONFIG_DCR);
282+
status = rockchip_pcie_read(rockchip, PCIE_RC_CONFIG_CR + PCI_EXP_DEVCAP);
283+
status |= FIELD_PREP(PCI_EXP_DEVCAP_PWR_VAL, power);
284+
status |= FIELD_PREP(PCI_EXP_DEVCAP_PWR_SCL, scale);
285+
rockchip_pcie_write(rockchip, status, PCIE_RC_CONFIG_CR + PCI_EXP_DEVCAP);
285286
}
286287

287288
/**
@@ -309,14 +310,14 @@ static int rockchip_pcie_host_init_port(struct rockchip_pcie *rockchip)
309310
rockchip_pcie_set_power_limit(rockchip);
310311

311312
/* Set RC's clock architecture as common clock */
312-
status = rockchip_pcie_read(rockchip, PCIE_RC_CONFIG_LCS);
313+
status = rockchip_pcie_read(rockchip, PCIE_RC_CONFIG_CR + PCI_EXP_LNKCTL);
313314
status |= PCI_EXP_LNKSTA_SLC << 16;
314-
rockchip_pcie_write(rockchip, status, PCIE_RC_CONFIG_LCS);
315+
rockchip_pcie_write(rockchip, status, PCIE_RC_CONFIG_CR + PCI_EXP_LNKCTL);
315316

316317
/* Set RC's RCB to 128 */
317-
status = rockchip_pcie_read(rockchip, PCIE_RC_CONFIG_LCS);
318+
status = rockchip_pcie_read(rockchip, PCIE_RC_CONFIG_CR + PCI_EXP_LNKCTL);
318319
status |= PCI_EXP_LNKCTL_RCB;
319-
rockchip_pcie_write(rockchip, status, PCIE_RC_CONFIG_LCS);
320+
rockchip_pcie_write(rockchip, status, PCIE_RC_CONFIG_CR + PCI_EXP_LNKCTL);
320321

321322
/* Enable Gen1 training */
322323
rockchip_pcie_write(rockchip, PCIE_CLIENT_LINK_TRAIN_ENABLE,
@@ -341,9 +342,13 @@ static int rockchip_pcie_host_init_port(struct rockchip_pcie *rockchip)
341342
* Enable retrain for gen2. This should be configured only after
342343
* gen1 finished.
343344
*/
344-
status = rockchip_pcie_read(rockchip, PCIE_RC_CONFIG_LCS);
345+
status = rockchip_pcie_read(rockchip, PCIE_RC_CONFIG_CR + PCI_EXP_LNKCTL2);
346+
status &= ~PCI_EXP_LNKCTL2_TLS;
347+
status |= PCI_EXP_LNKCTL2_TLS_5_0GT;
348+
rockchip_pcie_write(rockchip, status, PCIE_RC_CONFIG_CR + PCI_EXP_LNKCTL2);
349+
status = rockchip_pcie_read(rockchip, PCIE_RC_CONFIG_CR + PCI_EXP_LNKCTL);
345350
status |= PCI_EXP_LNKCTL_RL;
346-
rockchip_pcie_write(rockchip, status, PCIE_RC_CONFIG_LCS);
351+
rockchip_pcie_write(rockchip, status, PCIE_RC_CONFIG_CR + PCI_EXP_LNKCTL);
347352

348353
err = readl_poll_timeout(rockchip->apb_base + PCIE_CORE_CTRL,
349354
status, PCIE_LINK_IS_GEN2(status), 20,
@@ -380,15 +385,15 @@ static int rockchip_pcie_host_init_port(struct rockchip_pcie *rockchip)
380385

381386
/* Clear L0s from RC's link cap */
382387
if (of_property_read_bool(dev->of_node, "aspm-no-l0s")) {
383-
status = rockchip_pcie_read(rockchip, PCIE_RC_CONFIG_LINK_CAP);
384-
status &= ~PCIE_RC_CONFIG_LINK_CAP_L0S;
385-
rockchip_pcie_write(rockchip, status, PCIE_RC_CONFIG_LINK_CAP);
388+
status = rockchip_pcie_read(rockchip, PCIE_RC_CONFIG_CR + PCI_EXP_LNKCAP);
389+
status &= ~PCI_EXP_LNKCAP_ASPM_L0S;
390+
rockchip_pcie_write(rockchip, status, PCIE_RC_CONFIG_CR + PCI_EXP_LNKCAP);
386391
}
387392

388-
status = rockchip_pcie_read(rockchip, PCIE_RC_CONFIG_DCSR);
389-
status &= ~PCIE_RC_CONFIG_DCSR_MPS_MASK;
390-
status |= PCIE_RC_CONFIG_DCSR_MPS_256;
391-
rockchip_pcie_write(rockchip, status, PCIE_RC_CONFIG_DCSR);
393+
status = rockchip_pcie_read(rockchip, PCIE_RC_CONFIG_CR + PCI_EXP_DEVCTL);
394+
status &= ~PCI_EXP_DEVCTL_PAYLOAD;
395+
status |= PCI_EXP_DEVCTL_PAYLOAD_256B;
396+
rockchip_pcie_write(rockchip, status, PCIE_RC_CONFIG_CR + PCI_EXP_DEVCTL);
392397

393398
return 0;
394399
err_power_off_phy:

drivers/pci/controller/pcie-rockchip.h

Lines changed: 1 addition & 25 deletions
Original file line numberDiff line numberDiff line change
@@ -155,17 +155,7 @@
155155
#define PCIE_EP_CONFIG_DID_VID (PCIE_EP_CONFIG_BASE + 0x00)
156156
#define PCIE_EP_CONFIG_LCS (PCIE_EP_CONFIG_BASE + 0xd0)
157157
#define PCIE_RC_CONFIG_RID_CCR (PCIE_RC_CONFIG_BASE + 0x08)
158-
#define PCIE_RC_CONFIG_DCR (PCIE_RC_CONFIG_BASE + 0xc4)
159-
#define PCIE_RC_CONFIG_DCR_CSPL_SHIFT 18
160-
#define PCIE_RC_CONFIG_DCR_CSPL_LIMIT 0xff
161-
#define PCIE_RC_CONFIG_DCR_CPLS_SHIFT 26
162-
#define PCIE_RC_CONFIG_DCSR (PCIE_RC_CONFIG_BASE + 0xc8)
163-
#define PCIE_RC_CONFIG_DCSR_MPS_MASK GENMASK(7, 5)
164-
#define PCIE_RC_CONFIG_DCSR_MPS_256 (0x1 << 5)
165-
#define PCIE_RC_CONFIG_LINK_CAP (PCIE_RC_CONFIG_BASE + 0xcc)
166-
#define PCIE_RC_CONFIG_LINK_CAP_L0S BIT(10)
167-
#define PCIE_RC_CONFIG_LCS (PCIE_RC_CONFIG_BASE + 0xd0)
168-
#define PCIE_EP_CONFIG_LCS (PCIE_EP_CONFIG_BASE + 0xd0)
158+
#define PCIE_RC_CONFIG_CR (PCIE_RC_CONFIG_BASE + 0xc0)
169159
#define PCIE_RC_CONFIG_L1_SUBSTATE_CTRL2 (PCIE_RC_CONFIG_BASE + 0x90c)
170160
#define PCIE_RC_CONFIG_THP_CAP (PCIE_RC_CONFIG_BASE + 0x274)
171161
#define PCIE_RC_CONFIG_THP_CAP_NEXT_MASK GENMASK(31, 20)
@@ -215,20 +205,6 @@
215205
#define RC_REGION_0_TYPE_MASK GENMASK(3, 0)
216206
#define MAX_AXI_WRAPPER_REGION_NUM 33
217207

218-
#define ROCKCHIP_PCIE_MSG_ROUTING_TO_RC 0x0
219-
#define ROCKCHIP_PCIE_MSG_ROUTING_VIA_ADDR 0x1
220-
#define ROCKCHIP_PCIE_MSG_ROUTING_VIA_ID 0x2
221-
#define ROCKCHIP_PCIE_MSG_ROUTING_BROADCAST 0x3
222-
#define ROCKCHIP_PCIE_MSG_ROUTING_LOCAL_INTX 0x4
223-
#define ROCKCHIP_PCIE_MSG_ROUTING_PME_ACK 0x5
224-
#define ROCKCHIP_PCIE_MSG_CODE_ASSERT_INTA 0x20
225-
#define ROCKCHIP_PCIE_MSG_CODE_ASSERT_INTB 0x21
226-
#define ROCKCHIP_PCIE_MSG_CODE_ASSERT_INTC 0x22
227-
#define ROCKCHIP_PCIE_MSG_CODE_ASSERT_INTD 0x23
228-
#define ROCKCHIP_PCIE_MSG_CODE_DEASSERT_INTA 0x24
229-
#define ROCKCHIP_PCIE_MSG_CODE_DEASSERT_INTB 0x25
230-
#define ROCKCHIP_PCIE_MSG_CODE_DEASSERT_INTC 0x26
231-
#define ROCKCHIP_PCIE_MSG_CODE_DEASSERT_INTD 0x27
232208
#define ROCKCHIP_PCIE_MSG_ROUTING_MASK GENMASK(7, 5)
233209
#define ROCKCHIP_PCIE_MSG_ROUTING(route) \
234210
(((route) << 5) & ROCKCHIP_PCIE_MSG_ROUTING_MASK)

0 commit comments

Comments
 (0)