The i.MX fixes for 4.9:
- A couple of patches from Fabio to fix the GPC power domain regression which is caused by PM Domain core change 0159ec670763dd ("PM / Domains: Verify the PM domain is present when adding a provider"), and a related kernel crash seen with multi_v7_defconfig build. - Correct the PHY ID mask for AR8031 to match phy driver code. - Apply new added timer erratum A008585 for LS1043A and LS2080A SoC. - Correct vf610 global timer IRQ flag to avoid warning from gic driver after commit 992345a58e0c ("irqchip/gic: WARN if setting the interrupt type for a PPI fails"). -----BEGIN PGP SIGNATURE----- Version: GnuPG v1 iQEcBAABAgAGBQJYDhQ/AAoJEFBXWFqHsHzOjK8H/0BpUb5J1q+ULcJr5boRoErh LIILJA3q0voOXjONRhOcUx8d3yVccR4AFDsMxP3fzfzDvHrNJcK0ldqMg2I/TvL9 0hUt/IDxSoQ4dCtuuMpWMATeAiUGzCebxKfg12stB+wXUALD7upBrLNP509/Vifw O8xhPW5w5nWJ5g72QHpDQIqG0Le0Lf4lhuvPsS/hYOeL6mkGVfDTRMOduM3n3KLd YSMj9NuG1IH9f4xKxGVcs/2ZPdNk+t0PfP/NuPIY3S0qtWwkJRQSPV314WEsxDff pSCD/KhtkWf8VsHbOgiZUKXPQEsUuKLpqnjjkuF2Sm9KmYCgvaXfLfyX2eyyMN8= =Xh9e -----END PGP SIGNATURE----- Merge tag 'imx-fixes-4.9' of git://git.kernel.org/pub/scm/linux/kernel/git/shawnguo/linux into fixes The i.MX fixes for 4.9: - A couple of patches from Fabio to fix the GPC power domain regression which is caused by PM Domain core change 0159ec670763dd ("PM / Domains: Verify the PM domain is present when adding a provider"), and a related kernel crash seen with multi_v7_defconfig build. - Correct the PHY ID mask for AR8031 to match phy driver code. - Apply new added timer erratum A008585 for LS1043A and LS2080A SoC. - Correct vf610 global timer IRQ flag to avoid warning from gic driver after commit 992345a58e0c ("irqchip/gic: WARN if setting the interrupt type for a PPI fails"). * tag 'imx-fixes-4.9' of git://git.kernel.org/pub/scm/linux/kernel/git/shawnguo/linux: ARM: imx: mach-imx6q: Fix the PHY ID mask for AR8031 ARM: dts: vf610: fix IRQ flag of global timer ARM: imx: gpc: Fix the imx_gpc_genpd_init() error path ARM: imx: gpc: Initialize all power domains arm64: dts: Add timer erratum property for LS2080A and LS1043A Signed-off-by: Olof Johansson <olof@lixom.net>
This commit is contained in:
commit
fbaff059c2
@ -70,7 +70,7 @@
|
|||||||
global_timer: timer@40002200 {
|
global_timer: timer@40002200 {
|
||||||
compatible = "arm,cortex-a9-global-timer";
|
compatible = "arm,cortex-a9-global-timer";
|
||||||
reg = <0x40002200 0x20>;
|
reg = <0x40002200 0x20>;
|
||||||
interrupts = <GIC_PPI 11 IRQ_TYPE_LEVEL_HIGH>;
|
interrupts = <GIC_PPI 11 IRQ_TYPE_EDGE_RISING>;
|
||||||
interrupt-parent = <&intc>;
|
interrupt-parent = <&intc>;
|
||||||
clocks = <&clks VF610_CLK_PLATFORM_BUS>;
|
clocks = <&clks VF610_CLK_PLATFORM_BUS>;
|
||||||
};
|
};
|
||||||
|
@ -408,7 +408,7 @@ static struct genpd_onecell_data imx_gpc_onecell_data = {
|
|||||||
static int imx_gpc_genpd_init(struct device *dev, struct regulator *pu_reg)
|
static int imx_gpc_genpd_init(struct device *dev, struct regulator *pu_reg)
|
||||||
{
|
{
|
||||||
struct clk *clk;
|
struct clk *clk;
|
||||||
int i;
|
int i, ret;
|
||||||
|
|
||||||
imx6q_pu_domain.reg = pu_reg;
|
imx6q_pu_domain.reg = pu_reg;
|
||||||
|
|
||||||
@ -430,13 +430,22 @@ static int imx_gpc_genpd_init(struct device *dev, struct regulator *pu_reg)
|
|||||||
if (!IS_ENABLED(CONFIG_PM_GENERIC_DOMAINS))
|
if (!IS_ENABLED(CONFIG_PM_GENERIC_DOMAINS))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
pm_genpd_init(&imx6q_pu_domain.base, NULL, false);
|
for (i = 0; i < ARRAY_SIZE(imx_gpc_domains); i++)
|
||||||
return of_genpd_add_provider_onecell(dev->of_node,
|
pm_genpd_init(imx_gpc_domains[i], NULL, false);
|
||||||
&imx_gpc_onecell_data);
|
|
||||||
|
|
||||||
|
ret = of_genpd_add_provider_onecell(dev->of_node,
|
||||||
|
&imx_gpc_onecell_data);
|
||||||
|
if (ret)
|
||||||
|
goto power_off;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
power_off:
|
||||||
|
imx6q_pm_pu_power_off(&imx6q_pu_domain.base);
|
||||||
clk_err:
|
clk_err:
|
||||||
while (i--)
|
while (i--)
|
||||||
clk_put(imx6q_pu_domain.clk[i]);
|
clk_put(imx6q_pu_domain.clk[i]);
|
||||||
|
imx6q_pu_domain.reg = NULL;
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -173,7 +173,7 @@ static void __init imx6q_enet_phy_init(void)
|
|||||||
ksz9021rn_phy_fixup);
|
ksz9021rn_phy_fixup);
|
||||||
phy_register_fixup_for_uid(PHY_ID_KSZ9031, MICREL_PHY_ID_MASK,
|
phy_register_fixup_for_uid(PHY_ID_KSZ9031, MICREL_PHY_ID_MASK,
|
||||||
ksz9031rn_phy_fixup);
|
ksz9031rn_phy_fixup);
|
||||||
phy_register_fixup_for_uid(PHY_ID_AR8031, 0xffffffff,
|
phy_register_fixup_for_uid(PHY_ID_AR8031, 0xffffffef,
|
||||||
ar8031_phy_fixup);
|
ar8031_phy_fixup);
|
||||||
phy_register_fixup_for_uid(PHY_ID_AR8035, 0xffffffef,
|
phy_register_fixup_for_uid(PHY_ID_AR8035, 0xffffffef,
|
||||||
ar8035_phy_fixup);
|
ar8035_phy_fixup);
|
||||||
|
@ -123,6 +123,7 @@
|
|||||||
<1 14 0xf08>, /* Physical Non-Secure PPI */
|
<1 14 0xf08>, /* Physical Non-Secure PPI */
|
||||||
<1 11 0xf08>, /* Virtual PPI */
|
<1 11 0xf08>, /* Virtual PPI */
|
||||||
<1 10 0xf08>; /* Hypervisor PPI */
|
<1 10 0xf08>; /* Hypervisor PPI */
|
||||||
|
fsl,erratum-a008585;
|
||||||
};
|
};
|
||||||
|
|
||||||
pmu {
|
pmu {
|
||||||
|
@ -195,6 +195,7 @@
|
|||||||
<1 14 4>, /* Physical Non-Secure PPI, active-low */
|
<1 14 4>, /* Physical Non-Secure PPI, active-low */
|
||||||
<1 11 4>, /* Virtual PPI, active-low */
|
<1 11 4>, /* Virtual PPI, active-low */
|
||||||
<1 10 4>; /* Hypervisor PPI, active-low */
|
<1 10 4>; /* Hypervisor PPI, active-low */
|
||||||
|
fsl,erratum-a008585;
|
||||||
};
|
};
|
||||||
|
|
||||||
pmu {
|
pmu {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user