Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp4776444iob; Mon, 9 May 2022 01:03:31 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxxlGG5beZEEYvBpvuNEjCw2pYQlJP1eErZIxP26mmhmBEx2ES64rAxs4kQMTYRKOrfO4o7 X-Received: by 2002:a05:6e02:1ba1:b0:2cf:232b:aa85 with SMTP id n1-20020a056e021ba100b002cf232baa85mr5647773ili.2.1652083410978; Mon, 09 May 2022 01:03:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1652083410; cv=none; d=google.com; s=arc-20160816; b=hO9I7byfJb2SyCYQWltztP3HpjI0f8zNVBf47RsSC2GGbYdlmbCB/37/UNVrPHVAiR ZN2dzGGExFa210DZ4ZWyI8OpSA2Ikr93y54WqVPnUl2pMMDOp7J/5U6ZmMzR3Rr2bjMC yW/XZKPuKq+mS2j584hH2SBuSJUeJTs966z/Jr717miZO4tuuB0n5F/B6nSVHrQcRpRo 4SUQC0QOwYUxEc5S5FVczl7raBLfjQ4feC0yOnKi33TEn5Odyak6xFpgC1fjE4sKIxPn G3gb0VubIBv234y+ZxoCbTnyXxrETroaTnwMaa5jYfvxXvfcBtlsOuMGvTJ1kTR3cu0G 0uzA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=+DBZHgTgHhGifz1O+OvTLRL4mlr40VVe72aYyr9oFJs=; b=WTx5O1HWhgn0hkMZTSyMFR91zX0Y1yWEoznjOB3NvocfEgu6sXGFLLoWbdtzp+bMoj Wd0pVNKtpmtmgTkgk1hTvpMeZo/n7Qj/8HU7CVLLchl0zDZyPAXEI0MLJ9trewDt0vhm qVwB36Ogxv9uH4ne+75SxT4ST/cu7F1ssIeKIHQfUzda3e4fN68fEcvoVxdwwqls079T QpTtgDSWptk6wGE6BqMbEOAsBR7Hxbl7xW+dBOpqcjaZcPcE58CMNSaWhn10B9GVyGPH eBmhTmETFbBw9chdz/jnyUkJ/DACNE2c3rV4FJB8KCxgvte+5040RMs+P3G3tUnWmVS5 RALQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20210112 header.b=dufIc96P; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id l12-20020a0566022dcc00b00649f2da795bsi10203654iow.0.2022.05.09.01.03.30 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 09 May 2022 01:03:30 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20210112 header.b=dufIc96P; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 7E68C185406; Mon, 9 May 2022 00:54:53 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231906AbiEEAdN (ORCPT + 99 others); Wed, 4 May 2022 20:33:13 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51686 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231818AbiEEAdM (ORCPT ); Wed, 4 May 2022 20:33:12 -0400 Received: from mail-yw1-x1135.google.com (mail-yw1-x1135.google.com [IPv6:2607:f8b0:4864:20::1135]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C4B3B54BD1 for ; Wed, 4 May 2022 17:29:34 -0700 (PDT) Received: by mail-yw1-x1135.google.com with SMTP id 00721157ae682-2f7d621d1caso33113007b3.11 for ; Wed, 04 May 2022 17:29:34 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20210112; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=+DBZHgTgHhGifz1O+OvTLRL4mlr40VVe72aYyr9oFJs=; b=dufIc96PMUlxP7YcnxTZoMITLMW8Y8Vo05y80Fc6JcS6UdgaV0y+6VIGR01O9ZyAFn VzgCR2el/k9vlj/s3PNNu1ujfqQGw0o4JhuN6JoKakSGUfCC0EkykjyAuq+tQKFxgZZ/ GVl99IrkhYo99EI/plVjYvWuSlliV2lt3vfymRAoKwa/Bw7ItBwDYrcO+AhCCmNWjzcz FaLAW5c/R6V6hjaS0RaO65IAFph/k2zU7r4m3tPSKtOLZmPJtVpDRegKLE9+pCML2Hkr 6hV1zIFdE1SFEzA3r4ZR+kzUzCWEQBlKP1Dsw5QGGA9fC2MwHnt14Z2z4QLSXJN7nyDe i5Vg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=+DBZHgTgHhGifz1O+OvTLRL4mlr40VVe72aYyr9oFJs=; b=QdZNrJkCc4olCMiisc4cCmV0HJwg++nqtRoPxt0FPgBKaCFkiDzDul2e3nTnVRtuwy s5CPVDuk9yOLt68YC6zeRze1UIXcWuTxXm2/wS7e4HEonbR9dvF/KakehJReCu3VpNcK exDPJfrvhWkE5DEk9e+9mdtfA5sUz7enny1RNYLprnJl5jQBG+tFy+4gK4T9Qli6VArY 4/aLqXPwXgCgXvz934jX2dZyDOloS4dWxW+S3tpEaelhgeBH2NrxF+d+K3+jFi/LRmQX b1s99RQ89ZAS4Yxn6arVN6C/I36wKnJqATopPUjBC52PLNSaAub5IGZvnGtg2ecDow39 n9rw== X-Gm-Message-State: AOAM530uREQu7xi2DXcE9fJxErLPoBRkqK604Cj4IBVQ4vp8qYfbXp5F nrZK0k0gN0/3z2HNCGShE8dgQQSX9kvOuzWD1O5Tbg== X-Received: by 2002:a81:8d02:0:b0:2f8:c9f7:4041 with SMTP id d2-20020a818d02000000b002f8c9f74041mr21759476ywg.117.1651710573858; Wed, 04 May 2022 17:29:33 -0700 (PDT) MIME-Version: 1.0 References: <20220420004241.2093-1-joao@overdrivepizza.com> <20220420004241.2093-2-joao@overdrivepizza.com> <20220429013704.4n4lmadpstdioe7a@treble> <20220503220244.vyz5flk3gg3y6rbw@treble> In-Reply-To: From: Sami Tolvanen Date: Wed, 4 May 2022 17:28:57 -0700 Message-ID: Subject: Re: [RFC PATCH 01/11] x86: kernel FineIBT To: Peter Zijlstra Cc: Peter Collingbourne , Josh Poimboeuf , Joao Moreira , LKML , linux-hardening@vger.kernel.org, andrew.cooper3@citrix.com, Kees Cook , Mark Rutland , hjl.tools@gmail.com, alyssa.milburn@linux.intel.com, Nick Desaulniers , gabriel.gomes@linux.intel.com, rick.p.edgecombe@intel.com Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=-9.5 required=5.0 tests=BAYES_00,DKIMWL_WL_MED, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE, USER_IN_DEF_DKIM_WL autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, May 4, 2022 at 11:17 AM Peter Zijlstra wrote: > __cfi_\sym: __cfi_\sym: > int3; int3 # 2 > endbr # 4 mov \hash, %eax # 5 > call __fineibt_\hash # 5 int3; int3 # 2 > \sym: \sym: OK, that looks reasonable to me. > It seems to preserve the properties of the last one in that direct calls > will already be correct and we don't need linker fixups, and objtool can > simply parse the preamble as regular instructions without needing > further help. Wouldn't objtool still print out unreachable instruction warnings here? Sami