Received: by 2002:a89:288:0:b0:1f7:eeee:6653 with SMTP id j8csp434519lqh; Tue, 7 May 2024 03:57:32 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCWJI0DHv+EO1EIdDiloGYAWEHCNlXGOg5W6OxC4FrsrFRMuB81dO2K5Kb+D63CAPoz4PZH6FyZr6Q63HtIbSlwSJxP+QAZ/cJ19Jr0yYw== X-Google-Smtp-Source: AGHT+IGkV1gfWcpKiCnMIw9EOcJXEavOpD3waSWqNdNaWUvirhbpRzE+yNgajIhEDNQ4wBeo7oye X-Received: by 2002:a05:622a:14d2:b0:43a:ef4f:3f0e with SMTP id u18-20020a05622a14d200b0043aef4f3f0emr13587540qtx.39.1715079451930; Tue, 07 May 2024 03:57:31 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1715079451; cv=pass; d=google.com; s=arc-20160816; b=DyHRIy/sxXXM2DEtJOCHRVbfiVQEr2Y3P1l8k7jSt4IEJwrXOj0mwF/Fe+PyFSmzc6 1/9bqIIRmK1sDUx6w40wn+yrmHuaPtntfamBbeEyFdHC4oWwcY7SQKT9B8y1bRxjsWTW clRS1yQd6uc7ToeVFbzoYzVcaa7zgGlJ/stAP5av4elefGFzVi1jnrlqjPk8YoWvhAos pZegC+FZkHi84X3agzOeuGNfuy/EzP9WMAoFL4UIbzM1gKKX6ixXqI9a3aSRp2CvhviX LykEmW9MwnyXG0PZNPxyu2OvgMBoVs9t80EUdmA62qupUZ69lQbUvqgpbuNuAIBejiIf c8VQ== 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=ZYmlx2RlbhdbhfPObYp6Ew01hxCuhvQMusjMC+itTiY=; fh=nmDo0evxWwTAvBlxNELHY/fYZbxD4K9pluaUjPt1MrQ=; b=WbIBNxneSDnn+jNeIhl/r+xtcHxgaiRRr+iGfJd3EJHN3YC9HTqtxodLrR8hNgiJ93 U0q+suFQh+RorlOdDH1HmqbWCpT7f95P2qYSQsIuQEyg8BBkpRTNSSL9ENWX0NPAItRK vGhTQ3m8AGNFySs+XdJGBdzXAWDP1wyaabH9HHTmWEjq7Pj0WH2Au3LtgIP1VgXGIR6H UdGmEAXCHdeVybGH25IFCSqZcqZN3BYjimRyHwQ4bmWM89i3SVvzX0+e6wUVVlsoUqmb jZ0233en5pdxnlE3vIutS0kW7g6zUuK04fqxzdvwdYLt0hUX19CTZ2vn5aqeChE1e1R1 eHog==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=XtF5g+b+; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-171155-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-171155-linux.lists.archive=gmail.com@vger.kernel.org"; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from ny.mirrors.kernel.org (ny.mirrors.kernel.org. [147.75.199.223]) by mx.google.com with ESMTPS id v12-20020ac8578c000000b0043a904e3a55si11852091qta.85.2024.05.07.03.57.31 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 07 May 2024 03:57:31 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-171155-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) client-ip=147.75.199.223; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=XtF5g+b+; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-171155-linux.lists.archive=gmail.com@vger.kernel.org designates 147.75.199.223 as permitted sender) smtp.mailfrom="linux-kernel+bounces-171155-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 ny.mirrors.kernel.org (Postfix) with ESMTPS id BBDB01C226E2 for ; Tue, 7 May 2024 10:57:21 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 3A0C6154450; Tue, 7 May 2024 10:54:34 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="XtF5g+b+" 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 41B2B15350E; Tue, 7 May 2024 10:54:32 +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=1715079273; cv=none; b=VcRv0OthpYJj76frh5TAgxFQiZwQF309ibQhXlB98kQFw+9+kBfa5q4TPscsUFovja5cDF9T2so/fzLDPPeyKRoCG+Cv0f9JqetUxY/RC5nABqluBpmvBPG8IjBrAY90nWpVb8EcyloPXG1lm3RVnMVxUpnWG/rroU6slz8gLhI= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1715079273; c=relaxed/simple; bh=uRb5foIuQ5BNDFGImGEvFPC7L/pnPFQ3hNkGKHVAEbw=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=QPDfG8gGu0W9gHsrLB0FqgTGYXYPBU6SUYY0eCCoxJmhLHkxNYh883QsqfAQHl+iA+FDfpQRd2ixSVbWvXZQ0utTSkGIIN5KcITSi8oUi22VmxvDeTkaRfPrwDA3WujohKjlgFUqpGU4IRwyDv4WJ72K67oNRK0zpKAjFcOt3M0= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=XtF5g+b+; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id A5D6DC2BBFC; Tue, 7 May 2024 10:54:27 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1715079272; bh=uRb5foIuQ5BNDFGImGEvFPC7L/pnPFQ3hNkGKHVAEbw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=XtF5g+b+nB+TDswpNP+mqOaoVg42rNwRNfkQwbqNayMBvodvc5lRpvQNDnQOh5DdD DTQJqg1adMugKqpzGH41wq7vrf/UwkggklIwuY+YHzQ9IhNoken2zdIT9GsTn0kUpH tHoRmw487xdGRUhVhOtAimOUt0oTTSPcueuQ4JxhaJNb5T5nWO1hFYWqIxnVkrhzgE P29pHhD4BR/xgXeZegbeDjB6ima3Ev6o+1/DXc7aHGiGc7X1Udk2LzTuqeSjZBFUIS geVPw4fzNF3Xqas/qUDOUfFd2biy/U0YqOaGiC1d0HIQYepWSSJtQSXWcsVVN3GEeH uDecjZwpIRBfQ== 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: [PATCHv5 bpf-next 5/8] selftests/bpf: Add uretprobe syscall call from user space test Date: Tue, 7 May 2024 12:53:18 +0200 Message-ID: <20240507105321.71524-6-jolsa@kernel.org> X-Mailer: git-send-email 2.44.0 In-Reply-To: <20240507105321.71524-1-jolsa@kernel.org> References: <20240507105321.71524-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. 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..3ef324c2db50 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 462 +#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.44.0