diff options
| author | Amit Pundir <amit.pundir@linaro.org> | 2016-11-15 18:16:35 +0530 | 
|---|---|---|
| committer | Amit Pundir <amit.pundir@linaro.org> | 2016-11-15 18:33:34 +0530 | 
| commit | 91e63c11a5eb143f5d737cf0380088528e7fa327 (patch) | |
| tree | 34f5b35edf45c51b9a4d3aa5b04313d97be97754 /arch/arm64/kernel/psci.c | |
| parent | 79df8fa79b6a2aced892ad2b2c9832e7d9bdea6b (diff) | |
| parent | 29703588215bbf281aed9aa8cdec0641757fb9e1 (diff) | |
Merge branch 'linux-linaro-lsk-v4.4' into linux-linaro-lsk-v4.4-android
Conflicts:
* arch/arm64/include/asm/assembler.h
    Pick changes from AOSP Change-Id: I450594dc311b09b6b832b707a9abb357608cc6e4
    ("UPSTREAM: arm64: include alternative handling in dcache_by_line_op").
* drivers/android/binder.c
    Pick changes from LTS commit 14f09e8e7cd8 ("ANDROID: binder: Add strong ref checks"),
    instead of AOSP Change-Id: I66c15b066808f28bd27bfe50fd0e03ff45a09fca
    ("ANDROID: binder: Add strong ref checks").
* drivers/usb/gadget/function/u_ether.c
    Refactor throttling of highspeed IRQ logic in AOSP by adding
    a check for last queue request as intended by LTS commit
    660c04e8f174 ("usb: gadget: function: u_ether: don't starve tx request queue").
    Fixes AOSP Change-Id: I26515bfd9bbc8f7af38be7835692143f7093118a
    ("USB: gadget: u_ether: Fix data stall issue in RNDIS tethering mode").
Signed-off-by: Amit Pundir <amit.pundir@linaro.org>
Diffstat (limited to 'arch/arm64/kernel/psci.c')
| -rw-r--r-- | arch/arm64/kernel/psci.c | 99 | 
1 files changed, 2 insertions, 97 deletions
| diff --git a/arch/arm64/kernel/psci.c b/arch/arm64/kernel/psci.c index f67f35b6edb1..42816bebb1e0 100644 --- a/arch/arm64/kernel/psci.c +++ b/arch/arm64/kernel/psci.c @@ -20,7 +20,6 @@  #include <linux/smp.h>  #include <linux/delay.h>  #include <linux/psci.h> -#include <linux/slab.h>  #include <uapi/linux/psci.h> @@ -28,73 +27,6 @@  #include <asm/cpu_ops.h>  #include <asm/errno.h>  #include <asm/smp_plat.h> -#include <asm/suspend.h> - -static DEFINE_PER_CPU_READ_MOSTLY(u32 *, psci_power_state); - -static int __maybe_unused cpu_psci_cpu_init_idle(unsigned int cpu) -{ -	int i, ret, count = 0; -	u32 *psci_states; -	struct device_node *state_node, *cpu_node; - -	cpu_node = of_get_cpu_node(cpu, NULL); -	if (!cpu_node) -		return -ENODEV; - -	/* -	 * If the PSCI cpu_suspend function hook has not been initialized -	 * idle states must not be enabled, so bail out -	 */ -	if (!psci_ops.cpu_suspend) -		return -EOPNOTSUPP; - -	/* Count idle states */ -	while ((state_node = of_parse_phandle(cpu_node, "cpu-idle-states", -					      count))) { -		count++; -		of_node_put(state_node); -	} - -	if (!count) -		return -ENODEV; - -	psci_states = kcalloc(count, sizeof(*psci_states), GFP_KERNEL); -	if (!psci_states) -		return -ENOMEM; - -	for (i = 0; i < count; i++) { -		u32 state; - -		state_node = of_parse_phandle(cpu_node, "cpu-idle-states", i); - -		ret = of_property_read_u32(state_node, -					   "arm,psci-suspend-param", -					   &state); -		if (ret) { -			pr_warn(" * %s missing arm,psci-suspend-param property\n", -				state_node->full_name); -			of_node_put(state_node); -			goto free_mem; -		} - -		of_node_put(state_node); -		pr_debug("psci-power-state %#x index %d\n", state, i); -		if (!psci_power_state_is_valid(state)) { -			pr_warn("Invalid PSCI power state %#x\n", state); -			ret = -EINVAL; -			goto free_mem; -		} -		psci_states[i] = state; -	} -	/* Idle states parsed correctly, initialize per-cpu pointer */ -	per_cpu(psci_power_state, cpu) = psci_states; -	return 0; - -free_mem: -	kfree(psci_states); -	return ret; -}  static int __init cpu_psci_cpu_init(unsigned int cpu)  { @@ -178,38 +110,11 @@ static int cpu_psci_cpu_kill(unsigned int cpu)  }  #endif -static int psci_suspend_finisher(unsigned long index) -{ -	u32 *state = __this_cpu_read(psci_power_state); - -	return psci_ops.cpu_suspend(state[index - 1], -				    virt_to_phys(cpu_resume)); -} - -static int __maybe_unused cpu_psci_cpu_suspend(unsigned long index) -{ -	int ret; -	u32 *state = __this_cpu_read(psci_power_state); -	/* -	 * idle state index 0 corresponds to wfi, should never be called -	 * from the cpu_suspend operations -	 */ -	if (WARN_ON_ONCE(!index)) -		return -EINVAL; - -	if (!psci_power_state_loses_context(state[index - 1])) -		ret = psci_ops.cpu_suspend(state[index - 1], 0); -	else -		ret = cpu_suspend(index, psci_suspend_finisher); - -	return ret; -} -  const struct cpu_operations cpu_psci_ops = {  	.name		= "psci",  #ifdef CONFIG_CPU_IDLE -	.cpu_init_idle	= cpu_psci_cpu_init_idle, -	.cpu_suspend	= cpu_psci_cpu_suspend, +	.cpu_init_idle	= psci_cpu_init_idle, +	.cpu_suspend	= psci_cpu_suspend_enter,  #endif  	.cpu_init	= cpu_psci_cpu_init,  	.cpu_prepare	= cpu_psci_cpu_prepare, | 
