Received: by 2002:a25:8b12:0:0:0:0:0 with SMTP id i18csp1030031ybl; Fri, 16 Aug 2019 07:51:36 -0700 (PDT) X-Google-Smtp-Source: APXvYqy5SVIRKbLxWLT5fd97RGLqp1TquUoqUYt1J6HrWhwCNwTb+YiF/ZG2KKb64ofXEhutQsGi X-Received: by 2002:aa7:8746:: with SMTP id g6mr10675537pfo.191.1565967096596; Fri, 16 Aug 2019 07:51:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1565967096; cv=none; d=google.com; s=arc-20160816; b=qhe63GUpxukruMbgGn8eiwt8mhe5baMIWItTKedR/ApUypfk5Y8n1qyBKqTkyA+GAJ KolgGLJSKMXbUKtNs8VzdpGWpE23Q2oTRILxpyCwYbKvJRkGrxalOsmAJorZcJW360bs 7KsWfyN8vVHhXbbihXuUxLKmfuapEpyzkINFMD9g5SSaayUCB2FTjQBzhonoZ7yfsO1a 4gxF5P0mS43P3SmaTBSSQlFVKCyHkQ6rXa6OoOZtPwFRScCmqFlLRWkOlqU5tJKTj3qd foAGUQhUW5mBTHGy7tsdEV5WFoPyLmgB7jcEH+lO8n1iS84qTyJY5xHiJSj8TBdRovFY QC8A== 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:message-id :dkim-signature; bh=hpWgRSJjpWSuZNORQXd2qzqujrFlTrU3omHeRmI/oNk=; b=FSYUtfSxpjZ8ZL67fklHnT9/ifmN5tWSwEoHengxVbB+5Pcpn0KwEgP0U7cM5KP4PS Lr80lgURz9kSFw3plIF3WZk0sQWSIT0Qcel0kcE6HUSsjMdD1SJy+9lb8h6yXM3pIIwh EUS7xgJ9E1yj+j/tgpbHpdmHvJ8P1P+2MwOsQyY0Qt92/1SDhBS5Jdm8rjD3fqUYESWX ICPTRfd20aA2VGPnn0U5/lLg8taQsObsljXFnjaXnlqWouqCMFmKlXVpxL4WBJed7/TM +h582k8E3UCfF5uEG7D9ZvuCmUWwjeri5DIKpxCYGnvm8iaHCNrByarUK4DMG3JoEr3X s/xw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@c-s.fr header.s=mail header.b=NxRLm8Mg; 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 b18si4100168plz.389.2019.08.16.07.51.20; Fri, 16 Aug 2019 07:51:36 -0700 (PDT) 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=NxRLm8Mg; 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 S1727418AbfHPOsv (ORCPT + 99 others); Fri, 16 Aug 2019 10:48:51 -0400 Received: from pegase1.c-s.fr ([93.17.236.30]:43963 "EHLO pegase1.c-s.fr" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727362AbfHPOsu (ORCPT ); Fri, 16 Aug 2019 10:48:50 -0400 Received: from localhost (mailhub1-int [192.168.12.234]) by localhost (Postfix) with ESMTP id 4695mb1H04z9v05t; Fri, 16 Aug 2019 16:48:47 +0200 (CEST) Authentication-Results: localhost; dkim=pass reason="1024-bit key; insecure key" header.d=c-s.fr header.i=@c-s.fr header.b=NxRLm8Mg; 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 nstH652I8JiG; Fri, 16 Aug 2019 16:48:47 +0200 (CEST) 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 4695mb07L4z9v05s; Fri, 16 Aug 2019 16:48:47 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=c-s.fr; s=mail; t=1565966927; bh=hpWgRSJjpWSuZNORQXd2qzqujrFlTrU3omHeRmI/oNk=; h=From:Subject:To:Cc:Date:From; b=NxRLm8MgDFxBwG26J8ANg5Go1vOk3zU4Ou7OyIFcYpmZQeJkWgT9MJhGbr4CwGI7g ttuw2BZt8TKkgo2TJcOXDO+3lk/kpq6MZH/Y/OhNtZtlO1rqhuDWwXHSX0hH+ZdTo3 l57qawcfMo7LptnWU8aNgaiw5cjSbaYPLk9kKJBs= Received: from localhost (localhost [127.0.0.1]) by messagerie.si.c-s.fr (Postfix) with ESMTP id ADBD48B78A; Fri, 16 Aug 2019 16:48:48 +0200 (CEST) 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 7KHQN8PadwAx; Fri, 16 Aug 2019 16:48:48 +0200 (CEST) Received: from pc17473vm.idsi0.si.c-s.fr (po15451.idsi0.si.c-s.fr [172.25.230.101]) by messagerie.si.c-s.fr (Postfix) with ESMTP id 81D268B754; Fri, 16 Aug 2019 16:48:48 +0200 (CEST) Received: by pc17473vm.idsi0.si.c-s.fr (Postfix, from userid 0) id 547156B6CC; Fri, 16 Aug 2019 14:48:48 +0000 (UTC) Message-Id: <65f1ed51b9cff219b9380c81d88353570cafdfd3.1565966871.git.christophe.leroy@c-s.fr> From: Christophe Leroy Subject: [PATCH] powerpc/vdso32: inline __get_datapage() To: Benjamin Herrenschmidt , Paul Mackerras , Michael Ellerman Cc: linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org Date: Fri, 16 Aug 2019 14:48:48 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org __get_datapage() is only a few instructions to retrieve the address of the page where the kernel stores data to the VDSO. By inlining this function into its users, a bl/blr pair and a mflr/mtlr pair is avoided, plus a few reg moves. The improvement is noticeable (about 55 nsec/call on an 8xx) vdsotest before the patch: gettimeofday: vdso: 731 nsec/call clock-gettime-realtime-coarse: vdso: 668 nsec/call clock-gettime-monotonic-coarse: vdso: 745 nsec/call vdsotest after the patch: gettimeofday: vdso: 677 nsec/call clock-gettime-realtime-coarse: vdso: 613 nsec/call clock-gettime-monotonic-coarse: vdso: 690 nsec/call Signed-off-by: Christophe Leroy --- arch/powerpc/kernel/vdso32/cacheflush.S | 10 +++++----- arch/powerpc/kernel/vdso32/datapage.S | 29 ++++------------------------- arch/powerpc/kernel/vdso32/datapage.h | 12 ++++++++++++ arch/powerpc/kernel/vdso32/gettimeofday.S | 11 +++++------ 4 files changed, 26 insertions(+), 36 deletions(-) create mode 100644 arch/powerpc/kernel/vdso32/datapage.h diff --git a/arch/powerpc/kernel/vdso32/cacheflush.S b/arch/powerpc/kernel/vdso32/cacheflush.S index 7f882e7b9f43..e9453837e4ee 100644 --- a/arch/powerpc/kernel/vdso32/cacheflush.S +++ b/arch/powerpc/kernel/vdso32/cacheflush.S @@ -10,6 +10,8 @@ #include #include +#include "datapage.h" + .text /* @@ -24,14 +26,12 @@ V_FUNCTION_BEGIN(__kernel_sync_dicache) .cfi_startproc mflr r12 .cfi_register lr,r12 - mr r11,r3 - bl __get_datapage@local + get_datapage r10, r0 mtlr r12 - mr r10,r3 lwz r7,CFG_DCACHE_BLOCKSZ(r10) addi r5,r7,-1 - andc r6,r11,r5 /* round low to line bdy */ + andc r6,r3,r5 /* round low to line bdy */ subf r8,r6,r4 /* compute length */ add r8,r8,r5 /* ensure we get enough */ lwz r9,CFG_DCACHE_LOGBLOCKSZ(r10) @@ -48,7 +48,7 @@ V_FUNCTION_BEGIN(__kernel_sync_dicache) lwz r7,CFG_ICACHE_BLOCKSZ(r10) addi r5,r7,-1 - andc r6,r11,r5 /* round low to line bdy */ + andc r6,r3,r5 /* round low to line bdy */ subf r8,r6,r4 /* compute length */ add r8,r8,r5 lwz r9,CFG_ICACHE_LOGBLOCKSZ(r10) diff --git a/arch/powerpc/kernel/vdso32/datapage.S b/arch/powerpc/kernel/vdso32/datapage.S index 6984125b9fc0..d480d2d4a3fe 100644 --- a/arch/powerpc/kernel/vdso32/datapage.S +++ b/arch/powerpc/kernel/vdso32/datapage.S @@ -11,34 +11,13 @@ #include #include +#include "datapage.h" + .text .global __kernel_datapage_offset; __kernel_datapage_offset: .long 0 -V_FUNCTION_BEGIN(__get_datapage) - .cfi_startproc - /* We don't want that exposed or overridable as we want other objects - * to be able to bl directly to here - */ - .protected __get_datapage - .hidden __get_datapage - - mflr r0 - .cfi_register lr,r0 - - bcl 20,31,data_page_branch -data_page_branch: - mflr r3 - mtlr r0 - addi r3, r3, __kernel_datapage_offset-data_page_branch - lwz r0,0(r3) - .cfi_restore lr - add r3,r0,r3 - blr - .cfi_endproc -V_FUNCTION_END(__get_datapage) - /* * void *__kernel_get_syscall_map(unsigned int *syscall_count) ; * @@ -53,7 +32,7 @@ V_FUNCTION_BEGIN(__kernel_get_syscall_map) mflr r12 .cfi_register lr,r12 mr r4,r3 - bl __get_datapage@local + get_datapage r3, r0 mtlr r12 addi r3,r3,CFG_SYSCALL_MAP32 cmpli cr0,r4,0 @@ -74,7 +53,7 @@ V_FUNCTION_BEGIN(__kernel_get_tbfreq) .cfi_startproc mflr r12 .cfi_register lr,r12 - bl __get_datapage@local + get_datapage r3, r0 lwz r4,(CFG_TB_TICKS_PER_SEC + 4)(r3) lwz r3,CFG_TB_TICKS_PER_SEC(r3) mtlr r12 diff --git a/arch/powerpc/kernel/vdso32/datapage.h b/arch/powerpc/kernel/vdso32/datapage.h new file mode 100644 index 000000000000..ad96256be090 --- /dev/null +++ b/arch/powerpc/kernel/vdso32/datapage.h @@ -0,0 +1,12 @@ +/* SPDX-License-Identifier: GPL-2.0-or-later */ + +.macro get_datapage ptr, tmp + bcl 20,31,888f +888: + mflr \ptr + addi \ptr, \ptr, __kernel_datapage_offset - 888b + lwz \tmp, 0(\ptr) + add \ptr, \tmp, \ptr +.endm + + diff --git a/arch/powerpc/kernel/vdso32/gettimeofday.S b/arch/powerpc/kernel/vdso32/gettimeofday.S index e10098cde89c..91a58f01dcd5 100644 --- a/arch/powerpc/kernel/vdso32/gettimeofday.S +++ b/arch/powerpc/kernel/vdso32/gettimeofday.S @@ -12,6 +12,8 @@ #include #include +#include "datapage.h" + /* Offset for the low 32-bit part of a field of long type */ #ifdef CONFIG_PPC64 #define LOPART 4 @@ -35,8 +37,7 @@ V_FUNCTION_BEGIN(__kernel_gettimeofday) mr r10,r3 /* r10 saves tv */ mr r11,r4 /* r11 saves tz */ - bl __get_datapage@local /* get data page */ - mr r9, r3 /* datapage ptr in r9 */ + get_datapage r9, r0 cmplwi r10,0 /* check if tv is NULL */ beq 3f lis r7,1000000@ha /* load up USEC_PER_SEC */ @@ -82,8 +83,7 @@ V_FUNCTION_BEGIN(__kernel_clock_gettime) mflr r12 /* r12 saves lr */ .cfi_register lr,r12 mr r11,r4 /* r11 saves tp */ - bl __get_datapage@local /* get data page */ - mr r9,r3 /* datapage ptr in r9 */ + get_datapage r9, r0 lis r7,NSEC_PER_SEC@h /* want nanoseconds */ ori r7,r7,NSEC_PER_SEC@l beq cr5,70f @@ -235,8 +235,7 @@ V_FUNCTION_BEGIN(__kernel_time) .cfi_register lr,r12 mr r11,r3 /* r11 holds t */ - bl __get_datapage@local - mr r9, r3 /* datapage ptr in r9 */ + get_datapage r9, r0 lwz r3,STAMP_XTIME+TSPEC_TV_SEC(r9) -- 2.13.3