Received: by 2002:a05:7412:d8a:b0:e2:908c:2ebd with SMTP id b10csp319520rdg; Thu, 12 Oct 2023 06:43:43 -0700 (PDT) X-Google-Smtp-Source: AGHT+IHIiE5MYE6HyILKNQ21eAtknlXPi75j1EBOUhjm/6dhQ8xkJxACq3nMDSPkE6eMgTt/UySM X-Received: by 2002:a05:6a20:244f:b0:159:dccb:8bb4 with SMTP id t15-20020a056a20244f00b00159dccb8bb4mr25038750pzc.23.1697118223243; Thu, 12 Oct 2023 06:43:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1697118223; cv=none; d=google.com; s=arc-20160816; b=dHp+/D0vEKc5aVdiMA0iXTYxcOWtGUpY3egUp9KuEwFnOjXw9SUirm0Kx2mdxe7YJ2 SUaK6fPSdOn17IBTupXz2q9PFXYSzEYKu9BrwjYy/F/wVfJN64viFrV/W3EZi3PcwdWY ADkTdjX2J3YRD7/FWdTdi2bA6YqPXBjTsGEZrOm02scmGA0lBm1peNh4ds+6TdEM2zzu ia7mC6QN9Xx5M3mmpvQJ24sG/mvlp/0tva9Jo5jXO0hamWEoBczUxsiLHxabN8+aoLX7 iNUSIrkwBfQ/AvspZ0HvrofSwYXjnVd327vEyznDfHaIx18nfPPWIYwJZxeSQrKVJ/Fv R1zw== 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:subject:cc:to:from:date; bh=4tmlqm1KRS6MoGezrGUYvpp8RSLD86HOF4qlA1Tb9Dc=; fh=5LtBCus8HBjbolvSZkTKswaHAZKw9yzNDDsCssEqTMY=; b=LoYTp82bC1LGqPINfDNch3xkvNEZK2sQjwtd6ZMW1d7YprIzdn5DDyCYPCAzfu6IYZ y+RDYfs0C6vKOiX0bW9HfJRCp7fN6kl4a/5tESFX0TILC9Pt22mVparvkrIaEeHq9iNi /sMHnyYxGOBg2nzrmmluexKTX5Gr0HzfcboOqtl2Cs4ZNulA51ElGJRpQq4ZYbLYoYcD /+C53LfoibZ6suigWfAbo//+JcC35fFh3uVByx1ykCQacr6pH4x3lp03KGwW/njKx7Bf NeWNlpwr5y+kT/ukbIOQ1Q2MJAAB4j9/BV4wjcpzfAisKmLsioFclEezcCW1pM/xz1Jr M4fw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:5 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from groat.vger.email (groat.vger.email. [2620:137:e000::3:5]) by mx.google.com with ESMTPS id j1-20020a635501000000b00588d85be058si2329896pgb.708.2023.10.12.06.43.42 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 12 Oct 2023 06:43:43 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:5 as permitted sender) client-ip=2620:137:e000::3:5; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:5 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by groat.vger.email (Postfix) with ESMTP id 54DDE8229F1D; Thu, 12 Oct 2023 06:43:40 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at groat.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1378929AbjJLNn1 (ORCPT + 99 others); Thu, 12 Oct 2023 09:43:27 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56728 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1347290AbjJLNnZ (ORCPT ); Thu, 12 Oct 2023 09:43:25 -0400 Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 05DE991 for ; Thu, 12 Oct 2023 06:43:23 -0700 (PDT) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 6A10AC433C7; Thu, 12 Oct 2023 13:43:21 +0000 (UTC) Date: Thu, 12 Oct 2023 09:44:44 -0400 From: Steven Rostedt To: Artem Savkov Cc: Alexei Starovoitov , Daniel Borkmann , Andrii Nakryiko , bpf@vger.kernel.org, netdev@vger.kernel.org, Masami Hiramatsu , linux-kernel@vger.kernel.org, linux-trace-kernel@vger.kernel.org, Thomas Gleixner , linux-rt-users@vger.kernel.org, Jiri Olsa Subject: Re: [RFC PATCH bpf-next] bpf: change syscall_nr type to int in struct syscall_tp_t Message-ID: <20231012094444.0967fa79@gandalf.local.home> In-Reply-To: <20231012114550.152846-1-asavkov@redhat.com> References: <20231005123413.GA488417@alecto.usersys.redhat.com> <20231012114550.152846-1-asavkov@redhat.com> X-Mailer: Claws Mail 3.19.1 (GTK+ 2.24.33; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-0.8 required=5.0 tests=HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on groat.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (groat.vger.email [0.0.0.0]); Thu, 12 Oct 2023 06:43:40 -0700 (PDT) On Thu, 12 Oct 2023 13:45:50 +0200 Artem Savkov wrote: > linux-rt-devel tree contains a patch (b1773eac3f29c ("sched: Add support > for lazy preemption")) that adds an extra member to struct trace_entry. > This causes the offset of args field in struct trace_event_raw_sys_enter > be different from the one in struct syscall_trace_enter: > > struct trace_event_raw_sys_enter { > struct trace_entry ent; /* 0 12 */ > > /* XXX last struct has 3 bytes of padding */ > /* XXX 4 bytes hole, try to pack */ > > long int id; /* 16 8 */ > long unsigned int args[6]; /* 24 48 */ > /* --- cacheline 1 boundary (64 bytes) was 8 bytes ago --- */ > char __data[]; /* 72 0 */ > > /* size: 72, cachelines: 2, members: 4 */ > /* sum members: 68, holes: 1, sum holes: 4 */ > /* paddings: 1, sum paddings: 3 */ > /* last cacheline: 8 bytes */ > }; > > struct syscall_trace_enter { > struct trace_entry ent; /* 0 12 */ > > /* XXX last struct has 3 bytes of padding */ > > int nr; /* 12 4 */ > long unsigned int args[]; /* 16 0 */ > > /* size: 16, cachelines: 1, members: 3 */ > /* paddings: 1, sum paddings: 3 */ > /* last cacheline: 16 bytes */ > }; > > This, in turn, causes perf_event_set_bpf_prog() fail while running bpf > test_profiler testcase because max_ctx_offset is calculated based on the > former struct, while off on the latter: > > 10488 if (is_tracepoint || is_syscall_tp) { > 10489 int off = trace_event_get_offsets(event->tp_event); > 10490 > 10491 if (prog->aux->max_ctx_offset > off) > 10492 return -EACCES; > 10493 } > > What bpf program is actually getting is a pointer to struct > syscall_tp_t, defined in kernel/trace/trace_syscalls.c. This patch fixes > the problem by aligning struct syscall_tp_t with with struct > syscall_trace_(enter|exit) and changing the tests to use these structs > to dereference context. > > Signed-off-by: Artem Savkov Thanks for doing a proper fix. Acked-by: Steven Rostedt (Google) -- Steve