Received: by 2002:a5b:505:0:0:0:0:0 with SMTP id o5csp1063292ybp; Fri, 11 Oct 2019 08:27:05 -0700 (PDT) X-Google-Smtp-Source: APXvYqziySrWgRWrv9johQJ2ShlABQSuj06XDhCBERkYhC95LM+4XUg7OJ9Q/gPygRP94NhTVlfJ X-Received: by 2002:a05:6402:b02:: with SMTP id bm2mr14227204edb.244.1570807625646; Fri, 11 Oct 2019 08:27:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1570807625; cv=none; d=google.com; s=arc-20160816; b=0fcPTcmA8IAzDTRB8VizVk21VRXmzo6XQfKTvYRmH+pz2YY2F/BX9dUJab+KBA5Ev7 VZWLy4eJCMj4QlnqKf/f43c0TPnjio6n/+ez3s67COH8Rdl4OItNg3myu2RVPKcNV2ZC swsgX94+ml2N171px08eLDs+9bGpVfKuSDuToBswSGjBAITwHKNrSSQfOo4GvPDDSKmk dj6o7+YATsPguU71JiKC7giUV14hhOYVcOqrp0dHog3E0DjjrupOab5d6v5QlL6lRK0h Apq3tOdNAv7PPrYaH3epUVB5W56FKzscn9ikR0Pw5XT1ThiOcuLttmCr5EqAFk7uq5in V/9A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:openpgp:from:references:cc:to:subject:dkim-signature; bh=hjVVG+LCl45Ap93nqrjHPaMZ4hTq+jdNOcLl2h2isR4=; b=xdSR9pVmeePpLj6xEited09OdYPgQB67jbPudfS7uvTFvMCmapMdROdExGZe2SbBBb ozis3WSStZCp9KOOW1vGQl8sFrfmaFWPdqkXUwNVpkeTHHGysGkJkxtgNzjFUGtLUX5B dbd9L7qiS93UMt/3Gz5kO+hrBZ7VbZK4+xTry3EPDnowfKLAA/pSVuibghBgKW9j+7YX 1mZA5yaKMzwsl47AKun2bZW1jQ5L3PZUpPMJshN4F1wsLHeil05OIxftN3ibrULF24aM wzhTx39tEe3DtuRY1isumZ89t97edaK7pylvyuF7SSsmwg34+4j/7iCjpesjXFoUH0BM dv+Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=E0dKoxgv; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id oe23si5314925ejb.199.2019.10.11.08.26.41; Fri, 11 Oct 2019 08:27:05 -0700 (PDT) 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=pass header.i=@linaro.org header.s=google header.b=E0dKoxgv; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727785AbfJKPZh (ORCPT + 99 others); Fri, 11 Oct 2019 11:25:37 -0400 Received: from mail-yb1-f194.google.com ([209.85.219.194]:41568 "EHLO mail-yb1-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726707AbfJKPZh (ORCPT ); Fri, 11 Oct 2019 11:25:37 -0400 Received: by mail-yb1-f194.google.com with SMTP id 206so3221200ybc.8 for ; Fri, 11 Oct 2019 08:25:37 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=subject:to:cc:references:from:openpgp:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=hjVVG+LCl45Ap93nqrjHPaMZ4hTq+jdNOcLl2h2isR4=; b=E0dKoxgvUXWjFVVVks6GzW0TjExH0yK1lnbi91wV8UOgJXhezVXn6TKlZ8HQUqA4LB Ocx5BzIjuxG958WumzE9PHeFIKmdin8uJ80H+haes7A8Uss5tac+84Bu78gsZut6QXAH lAk8SDxXuvS8brS+1lB1ksHLQ4k/RGyUL6wLn/UpINn7yR8VT+jswqGAyCr8ZhDTczre 5iQpR0zvXXa+jUNmN6dDOszzNYTbsXpTuYHQnlbsTKD8jioNaXyu0auTjxbbs/cFails zGhGXYBrnMUWJ8wU2JABRejO0vxitMy0Ol37RK7oCzGgGTyKxkikYq8uCPF7weNSTt9/ JvtQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:openpgp:message-id :date:user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=hjVVG+LCl45Ap93nqrjHPaMZ4hTq+jdNOcLl2h2isR4=; b=hn8IcF3+Quwc+xCkDl3RY+Ll/tVudtTl0HTR6PNX7MAVP/3Gy73zuTQQxR5poD7lCb YgEILmbDRQSz2V0f7HZT5hQCH5nPZtd0peoawIXBA/8yp648BSqLNQqd7gpRY0a5i9X8 JGnPtKmRLnL6E1kVQ2li4hT3blGU7WbmglT7heTBpi/xgE9kCFE8B0mFmr6ujV6v+HRD RXHlFb4/EmdsvsNNUusXJEfQiSGcSU04yej6OGC5BUAcKoCnOfZnd2LvAB6W6k8mhRWA 26CtyJ1sn5quX7lda+f4s7h+1/buDyTyOBGSNkCWCJX8NddFGC6Q0trmLd2nq1LQQYAr DTlQ== X-Gm-Message-State: APjAAAVBcCGWszmjZXJ2i1bChOmt7Ch1wwt7ejBYipoNR13wqmmALn+4 1O+pA1bqDyrWM5KlGM/sR61/eA== X-Received: by 2002:a25:2d49:: with SMTP id s9mr9205759ybe.450.1570807536250; Fri, 11 Oct 2019 08:25:36 -0700 (PDT) Received: from [192.168.1.44] (67.216.151.25.pool.hargray.net. [67.216.151.25]) by smtp.gmail.com with ESMTPSA id t82sm2316781ywc.26.2019.10.11.08.25.34 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 11 Oct 2019 08:25:35 -0700 (PDT) Subject: Re: [PATCH v2 05/12] arm64: Basic Branch Target Identification support To: Mark Rutland , Dave Martin Cc: linux-kernel@vger.kernel.org, Andrew Jones , Arnd Bergmann , Catalin Marinas , Eugene Syromiatnikov , Florian Weimer , "H.J. Lu" , Jann Horn , Kees Cook , =?UTF-8?Q?Kristina_Mart=c5=a1enko?= , Mark Brown , Paul Elliott , Peter Zijlstra , Sudakshina Das , Szabolcs Nagy , Thomas Gleixner , Will Deacon , Yu-cheng Yu , Amit Kachhap , Vincenzo Frascino , linux-arch@vger.kernel.org, linux-arm-kernel@lists.infradead.org References: <1570733080-21015-1-git-send-email-Dave.Martin@arm.com> <1570733080-21015-6-git-send-email-Dave.Martin@arm.com> <20191011151028.GE33537@lakrids.cambridge.arm.com> From: Richard Henderson Openpgp: preference=signencrypt Message-ID: <4e09ca54-f353-9448-64ed-4ba1e38c6ebc@linaro.org> Date: Fri, 11 Oct 2019 11:25:33 -0400 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.8.0 MIME-Version: 1.0 In-Reply-To: <20191011151028.GE33537@lakrids.cambridge.arm.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 10/11/19 11:10 AM, Mark Rutland wrote: > On Thu, Oct 10, 2019 at 07:44:33PM +0100, Dave Martin wrote: >> @@ -730,6 +730,11 @@ static void setup_return >> regs->regs[29] = (unsigned long)&user->next_frame->fp; >> regs->pc = (unsigned long)ka->sa.sa_handler; >> >> + if (system_supports_bti()) { >> + regs->pstate &= ~PSR_BTYPE_MASK; >> + regs->pstate |= PSR_BTYPE_CALL; >> + } >> + > > I think we might need a comment as to what we're trying to ensure here. > > I was under the (perhaps mistaken) impression that we'd generate a > pristine pstate for a signal handler, and it's not clear to me that we > must ensure the first instruction is a target instruction. I think it makes sense to treat entry into a signal handler as a call. Code that has been compiled for BTI, and whose page has been marked with PROT_BTI, will already have the pauth/bti markup at the beginning of the signal handler function; we might as well verify that. Otherwise sigaction becomes a hole by which an attacker can force execution to start at any arbitrary address. r~