Received: by 10.223.176.5 with SMTP id f5csp3134065wra; Mon, 29 Jan 2018 09:16:17 -0800 (PST) X-Google-Smtp-Source: AH8x224urHoZAtNNuj8fGqD6PAgQwZozT8ccP+ZyQa2jLLG0V8BQk9TiDicTju4LgmR4nEPfvVLG X-Received: by 10.98.238.2 with SMTP id e2mr27619050pfi.206.1517246177399; Mon, 29 Jan 2018 09:16:17 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517246177; cv=none; d=google.com; s=arc-20160816; b=DCEADrFSl3icjrUPwAepfDVcchTw8Tn+mAUspazJ0jCz9QIURWsy0a5Ss9316qzyOH 0C9nplamD+JP6YU8WAD9JdzC6TYu3rWAfmVEoXVjls2xqsHPeFQzNpqSq8YsNbkNogSZ YIeAnT+Fbmdl2QYbBl5VeN5xClKi2VC6rAe9NqQz/ZF1dYTCJO8+YqFlgM4vY5W59W0/ tWfOUTqiWw59AnxNQEjD97c4GaUew9epCbFl7kr0LYrM4Y5B55ODRdv/DPWAcN9zqG2K DGBxNgH+KXA2DnuHceZrb9LThq/O83tEXVFp8+CH8dWF0bJ7g3/CyhyqdOoYJ2RucXua vFsw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-transfer-encoding:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature :arc-authentication-results; bh=Ok69rFURI7au9jJS5mtIbMjUwqv7rhftJ/LtUgUO0HE=; b=hkgEbmjL5zFYquUB8oBBCF27T/nbBSMx42Vt8KskywJ4GfByerCXysPrTCTWXE7D89 ER24ECc5nBBkTWIvKkoPUdyUhcrgUFlfT5S3dDX8HBO4wpzsuKvkXgmAMRnspgLHxGQK 0Fb6HEKM0L+RYqkhrHu5Hw0GFaOER/f90Dt8X8zFcLk9Rgf6Bm3YUaYbNRBXizdNSd0f JfgwhoU+pFFT+87MYvR3acX6T1/HNaVlWMcH57Tf8wjg/BLVOcKs6Q6J/0+aE7OXNk5p bG756yi2JmFGmS4YthjA3ZPq9/o8KaKZwzf3T6RerEtxDny7fSciQNCFFZPrwVgtxh1u 628g== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@gmail.com header.s=20161025 header.b=dfFai7T1; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x20si12408118pfa.129.2018.01.29.09.16.02; Mon, 29 Jan 2018 09:16:17 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=fail header.i=@gmail.com header.s=20161025 header.b=dfFai7T1; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751436AbeA2RPa (ORCPT + 99 others); Mon, 29 Jan 2018 12:15:30 -0500 Received: from mail-pf0-f194.google.com ([209.85.192.194]:45021 "EHLO mail-pf0-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750959AbeA2RP2 (ORCPT ); Mon, 29 Jan 2018 12:15:28 -0500 Received: by mail-pf0-f194.google.com with SMTP id 17so4434266pfw.11 for ; Mon, 29 Jan 2018 09:15:28 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=sender:date:from:to:cc:subject:message-id:references:mime-version :content-disposition:content-transfer-encoding:in-reply-to :user-agent; bh=Ok69rFURI7au9jJS5mtIbMjUwqv7rhftJ/LtUgUO0HE=; b=dfFai7T1Rzgoq9L6/mTvwDSwHpjcx3JMCHHffpcOFWF852A7193cT0dssfV0HQ3EFq FOWzX4MiJUqJJMZfrPBjYc6JkAo3AAA1zTAs6JSe5br39qZ8VkxWUZ+YH0/pM+MoFry/ Vd3IKWAy3UG+pvttrinOXwLZYyIZ0IVKM6HbhRz5rRb4hVBevHQY1mEpM9itTiFTP1yl U1iDbYO6jZ1dNR8Z2s95CT38yIyDzsfCHrxDCrl2YvgtldnigjBPusdZyVA9dEZxFU/F f8rOjSTee6Bf6WTdzjdgZPsZIp70YhHZvzuTERJwxDNzyWgFbHkWBbSyHHisxF3wBsEa uprw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:date:from:to:cc:subject:message-id :references:mime-version:content-disposition :content-transfer-encoding:in-reply-to:user-agent; bh=Ok69rFURI7au9jJS5mtIbMjUwqv7rhftJ/LtUgUO0HE=; b=ZfRBauHPDRNeuHcbtegC2beSbXoufnxMITNEBeUvmQIUv24dHJnC7OEl3A4Mw8ep+y YjyNSJ0AY6iKJB42vrga7DgeBLFfw1PiwR+FP6pLjjl3LuqFWR1eLknA2mNx6uPodkO2 d39LwyIE24pPTSJo4H50vHOMjzKq6M2I98knCsSwoL4nF8OVdPE5/m2cfjelbqZg32qF Vd2aQRZDRd+5bxbMFhp7mqnYaCnU7M73Cn2LbI079XQ5VUFC3ObnNbMTHnXP6HmZrGOl LWJfGni7mo+kyBMToYNGDN34+JZiRkZvDy706Rttkqvnpje0axSylptkeYzJI6Zxw+YO yTqw== X-Gm-Message-State: AKwxytfq0sRp5nA9jKbI1sSfMAg/DJb9TVjO80zQOPAUs02Nv2maDDJ6 JDgw3wPPjQN0eTquyN09gDQ= X-Received: by 10.99.120.199 with SMTP id t190mr21335460pgc.180.1517246128213; Mon, 29 Jan 2018 09:15:28 -0800 (PST) Received: from localhost (108-223-40-66.lightspeed.sntcca.sbcglobal.net. [108.223.40.66]) by smtp.gmail.com with ESMTPSA id l64sm31149005pfi.46.2018.01.29.09.15.26 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 29 Jan 2018 09:15:27 -0800 (PST) Date: Mon, 29 Jan 2018 09:15:26 -0800 From: Guenter Roeck To: Josh Poimboeuf Cc: David Woodhouse , Andi Kleen , Paul Turner , LKML , Linus Torvalds , Greg Kroah-Hartman , Tim Chen , Dave Hansen , tglx@linutronix.de, Kees Cook , Rik van Riel , Peter Zijlstra , Andy Lutomirski , Jiri Kosina , gnomes@lxorguk.ukuu.org.uk, x86@kernel.org, thomas.lendacky@amd.com Subject: Re: [v8,02/12] objtool: Allow alternatives to be ignored Message-ID: <20180129171526.GA17121@roeck-us.net> References: <1515707194-20531-3-git-send-email-dwmw@amazon.co.uk> <20180118190931.GA27143@roeck-us.net> <20180118193315.zrrya7qo6kf7pmzp@treble> <20180118194112.GA28449@roeck-us.net> <1516649644.9521.61.camel@infradead.org> <20180122202522.GA29081@roeck-us.net> <20180128210642.xob2win53h2gztak@treble> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <20180128210642.xob2win53h2gztak@treble> User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, Jan 28, 2018 at 03:06:42PM -0600, Josh Poimboeuf wrote: > On Mon, Jan 22, 2018 at 12:25:22PM -0800, Guenter Roeck wrote: > > Hi David, > > > > On Mon, Jan 22, 2018 at 07:34:04PM +0000, David Woodhouse wrote: > > > On Thu, 2018-01-18 at 11:41 -0800, Guenter Roeck wrote: > > > > > > > > > Not sure, does your gcc have retpolines?? Give me your .o file and I can > > > > > diagnose it. > > > > >? > > > > Yes, it does, only it is the gcc from the Google toolchain which may > > > > generate different code than the upstream version. > > > > > > > > I attached an affected object file. Please let me know if there is anything else > > > > I can do to help. > > > Disassembly of section .text.__x86.indirect_thunk: > > > > > > 0000000000000000 <__x86.indirect_thunk>: > > > ???0: e8 04 00 00 00??????? callq??9 <__x86.indirect_thunk+0x9> > > > ???5: f3 90???????????????? pause?? > > > ???7: eb fc???????????????? jmp????5 <__x86.indirect_thunk+0x5> > > > ???9: 48 8d 64 24 08??????? lea????0x8(%rsp),%rsp > > > ???e: c3??????????????????? retq??? > > > > > > That has the old-style CET-incompatible retpoline in a COMDAT section > > > in the .o file. What compiler options are being used for that? The > > > kernel should only use retpoline if GCC supports both of > > > -mindirect-branch=thunk-extern and -mindirect-branch-register, and this > > > compiler is doing *neither* of those.? > > > > It uses "-mindirect-branch=thunk -mindirect-branch-loop=pause > > -fno-jump-tables", though I don't know if that even exists in > > upstream gcc (it is the gcc use for Chrome OS builds). I'll pass > > your feedback to our compiler team. > > > > Either case, I think it is less than optimal that objtool crashes > > with _any_ object code. > > I've got a pending fix for this, so that objtool doesn't seg fault, and > instead prints out a warning: > > quirks.o: warning: objtool: efi_delete_dummy_variable()+0x99: unsupported intra-function call > quirks.o: warning: objtool: If this is a retpoline, please patch it in with alternatives and annotate it with ANNOTATE_NOSPEC_ALTERNATIVE. > > The code is here, along with a few more fixes: > > https://git.kernel.org/pub/scm/linux/kernel/git/jpoimboe/linux.git/log/?h=TODO-objtool-seg-fault > 'objtool: Improve retpoline alternative handling' works for me. Thanks! Guenter