ARM: SoC fixes
Two more fixes for 4.5: - One is a fix for OMAP that is urgently needed to avoid DRA7xx chips from premature aging, by always keeping the Ethernet clock enabled. - The other solves a I/O memory layout issue on Armada, where SROM and PCI memory windows were conflicting in some configurations. -----BEGIN PGP SIGNATURE----- Version: GnuPG v1 iQIcBAABAgAGBQJW4yITAAoJEIwa5zzehBx38BsQAJRjZOeAec3/F+T8+3pnV0Jl URcyIFBgXQm6AVW9bwrn7bg9GOcWm0hNk4lgQ/E6KgaZpRVJQ+bhqb79Rz45LhCG 7YmxEXtM8zhVY80/AJsEF0vzogfZsPPI3SiGF9OeIwiMEO91hpRMyvFbOqJC2H40 YX17ARv2BTozLJ2PaW9BKoFAJX2uJJqIB6QOi307m3TVFRPQ5qPpVvh43L1+7flF ntugOzbEhIg1ZENeb0sNMtrhWlsNlQvulJl2xcp3sbXqkj3sPNIHzyvrPXhxOYQI VFJKHDC1Op6c2PFK8H0iOQMKq+WWuOidjCGwyg5/PNAoQ4cP+AoD0EpEuXXNjh7e 8DlVhCiYNSJl7M88jahHj1pq3X+CxwQraGANHIa0nijKYp4pqOqv+CZA0sgAX5cq Ro6U5v5XZxgSR6QGwNBtjCxmXC4z9YaYIP/nkCW2zbPQkaeocKYNykOifp1fOI59 VWufA0OTqk1XjVGcYorpgDaLFUAhgc14JEz1VLQGlw1/M+nVVcfr598FtTWrEoNI C1L2H7ahqKpVRSYCCtUlXg4TipyurjBk3A91mVBVcrSj/A4ztGkqjwMx995KzP+w HXI7PSulXK/HDupXslUcUCmVwkI5nxhcH7kuk978zwFFyQvDwB+A1mPysR+Naenz sI0wqCBHKZj70kyFCflm =/uWT -----END PGP SIGNATURE----- Merge tag 'armsoc-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc Pull ARM SoC fixes from Olof Johansson: "Two more fixes for 4.5: - One is a fix for OMAP that is urgently needed to avoid DRA7xx chips from premature aging, by always keeping the Ethernet clock enabled. - The other solves a I/O memory layout issue on Armada, where SROM and PCI memory windows were conflicting in some configurations" * tag 'armsoc-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/arm/arm-soc: ARM: mvebu: fix overlap of Crypto SRAM with PCIe memory window ARM: dts: dra7: do not gate cpsw clock due to errata i877 ARM: OMAP2+: hwmod: Introduce ti,no-idle dt property
This commit is contained in:
commit
2a4fb270da
@ -23,6 +23,7 @@ Optional properties:
|
|||||||
during suspend.
|
during suspend.
|
||||||
- ti,no-reset-on-init: When present, the module should not be reset at init
|
- ti,no-reset-on-init: When present, the module should not be reset at init
|
||||||
- ti,no-idle-on-init: When present, the module should not be idled at init
|
- ti,no-idle-on-init: When present, the module should not be idled at init
|
||||||
|
- ti,no-idle: When present, the module is never allowed to idle.
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
|
|
||||||
|
@ -70,8 +70,8 @@
|
|||||||
soc {
|
soc {
|
||||||
ranges = <MBUS_ID(0xf0, 0x01) 0 0 0xf1000000 0x100000
|
ranges = <MBUS_ID(0xf0, 0x01) 0 0 0xf1000000 0x100000
|
||||||
MBUS_ID(0x01, 0x1d) 0 0 0xfff00000 0x100000
|
MBUS_ID(0x01, 0x1d) 0 0 0xfff00000 0x100000
|
||||||
MBUS_ID(0x09, 0x09) 0 0 0xf8100000 0x10000
|
MBUS_ID(0x09, 0x09) 0 0 0xf1100000 0x10000
|
||||||
MBUS_ID(0x09, 0x05) 0 0 0xf8110000 0x10000>;
|
MBUS_ID(0x09, 0x05) 0 0 0xf1110000 0x10000>;
|
||||||
|
|
||||||
pcie-controller {
|
pcie-controller {
|
||||||
status = "okay";
|
status = "okay";
|
||||||
|
@ -76,8 +76,8 @@
|
|||||||
ranges = <MBUS_ID(0xf0, 0x01) 0 0 0xf1000000 0x100000
|
ranges = <MBUS_ID(0xf0, 0x01) 0 0 0xf1000000 0x100000
|
||||||
MBUS_ID(0x01, 0x1d) 0 0 0xfff00000 0x100000
|
MBUS_ID(0x01, 0x1d) 0 0 0xfff00000 0x100000
|
||||||
MBUS_ID(0x01, 0x2f) 0 0 0xf0000000 0x1000000
|
MBUS_ID(0x01, 0x2f) 0 0 0xf0000000 0x1000000
|
||||||
MBUS_ID(0x09, 0x09) 0 0 0xf8100000 0x10000
|
MBUS_ID(0x09, 0x09) 0 0 0xf1100000 0x10000
|
||||||
MBUS_ID(0x09, 0x05) 0 0 0xf8110000 0x10000>;
|
MBUS_ID(0x09, 0x05) 0 0 0xf1110000 0x10000>;
|
||||||
|
|
||||||
devbus-bootcs {
|
devbus-bootcs {
|
||||||
status = "okay";
|
status = "okay";
|
||||||
|
@ -95,8 +95,8 @@
|
|||||||
ranges = <MBUS_ID(0xf0, 0x01) 0 0 0xf1000000 0x100000
|
ranges = <MBUS_ID(0xf0, 0x01) 0 0 0xf1000000 0x100000
|
||||||
MBUS_ID(0x01, 0x1d) 0 0 0xfff00000 0x100000
|
MBUS_ID(0x01, 0x1d) 0 0 0xfff00000 0x100000
|
||||||
MBUS_ID(0x01, 0x2f) 0 0 0xf0000000 0x1000000
|
MBUS_ID(0x01, 0x2f) 0 0 0xf0000000 0x1000000
|
||||||
MBUS_ID(0x09, 0x09) 0 0 0xf8100000 0x10000
|
MBUS_ID(0x09, 0x09) 0 0 0xf1100000 0x10000
|
||||||
MBUS_ID(0x09, 0x05) 0 0 0xf8110000 0x10000>;
|
MBUS_ID(0x09, 0x05) 0 0 0xf1110000 0x10000>;
|
||||||
|
|
||||||
devbus-bootcs {
|
devbus-bootcs {
|
||||||
status = "okay";
|
status = "okay";
|
||||||
|
@ -65,8 +65,8 @@
|
|||||||
soc {
|
soc {
|
||||||
ranges = <MBUS_ID(0xf0, 0x01) 0 0 0xd0000000 0x100000
|
ranges = <MBUS_ID(0xf0, 0x01) 0 0 0xd0000000 0x100000
|
||||||
MBUS_ID(0x01, 0x1d) 0 0 0xfff00000 0x100000
|
MBUS_ID(0x01, 0x1d) 0 0 0xfff00000 0x100000
|
||||||
MBUS_ID(0x09, 0x09) 0 0 0xf8100000 0x10000
|
MBUS_ID(0x09, 0x09) 0 0 0xf1100000 0x10000
|
||||||
MBUS_ID(0x09, 0x05) 0 0 0xf8110000 0x10000>;
|
MBUS_ID(0x09, 0x05) 0 0 0xf1110000 0x10000>;
|
||||||
|
|
||||||
pcie-controller {
|
pcie-controller {
|
||||||
status = "okay";
|
status = "okay";
|
||||||
|
@ -70,8 +70,8 @@
|
|||||||
soc {
|
soc {
|
||||||
ranges = <MBUS_ID(0xf0, 0x01) 0 0 0xf1000000 0x100000
|
ranges = <MBUS_ID(0xf0, 0x01) 0 0 0xf1000000 0x100000
|
||||||
MBUS_ID(0x01, 0x1d) 0 0 0xfff00000 0x100000
|
MBUS_ID(0x01, 0x1d) 0 0 0xfff00000 0x100000
|
||||||
MBUS_ID(0x09, 0x09) 0 0 0xf8100000 0x10000
|
MBUS_ID(0x09, 0x09) 0 0 0xf1100000 0x10000
|
||||||
MBUS_ID(0x09, 0x05) 0 0 0xf8110000 0x10000>;
|
MBUS_ID(0x09, 0x05) 0 0 0xf1110000 0x10000>;
|
||||||
|
|
||||||
pcie-controller {
|
pcie-controller {
|
||||||
status = "okay";
|
status = "okay";
|
||||||
|
@ -68,8 +68,8 @@
|
|||||||
soc {
|
soc {
|
||||||
ranges = <MBUS_ID(0xf0, 0x01) 0 0 0xf1000000 0x100000
|
ranges = <MBUS_ID(0xf0, 0x01) 0 0 0xf1000000 0x100000
|
||||||
MBUS_ID(0x01, 0x1d) 0 0 0xfff00000 0x100000
|
MBUS_ID(0x01, 0x1d) 0 0 0xfff00000 0x100000
|
||||||
MBUS_ID(0x09, 0x09) 0 0 0xf8100000 0x10000
|
MBUS_ID(0x09, 0x09) 0 0 0xf1100000 0x10000
|
||||||
MBUS_ID(0x09, 0x05) 0 0 0xf8110000 0x10000>;
|
MBUS_ID(0x09, 0x05) 0 0 0xf1110000 0x10000>;
|
||||||
|
|
||||||
internal-regs {
|
internal-regs {
|
||||||
serial@12000 {
|
serial@12000 {
|
||||||
|
@ -64,8 +64,8 @@
|
|||||||
soc {
|
soc {
|
||||||
ranges = <MBUS_ID(0xf0, 0x01) 0 0 0xd0000000 0x100000
|
ranges = <MBUS_ID(0xf0, 0x01) 0 0 0xd0000000 0x100000
|
||||||
MBUS_ID(0x01, 0x1d) 0 0 0xfff00000 0x100000
|
MBUS_ID(0x01, 0x1d) 0 0 0xfff00000 0x100000
|
||||||
MBUS_ID(0x09, 0x09) 0 0 0xf8100000 0x10000
|
MBUS_ID(0x09, 0x09) 0 0 0xf1100000 0x10000
|
||||||
MBUS_ID(0x09, 0x05) 0 0 0xf8110000 0x10000>;
|
MBUS_ID(0x09, 0x05) 0 0 0xf1110000 0x10000>;
|
||||||
|
|
||||||
pcie-controller {
|
pcie-controller {
|
||||||
status = "okay";
|
status = "okay";
|
||||||
|
@ -65,9 +65,9 @@
|
|||||||
soc {
|
soc {
|
||||||
ranges = <MBUS_ID(0xf0, 0x01) 0 0 0xd0000000 0x100000
|
ranges = <MBUS_ID(0xf0, 0x01) 0 0 0xd0000000 0x100000
|
||||||
MBUS_ID(0x01, 0x1d) 0 0 0xfff00000 0x100000
|
MBUS_ID(0x01, 0x1d) 0 0 0xfff00000 0x100000
|
||||||
MBUS_ID(0x01, 0x2f) 0 0 0xf0000000 0x8000000
|
MBUS_ID(0x01, 0x2f) 0 0 0xe8000000 0x8000000
|
||||||
MBUS_ID(0x09, 0x09) 0 0 0xf8100000 0x10000
|
MBUS_ID(0x09, 0x09) 0 0 0xf1100000 0x10000
|
||||||
MBUS_ID(0x09, 0x05) 0 0 0xf8110000 0x10000>;
|
MBUS_ID(0x09, 0x05) 0 0 0xf1110000 0x10000>;
|
||||||
|
|
||||||
devbus-bootcs {
|
devbus-bootcs {
|
||||||
status = "okay";
|
status = "okay";
|
||||||
|
@ -78,8 +78,8 @@
|
|||||||
soc {
|
soc {
|
||||||
ranges = <MBUS_ID(0xf0, 0x01) 0 0 0xf1000000 0x100000
|
ranges = <MBUS_ID(0xf0, 0x01) 0 0 0xf1000000 0x100000
|
||||||
MBUS_ID(0x01, 0x1d) 0 0 0xfff00000 0x100000
|
MBUS_ID(0x01, 0x1d) 0 0 0xfff00000 0x100000
|
||||||
MBUS_ID(0x09, 0x09) 0 0 0xf8100000 0x10000
|
MBUS_ID(0x09, 0x09) 0 0 0xf1100000 0x10000
|
||||||
MBUS_ID(0x09, 0x05) 0 0 0xf8110000 0x10000>;
|
MBUS_ID(0x09, 0x05) 0 0 0xf1110000 0x10000>;
|
||||||
|
|
||||||
pcie-controller {
|
pcie-controller {
|
||||||
status = "okay";
|
status = "okay";
|
||||||
|
@ -1500,6 +1500,16 @@
|
|||||||
0x48485200 0x2E00>;
|
0x48485200 0x2E00>;
|
||||||
#address-cells = <1>;
|
#address-cells = <1>;
|
||||||
#size-cells = <1>;
|
#size-cells = <1>;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Do not allow gating of cpsw clock as workaround
|
||||||
|
* for errata i877. Keeping internal clock disabled
|
||||||
|
* causes the device switching characteristics
|
||||||
|
* to degrade over time and eventually fail to meet
|
||||||
|
* the data manual delay time/skew specs.
|
||||||
|
*/
|
||||||
|
ti,no-idle;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* rx_thresh_pend
|
* rx_thresh_pend
|
||||||
* rx_pend
|
* rx_pend
|
||||||
|
@ -2200,6 +2200,11 @@ static int _enable(struct omap_hwmod *oh)
|
|||||||
*/
|
*/
|
||||||
static int _idle(struct omap_hwmod *oh)
|
static int _idle(struct omap_hwmod *oh)
|
||||||
{
|
{
|
||||||
|
if (oh->flags & HWMOD_NO_IDLE) {
|
||||||
|
oh->_int_flags |= _HWMOD_SKIP_ENABLE;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
pr_debug("omap_hwmod: %s: idling\n", oh->name);
|
pr_debug("omap_hwmod: %s: idling\n", oh->name);
|
||||||
|
|
||||||
if (oh->_state != _HWMOD_STATE_ENABLED) {
|
if (oh->_state != _HWMOD_STATE_ENABLED) {
|
||||||
@ -2504,6 +2509,8 @@ static int __init _init(struct omap_hwmod *oh, void *data)
|
|||||||
oh->flags |= HWMOD_INIT_NO_RESET;
|
oh->flags |= HWMOD_INIT_NO_RESET;
|
||||||
if (of_find_property(np, "ti,no-idle-on-init", NULL))
|
if (of_find_property(np, "ti,no-idle-on-init", NULL))
|
||||||
oh->flags |= HWMOD_INIT_NO_IDLE;
|
oh->flags |= HWMOD_INIT_NO_IDLE;
|
||||||
|
if (of_find_property(np, "ti,no-idle", NULL))
|
||||||
|
oh->flags |= HWMOD_NO_IDLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
oh->_state = _HWMOD_STATE_INITIALIZED;
|
oh->_state = _HWMOD_STATE_INITIALIZED;
|
||||||
@ -2630,7 +2637,7 @@ static void __init _setup_postsetup(struct omap_hwmod *oh)
|
|||||||
* XXX HWMOD_INIT_NO_IDLE does not belong in hwmod data -
|
* XXX HWMOD_INIT_NO_IDLE does not belong in hwmod data -
|
||||||
* it should be set by the core code as a runtime flag during startup
|
* it should be set by the core code as a runtime flag during startup
|
||||||
*/
|
*/
|
||||||
if ((oh->flags & HWMOD_INIT_NO_IDLE) &&
|
if ((oh->flags & (HWMOD_INIT_NO_IDLE | HWMOD_NO_IDLE)) &&
|
||||||
(postsetup_state == _HWMOD_STATE_IDLE)) {
|
(postsetup_state == _HWMOD_STATE_IDLE)) {
|
||||||
oh->_int_flags |= _HWMOD_SKIP_ENABLE;
|
oh->_int_flags |= _HWMOD_SKIP_ENABLE;
|
||||||
postsetup_state = _HWMOD_STATE_ENABLED;
|
postsetup_state = _HWMOD_STATE_ENABLED;
|
||||||
|
@ -525,6 +525,8 @@ struct omap_hwmod_omap4_prcm {
|
|||||||
* or idled.
|
* or idled.
|
||||||
* HWMOD_OPT_CLKS_NEEDED: The optional clocks are needed for the module to
|
* HWMOD_OPT_CLKS_NEEDED: The optional clocks are needed for the module to
|
||||||
* operate and they need to be handled at the same time as the main_clk.
|
* operate and they need to be handled at the same time as the main_clk.
|
||||||
|
* HWMOD_NO_IDLE: Do not idle the hwmod at all. Useful to handle certain
|
||||||
|
* IPs like CPSW on DRA7, where clocks to this module cannot be disabled.
|
||||||
*/
|
*/
|
||||||
#define HWMOD_SWSUP_SIDLE (1 << 0)
|
#define HWMOD_SWSUP_SIDLE (1 << 0)
|
||||||
#define HWMOD_SWSUP_MSTANDBY (1 << 1)
|
#define HWMOD_SWSUP_MSTANDBY (1 << 1)
|
||||||
@ -541,6 +543,7 @@ struct omap_hwmod_omap4_prcm {
|
|||||||
#define HWMOD_SWSUP_SIDLE_ACT (1 << 12)
|
#define HWMOD_SWSUP_SIDLE_ACT (1 << 12)
|
||||||
#define HWMOD_RECONFIG_IO_CHAIN (1 << 13)
|
#define HWMOD_RECONFIG_IO_CHAIN (1 << 13)
|
||||||
#define HWMOD_OPT_CLKS_NEEDED (1 << 14)
|
#define HWMOD_OPT_CLKS_NEEDED (1 << 14)
|
||||||
|
#define HWMOD_NO_IDLE (1 << 15)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* omap_hwmod._int_flags definitions
|
* omap_hwmod._int_flags definitions
|
||||||
|
Loading…
Reference in New Issue
Block a user