Received: by 2002:a05:6359:c8b:b0:c7:702f:21d4 with SMTP id go11csp1762474rwb; Fri, 23 Sep 2022 18:53:10 -0700 (PDT) X-Google-Smtp-Source: AMsMyM5CbVudkApJLTXnMZa+eFsgzmV7RJF9xsrwdtiot14hn01kd9b3HyiNPdYu0ocUepa6hWCm X-Received: by 2002:a17:903:1110:b0:178:9f67:b543 with SMTP id n16-20020a170903111000b001789f67b543mr11204102plh.131.1663984390625; Fri, 23 Sep 2022 18:53:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1663984390; cv=none; d=google.com; s=arc-20160816; b=C0nJGTK9e8GbqqZpRTm7zoWtlgMzl9puKB8s2w0WSuOHy9pwMggSw2rvm9xf8pWOxu d/3vkmn3X8InSI77CrNl1EY/A/i92gmiC2dDcRvhISn3RMbF1ljCvIcmj0uLax2GkE2w rkvDw/gpvMWy97/EcpgWKQU2S6HKrgXKzSWEjnqwblqfDlYoNxebiT/5sdYM+XVxUtfN HOIBf2d8iEHl5Ccm/ftgK/ajTbnhzHbcce7W+X/41Q5fgL21zi3LcuKqnO/I5L9SBqVc l7TvBo7NmjUlsZdAFkKe0Ks9FiklhchG0r4c8jLxBTe+8hvNRHgpAUsc+oaO07ozw4HC Z7Rw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :to:subject; bh=u1sv2ha5kyu2eaGRKyFIpw7nig/SjT6pZzZeDS2unHk=; b=IktDbbjCSkXfaqmu5t2GvW275EUxzbznlkkl2mvc5hIxGwge+iPSfo87UUtt0RNKbW n/JUeIuy7tGfWzidU4/G2OSUqKhnjslEbVfVeGPhwXj4mmtFa07Be3LEK03IVyZ3gnn9 /DFtiva3WSvS3gjgFv1qXflm13eOT0AIuPHfTycDEwxtgopX71vSJZ9HsCy5fQ/Vkt+Z QNIFwNGnIbILgEuy4s422sx9F0FZdK9/O1XSC5uH/Zy6guRxJ8JSu9j9QV+YfGwp+QiD Jjfk4+2WRG7ey3NHHh17M16rsPxm0ebm3HetjIu+qxn9a82vz4p+gkDrzA3uWVnRpjA9 sGpQ== 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; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id h18-20020a170902f7d200b00174acacf74bsi4064129plw.562.2022.09.23.18.52.59; Fri, 23 Sep 2022 18:53:10 -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; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232818AbiIXBLm (ORCPT + 99 others); Fri, 23 Sep 2022 21:11:42 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54002 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230514AbiIXBLl (ORCPT ); Fri, 23 Sep 2022 21:11:41 -0400 Received: from szxga01-in.huawei.com (szxga01-in.huawei.com [45.249.212.187]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E9BBA121115; Fri, 23 Sep 2022 18:11:38 -0700 (PDT) Received: from dggpemm500023.china.huawei.com (unknown [172.30.72.57]) by szxga01-in.huawei.com (SkyGuard) with ESMTP id 4MZ9q22WDNzlXYM; Sat, 24 Sep 2022 09:07:26 +0800 (CST) Received: from dggpemm500006.china.huawei.com (7.185.36.236) by dggpemm500023.china.huawei.com (7.185.36.83) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.31; Sat, 24 Sep 2022 09:11:36 +0800 Received: from [10.174.178.55] (10.174.178.55) by dggpemm500006.china.huawei.com (7.185.36.236) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.31; Sat, 24 Sep 2022 09:11:36 +0800 Subject: Re: [PATCH v5 08/10] livepatch: Improve the search performance of module_kallsyms_on_each_symbol() To: Josh Poimboeuf , Jiri Kosina , Miroslav Benes , Petr Mladek , Joe Lawrence , , , Masahiro Yamada , Alexei Starovoitov , Jiri Olsa , Kees Cook , Andrew Morton , "Luis Chamberlain" , , "Steven Rostedt" , Ingo Molnar References: <20220923112033.1958-1-thunder.leizhen@huawei.com> <20220923112033.1958-9-thunder.leizhen@huawei.com> From: "Leizhen (ThunderTown)" Message-ID: <4ef46874-4dbc-2663-ebad-7adbbbfa3b18@huawei.com> Date: Sat, 24 Sep 2022 09:11:24 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:60.0) Gecko/20100101 Thunderbird/60.7.0 MIME-Version: 1.0 In-Reply-To: <20220923112033.1958-9-thunder.leizhen@huawei.com> Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 7bit X-Originating-IP: [10.174.178.55] X-ClientProxiedBy: dggems703-chm.china.huawei.com (10.3.19.180) To dggpemm500006.china.huawei.com (7.185.36.236) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_PASS 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 On 2022/9/23 19:20, Zhen Lei wrote: > Currently we traverse all symbols of all modules to find the specified > function for the specified module. But in reality, we just need to find > the given module and then traverse all the symbols in it. > > In order to achieve this purpose, split the call to hook 'fn' into two > phases: > 1. Finds the given module. Pass pointer 'mod'. Hook 'fn' directly returns > the comparison result of the module name without comparing the function > name. > 2. Finds the given function in that module. Pass pointer 'mod = NULL'. > Hook 'fn' skip the comparison of module name and directly compare > function names. Sorry, I forgot to change the description. I will fix it in v6, after I've collected review comments. > > Phase1: mod1-->mod2..(subsequent modules do not need to be compared) > | > Phase2: -->f1-->f2-->f3 > > Signed-off-by: Zhen Lei > --- > include/linux/module.h | 4 ++-- > kernel/livepatch/core.c | 13 ++----------- > kernel/module/kallsyms.c | 15 ++++++++++++--- > 3 files changed, 16 insertions(+), 16 deletions(-) > > diff --git a/include/linux/module.h b/include/linux/module.h > index 518296ea7f73af6..6e1a531d78e7e8b 100644 > --- a/include/linux/module.h > +++ b/include/linux/module.h > @@ -879,8 +879,8 @@ static inline bool module_sig_ok(struct module *module) > } > #endif /* CONFIG_MODULE_SIG */ > > -int module_kallsyms_on_each_symbol(int (*fn)(void *, const char *, > - struct module *, unsigned long), > +int module_kallsyms_on_each_symbol(const char *modname, > + int (*fn)(void *, const char *, unsigned long), > void *data); > > #endif /* _LINUX_MODULE_H */ > diff --git a/kernel/livepatch/core.c b/kernel/livepatch/core.c > index 31b57ccf908017e..b02de4cb311c703 100644 > --- a/kernel/livepatch/core.c > +++ b/kernel/livepatch/core.c > @@ -118,27 +118,19 @@ static struct klp_object *klp_find_object(struct klp_patch *patch, > } > > struct klp_find_arg { > - const char *objname; > const char *name; > unsigned long addr; > unsigned long count; > unsigned long pos; > }; > > -static int klp_find_callback(void *data, const char *name, > - struct module *mod, unsigned long addr) > +static int klp_find_callback(void *data, const char *name, unsigned long addr) > { > struct klp_find_arg *args = data; > > - if ((mod && !args->objname) || (!mod && args->objname)) > - return 0; > - > if (strcmp(args->name, name)) > return 0; > > - if (args->objname && strcmp(args->objname, mod->name)) > - return 0; > - > args->addr = addr; > args->count++; > > @@ -175,7 +167,6 @@ static int klp_find_object_symbol(const char *objname, const char *name, > unsigned long sympos, unsigned long *addr) > { > struct klp_find_arg args = { > - .objname = objname, > .name = name, > .addr = 0, > .count = 0, > @@ -183,7 +174,7 @@ static int klp_find_object_symbol(const char *objname, const char *name, > }; > > if (objname) > - module_kallsyms_on_each_symbol(klp_find_callback, &args); > + module_kallsyms_on_each_symbol(objname, klp_find_callback, &args); > else > kallsyms_on_each_match_symbol(klp_match_callback, name, &args); > > diff --git a/kernel/module/kallsyms.c b/kernel/module/kallsyms.c > index f5c5c9175333df7..329cef573675d49 100644 > --- a/kernel/module/kallsyms.c > +++ b/kernel/module/kallsyms.c > @@ -495,8 +495,8 @@ unsigned long module_kallsyms_lookup_name(const char *name) > } > > #ifdef CONFIG_LIVEPATCH > -int module_kallsyms_on_each_symbol(int (*fn)(void *, const char *, > - struct module *, unsigned long), > +int module_kallsyms_on_each_symbol(const char *modname, > + int (*fn)(void *, const char *, unsigned long), > void *data) > { > struct module *mod; > @@ -510,6 +510,9 @@ int module_kallsyms_on_each_symbol(int (*fn)(void *, const char *, > if (mod->state == MODULE_STATE_UNFORMED) > continue; > > + if (strcmp(modname, mod->name)) > + continue; > + > /* Use rcu_dereference_sched() to remain compliant with the sparse tool */ > preempt_disable(); > kallsyms = rcu_dereference_sched(mod->kallsyms); > @@ -522,10 +525,16 @@ int module_kallsyms_on_each_symbol(int (*fn)(void *, const char *, > continue; > > ret = fn(data, kallsyms_symbol_name(kallsyms, i), > - mod, kallsyms_symbol_value(sym)); > + kallsyms_symbol_value(sym)); > if (ret != 0) > goto out; > } > + > + /* > + * The given module is found, the subsequent modules do not > + * need to be compared. > + */ > + break; > } > out: > mutex_unlock(&module_mutex); > -- Regards, Zhen Lei