tile PCI RC: tweak the the pcie_rc_delay support
Allow longer delays if requested, and print the info messages as we are performing the delay, not when parsing the arguments. Signed-off-by: Chris Metcalf <cmetcalf@tilera.com>
This commit is contained in:
parent
2be705523f
commit
b3ad73a33e
@ -69,17 +69,14 @@ static int pcie_rc[TILEGX_NUM_TRIO][TILEGX_TRIO_PCIES];
|
|||||||
* a HW PCIe link-training bug. The exact delay is specified with
|
* a HW PCIe link-training bug. The exact delay is specified with
|
||||||
* a kernel boot argument in the form of "pcie_rc_delay=T,P,S",
|
* a kernel boot argument in the form of "pcie_rc_delay=T,P,S",
|
||||||
* where T is the TRIO instance number, P is the port number and S is
|
* where T is the TRIO instance number, P is the port number and S is
|
||||||
* the delay in seconds. If the delay is not provided, the value
|
* the delay in seconds. If the argument is specified, but the delay is
|
||||||
* will be DEFAULT_RC_DELAY.
|
* not provided, the value will be DEFAULT_RC_DELAY.
|
||||||
*/
|
*/
|
||||||
static int rc_delay[TILEGX_NUM_TRIO][TILEGX_TRIO_PCIES];
|
static int rc_delay[TILEGX_NUM_TRIO][TILEGX_TRIO_PCIES];
|
||||||
|
|
||||||
/* Default number of seconds that the PCIe RC port probe can be delayed. */
|
/* Default number of seconds that the PCIe RC port probe can be delayed. */
|
||||||
#define DEFAULT_RC_DELAY 10
|
#define DEFAULT_RC_DELAY 10
|
||||||
|
|
||||||
/* Max number of seconds that the PCIe RC port probe can be delayed. */
|
|
||||||
#define MAX_RC_DELAY 20
|
|
||||||
|
|
||||||
/* Array of the PCIe ports configuration info obtained from the BIB. */
|
/* Array of the PCIe ports configuration info obtained from the BIB. */
|
||||||
struct pcie_port_property pcie_ports[TILEGX_NUM_TRIO][TILEGX_TRIO_PCIES];
|
struct pcie_port_property pcie_ports[TILEGX_NUM_TRIO][TILEGX_TRIO_PCIES];
|
||||||
|
|
||||||
@ -570,14 +567,9 @@ static int setup_pcie_rc_delay(char *str)
|
|||||||
if (!isdigit(*str))
|
if (!isdigit(*str))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
delay = simple_strtoul(str, (char **)&str, 10);
|
delay = simple_strtoul(str, (char **)&str, 10);
|
||||||
if (delay > MAX_RC_DELAY)
|
|
||||||
return -EINVAL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
rc_delay[trio_index][mac] = delay ? : DEFAULT_RC_DELAY;
|
rc_delay[trio_index][mac] = delay ? : DEFAULT_RC_DELAY;
|
||||||
pr_info("Delaying PCIe RC link training for %u sec"
|
|
||||||
" on MAC %lu on TRIO %lu\n", rc_delay[trio_index][mac],
|
|
||||||
mac, trio_index);
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
early_param("pcie_rc_delay", setup_pcie_rc_delay);
|
early_param("pcie_rc_delay", setup_pcie_rc_delay);
|
||||||
@ -682,12 +674,6 @@ int __init pcibios_init(void)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Delay the RC link training if needed.
|
|
||||||
*/
|
|
||||||
if (rc_delay[trio_index][mac])
|
|
||||||
msleep(rc_delay[trio_index][mac] * 1000);
|
|
||||||
|
|
||||||
ret = gxio_trio_force_rc_link_up(trio_context, mac);
|
ret = gxio_trio_force_rc_link_up(trio_context, mac);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
pr_err("PCI: PCIE_FORCE_LINK_UP failure, "
|
pr_err("PCI: PCIE_FORCE_LINK_UP failure, "
|
||||||
@ -697,10 +683,21 @@ int __init pcibios_init(void)
|
|||||||
trio_index, controller->mac);
|
trio_index, controller->mac);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Wait a bit here because some EP devices take longer
|
* Delay the bus probe if needed.
|
||||||
* to come up.
|
*/
|
||||||
|
if (rc_delay[trio_index][mac]) {
|
||||||
|
pr_info("Delaying PCIe RC bus enumerating %d sec"
|
||||||
|
" on MAC %d on TRIO %d\n",
|
||||||
|
rc_delay[trio_index][mac], mac,
|
||||||
|
trio_index);
|
||||||
|
msleep(rc_delay[trio_index][mac] * 1000);
|
||||||
|
} else {
|
||||||
|
/*
|
||||||
|
* Wait a bit here because some EP devices
|
||||||
|
* take longer to come up.
|
||||||
*/
|
*/
|
||||||
msleep(1000);
|
msleep(1000);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Check for PCIe link-up status.
|
* Check for PCIe link-up status.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user