From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from kanga.kvack.org (kanga.kvack.org [205.233.56.17]) (using TLSv1 with cipher DHE-RSA-AES256-SHA (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 263DACCD1BC for ; Thu, 23 Oct 2025 16:06:22 +0000 (UTC) Received: by kanga.kvack.org (Postfix) id 83D758E0009; Thu, 23 Oct 2025 12:06:21 -0400 (EDT) Received: by kanga.kvack.org (Postfix, from userid 40) id 815548E0002; Thu, 23 Oct 2025 12:06:21 -0400 (EDT) X-Delivered-To: int-list-linux-mm@kvack.org Received: by kanga.kvack.org (Postfix, from userid 63042) id 72B018E0009; Thu, 23 Oct 2025 12:06:21 -0400 (EDT) X-Delivered-To: linux-mm@kvack.org Received: from relay.hostedemail.com (smtprelay0012.hostedemail.com [216.40.44.12]) by kanga.kvack.org (Postfix) with ESMTP id 5BB7B8E0002 for ; Thu, 23 Oct 2025 12:06:21 -0400 (EDT) Received: from smtpin04.hostedemail.com (a10.router.float.18 [10.200.18.1]) by unirelay01.hostedemail.com (Postfix) with ESMTP id EB959490B5 for ; Thu, 23 Oct 2025 16:06:20 +0000 (UTC) X-FDA: 84029856120.04.6C775A6 Received: from mx0a-001b2d01.pphosted.com (mx0a-001b2d01.pphosted.com [148.163.156.1]) by imf16.hostedemail.com (Postfix) with ESMTP id 6A670180009 for ; Thu, 23 Oct 2025 16:06:18 +0000 (UTC) Authentication-Results: imf16.hostedemail.com; dkim=pass header.d=ibm.com header.s=pp1 header.b=hYEAcFaB; spf=pass (imf16.hostedemail.com: domain of jremus@linux.ibm.com designates 148.163.156.1 as permitted sender) smtp.mailfrom=jremus@linux.ibm.com; dmarc=pass (policy=none) header.from=ibm.com ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=hostedemail.com; s=arc-20220608; t=1761235578; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references:dkim-signature; bh=HRKplFgc/N23qIp2sTDF45qMxKOLUtK3bExzmctco20=; b=dXtIwRa9vOKm0HttcpnLvZ5nN2blHZ3LsEOsNTZkYNS+H1hRgAS74X6lDXzStGYW1/cwag zeKKGDoCb9tVWGaQhwsrbHw2dKV18EVYSKfLFm7hx6mKygwq7+ZtjUKuzC5bPNOH5CoUqd HwhcFAqDFyMR+a5OYEsn5TW7UUPS4Hg= ARC-Authentication-Results: i=1; imf16.hostedemail.com; dkim=pass header.d=ibm.com header.s=pp1 header.b=hYEAcFaB; spf=pass (imf16.hostedemail.com: domain of jremus@linux.ibm.com designates 148.163.156.1 as permitted sender) smtp.mailfrom=jremus@linux.ibm.com; dmarc=pass (policy=none) header.from=ibm.com ARC-Seal: i=1; s=arc-20220608; d=hostedemail.com; t=1761235578; a=rsa-sha256; cv=none; b=A0oMBoEnEdomo4cdpstKte7WuF6YaDkafCfZPJN3hFJXGv96mOrb4lukaFR5rWn8i7PnTG 5MV3BSSALQJeFBF6MkzcfI5BbJe5zz5ke/sWAiq1dFz08xGfJeUFbbQ4jYIuYBUPWYDErl XqbyKzPfEsmXH+z4jiui6uZffxaSGQQ= Received: from pps.filterd (m0353729.ppops.net [127.0.0.1]) by mx0a-001b2d01.pphosted.com (8.18.1.2/8.18.1.2) with ESMTP id 59N7psvY027549; Thu, 23 Oct 2025 16:05:56 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ibm.com; h=cc :content-transfer-encoding:date:from:in-reply-to:message-id :mime-version:references:subject:to; s=pp1; bh=HRKplFgc/N23qIp2s TDF45qMxKOLUtK3bExzmctco20=; b=hYEAcFaBVwAUiN0NTaIMptAk+WPdTS67+ Qtte2gen6qAzvGM0a858JeyD+fvkgLI2aCOG4QOA11LzwVxBFGuVvN/Yi5JxSdVD 96/URo/fMi/E+xclZbJVSTg5Ui4UGSmWrI8eZYbYxVQ2ao1eXBAUlxFyBK4J16UJ z28sklUPgNoyVv/0BwFXUWHmDSMLRTVgpprQXGgRBVLEnnNUn19nsRC3czKDD98/ pcQtvtsZjlbuvm2fJJg/YUyEqlfcEypU3K4s/Jnj6g+NrvTVmm/RWkB8+CyEB0Q2 uwjGMC5HqRWo1+E4qJmE0WgXR76//hoJJmsRvbq6BScwHKSH3A+uw== Received: from pps.reinject (localhost [127.0.0.1]) by mx0a-001b2d01.pphosted.com (PPS) with ESMTPS id 49v33fk7xt-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Thu, 23 Oct 2025 16:05:55 +0000 (GMT) Received: from m0353729.ppops.net (m0353729.ppops.net [127.0.0.1]) by pps.reinject (8.18.1.12/8.18.0.8) with ESMTP id 59NG5Rtp014464; Thu, 23 Oct 2025 16:05:55 GMT Received: from ppma23.wdc07v.mail.ibm.com (5d.69.3da9.ip4.static.sl-reverse.com [169.61.105.93]) by mx0a-001b2d01.pphosted.com (PPS) with ESMTPS id 49v33fk7xn-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Thu, 23 Oct 2025 16:05:54 +0000 (GMT) Received: from pps.filterd (ppma23.wdc07v.mail.ibm.com [127.0.0.1]) by ppma23.wdc07v.mail.ibm.com (8.18.1.2/8.18.1.2) with ESMTP id 59NE0lhC024987; Thu, 23 Oct 2025 16:05:53 GMT Received: from smtprelay02.fra02v.mail.ibm.com ([9.218.2.226]) by ppma23.wdc07v.mail.ibm.com (PPS) with ESMTPS id 49vpqk6jqj-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Thu, 23 Oct 2025 16:05:53 +0000 Received: from smtpav02.fra02v.mail.ibm.com (smtpav02.fra02v.mail.ibm.com [10.20.54.101]) by smtprelay02.fra02v.mail.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id 59NG5n9q43188482 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Thu, 23 Oct 2025 16:05:49 GMT Received: from smtpav02.fra02v.mail.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 7CE3120043; Thu, 23 Oct 2025 16:05:49 +0000 (GMT) Received: from smtpav02.fra02v.mail.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id F0A742004E; Thu, 23 Oct 2025 16:05:48 +0000 (GMT) Received: from tuxmaker.lnxne.boe (unknown [9.152.85.9]) by smtpav02.fra02v.mail.ibm.com (Postfix) with ESMTP; Thu, 23 Oct 2025 16:05:48 +0000 (GMT) From: Jens Remus To: linux-kernel@vger.kernel.org, linux-trace-kernel@vger.kernel.org, bpf@vger.kernel.org, x86@kernel.org, linux-mm@kvack.org, Steven Rostedt Cc: Jens Remus , Josh Poimboeuf , Masami Hiramatsu , Mathieu Desnoyers , Peter Zijlstra , Ingo Molnar , Jiri Olsa , Arnaldo Carvalho de Melo , Namhyung Kim , Thomas Gleixner , Andrii Nakryiko , Indu Bhagat , "Jose E. Marchesi" , Beau Belgrave , Linus Torvalds , Andrew Morton , Florian Weimer , Kees Cook , "Carlos O'Donell" , Sam James , Borislav Petkov , Dave Hansen , David Hildenbrand , "H. Peter Anvin" , "Liam R. Howlett" , Lorenzo Stoakes , Michal Hocko , Mike Rapoport , Suren Baghdasaryan , Vlastimil Babka , Heiko Carstens , Vasily Gorbik Subject: [RFC PATCH 2/2] fixup! unwind_user/sframe: Add .sframe validation option Date: Thu, 23 Oct 2025 18:05:45 +0200 Message-ID: <20251023160545.549532-2-jremus@linux.ibm.com> X-Mailer: git-send-email 2.48.1 In-Reply-To: <20251023160545.549532-1-jremus@linux.ibm.com> References: <20251022144326.4082059-1-jremus@linux.ibm.com> <20251023160545.549532-1-jremus@linux.ibm.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-TM-AS-GCONF: 00 X-Authority-Analysis: v=2.4 cv=FMYWBuos c=1 sm=1 tr=0 ts=68fa5263 cx=c_pps a=3Bg1Hr4SwmMryq2xdFQyZA==:117 a=3Bg1Hr4SwmMryq2xdFQyZA==:17 a=x6icFKpwvdMA:10 a=VkNPw1HP01LnGYTKEx00:22 a=VnNF1IyMAAAA:8 a=RXKZOtKmAAAA:8 a=QM4A5weLxKa4Be6FPkMA:9 a=UFF3uGjEBZWolfm0k6KQ:22 a=poXaRoVlC6wW9_mwW8W4:22 a=DXsff8QfwkrTrK3sU8N1:22 a=p-dnK0njbqwfn1k4-x12:22 a=7aar8cbMflRChVwg8ngv:22 X-Proofpoint-GUID: JQOQOsgBFhMmP2VrUNQfgcLdi1PTmTK7 X-Proofpoint-Spam-Details-Enc: AW1haW4tMjUxMDE4MDAyMiBTYWx0ZWRfX7i7elW/X49hm rd4PYzXvuZOcz+YChHWDjPYMaoks8NQ6lv4D+jK8NDgGKbOyFW0Q5nnVNsOVZS+msSRFtuelnBl kboV7c7ljE9Xxvu1QpTNQiaSZyLr1bPAdCizLxsEKGWC+P2q9aV/m5WaN4DcK58sRrOGBpsfrbu ewfRBloJPYeB7Dm0bFRBky0A6qVcoiD5L/pFsICGXhbzonBeszCYrFV2VXdjl4xvsNs4sCiT6qI sQY/Y4NFTz7z3Rvdra3u9ICOZb0TqAtLC8fzGzDtbHHp7SeZqwi+xc85mMRwisesQNHDx/yK0zO WoyPX9h4aN3kQFgDUl1/RidYa6GME/RoFerXW33s3Rnmqn93SRMMsD6lJ84umhPQ078TQQKDTbm AovBvFswYrncVfmtPncAJsdz2t+bMw== X-Proofpoint-ORIG-GUID: 2pQ0g_imgIn4r0izGJe5pHdkYBlMN7vJ X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.293,Aquarius:18.0.1121,Hydra:6.1.9,FMLib:17.12.80.40 definitions=2025-10-23_01,2025-10-22_01,2025-03-28_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 clxscore=1015 impostorscore=0 priorityscore=1501 adultscore=0 bulkscore=0 lowpriorityscore=0 suspectscore=0 phishscore=0 spamscore=0 malwarescore=0 classifier=typeunknown authscore=0 authtc= authcc= route=outbound adjust=0 reason=mlx scancount=1 engine=8.19.0-2510020000 definitions=main-2510180022 X-Stat-Signature: zzgbu8fqg7iuwizjgehicc5jih3rqju1 X-Rspamd-Queue-Id: 6A670180009 X-Rspam-User: X-Rspamd-Server: rspam08 X-HE-Tag: 1761235578-414022 X-HE-Meta: U2FsdGVkX18SXkn4P2iPwfByTMb9OI20+NcaUqG6gcKL1wkUgWBqB7BUeFjgG5S/quZgE0BOsNmNNpRakuxdgxnBc0pKzVvWt/w7nJk2Y3leyDlPlGPVPU7ChErln/WDCZK0ybHVk0qg1XJDtci/zCM/dYM5Wy57GFUPS+cbyYVKAsN0ksp1OH//RUsZUqUnnnvbLqqbI7UfUSXdCQbOy9JVrlFiVzI9ZK3901F7VZFGi6kNs0DvAJkyekR2Jogr8TUaNflNr0zbnTAKcQgWIHApU6chYr7yKyZKmHPWXxeFBGIIuWzOzuLypQe9N2HRSCsJf/b87Mc4MpLXOGo1nkBObVe5MsIj7rDUrRu2D9ucZdqf7w1LDrPF5+aT56LdaY0VOTh6nO+Ma0qPZUnwfaWDSRxzmQYxTLm7r5SFLTayHOwCWPv5tNpDL1+iPWESg0UcUdfHWhAwNktFOecIPTOI3jm5xFxWI+uJKgj9zG6U5dm3RtrOrvII4rZD+TsM3IwQro7HLECniHf+AA5G9pB88TCJiOH8GS0KEYiP5ygerskJEhGtNwxLmsxVmS4skCXNx5UWLHLuUqHn4jBiwfiyZGfKitVc5PxTMl5Kt1u8RRWAD+tPDuMPj52HJiQiLDY2k/2EEnFJR5AgxrrJOPvs4j8M8R62I9XANh12KPdXLiNflLZlHcFMP6iztpr0dDFzgMd/ur+9mUd5YP7xeg3QQw8K/KpMFazZys4Ogl4ShcN+vACA3kWYAnJwTGDeOfGO7jy6TTWbqH8qaniUWEsdEWb7TPIoKbt+Q/o5o+Fd+qd/+8jW2SBR4noRpHCqij7fOq9yFmiFVj6X8QNyA8vYcEbD1Xl887600VwYjYSEwJ5cttHwTHfDWpL44SmlhZtrvtSoXQ4VopsmQxnofSh/ThnuBcVxLgaLrF4L+TU3I93w2zUnOKVX+mNO7HQ7GIQfEeL2WUwi3mKUPSD egIDiJya 84srmneDew5+kuPKpiOUVEKBIKXkq0uXX3bvP1kNROnnchEqs9iLy1mlNtfySk/LZMVBvu59RrPKxMfM4jZ0rdIPSHQ2dAzSRBzXqC2TsirCAL/EUNDhEABcxuEJN4aKXR55NpM4Wp00sTo4RlM12zTB7WAWOposCMNNhbrHUl+o+DMBWttNcO8X1yX1CmhWcNQIV3I2Rm6iaOrFH7Q1HVh8V0tcFuoq7yGov51Up3YCPaIwx5K7jKs3p1cAEldsQoG6VQHXG0rZepC7BvAN2yjlGUET+cU3Rg1JJuhxdQpakMpAwzOIPz7SuaZ5VZiKZ9fJ+f9a+HriUD9ZCMzTGg02QSLsZ2oXr0nKC X-Bogosity: Ham, tests=bogofilter, spamicity=0.000000, version=1.2.4 Sender: owner-linux-mm@kvack.org Precedence: bulk X-Loop: owner-majordomo@kvack.org List-ID: List-Subscribe: List-Unsubscribe: This RFC fixup is POC to demonstrate how the SFrame validation code would adjust if introducing an internal FDE representation (struct sframe_fde_internal) similar to the used internal FRE representation (struct sframe_fre) in the SFrame reading code. The goal is to eliminate the passing through of fde_start_base in many places as well as the various computations of the effective function start address (= *fde_start_base + fde->start_addr) throughout this module. The internal FDE representation simply conveys the effective function start address via the "unsigned long func_start_addr" field. Signed-off-by: Jens Remus --- kernel/unwind/sframe.c | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/kernel/unwind/sframe.c b/kernel/unwind/sframe.c index f88fc2c92c58..f2977c010117 100644 --- a/kernel/unwind/sframe.c +++ b/kernel/unwind/sframe.c @@ -354,21 +354,21 @@ int sframe_find(unsigned long ip, struct unwind_user_frame *frame) #ifdef CONFIG_SFRAME_VALIDATION static int safe_read_fde(struct sframe_section *sec, - unsigned int fde_num, struct sframe_fde *fde, - unsigned long *fde_start_base) + unsigned int fde_num, struct sframe_fde_internal *fde) { int ret; if (!user_read_access_begin((void __user *)sec->sframe_start, sec->sframe_end - sec->sframe_start)) return -EFAULT; - ret = __read_fde(sec, fde_num, fde, fde_start_base); + ret = __read_fde(sec, fde_num, fde); user_read_access_end(); return ret; } static int safe_read_fre(struct sframe_section *sec, - struct sframe_fde *fde, unsigned long fre_addr, + struct sframe_fde_internal *fde, + unsigned long fre_addr, struct sframe_fre *fre) { int ret; @@ -388,18 +388,18 @@ static int sframe_validate_section(struct sframe_section *sec) for (i = 0; i < sec->num_fdes; i++) { struct sframe_fre *fre, *prev_fre = NULL; - unsigned long ip, fde_start_base, fre_addr; - struct sframe_fde fde; + unsigned long ip, fre_addr; + struct sframe_fde_internal fde; struct sframe_fre fres[2]; bool which = false; unsigned int j; int ret; - ret = safe_read_fde(sec, i, &fde, &fde_start_base); + ret = safe_read_fde(sec, i, &fde); if (ret) return ret; - ip = fde_start_base + fde.start_addr; + ip = fde.func_start_addr; if (ip <= prev_ip) { dbg_sec("fde %u not sorted\n", i); return -EFAULT; @@ -416,8 +416,8 @@ static int sframe_validate_section(struct sframe_section *sec) ret = safe_read_fre(sec, &fde, fre_addr, fre); if (ret) { dbg_sec("fde %u: __read_fre(%u) failed\n", i, j); - dbg_sec("FDE: start_addr:0x%x func_size:0x%x fres_off:0x%x fres_num:%d info:%u rep_size:%u\n", - fde.start_addr, fde.func_size, + dbg_sec("FDE: func_start_addr:0x%lx func_size:0x%x fres_off:0x%x fres_num:%d info:%u rep_size:%u\n", + fde.func_start_addr, fde.func_size, fde.fres_off, fde.fres_num, fde.info, fde.rep_size); return ret; -- 2.48.1