mirror of
https://github.com/edk2-porting/linux-next.git
synced 2024-12-22 20:23:57 +08:00
SMP special case for the rk3036 and addition of the rk3228
quad-core Cortex-A7 cpu. -----BEGIN PGP SIGNATURE----- Version: GnuPG v1 iQEcBAABCAAGBQJWcdThAAoJEPOmecmc0R2BFeMH/2jlwJrDe88hK1/7uQaFhKTN Ykiphn6JM33/32D8iGNeoU1/ylW8y72Yb09mPwaBbpwCqtNlhb7iJIIhVqAOac57 PfJgTvq6bzXeqsKQkstZ3fCu/TP4rucXH6D1XUmR3N5BIfo7iNjrxR2QnKXv522E HABnLjS7AY/CZXp2yudwku9RBBG1w0yGqxbvyfJEnOsuzopb50yBEAls6UXY1yei W/bY2fEeiQLtt2SWjS40p9+PZcrG2VQHDuKefhD8HeRIROXg/36QfM/DXxGJnJOA 3mMYx+zGxfWul+b82SsS6Z4tKQ+GCG7G5ABc2Gnd2NYpa3ESIJJQRLGU3VozidA= =NGaT -----END PGP SIGNATURE----- Merge tag 'v4.5-rockchip-soc-1' of git://git.kernel.org/pub/scm/linux/kernel/git/mmind/linux-rockchip into next/soc SMP special case for the rk3036 and addition of the rk3228 quad-core Cortex-A7 cpu. * tag 'v4.5-rockchip-soc-1' of git://git.kernel.org/pub/scm/linux/kernel/git/mmind/linux-rockchip: ARM: rockchip: enable support for RK3228 SoCs ARM: rockchip: use const and __initconst for rk3036 smp_operations ARM: rockchip: add support smp for rk3036 Signed-off-by: Olof Johansson <olof@lixom.net>
This commit is contained in:
commit
9cdac4a20a
@ -200,6 +200,7 @@ nodes to be present and contain the properties described below.
|
||||
"qcom,gcc-msm8660"
|
||||
"qcom,kpss-acc-v1"
|
||||
"qcom,kpss-acc-v2"
|
||||
"rockchip,rk3036-smp"
|
||||
"rockchip,rk3066-smp"
|
||||
"ste,dbx500-smp"
|
||||
|
||||
|
@ -42,6 +42,7 @@ static int ncores;
|
||||
#define PMU_PWRDN_SCU 4
|
||||
|
||||
static struct regmap *pmu;
|
||||
static int has_pmu = true;
|
||||
|
||||
static int pmu_power_domain_is_on(int pd)
|
||||
{
|
||||
@ -89,20 +90,23 @@ static int pmu_set_power_domain(int pd, bool on)
|
||||
if (!IS_ERR(rstc) && !on)
|
||||
reset_control_assert(rstc);
|
||||
|
||||
ret = regmap_update_bits(pmu, PMU_PWRDN_CON, BIT(pd), val);
|
||||
if (ret < 0) {
|
||||
pr_err("%s: could not update power domain\n", __func__);
|
||||
return ret;
|
||||
}
|
||||
|
||||
ret = -1;
|
||||
while (ret != on) {
|
||||
ret = pmu_power_domain_is_on(pd);
|
||||
if (has_pmu) {
|
||||
ret = regmap_update_bits(pmu, PMU_PWRDN_CON, BIT(pd), val);
|
||||
if (ret < 0) {
|
||||
pr_err("%s: could not read power domain state\n",
|
||||
pr_err("%s: could not update power domain\n",
|
||||
__func__);
|
||||
return ret;
|
||||
}
|
||||
|
||||
ret = -1;
|
||||
while (ret != on) {
|
||||
ret = pmu_power_domain_is_on(pd);
|
||||
if (ret < 0) {
|
||||
pr_err("%s: could not read power domain state\n",
|
||||
__func__);
|
||||
return ret;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (!IS_ERR(rstc)) {
|
||||
@ -122,7 +126,7 @@ static int rockchip_boot_secondary(unsigned int cpu, struct task_struct *idle)
|
||||
{
|
||||
int ret;
|
||||
|
||||
if (!sram_base_addr || !pmu) {
|
||||
if (!sram_base_addr || (has_pmu && !pmu)) {
|
||||
pr_err("%s: sram or pmu missing for cpu boot\n", __func__);
|
||||
return -ENXIO;
|
||||
}
|
||||
@ -275,7 +279,7 @@ static void __init rockchip_smp_prepare_cpus(unsigned int max_cpus)
|
||||
return;
|
||||
}
|
||||
|
||||
if (rockchip_smp_prepare_pmu())
|
||||
if (has_pmu && rockchip_smp_prepare_pmu())
|
||||
return;
|
||||
|
||||
if (read_cpuid_part() == ARM_CPU_PART_CORTEX_A9) {
|
||||
@ -318,6 +322,13 @@ static void __init rockchip_smp_prepare_cpus(unsigned int max_cpus)
|
||||
pmu_set_power_domain(0 + i, false);
|
||||
}
|
||||
|
||||
static void __init rk3036_smp_prepare_cpus(unsigned int max_cpus)
|
||||
{
|
||||
has_pmu = false;
|
||||
|
||||
rockchip_smp_prepare_cpus(max_cpus);
|
||||
}
|
||||
|
||||
#ifdef CONFIG_HOTPLUG_CPU
|
||||
static int rockchip_cpu_kill(unsigned int cpu)
|
||||
{
|
||||
@ -340,6 +351,15 @@ static void rockchip_cpu_die(unsigned int cpu)
|
||||
}
|
||||
#endif
|
||||
|
||||
static const struct smp_operations rk3036_smp_ops __initconst = {
|
||||
.smp_prepare_cpus = rk3036_smp_prepare_cpus,
|
||||
.smp_boot_secondary = rockchip_boot_secondary,
|
||||
#ifdef CONFIG_HOTPLUG_CPU
|
||||
.cpu_kill = rockchip_cpu_kill,
|
||||
.cpu_die = rockchip_cpu_die,
|
||||
#endif
|
||||
};
|
||||
|
||||
static struct smp_operations rockchip_smp_ops __initdata = {
|
||||
.smp_prepare_cpus = rockchip_smp_prepare_cpus,
|
||||
.smp_boot_secondary = rockchip_boot_secondary,
|
||||
@ -349,4 +369,5 @@ static struct smp_operations rockchip_smp_ops __initdata = {
|
||||
#endif
|
||||
};
|
||||
|
||||
CPU_METHOD_OF_DECLARE(rk3036_smp, "rockchip,rk3036-smp", &rk3036_smp_ops);
|
||||
CPU_METHOD_OF_DECLARE(rk3066_smp, "rockchip,rk3066-smp", &rockchip_smp_ops);
|
||||
|
@ -82,6 +82,7 @@ static const char * const rockchip_board_dt_compat[] = {
|
||||
"rockchip,rk3066a",
|
||||
"rockchip,rk3066b",
|
||||
"rockchip,rk3188",
|
||||
"rockchip,rk3228",
|
||||
"rockchip,rk3288",
|
||||
NULL,
|
||||
};
|
||||
|
Loading…
Reference in New Issue
Block a user