Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp2172996imu; Thu, 24 Jan 2019 08:20:28 -0800 (PST) X-Google-Smtp-Source: ALg8bN6jo1FwSCORNlp37LSf/70XvRTXEq3kMCQOVZGednSEFuCao3uyGSrce5wQTNxQhZUOkRYD X-Received: by 2002:a63:6984:: with SMTP id e126mr6596808pgc.143.1548346828872; Thu, 24 Jan 2019 08:20:28 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1548346828; cv=none; d=google.com; s=arc-20160816; b=l54HFFVgZjWffxgcQfF+ruqJrDCKfNSlCWsNB1ZKhzzaIH2jqoIVOdIGYLcsrANEj1 QCEpe7Ho7qksVxBM4CDX+1wGhOCn/cDyErgG+yZFHPwOGxmOCsIT7Uda4ESvEmsnm5ao JZ6+j0nknCfuS8GmLWM6p8yfZeWpS9dhIomPMsw245tBCsyLVZxfs0KpniX41HUN+mBo oAjCJ29RGZXPXwZRqlO3vf2EHp2khqLwXdq2v7/Giy96aV5XKTjlTahpqFxFMbcHK+Rv VUXzcTwHlDGvcARw7BZC1eqW8u+8U1xKLF81Sxp+ZDbe93ZJ2rVurDRfroqlAaOrk3Z7 xZwA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:date:cc:to:subject:from:references :in-reply-to:message-id:dkim-signature; bh=hVjK/MF3Hc5p9MN1ZxIhqr5H11q0ZLvAMSBdtHgzqB0=; b=Se5m0/bLaYnQk0sr0ERbyAZzrVBK2AQuIhCoqEUnrjsTKR8JNdKI4IV9/KvmdygOAL 4mpMQ8DBMdMOjnftD+awy6ji5EUTdZ1ptjvsDWOv9nWzpKJez1jmGGM3K0H4vp8e8KVK dylHJt9vvu0U16B+nwuXlJ/50pSsez48ft+jivy5HpE/wC8X2FYAvmmv5ubEL0ACTI7t /geKaTZRbEKBlCwLV2TiahaUe4J3DwSM/6zJ9KvRpWqOABisG4RfAoCTVkImLDRQ0jX4 TvgAHufYFGh1cdQ2LzVWvHxrcmKXVX6QFz5+qcsTuPFMD7Mm5xQr4ygNP2CtNRZyYUSz 4lCQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@c-s.fr header.s=mail header.b=BQwllRYq; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id d34si21079033pgb.43.2019.01.24.08.20.12; Thu, 24 Jan 2019 08:20:28 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@c-s.fr header.s=mail header.b=BQwllRYq; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728903AbfAXQTx (ORCPT + 99 others); Thu, 24 Jan 2019 11:19:53 -0500 Received: from pegase1.c-s.fr ([93.17.236.30]:42389 "EHLO pegase1.c-s.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728756AbfAXQTu (ORCPT ); Thu, 24 Jan 2019 11:19:50 -0500 Received: from localhost (mailhub1-int [192.168.12.234]) by localhost (Postfix) with ESMTP id 43lnRk2N1zz9v01g; Thu, 24 Jan 2019 17:19:46 +0100 (CET) Authentication-Results: localhost; dkim=pass reason="1024-bit key; insecure key" header.d=c-s.fr header.i=@c-s.fr header.b=BQwllRYq; dkim-adsp=pass; dkim-atps=neutral X-Virus-Scanned: Debian amavisd-new at c-s.fr Received: from pegase1.c-s.fr ([192.168.12.234]) by localhost (pegase1.c-s.fr [192.168.12.234]) (amavisd-new, port 10024) with ESMTP id ubKp3yOxqklK; Thu, 24 Jan 2019 17:19:46 +0100 (CET) Received: from messagerie.si.c-s.fr (messagerie.si.c-s.fr [192.168.25.192]) by pegase1.c-s.fr (Postfix) with ESMTP id 43lnRk1FZRz9v01Z; Thu, 24 Jan 2019 17:19:46 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=c-s.fr; s=mail; t=1548346786; bh=hVjK/MF3Hc5p9MN1ZxIhqr5H11q0ZLvAMSBdtHgzqB0=; h=In-Reply-To:References:From:Subject:To:Cc:Date:From; b=BQwllRYqC4BEBI6Ry4yMu5pnRMBabKpqG2KwDRJang3wWyGD9MHeeuraNjwIwMlx8 pJKxZWYKkF8PdrKQHdJ1p8wWjwGkNRyidQ2v6hlrOfW9SqRXQXuPH/JfbIvfHK6nDF jLsRR/OA7GCFb2odnPT6ti8l9hdW5ikHdQGvM4dY= Received: from localhost (localhost [127.0.0.1]) by messagerie.si.c-s.fr (Postfix) with ESMTP id B810B8B863; Thu, 24 Jan 2019 17:19:47 +0100 (CET) X-Virus-Scanned: amavisd-new at c-s.fr Received: from messagerie.si.c-s.fr ([127.0.0.1]) by localhost (messagerie.si.c-s.fr [127.0.0.1]) (amavisd-new, port 10023) with ESMTP id lZV-EF0NBgB5; Thu, 24 Jan 2019 17:19:47 +0100 (CET) Received: from po16846vm.idsi0.si.c-s.fr (unknown [192.168.4.90]) by messagerie.si.c-s.fr (Postfix) with ESMTP id 78D8C8B850; Thu, 24 Jan 2019 17:19:47 +0100 (CET) Received: by po16846vm.idsi0.si.c-s.fr (Postfix, from userid 0) id 3C7BF72D88; Thu, 24 Jan 2019 16:19:47 +0000 (UTC) Message-Id: <57089c9946761af92eae666c437f19d4bc9f3528.1548346225.git.christophe.leroy@c-s.fr> In-Reply-To: References: From: Christophe Leroy Subject: [PATCH v14 09/12] powerpc: 'current_set' is now a table of task_struct pointers To: Benjamin Herrenschmidt , Paul Mackerras , Michael Ellerman , Nicholas Piggin , Mike Rapoport Cc: linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, Mark Rutland Date: Thu, 24 Jan 2019 16:19:47 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The table of pointers 'current_set' has been used for retrieving the stack and current. They used to be thread_info pointers as they were pointing to the stack and current was taken from the 'task' field of the thread_info. Now, the pointers of 'current_set' table are now both pointers to task_struct and pointers to thread_info. As they are used to get current, and the stack pointer is retrieved from current's stack field, this patch changes their type to task_struct, and renames secondary_ti to secondary_current. Reviewed-by: Nicholas Piggin Signed-off-by: Christophe Leroy --- arch/powerpc/include/asm/asm-prototypes.h | 4 ++-- arch/powerpc/kernel/head_32.S | 6 +++--- arch/powerpc/kernel/head_44x.S | 4 ++-- arch/powerpc/kernel/head_fsl_booke.S | 4 ++-- arch/powerpc/kernel/smp.c | 10 ++++------ 5 files changed, 13 insertions(+), 15 deletions(-) diff --git a/arch/powerpc/include/asm/asm-prototypes.h b/arch/powerpc/include/asm/asm-prototypes.h index 1d911f68a23b..1484df6779ab 100644 --- a/arch/powerpc/include/asm/asm-prototypes.h +++ b/arch/powerpc/include/asm/asm-prototypes.h @@ -23,8 +23,8 @@ #include /* SMP */ -extern struct thread_info *current_set[NR_CPUS]; -extern struct thread_info *secondary_ti; +extern struct task_struct *current_set[NR_CPUS]; +extern struct task_struct *secondary_current; void start_secondary(void *unused); /* kexec */ diff --git a/arch/powerpc/kernel/head_32.S b/arch/powerpc/kernel/head_32.S index 309a45779ad5..146385b1c2da 100644 --- a/arch/powerpc/kernel/head_32.S +++ b/arch/powerpc/kernel/head_32.S @@ -846,9 +846,9 @@ __secondary_start: #endif /* CONFIG_PPC_BOOK3S_32 */ /* get current's stack and current */ - lis r1,secondary_ti@ha - tophys(r1,r1) - lwz r2,secondary_ti@l(r1) + lis r2,secondary_current@ha + tophys(r2,r2) + lwz r2,secondary_current@l(r2) tophys(r1,r2) lwz r1,TASK_STACK(r1) diff --git a/arch/powerpc/kernel/head_44x.S b/arch/powerpc/kernel/head_44x.S index f94a93b6c2f2..37117ab11584 100644 --- a/arch/powerpc/kernel/head_44x.S +++ b/arch/powerpc/kernel/head_44x.S @@ -1020,8 +1020,8 @@ _GLOBAL(start_secondary_47x) /* Now we can get our task struct and real stack pointer */ /* Get current's stack and current */ - lis r1,secondary_ti@ha - lwz r2,secondary_ti@l(r1) + lis r2,secondary_current@ha + lwz r2,secondary_current@l(r2) lwz r1,TASK_STACK(r2) /* Current stack pointer */ diff --git a/arch/powerpc/kernel/head_fsl_booke.S b/arch/powerpc/kernel/head_fsl_booke.S index 11f38adbe020..4ed2a7c8e89b 100644 --- a/arch/powerpc/kernel/head_fsl_booke.S +++ b/arch/powerpc/kernel/head_fsl_booke.S @@ -1091,8 +1091,8 @@ __secondary_start: bl call_setup_cpu /* get current's stack and current */ - lis r1,secondary_ti@ha - lwz r2,secondary_ti@l(r1) + lis r2,secondary_current@ha + lwz r2,secondary_current@l(r2) lwz r1,TASK_STACK(r2) /* stack */ diff --git a/arch/powerpc/kernel/smp.c b/arch/powerpc/kernel/smp.c index aa4517686f90..a41fa8924004 100644 --- a/arch/powerpc/kernel/smp.c +++ b/arch/powerpc/kernel/smp.c @@ -76,7 +76,7 @@ static DEFINE_PER_CPU(int, cpu_state) = { 0 }; #endif -struct thread_info *secondary_ti; +struct task_struct *secondary_current; bool has_big_cores; DEFINE_PER_CPU(cpumask_var_t, cpu_sibling_map); @@ -664,7 +664,7 @@ void smp_send_stop(void) } #endif /* CONFIG_NMI_IPI */ -struct thread_info *current_set[NR_CPUS]; +struct task_struct *current_set[NR_CPUS]; static void smp_store_cpu_info(int id) { @@ -929,7 +929,7 @@ void smp_prepare_boot_cpu(void) paca_ptrs[boot_cpuid]->__current = current; #endif set_numa_node(numa_cpu_lookup_table[boot_cpuid]); - current_set[boot_cpuid] = task_thread_info(current); + current_set[boot_cpuid] = current; } #ifdef CONFIG_HOTPLUG_CPU @@ -1014,15 +1014,13 @@ static bool secondaries_inhibited(void) static void cpu_idle_thread_init(unsigned int cpu, struct task_struct *idle) { - struct thread_info *ti = task_thread_info(idle); - #ifdef CONFIG_PPC64 paca_ptrs[cpu]->__current = idle; paca_ptrs[cpu]->kstack = (unsigned long)task_stack_page(idle) + THREAD_SIZE - STACK_FRAME_OVERHEAD; #endif idle->cpu = cpu; - secondary_ti = current_set[cpu] = ti; + secondary_current = current_set[cpu] = idle; } int __cpu_up(unsigned int cpu, struct task_struct *tidle) -- 2.13.3