Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp196178iog; Tue, 14 Jun 2022 23:45:52 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxXfdGJHmpcipZVVcg+4zg88L6dIRag8ITPPj2jxupsHhfqkGc1son7Dy1lT9G2o35ImgLr X-Received: by 2002:a63:f915:0:b0:3fd:876b:808e with SMTP id h21-20020a63f915000000b003fd876b808emr7745488pgi.403.1655275552401; Tue, 14 Jun 2022 23:45:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655275552; cv=none; d=google.com; s=arc-20160816; b=KwDJ/YcBetr8RmpoYeKIZjFHCpOPJEPjxUMV05+qUVqISmKlNen6SVgwQdeHgg0pyC 1JcndisETICFQHnIkToWATbgakiwYN47CrwA+aS6fA1BvpBSaLF+UIFZimWIIq/1jbh2 sIR6UMKNDLvboZp+3CICOlKV/6MeTTfDIxdWLTsBtEWLuizEVG3PfZr+13Q2jCh6e4L8 25Fe+18c5YplKQxA2tVhAgqmZDj+fExjBslqHOVdcWv2LtWukKliSjvtxQ0j9Rl9fgN5 AJ6pFOYFnWIuNunyZypDSbSHmMiEQZruO19d2TGwid0lk6EWSu0dT+d8lQDeNmjONfuu 1JAQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from; bh=LZbXQZCni7Bwqq0H7O5PMM0JmL4CsjSstdYqCs5VoE8=; b=sQrQ+YYbF/67PRCja9QMLOYfFWR2WzUSOrpFUaoVMclmCYth+zpYMDFFyquj7TY1W8 7s02ZboZq/dP2Tp/NWS4/H/dKsIn6C0R7H2B39rhO2svj7fMnQ6FGGyFqikm0PoOGYj9 3thbyE8Sc/vlqvMM+GpFuMvH9QuXYjMss/OVOdbEzRT7WdrZsAI+TRfiYX1c3+TxYW3S O60yqj3NxbB69zD1i8GHeANMdLbIQT9yYr+6onzUwGzoKZ5bwWtl16r7GRUKfrQSqXA5 BeRF2koZyhVQQICsbW8/13VKumXPY2QABqnysOKux4XEgYIX5tPax8VniQBjXL4ZGQSk HoRQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id o1-20020a170902d4c100b0015a16b86c56si19582025plg.81.2022.06.14.23.45.37; Tue, 14 Jun 2022 23:45:52 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1354277AbiFOGiH (ORCPT + 99 others); Wed, 15 Jun 2022 02:38:07 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53582 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S243437AbiFOGiF (ORCPT ); Wed, 15 Jun 2022 02:38:05 -0400 Received: from loongson.cn (mail.loongson.cn [114.242.206.163]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id B14483A5FC for ; Tue, 14 Jun 2022 23:38:02 -0700 (PDT) Received: from linux.localdomain (unknown [113.200.148.30]) by mail.loongson.cn (Coremail) with SMTP id AQAAf9Dxr99HfqliljRDAA--.20432S3; Wed, 15 Jun 2022 14:38:00 +0800 (CST) From: Tiezhu Yang To: Huacai Chen , WANG Xuerui Cc: Xuefeng Li , Jianmin Lv , Jun Yi , Rui Wang , linux-kernel@vger.kernel.org Subject: [RFC PATCH v2 1/2] LoongArch: Only clone and clone3 need to call SAVE_STATIC Date: Wed, 15 Jun 2022 14:37:58 +0800 Message-Id: <1655275079-17651-2-git-send-email-yangtiezhu@loongson.cn> X-Mailer: git-send-email 2.1.0 In-Reply-To: <1655275079-17651-1-git-send-email-yangtiezhu@loongson.cn> References: <1655275079-17651-1-git-send-email-yangtiezhu@loongson.cn> X-CM-TRANSID: AQAAf9Dxr99HfqliljRDAA--.20432S3 X-Coremail-Antispam: 1UD129KBjvdXoWrZr1ktw17tr1kWr4UGryrCrg_yoWkuFX_A3 ZrG3yUWrWrAa92vF9rXF4fXasrAw48GF1FkFn2grWjka4UtrWDJwsIvw1UZFn8Kr4kXrs5 ZrWUWF92vr1FkjkaLaAFLSUrUUUUUb8apTn2vfkv8UJUUUU8Yxn0WfASr-VFAUDa7-sFnT 9fnUUIcSsGvfJTRUUUbSkFF20E14v26r4j6ryUM7CY07I20VC2zVCF04k26cxKx2IYs7xG 6rWj6s0DM7CIcVAFz4kK6r1j6r18M28IrcIa0xkI8VA2jI8067AKxVWUGwA2048vs2IY02 0Ec7CjxVAFwI0_JFI_Gr1l8cAvFVAK0II2c7xJM28CjxkF64kEwVA0rcxSw2x7M28EF7xv wVC0I7IYx2IY67AKxVW5JVW7JwA2z4x0Y4vE2Ix0cI8IcVCY1x0267AKxVW8JVWxJwA2z4 x0Y4vEx4A2jsIE14v26F4UJVW0owA2z4x0Y4vEx4A2jsIEc7CjxVAFwI0_GcCE3s1le2I2 62IYc4CY6c8Ij28IcVAaY2xG8wAqx4xG64xvF2IEw4CE5I8CrVC2j2WlYx0E2Ix0cI8IcV AFwI0_Jr0_Jr4lYx0Ex4A2jsIE14v26r4j6F4UMcvjeVCFs4IE7xkEbVWUJVW8JwACjcxG 0xvY0x0EwIxGrwACjI8F5VA0II8E6IAqYI8I648v4I1lc2xSY4AK67AK6r47MxAIw28Icx kI7VAKI48JMxC20s026xCaFVCjc4AY6r1j6r4UMI8I3I0E5I8CrVAFwI0_Jr0_Jr4lx2Iq xVCjr7xvwVAFwI0_JrI_JrWlx4CE17CEb7AF67AKxVWUAVWUtwCIc40Y0x0EwIxGrwCI42 IY6xIIjxv20xvE14v26r1j6r1xMIIF0xvE2Ix0cI8IcVCY1x0267AKxVW8JVWxJwCI42IY 6xAIw20EY4v20xvaj40_Jr0_JF4lIxAIcVC2z280aVAFwI0_Gr0_Cr1lIxAIcVC2z280aV CY1x0267AKxVW8JVW8JrUvcSsGvfC2KfnxnUUI43ZEXa7VUU-J5DUUUUU== X-CM-SenderInfo: p1dqw3xlh2x3gn0dqz5rrqw2lrqou0/ X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,SPF_HELO_PASS, SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In handle_syscall, it is unnecessary to call SAVE_STATIC for all syscalls, only clone and clone3 need to do this operation, so it is better to check the syscall number before call SAVE_STATIC. With this patch, it can reduce many store instructions. Signed-off-by: Tiezhu Yang --- arch/loongarch/kernel/entry.S | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/arch/loongarch/kernel/entry.S b/arch/loongarch/kernel/entry.S index d5b3dbc..53ce2cb 100644 --- a/arch/loongarch/kernel/entry.S +++ b/arch/loongarch/kernel/entry.S @@ -14,6 +14,7 @@ #include #include #include +#include .text .cfi_sections .debug_frame @@ -56,8 +57,21 @@ SYM_FUNC_START(handle_syscall) cfi_st u0, PT_R21 cfi_st fp, PT_R22 + /* + * Syscall number held in a7 which is stored in PT_R11. + * Only if syscall number is __NR_clone and __NR_clone3, call SAVE_STATIC. + */ + cfi_ld t3, PT_R11 + li.w t4, __NR_clone + beq t3, t4, 1f + li.w t4, __NR_clone3 + beq t3, t4, 1f + b 2f + +1: SAVE_STATIC +2: move u0, t0 li.d tp, ~_THREAD_MASK and tp, tp, sp -- 2.1.0