Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp4387384iob; Sun, 8 May 2022 11:03:15 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxpjb8kpb6OgO2Kr8o0QEIB9fGxJaHGafDOa43UcjAv9Q5oW9AlKt9s+cWLW0s/a6NhX94S X-Received: by 2002:a05:6a00:10cc:b0:506:e0:d6c3 with SMTP id d12-20020a056a0010cc00b0050600e0d6c3mr12395169pfu.33.1652032995158; Sun, 08 May 2022 11:03:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1652032995; cv=none; d=google.com; s=arc-20160816; b=MC3DESiLpd435mv9XzT5CWUmLUqBL80rprfje9Qx/4owym83+LMiHV/MBxCvqELzdh EatgcM4npa+eF79qJ1wtjRmRtesnaJZZSilWenPjbuOze8iBPPfr4IzUJdxrafhG/Qu7 fD9bym95GrEuw7v2h6GFf5WvMUycPuXWAsgqTKK9uInrq2kqrYv9pR4n8xVOBn+T+mz3 MHolNIbR1SO40fS6LkrACabsuM8ORMdG8/6AxvwlTq4K4MkNZVePhCIa1gegGVhkuy2t YHLoshZi/oINmwR0HQFSj5iKUiTeXGiQXnNS3I8w0pywl9w7vh0601iKtOJaKYHvZ4WR 8z1Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=HWpuzfDoYn0p1lrAIAyg/V5gRGHjZrxOX5JD1m9N4lI=; b=VN5/xTcLoi9GGjgNkPEmh+Ik6wUqlDVMuxw9rjYGnnTsY5TIB7sDZNz+0CFsyQ8ix3 spT4N3oVmOivj3IKyGqDQB8vYG8UHRARqf/whN8V7BOhHHbRYcE+1cI1YoupC7A5zyp2 DVrzKV6zJJT65x/KBMD4lR2qb7NE8CzjMG31dPN/gIuho0EJbpOHbhFdmvUgnXuvUaAv x4Bxf+bP24+yr1zosX5d3jqyEsjY1h9TIb3esMgjqf7Eqx6Dz4LCpEx+2Yx/B+5CsJE5 jdbNHUaBP8kUTem04VQjhXIrr2Xe2YXISGgTu/Oioe7Y7ecdLo46KDTjy6KnBVRMLss1 nWmg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=WTYvHliG; 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=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id n10-20020a170902f60a00b0015e8c77a56bsi8417510plg.570.2022.05.08.11.02.59; Sun, 08 May 2022 11:03:15 -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; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=WTYvHliG; 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=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1446418AbiEGNB2 (ORCPT + 99 others); Sat, 7 May 2022 09:01:28 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34100 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1446417AbiEGNBY (ORCPT ); Sat, 7 May 2022 09:01:24 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [IPv6:2604:1380:4641:c500::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 0005213E92; Sat, 7 May 2022 05:57:37 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 87D9161204; Sat, 7 May 2022 12:57:37 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 2B7A9C385A5; Sat, 7 May 2022 12:57:34 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1651928256; bh=KAiQ5W5hAGDU6i4Df8wj0mhvFdTYADJ80j8ZSN2MJIk=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=WTYvHliGf+ax5OUbfGeiJmyKeNbqR25sZuqcVGsIBoigkaag+SXggvnpQbvkyR1KY pfKb/zosKmfnlUg2/UTPwhC24OPe7p545vHdLkwRZlkLPfHEgZZ5z5IiEqq8kMau00 0+9S3soRzAoEvfFjZa4qy2Q62tKn8XhG2AgqC5RBeqdRoHdv9R9IxvDJxKXEafl7XL 0zmdA+XBZ3kdqvcVkSHiIh0JCotzPWzIAA6Rhzy1g2AUbINc9Jgp+5dE/SwDPXXNsO hOY2BgSGM6tppKyOld9bn7J/z0Z5MGhO9kDgIcZXrCanHO6HKlU64l09NXjWyOxtdC 8U0mN5nKjE/YA== From: Jiri Olsa To: Alexei Starovoitov , Daniel Borkmann , Andrii Nakryiko , Masami Hiramatsu Cc: netdev@vger.kernel.org, bpf@vger.kernel.org, lkml , Martin KaFai Lau , Song Liu , Yonghong Song , John Fastabend , KP Singh , Steven Rostedt Subject: [PATCHv5 bpf-next 2/5] ftrace: Add ftrace_lookup_symbols function Date: Sat, 7 May 2022 14:57:08 +0200 Message-Id: <20220507125711.2022238-3-jolsa@kernel.org> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220507125711.2022238-1-jolsa@kernel.org> References: <20220507125711.2022238-1-jolsa@kernel.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.7 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,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 Adding ftrace_lookup_symbols function that resolves array of symbols with single pass over kallsyms. The user provides array of string pointers with count and pointer to allocated array for resolved values. int ftrace_lookup_symbols(const char **sorted_syms, size_t cnt, unsigned long *addrs) It iterates all kallsyms symbols and tries to loop up each in provided symbols array with bsearch. The symbols array needs to be sorted by name for this reason. We also check each symbol to pass ftrace_location, because this API will be used for fprobe symbols resolving. Suggested-by: Andrii Nakryiko Acked-by: Andrii Nakryiko Reviewed-by: Masami Hiramatsu Signed-off-by: Jiri Olsa --- include/linux/ftrace.h | 6 ++++ kernel/kallsyms.c | 1 + kernel/trace/ftrace.c | 62 ++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 69 insertions(+) diff --git a/include/linux/ftrace.h b/include/linux/ftrace.h index 4816b7e11047..820500430eae 100644 --- a/include/linux/ftrace.h +++ b/include/linux/ftrace.h @@ -303,6 +303,8 @@ int unregister_ftrace_function(struct ftrace_ops *ops); extern void ftrace_stub(unsigned long a0, unsigned long a1, struct ftrace_ops *op, struct ftrace_regs *fregs); + +int ftrace_lookup_symbols(const char **sorted_syms, size_t cnt, unsigned long *addrs); #else /* !CONFIG_FUNCTION_TRACER */ /* * (un)register_ftrace_function must be a macro since the ops parameter @@ -313,6 +315,10 @@ extern void ftrace_stub(unsigned long a0, unsigned long a1, static inline void ftrace_kill(void) { } static inline void ftrace_free_init_mem(void) { } static inline void ftrace_free_mem(struct module *mod, void *start, void *end) { } +static inline int ftrace_lookup_symbols(const char **sorted_syms, size_t cnt, unsigned long *addrs) +{ + return -EOPNOTSUPP; +} #endif /* CONFIG_FUNCTION_TRACER */ struct ftrace_func_entry { diff --git a/kernel/kallsyms.c b/kernel/kallsyms.c index fdfd308bebc4..fbdf8d3279ac 100644 --- a/kernel/kallsyms.c +++ b/kernel/kallsyms.c @@ -29,6 +29,7 @@ #include #include #include +#include /* * These will be re-linked against their real values diff --git a/kernel/trace/ftrace.c b/kernel/trace/ftrace.c index 4f1d2f5e7263..07d87c7a525d 100644 --- a/kernel/trace/ftrace.c +++ b/kernel/trace/ftrace.c @@ -7964,3 +7964,65 @@ ftrace_enable_sysctl(struct ctl_table *table, int write, mutex_unlock(&ftrace_lock); return ret; } + +static int symbols_cmp(const void *a, const void *b) +{ + const char **str_a = (const char **) a; + const char **str_b = (const char **) b; + + return strcmp(*str_a, *str_b); +} + +struct kallsyms_data { + unsigned long *addrs; + const char **syms; + size_t cnt; + size_t found; +}; + +static int kallsyms_callback(void *data, const char *name, + struct module *mod, unsigned long addr) +{ + struct kallsyms_data *args = data; + + if (!bsearch(&name, args->syms, args->cnt, sizeof(*args->syms), symbols_cmp)) + return 0; + + addr = ftrace_location(addr); + if (!addr) + return 0; + + args->addrs[args->found++] = addr; + return args->found == args->cnt ? 1 : 0; +} + +/** + * ftrace_lookup_symbols - Lookup addresses for array of symbols + * + * @sorted_syms: array of symbols pointers symbols to resolve, + * must be alphabetically sorted + * @cnt: number of symbols/addresses in @syms/@addrs arrays + * @addrs: array for storing resulting addresses + * + * This function looks up addresses for array of symbols provided in + * @syms array (must be alphabetically sorted) and stores them in + * @addrs array, which needs to be big enough to store at least @cnt + * addresses. + * + * This function returns 0 if all provided symbols are found, + * -ESRCH otherwise. + */ +int ftrace_lookup_symbols(const char **sorted_syms, size_t cnt, unsigned long *addrs) +{ + struct kallsyms_data args; + int err; + + args.addrs = addrs; + args.syms = sorted_syms; + args.cnt = cnt; + args.found = 0; + err = kallsyms_on_each_symbol(kallsyms_callback, &args); + if (err < 0) + return err; + return args.found == args.cnt ? 0 : -ESRCH; +} -- 2.35.1