Received: by 2002:a05:7412:b795:b0:e2:908c:2ebd with SMTP id iv21csp314572rdb; Thu, 2 Nov 2023 04:48:14 -0700 (PDT) X-Google-Smtp-Source: AGHT+IHOf/Qx7h5ymFiO5jqkppbcm3OipbBJL/X8PpPxb/AVjZT9dqkP9yn6RsT48RRqCSJzPNu5 X-Received: by 2002:a17:90b:1b51:b0:27d:469b:8847 with SMTP id nv17-20020a17090b1b5100b0027d469b8847mr7664116pjb.3.1698925694151; Thu, 02 Nov 2023 04:48:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1698925694; cv=none; d=google.com; s=arc-20160816; b=YOaG3GSW848TSyfraMgnh9GO+NAFYPIFQD545V4HSzHUGiI+9rIKZkDXicY2n3e2ff VqvL7bwQe0rPOZRFjqer/mOaWnHmHLt8nlfq23wnYrn3huMIbJwiYBciql0Rey3QFEV1 SyHMsgS08S8t5mXh3n981OEvCl+JJgpFWDwqpRV+VXlwBtWIPKMjnltugw7WTvadPcs4 IuRM/0TyFmImtveaVYz2sH3gk+V8nM8Lxsszx8Fo6y370GHe/5+pyWSyp0cYlspvgoUz GixOs+Wem9BuwrZJ3YZju78xuX+TknInessD95nBjt4yOsIQ2HQjNvu8ytKcJx2omK1t 93Cg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=Vpp2Uxr7P1r+KWM6T9cEExjrYczEsClmj3xLm7KkeJ4=; fh=Uy/4dU/oFQl9I9p3t1iqR6OPxvM6mEHVRCPnvwnQzNs=; b=YdSEKBMCkQYdobFjiuMtOp4bdqWHfXKIdG6ztYVi79k76TjvJduMXZuv+5RB9PCUwa /CN/P4femDh2arqVzmhIBycAd0y5pKVX+VH62Z+o/MygwXj+CcNZZzCTqk1JNq5NerY2 rsMTcePpYBsq1mpZn9x4X64OodexXCJHV13HlaHTLxX9In4tropPqJOTetO7Sg7ZMbl3 2XQ+KynZW6BaNwJy5VRfqIFffKJ56qINOEB0xQA6C37nH3I1thy67K5NbRr5dsLbCEtM banRW5xrKqpEsskpghHMibUu67uzJD/AAoZcWP58KmhUNcCw3kXluwKJugI0dIxK59zt i1tg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@infradead.org header.s=casper.20170209 header.b=i1iywDuX; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.32 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from agentk.vger.email (agentk.vger.email. [23.128.96.32]) by mx.google.com with ESMTPS id s3-20020a17090aba0300b0028016799242si2627234pjr.80.2023.11.02.04.48.13 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 02 Nov 2023 04:48:14 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.32 as permitted sender) client-ip=23.128.96.32; Authentication-Results: mx.google.com; dkim=pass header.i=@infradead.org header.s=casper.20170209 header.b=i1iywDuX; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.32 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 agentk.vger.email (Postfix) with ESMTP id 14C068083B02; Thu, 2 Nov 2023 04:48:11 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at agentk.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233356AbjKBLq5 (ORCPT + 99 others); Thu, 2 Nov 2023 07:46:57 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:43506 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230000AbjKBLqz (ORCPT ); Thu, 2 Nov 2023 07:46:55 -0400 Received: from casper.infradead.org (casper.infradead.org [IPv6:2001:8b0:10b:1236::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E7409137 for ; Thu, 2 Nov 2023 04:46:49 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=casper.20170209; h=In-Reply-To:Content-Type:MIME-Version: References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description; bh=Vpp2Uxr7P1r+KWM6T9cEExjrYczEsClmj3xLm7KkeJ4=; b=i1iywDuXiIwiloBmtE1zOwLAdq 12wJ0w9end9erLtLUmTNn9VqpmIIcbUgP3TqeoL5pL46Mt6rOqDd0LGy5k79y0b6oMC6g+QsbxLBL rcKyRf8cVbWWkFY1jSPOvT4GsJimNxvxviDY+1jgtrBc4HrjmMajm3MWaSy8MprJ5kjzUZrNBe1ff cXxXZjVWX8PvNmySpdO/fmd3qzp+0owmF4TnibGTfh+w4fhUPby3dNFsHhPIxQzWtNPx9bh8dudIc 3wKPD6zbroSWFZhh0kE943qBoV+nLDy9u4xt+ODdhWfA6x/I9ZBxDfRMUVfvnql6C8F0f2b8qFa+P 32d0uvlw==; Received: from j130084.upc-j.chello.nl ([24.132.130.84] helo=noisy.programming.kicks-ass.net) by casper.infradead.org with esmtpsa (Exim 4.94.2 #2 (Red Hat Linux)) id 1qyW7b-004G9W-4A; Thu, 02 Nov 2023 11:44:23 +0000 Received: by noisy.programming.kicks-ass.net (Postfix, from userid 1000) id BE7A93004AB; Thu, 2 Nov 2023 12:44:22 +0100 (CET) Date: Thu, 2 Nov 2023 12:44:22 +0100 From: Peter Zijlstra To: Uros Bizjak Cc: x86@kernel.org, linux-kernel@vger.kernel.org, Thomas Gleixner , Ingo Molnar , Borislav Petkov , Dave Hansen , "H. Peter Anvin" Subject: Re: [PATCH 2/3] x86/callthunks: Handle %rip-relative relocations in call thunk template Message-ID: <20231102114422.GB3818@noisy.programming.kicks-ass.net> References: <20231102112850.3448745-1-ubizjak@gmail.com> <20231102112850.3448745-3-ubizjak@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20231102112850.3448745-3-ubizjak@gmail.com> X-Spam-Status: No, score=-0.9 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on agentk.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 (agentk.vger.email [0.0.0.0]); Thu, 02 Nov 2023 04:48:11 -0700 (PDT) On Thu, Nov 02, 2023 at 12:25:47PM +0100, Uros Bizjak wrote: > @@ -166,13 +168,51 @@ static const u8 nops[] = { > 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, > }; > > +#define apply_reloc_n(n_, p_, d_) \ > + do { \ > + s32 v = *(s##n_ *)(p_); \ > + v += (d_); \ > + BUG_ON((v >> 31) != (v >> (n_-1))); \ > + *(s##n_ *)(p_) = (s##n_)v; \ > + } while (0) > + > +static __always_inline > +void apply_reloc(int n, void *ptr, uintptr_t diff) > +{ > + switch (n) { > + case 4: apply_reloc_n(32, ptr, diff); break; > + default: BUG(); > + } > +} > + > +static void apply_relocation(u8 *buf, size_t len, u8 *dest, u8 *src) > +{ > + for (int next, i = 0; i < len; i = next) { > + struct insn insn; > + > + if (WARN_ON_ONCE(insn_decode_kernel(&insn, &buf[i]))) > + return; > + > + next = i + insn.length; > + > + if (insn_rip_relative(&insn)) > + apply_reloc(insn.displacement.nbytes, > + buf + i + insn_offset_displacement(&insn), > + src - dest); > + } > +} Isn't it simpler to use apply_relocation() from alternative.c? Remove static, add decl, stuff like that?