Received: by 2002:ab2:60d1:0:b0:1f7:5705:b850 with SMTP id i17csp1096861lqm; Thu, 2 May 2024 05:25:19 -0700 (PDT) X-Forwarded-Encrypted: i=3; AJvYcCWy/X7bexDwIq94B5Pp+fMtSpqT0Na+l7hn0M8BqH3NnvvXpHJiVLuG9nWqonawebkBTX1M0fj6HVZjiC3vKGWjLatQnPe2wCVwmnjpYA== X-Google-Smtp-Source: AGHT+IEXeR/5Jlm+vfFT1ycFD5Xp+zHFPucX2xwB2OqYSAsuSLX6ZZS8KCBDPgh3/r/H+R3luiv3 X-Received: by 2002:a05:690c:350d:b0:61a:7d6e:80e8 with SMTP id fq13-20020a05690c350d00b0061a7d6e80e8mr2059408ywb.36.1714652719384; Thu, 02 May 2024 05:25:19 -0700 (PDT) ARC-Seal: i=2; a=rsa-sha256; t=1714652719; cv=pass; d=google.com; s=arc-20160816; b=pz25YWODn6i0zBEfIFSKnAh3K/CYZ8DNzoI+Cz89r+ripvLDALJJc9fuAibPSXOVzP 5bpw7X3ZE3o87HBf5LHiqte0OXcmuvELVK18UcwJohkIknCoGdHRfZJ7VwLTPCbTYzKo apbu655vRrD8LgI9UQZ5nAcoaytEK5sjflCZTOL+xODtnTozN53WTPAh6zrEckRTLx4j cc97JqZoTkH2/nzAzGIMFmiiM4vUqxS1XuH+V8wZbo1QPmkrZsf2YMj9Y3CKVRCriG+W J00BufpIwsQdz8SMwV/RPVPApM6UVGWDgprLCUDQyNmeicFJ4eCqjPAAGiVF0qXMWePQ 6xKg== 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=h1h9NlA53OjYpAiqrU0MSt79VCxEgWQUg6KztN0v6SE=; fh=u6oFqhax+rdToeRfofEe2lYdipIB9IHQSSbHp+u1raI=; b=nYwHQOWWcXM9zN2ra5lpLVVkKRm0rB6ZUYQMp+6a8fdqJuf52+Vc81gkIvRd9puSSp 9POC1mYJTq2Xhtc9LCouMJtlgxtrqZ05b4LXY41wJ5empT525asOxTN2veM5IisdnAiX mJKiNXNufKUgi+f6WyLx83BPWIlfIUnjV1n20McOe+2kh7cto6WRIA6VMF5sdZ7rWLlF F6DvCIKxgdBMRFXX1lTUzHZP+g24yIVqQKMLvT2j+EPAnx/Je1PV5Pps0dkWSXTzB0DH 7FK5jyHLzFKDilxQH9gv4c6AsxAfE01gVf46NXz2ys6Qni24p1ChSIpcPFN9sdWoMc43 WDzQ==; dara=google.com ARC-Authentication-Results: i=2; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=jLc3wmUf; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-166444-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-166444-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. [2604:1380:45d1:ec00::1]) by mx.google.com with ESMTPS id f17-20020ac85d11000000b0043af565a4e4si870310qtx.504.2024.05.02.05.25.18 for (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 02 May 2024 05:25:19 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel+bounces-166444-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) client-ip=2604:1380:45d1:ec00::1; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=jLc3wmUf; arc=pass (i=1 dkim=pass dkdomain=kernel.org); spf=pass (google.com: domain of linux-kernel+bounces-166444-linux.lists.archive=gmail.com@vger.kernel.org designates 2604:1380:45d1:ec00::1 as permitted sender) smtp.mailfrom="linux-kernel+bounces-166444-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 D87151C21C37 for ; Thu, 2 May 2024 12:25:18 +0000 (UTC) Received: from localhost.localdomain (localhost.localdomain [127.0.0.1]) by smtp.subspace.kernel.org (Postfix) with ESMTP id 03C0B824A3; Thu, 2 May 2024 12:24:23 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b="jLc3wmUf" 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 E50907E107; Thu, 2 May 2024 12:24:21 +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=1714652662; cv=none; b=CiI8SLDtLu33TVkkWKFVaiRcx4B5vA/t4p6bRDLc3T9DuhJH7LAZ/MqZfTiHvqbX0cb83FNak+8PhXfATlvREThBPtvKeZWd+WcXRJ80JjLTeuwJAUDcazajGCK8as5lwvn11BhKSB4/hUwhK9dRVbYpPXo3gmWcwA8VNcvWi+Q= ARC-Message-Signature:i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1714652662; c=relaxed/simple; bh=tdd0DLiX6XUPXbMSZMcGly7Lb8412HmbtAEmC83jpvI=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=Nt97CgTFic23XS6tLikqBuxYKwu3Hqb6WXO7YGcH/EJsbWXpeQvkDT5QudobOx8MCgQWv1iFUtENs9Q+qlSkI+P0nLIqnPmPogW9gWaA4VT+6Qu+viAyty/Tin3J22J/8ohwvhd6Ps0qMWRFKKB6o4xV/PaeGFBrERTPaPKTiwU= ARC-Authentication-Results:i=1; smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=kernel.org header.i=@kernel.org header.b=jLc3wmUf; arc=none smtp.client-ip=10.30.226.201 Received: by smtp.kernel.org (Postfix) with ESMTPSA id CC7D4C113CC; Thu, 2 May 2024 12:24:16 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1714652661; bh=tdd0DLiX6XUPXbMSZMcGly7Lb8412HmbtAEmC83jpvI=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=jLc3wmUfPnifVo6iNmCMOeWromMDp1tC3tmY02ms/BM2/aLj+0HH8n8kt8PFR61gQ hU0uupVaANPJILaHaVQnqOr/OOubAJOJOkBvGeoiQa1oaoIxDqq1i+XcC4itVrS/im ig6K3EeD5iO+rlcJB0rGq4OBpjr6RQO0JyCNlc59fuQEKaZZXISr21/2FWD/pPIJFi ZaepEqSkK9ISpjE31pWrLTmy83Dnfdp06c3TfSIquiGsS2wxqDrhT2hOTPiHJ7xve7 ZhPBkuPCupibkYuj9EGzOKuavRezjdNq0QzXCnkL1r/IEfjNRqKi/Ds7VaT9DJZhLW Z2CXT2P/cxw3Q== 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 Subject: [PATCHv4 bpf-next 5/7] selftests/bpf: Add uretprobe syscall call from user space test Date: Thu, 2 May 2024 14:23:11 +0200 Message-ID: <20240502122313.1579719-6-jolsa@kernel.org> X-Mailer: git-send-email 2.44.0 In-Reply-To: <20240502122313.1579719-1-jolsa@kernel.org> References: <20240502122313.1579719-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..c6fdb8c59ea3 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 (pipe(go)) + 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