Received: by 2002:a05:6358:16cc:b0:ea:6187:17c9 with SMTP id r12csp6867109rwl; Thu, 29 Dec 2022 23:00:20 -0800 (PST) X-Google-Smtp-Source: AMrXdXu3XtKhJ3uSsY3HBwGRAVrNJWFHjMuUIz1Yk2L9OfpN0XVrToT2CZvjhEh1g9KvPHiQadBJ X-Received: by 2002:aa7:c395:0:b0:48a:cae7:71db with SMTP id k21-20020aa7c395000000b0048acae771dbmr1442214edq.21.1672383620389; Thu, 29 Dec 2022 23:00:20 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1672383620; cv=none; d=google.com; s=arc-20160816; b=ceNMqetmBv0rHM7JPVGg9oLJ8l3I3pBjq9ppLmD9Kcyg7jiL9DHQ1loj/IEMD8SzRn ga56d/MjBqvhsKSrT4GdeecO0wprS3LmedOaDQCjOW4w/t7IDFYjl7xrUjPuFLoGEQ1x xV6JrhoqVh+4ENS+oPfPrQkly2W5JvNL/KkU0RslN6jV5YjDRl0yLvqmATKEAmrZqrZG u0NJN87T75Yg6wKZbnQf0+ZzRAwiNcSAulameVrbvmwc7YsHzyFCwHwZkZswQxSVeQ72 jyQ91BldRORQaviuGHZofBSy8Z1IKm+SJbl9sw3EqDCeuBXSoVE7c6vnWvbF1pcIp+S6 bgNA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:subject:cc:to:from:sender :hmm_source_type:hmm_attache_num:hmm_source_ip; bh=nkFfDPWQf+60+rsJMcAPg1BpiLbT5ig0HM315L6jtGw=; b=qM2jBHcgmRj8I5yhyg3z1Tl3Q8VqXr7BV66GfdmDXPJcTtYRLaJZe3oYgDs0I/ZMRF u3396qdDLZjituBF/7FapLt/K8ZNy+DEHiwJEtXzI6IzDWQXnfuU2IxfTuYQ8lYu09QT qEy+/5n3NV9HvHhPgSNFkD/0Hs5yaFkiAbMqbIzfEUyUyzHTbHmWlN3wh7JhqF+NIcn1 7v1PpY+y1Fhdga/v5r3Bn06ByIiSxG8kNUgxQ2900Vy7lDuEO8pu4K2SojoTK9Gt0Zro ltw/NPIj3pFobGBgyy0QrRmpERqZAnEXRx1MMYLxG9WmnSlDYx4SUkIOqw0DVyuzGci4 84Ig== 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 fd6-20020a056402388600b004844b4fe450si11743699edb.407.2022.12.29.23.00.04; Thu, 29 Dec 2022 23:00:20 -0800 (PST) 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 S234676AbiL3G0n (ORCPT + 64 others); Fri, 30 Dec 2022 01:26:43 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39606 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234673AbiL3G02 (ORCPT ); Fri, 30 Dec 2022 01:26:28 -0500 Received: from 189.cn (ptr.189.cn [183.61.185.102]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id BB10AE10; Thu, 29 Dec 2022 22:26:26 -0800 (PST) HMM_SOURCE_IP: 10.64.8.43:59430.503948632 HMM_ATTACHE_NUM: 0000 HMM_SOURCE_TYPE: SMTP Received: from clientip-123.150.8.42 (unknown [10.64.8.43]) by 189.cn (HERMES) with SMTP id 139AE100283; Fri, 30 Dec 2022 14:26:25 +0800 (CST) Received: from ([123.150.8.42]) by gateway-153622-dep-79f476db8-qhshz with ESMTP id 10773a193faf4068ae3c9f824be272f0 for rostedt@goodmis.org; Fri, 30 Dec 2022 14:26:26 CST X-Transaction-ID: 10773a193faf4068ae3c9f824be272f0 X-Real-From: chensong_2000@189.cn X-Receive-IP: 123.150.8.42 X-MEDUSA-Status: 0 Sender: chensong_2000@189.cn From: Song Chen To: rostedt@goodmis.org, mhiramat@kernel.org, arnd@arndb.de Cc: linux-kernel@vger.kernel.org, linux-trace-kernel@vger.kernel.org, linux-arch@vger.kernel.org, Song Chen Subject: [PATCH v5 3/3] kernel/trace: extract common part in process_fetch_insn Date: Fri, 30 Dec 2022 14:33:53 +0800 Message-Id: <1672382033-18390-1-git-send-email-chensong_2000@189.cn> X-Mailer: git-send-email 2.7.4 X-Spam-Status: No, score=-1.7 required=5.0 tests=BAYES_00, FREEMAIL_ENVFROM_END_DIGIT,FREEMAIL_FROM,RCVD_IN_MSPIKE_H2, SPF_HELO_PASS,SPF_PASS autolearn=no 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 Each probe has an instance of process_fetch_insn respectively, but they have something in common. This patch aims to extract the common part into process_common_fetch_insn which can be shared by each probe, and they only need to focus on their special cases. Signed-off-by: Song Chen Suggested-by: Masami Hiramatsu --- kernel/trace/trace_eprobe.c | 26 ++++++-------------------- kernel/trace/trace_kprobe.c | 14 ++++---------- kernel/trace/trace_probe_tmpl.h | 20 ++++++++++++++++++++ kernel/trace/trace_uprobe.c | 11 ++++------- 4 files changed, 34 insertions(+), 37 deletions(-) diff --git a/kernel/trace/trace_eprobe.c b/kernel/trace/trace_eprobe.c index ca5d097eec4f..bff0f48f4b44 100644 --- a/kernel/trace/trace_eprobe.c +++ b/kernel/trace/trace_eprobe.c @@ -395,20 +395,12 @@ static int get_eprobe_size(struct trace_probe *tp, void *rec) case FETCH_OP_TP_ARG: val = get_event_field(code, rec); break; - case FETCH_OP_IMM: - val = code->immediate; - break; - case FETCH_OP_COMM: - val = (unsigned long)current->comm; - break; - case FETCH_OP_DATA: - val = (unsigned long)code->data; - break; case FETCH_NOP_SYMBOL: /* Ignore a place holder */ code++; goto retry; default: - continue; + if (process_common_fetch_insn(code, &val) < 0) + continue; } code++; len = process_fetch_insn_bottom(code, val, NULL, NULL); @@ -428,26 +420,20 @@ process_fetch_insn(struct fetch_insn *code, void *rec, void *dest, void *base) { unsigned long val; + int ret; retry: switch (code->op) { case FETCH_OP_TP_ARG: val = get_event_field(code, rec); break; - case FETCH_OP_IMM: - val = code->immediate; - break; - case FETCH_OP_COMM: - val = (unsigned long)current->comm; - break; - case FETCH_OP_DATA: - val = (unsigned long)code->data; - break; case FETCH_NOP_SYMBOL: /* Ignore a place holder */ code++; goto retry; default: - return -EILSEQ; + ret = process_common_fetch_insn(code, &val); + if (ret < 0) + return ret; } code++; return process_fetch_insn_bottom(code, val, dest, base); diff --git a/kernel/trace/trace_kprobe.c b/kernel/trace/trace_kprobe.c index 714fe9c04eb6..af8b2023a76b 100644 --- a/kernel/trace/trace_kprobe.c +++ b/kernel/trace/trace_kprobe.c @@ -1225,6 +1225,7 @@ process_fetch_insn(struct fetch_insn *code, void *rec, void *dest, { struct pt_regs *regs = rec; unsigned long val; + int ret; retry: /* 1st stage: get value from context */ @@ -1241,15 +1242,6 @@ process_fetch_insn(struct fetch_insn *code, void *rec, void *dest, case FETCH_OP_RETVAL: val = regs_return_value(regs); break; - case FETCH_OP_IMM: - val = code->immediate; - break; - case FETCH_OP_COMM: - val = (unsigned long)current->comm; - break; - case FETCH_OP_DATA: - val = (unsigned long)code->data; - break; #ifdef CONFIG_HAVE_FUNCTION_ARG_ACCESS_API case FETCH_OP_ARG: val = regs_get_kernel_argument(regs, code->param); @@ -1259,7 +1251,9 @@ process_fetch_insn(struct fetch_insn *code, void *rec, void *dest, code++; goto retry; default: - return -EILSEQ; + ret = process_common_fetch_insn(code, &val); + if (ret < 0) + return ret; } code++; diff --git a/kernel/trace/trace_probe_tmpl.h b/kernel/trace/trace_probe_tmpl.h index 1b57420857e1..17258eca0125 100644 --- a/kernel/trace/trace_probe_tmpl.h +++ b/kernel/trace/trace_probe_tmpl.h @@ -67,6 +67,26 @@ probe_mem_read(void *dest, void *src, size_t size); static nokprobe_inline int probe_mem_read_user(void *dest, void *src, size_t size); +/* common part of process_fetch_insn*/ +static nokprobe_inline int +process_common_fetch_insn(struct fetch_insn *code, unsigned long *val) +{ + switch (code->op) { + case FETCH_OP_IMM: + *val = code->immediate; + break; + case FETCH_OP_COMM: + *val = (unsigned long)current->comm; + break; + case FETCH_OP_DATA: + *val = (unsigned long)code->data; + break; + default: + return -EILSEQ; + } + return 0; +} + /* From the 2nd stage, routine is same */ static nokprobe_inline int process_fetch_insn_bottom(struct fetch_insn *code, unsigned long val, diff --git a/kernel/trace/trace_uprobe.c b/kernel/trace/trace_uprobe.c index 1ff8f87211a6..c53b0752533f 100644 --- a/kernel/trace/trace_uprobe.c +++ b/kernel/trace/trace_uprobe.c @@ -220,6 +220,7 @@ process_fetch_insn(struct fetch_insn *code, void *rec, void *dest, { struct pt_regs *regs = rec; unsigned long val; + int ret; /* 1st stage: get value from context */ switch (code->op) { @@ -235,20 +236,16 @@ process_fetch_insn(struct fetch_insn *code, void *rec, void *dest, case FETCH_OP_RETVAL: val = regs_return_value(regs); break; - case FETCH_OP_IMM: - val = code->immediate; - break; case FETCH_OP_COMM: val = FETCH_TOKEN_COMM; break; - case FETCH_OP_DATA: - val = (unsigned long)code->data; - break; case FETCH_OP_FOFFS: val = translate_user_vaddr(code->immediate); break; default: - return -EILSEQ; + ret = process_common_fetch_insn(code, &val); + if (ret < 0) + return ret; } code++; -- 2.25.1