Received: by 2002:ab2:69cc:0:b0:1fd:c486:4f03 with SMTP id n12csp275349lqp; Tue, 11 Jun 2024 04:24:24 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCVVVLqrq8FDeaTdegNDbJVR7RLjiNELre5VaoFpR4P3PRx4UU5Ow7VqoTWr/QpQKZjEnY0ndIDJV/BEPcDH/0UYeTUrST88f+cnlmzl7A== X-Google-Smtp-Source: AGHT+IGNdZmhvagZb+sx9AE3h+arqInlyEvhSdKhR81EaaiiDL2WNXT6yCnJbPtDYtAMQ5H5pa65 X-Received: by 2002:a17:902:cecd:b0:1f7:18f4:8114 with SMTP id d9443c01a7336-1f718f4839fmr68840185ad.35.1718105064096; Tue, 11 Jun 2024 04:24:24 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1718105064; cv=pass; d=google.com; s=arc-20160816; b=VboZ7JqWz9wrFErUks2ON1887ycb9t4ZylWbqpSMv2u7Ij4eifkmTiS+ZFcfjBKwj9 TQcxQDaISOeUsMWVdiSjiEKdJqSgV+wpF1E2zU/8CMy6UkxGHoSlQP5DLmvR7a0wpdhG +GXGqURCIp2mDyWXCBQa+0xvNb+fOn2GMhzSifb8mje6eWT+7Hv63VX6YdJ2aN5pv9Rv Qywa5g94OXcSOezcwlZ3ac91GG36PjNSzvi2dJ7O1z2hAzDdjEaAk4fHC4iM3me/hPyO zbKfGUnm6c9aoeJ0Tqfu56c83B9it7Nzi2kelKbjY2m60m7u3Ld4NEY4+n/yIee53ZVB iNOw== ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=content-transfer-encoding:mime-version:list-unsubscribe :list-subscribe:list-id:precedence:references:in-reply-to:message-id :date:subject:cc:to:from:dkim-signature; bh=n69Xb76OxvaWH4Gj22fMtlRb9UAxXueI1sLr5/42Gnc=; fh=nmDo0evxWwTAvBlxNELHY/fYZbxD4K9pluaUjPt1MrQ=; b=rrmhTt6lTqW3NgDATbyvKtjnN11zIoYUGQ9mKWnWMpw932NWhX+iIONw31jJOpIjrT 14DSdM45+lh20AN/qKtaDIUm+ZtrYk2GRE9v/AVIxBZLdey05bivRqFMu/99w9uV/t02 lo9eB41a/QvIss4eiziXR+lsmEGT2DKzXOwDMSGqi3O5rcfp/Vr2zGM6MH6n1kE94ivb UAMlgaD1/7+USOIfsJnOuLNxPoKAO18U4EgEKDGOEdHdqZlJ3UXfSfK+QrTfcEdnpS41 Cam+f+i8vcVamJHkACi1o4gvnXXI791C4KuxBQ8MzJXaoFufhBXth99Wq2t14h6/b/yq vgtg==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=ZDPpeosE; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-209723-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-209723-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from sv.mirrors.kernel.org (sv.mirrors.kernel.org. [139.178.88.99]) by mx.google.com with ESMTPS id d9443c01a7336-1f70827b51bsi42135825ad.376.2024.06.11.04.24.23 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 11 Jun 2024 04:24:24 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-209723-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) client-ip=139.178.88.99; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=ZDPpeosE; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-209723-linux.lists.archive=gmail.com@vger.kernel.org designates 139.178.88.99 as permitted sender) smtp.mailfrom="linux-kernel+bounces-209723-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from smtp.subspace.kernel.org (wormhole.subspace.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by sv.mirrors.kernel.org (Postfix) with ESMTPS id AEB232867A0 for ; Tue, 11 Jun 2024 11:24:23 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 6D25617C21B; Tue, 11 Jun 2024 11:23:32 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="ZDPpeosE" Received: from smtp.kernel.org (aws-us-west-2-korg-mail-1.web.codeaurora.org [10.30.226.201]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 7D48417B43C; Tue, 11 Jun 2024 11:23:31 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=10.30.226.201 ARC-Seal:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1718105011; cv=none; b=U5AbgSwEK9MtG+vpYXkMEz2F30Wd7q8dGSzAT398AhzaAF9MwhsjfqMo9WK9hSrEWz1b4h/qgtUlKLeggKTee676ugJLrJZK/Lqhnmj27AqyMNAC8CB5zekacaUaxFI9w8qsGQIHDnQ2Z4V3cp503bDjBvBG57Ay6TqE1k7tSe0= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1718105011; c=relaxed/simple; bh=DS7+Hm0OTr8osb55SvuyMe5tP8h/Tdu7u34TgYWZPvY=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=F62dBn8OSxiMJydSxHqJ7jIp852aGfQEW9DV4lXFKH06dtUcC3PicPUkWCz+Y8tCB2f6kqA+PPVvhzkFR4jv7LCQiPvpFdyviJqyyd6WDE1FkIFg/OMr5uKsTHsP4N8HpGeYobgb3szzIRkPGc3CggpNErJ/n5DWip/VopYzefo= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=ZDPpeosE; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id 96188C2BD10; Tue, 11 Jun 2024 11:23:26 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1718105011; bh=DS7+Hm0OTr8osb55SvuyMe5tP8h/Tdu7u34TgYWZPvY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=ZDPpeosE+xJNrxZxbqf+GIQzdu1azY0JaPfrO+WFsnebOBCD9J+ZdvlkdKE1GZ3kY x1FEJB0f2M4nTLyuQ991TK1EDwlRq0YWSvX1clzNuRqV+li1OGR7mx4B0Ay8X9NxxJ x3FR3iiAN3IK8MzqPU83AXPyX7S2IIU2UZXuy4Y4TvhE2Ii6afukrdAGFTlExSzK30 cAJRsBiNBhWkkP3XrVC98aUxQHAsH6Ji5mZlaf7McUjoBpdvGy+4ZhnFPB+ASP3y4t SQbCFiWbuI+Ddr1ibAQ5akPC3T6VWPaPmXkcHSJyDQifFMqh3AkG9jEpjwPuOA9Oa0 lINLeKphbq8vQ== From: Jiri Olsa To: Steven Rostedt , Masami Hiramatsu , Oleg Nesterov , Alexei Starovoitov , Daniel Borkmann , Andrii Nakryiko Cc: linux-kernel@vger.kernel.org, linux-trace-kernel@vger.kernel.org, linux-api@vger.kernel.org, linux-man@vger.kernel.org, x86@kernel.org, bpf@vger.kernel.org, Song Liu , Yonghong Song , John Fastabend , Peter Zijlstra , Thomas Gleixner , "Borislav Petkov (AMD)" , Ingo Molnar , Andy Lutomirski , "Edgecombe, Rick P" , Deepak Gupta Subject: [PATCHv8 bpf-next 7/9] selftests/bpf: Add uretprobe syscall call from user space test Date: Tue, 11 Jun 2024 13:21:56 +0200 Message-ID: <20240611112158.40795-8-jolsa@kernel.org> X-Mailer: git-send-email 2.45.1 In-Reply-To: <20240611112158.40795-1-jolsa@kernel.org> References: <20240611112158.40795-1-jolsa@kernel.org> Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Adding test to verify that when called from outside of the trampoline provided by kernel, the uretprobe syscall will cause calling process to receive SIGILL signal and the attached bpf program is not executed. Acked-by: Andrii Nakryiko Reviewed-by: Masami Hiramatsu (Google) Signed-off-by: Jiri Olsa --- .../selftests/bpf/prog_tests/uprobe_syscall.c | 95 +++++++++++++++++++ .../bpf/progs/uprobe_syscall_executed.c | 17 ++++ 2 files changed, 112 insertions(+) create mode 100644 tools/testing/selftests/bpf/progs/uprobe_syscall_executed.c diff --git a/tools/testing/selftests/bpf/prog_tests/uprobe_syscall.c b/tools/testing/selftests/bpf/prog_tests/uprobe_syscall.c index 1a50cd35205d..11ccd693ef73 100644 --- a/tools/testing/selftests/bpf/prog_tests/uprobe_syscall.c +++ b/tools/testing/selftests/bpf/prog_tests/uprobe_syscall.c @@ -7,7 +7,10 @@ #include #include #include +#include +#include #include "uprobe_syscall.skel.h" +#include "uprobe_syscall_executed.skel.h" __naked unsigned long uretprobe_regs_trigger(void) { @@ -209,6 +212,91 @@ static void test_uretprobe_regs_change(void) } } +#ifndef __NR_uretprobe +#define __NR_uretprobe 463 +#endif + +__naked unsigned long uretprobe_syscall_call_1(void) +{ + /* + * Pretend we are uretprobe trampoline to trigger the return + * probe invocation in order to verify we get SIGILL. + */ + asm volatile ( + "pushq %rax\n" + "pushq %rcx\n" + "pushq %r11\n" + "movq $" __stringify(__NR_uretprobe) ", %rax\n" + "syscall\n" + "popq %r11\n" + "popq %rcx\n" + "retq\n" + ); +} + +__naked unsigned long uretprobe_syscall_call(void) +{ + asm volatile ( + "call uretprobe_syscall_call_1\n" + "retq\n" + ); +} + +static void test_uretprobe_syscall_call(void) +{ + LIBBPF_OPTS(bpf_uprobe_multi_opts, opts, + .retprobe = true, + ); + struct uprobe_syscall_executed *skel; + int pid, status, err, go[2], c; + + if (ASSERT_OK(pipe(go), "pipe")) + return; + + skel = uprobe_syscall_executed__open_and_load(); + if (!ASSERT_OK_PTR(skel, "uprobe_syscall_executed__open_and_load")) + goto cleanup; + + pid = fork(); + if (!ASSERT_GE(pid, 0, "fork")) + goto cleanup; + + /* child */ + if (pid == 0) { + close(go[1]); + + /* wait for parent's kick */ + err = read(go[0], &c, 1); + if (err != 1) + exit(-1); + + uretprobe_syscall_call(); + _exit(0); + } + + skel->links.test = bpf_program__attach_uprobe_multi(skel->progs.test, pid, + "/proc/self/exe", + "uretprobe_syscall_call", &opts); + if (!ASSERT_OK_PTR(skel->links.test, "bpf_program__attach_uprobe_multi")) + goto cleanup; + + /* kick the child */ + write(go[1], &c, 1); + err = waitpid(pid, &status, 0); + ASSERT_EQ(err, pid, "waitpid"); + + /* verify the child got killed with SIGILL */ + ASSERT_EQ(WIFSIGNALED(status), 1, "WIFSIGNALED"); + ASSERT_EQ(WTERMSIG(status), SIGILL, "WTERMSIG"); + + /* verify the uretprobe program wasn't called */ + ASSERT_EQ(skel->bss->executed, 0, "executed"); + +cleanup: + uprobe_syscall_executed__destroy(skel); + close(go[1]); + close(go[0]); +} #else static void test_uretprobe_regs_equal(void) { @@ -219,6 +307,11 @@ static void test_uretprobe_regs_change(void) { test__skip(); } + +static void test_uretprobe_syscall_call(void) +{ + test__skip(); +} #endif void test_uprobe_syscall(void) @@ -227,4 +320,6 @@ void test_uprobe_syscall(void) test_uretprobe_regs_equal(); if (test__start_subtest("uretprobe_regs_change")) test_uretprobe_regs_change(); + if (test__start_subtest("uretprobe_syscall_call")) + test_uretprobe_syscall_call(); } diff --git a/tools/testing/selftests/bpf/progs/uprobe_syscall_executed.c b/tools/testing/selftests/bpf/progs/uprobe_syscall_executed.c new file mode 100644 index 000000000000..0d7f1a7db2e2 --- /dev/null +++ b/tools/testing/selftests/bpf/progs/uprobe_syscall_executed.c @@ -0,0 +1,17 @@ +// SPDX-License-Identifier: GPL-2.0 +#include "vmlinux.h" +#include +#include + +struct pt_regs regs; + +char _license[] SEC("license") = "GPL"; + +int executed = 0; + +SEC("uretprobe.multi") +int test(struct pt_regs *regs) +{ + executed = 1; + return 0; +} -- 2.45.1