Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp10038981imu; Wed, 5 Dec 2018 15:00:46 -0800 (PST) X-Google-Smtp-Source: AFSGD/U6bEJC/HweF0UB/49AJ08YfS4/mZOJf9TRtL06lZnHxIHGWwOHeQUXiUOtORrnTbghC0Y5 X-Received: by 2002:a62:d74d:: with SMTP id v13mr25747775pfl.34.1544050846891; Wed, 05 Dec 2018 15:00:46 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1544050846; cv=none; d=google.com; s=arc-20160816; b=WNHO4vAC0jwx1JxWwlMuD++XLC9R4TpN1CKSRGk1Yn8MOiTEnHD6YI/DUbbPJE7FhW r18x8UccUlarcAXstGp7PCrC4ihjhvgksTXgYAzoT5+8TDhYNJ52Iarv7VV2LdD6mB8Z ZtxwzZyI20uXr/5Ef6Pdg1kqLHau1+qyHuZC+Zu9f6SVesO1Nk9wYM7Xgo6mhyiEx25N errEiOJlwnIj+3GsQdIKdrhn5xFbngjzeQvyOTKaogFpfQeKZuY3bngKFn0tQI1J/1Mh fsJP0JQuboL7SXaVRt8og65SpSyOrOcIa5jRRCwU+kB8M9KsyxSdbElxzTnZWbC/CEuc qWTw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:message-id:references :in-reply-to:subject:cc:to:from:date:content-transfer-encoding :mime-version:dkim-signature; bh=KVYxo4u0la4cM7i7reyYTw5IJsYJFBEQtgfd+YN7xl8=; b=vP/0SCIMc01cNRBJu63HPYY5hfEiDbSbKInSloLyJ0YvYm1mIQErhnpWKQAaI/Ag2a xMcnQNbySB5f0RdwexvlRSpMEHPkYyB5zjg1RZ7S0Ko4ko7ftkmOISRyTi00oBYkNDgB 9TeGmrKI7yb3uJHg5CjOa9tC/4cG5t95IzBeSeCpRljow/m5hqXM/25aUmkEfgY+Mhbu gKl1KlUA28/7XlAWjhA8jvN4PdYX7+a1Es/l2MuUzSr+9epU5lrw5NVESs1bdzXOxbQc VWTbs396UfL9DUDivxVhOp3+inFuL71RoUfkRR+AIoT9HdDNfywXS+HPJRttTyEP6/82 TkTg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@agner.ch header.s=dkim header.b="OIuSAW/o"; 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 g1si21627750pld.197.2018.12.05.15.00.31; Wed, 05 Dec 2018 15:00:46 -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=pass header.i=@agner.ch header.s=dkim header.b="OIuSAW/o"; 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 S1727823AbeLEW7y (ORCPT + 99 others); Wed, 5 Dec 2018 17:59:54 -0500 Received: from mail.kmu-office.ch ([178.209.48.109]:60724 "EHLO mail.kmu-office.ch" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727337AbeLEW7y (ORCPT ); Wed, 5 Dec 2018 17:59:54 -0500 Received: from webmail.kmu-office.ch (unknown [IPv6:2a02:418:6a02::a3]) by mail.kmu-office.ch (Postfix) with ESMTPSA id EADCB5C0604; Wed, 5 Dec 2018 23:59:49 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=agner.ch; s=dkim; t=1544050789; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=KVYxo4u0la4cM7i7reyYTw5IJsYJFBEQtgfd+YN7xl8=; b=OIuSAW/oAyttAZOm1K2O2UJ1k4Ml4RwcA1IDbjNm8D2QPwk+dAOhZgOfNby5poVLZvHdoM RBVSzEb7lPNdFeFn9u+27xKfHHMFctjkOx8CERzY46FoVaMtvhHmv+M77nKY2fTiWXo738 6m9ZDbpD0eFraLtoU/mI3azsPv1njBc= MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Date: Wed, 05 Dec 2018 23:59:49 +0100 From: Stefan Agner To: Nick Desaulniers Cc: Ard Biesheuvel , Nathan Chancellor , Arnd Bergmann , linux@armlinux.org.uk, Linux ARM , LKML , Nicolas Pitre Subject: Re: [PATCH 2/2] ARM: Wrap '--pic-veneer' with ld-option In-Reply-To: References: <20181205014213.943-1-natechancellor@gmail.com> <20181205014213.943-2-natechancellor@gmail.com> <20181205080645.GA11936@flashbox> <20181205183606.GA7274@flashbox> Message-ID: X-Sender: stefan@agner.ch User-Agent: Roundcube Webmail/1.3.7 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 05.12.2018 19:41, Nick Desaulniers wrote: > On Wed, Dec 5, 2018 at 10:40 AM Ard Biesheuvel > wrote: >> >> On Wed, 5 Dec 2018 at 19:36, Nathan Chancellor wrote: >> > >> > On Wed, Dec 05, 2018 at 09:09:56AM +0100, Ard Biesheuvel wrote: >> > > (+ Arnd) >> > > >> > > On Wed, 5 Dec 2018 at 09:06, Nathan Chancellor wrote: >> > > > >> > > > On Wed, Dec 05, 2018 at 08:37:05AM +0100, Ard Biesheuvel wrote: >> > > > > On Wed, 5 Dec 2018 at 02:42, Nathan Chancellor wrote: >> > > > > > >> > > > > > This flag is not supported by lld: >> > > > > > >> > > > > > ld.lld: error: unknown argument: --pic-veneer >> > > > > > >> > > > > > Signed-off-by: Nathan Chancellor >> > > > > >> > > > > Hi Nate, >> > > > > >> > > > > Does this mean ld.lld is guaranteed to produce position independent >> > > > > veneers if you build kernels that are bigger than the typical range of >> > > > > a relative branch? >> > > > > >> > > > >> > > > Hi Ard, >> > > > >> > > > Honestly, I'm not quite sure. I saw your commit that introduced this >> > > > flag and I wasn't quite sure what to make of it for lld. What >> > > > configuration would I use to verify and what would I check for? >> > > > >> > > >> > > Try building allyesconfig, and check the resulting binary for veneers >> > > (which have 'veneer' in the symbol name, at least when ld.bfd emits >> > > them). These veneers should not take the [virtual] address of the >> > > branch target directly, but take a PC relative offset (as in the >> > > example in the commit log of that patch you are referring to) >> > > >> > >> > Alright, compiling with allyesconfig is a little rough at the moment >> > (bug reports I will file in due time) but I was able to do it. Here's >> > the disassembly specifically for the functions you had in your commit, >> > my assembly knowledge is pretty much non-existent unfortunately so I am >> > not sure what to make of it (it doesn't look like there is a virtual >> > address for pc in that mix?). I am happy to provide any more information >> > that is needed. >> > >> > c03030cc <__enable_mmu>: >> > c03030cc: e3c00002 bic r0, r0, #2 >> > c03030d0: e3c00b02 bic r0, r0, #2048 ; 0x800 >> > c03030d4: e3c00a01 bic r0, r0, #4096 ; 0x1000 >> > c03030d8: e3a05051 mov r5, #81 ; 0x51 >> > c03030dc: ee035f10 mcr 15, 0, r5, cr3, cr0, {0} >> > c03030e0: ee024f10 mcr 15, 0, r4, cr2, cr0, {0} >> > c03030e4: eafff3c5 b c0300000 <__turn_mmu_on> >> > c03030e8: e320f000 nop {0} >> > c03030ec: e320f000 nop {0} >> > c03030f0: e320f000 nop {0} >> > c03030f4: e320f000 nop {0} >> > c03030f8: e320f000 nop {0} >> > c03030fc: e320f000 nop {0} >> > >> > c0300000 <__turn_mmu_on>: >> > c0300000: e1a00000 nop ; (mov r0, r0) >> > c0300004: ee070f95 mcr 15, 0, r0, cr7, cr5, {4} >> > c0300008: ee010f10 mcr 15, 0, r0, cr1, cr0, {0} >> > c030000c: ee103f10 mrc 15, 0, r3, cr0, cr0, {0} >> > c0300010: ee070f95 mcr 15, 0, r0, cr7, cr5, {4} >> > c0300014: e1a03003 mov r3, r3 >> > c0300018: e1a0300d mov r3, sp >> > c030001c: e1a0f003 mov pc, r3 >> > >> >> Thanks Nate. >> >> So these functions no longer appear to reside far away from each >> other, so there no veneer has been emitted. >> >> What we're looking for are veneers, i.e., snippets inserted by the >> linker that serve as a trampoline so a branch target that is far away >> can be reached. >> >> If no symbols exist with 'veneer' in their name *, it might make sense >> to rebuild the kernel as Thumb2, which has a branching range of only 8 >> MB (as opposed to 16 MB for ARM mode) > > Heh, Arnd and I were just talking about this yesterday. Is there a > config that sets Thumb2 mode for the kernel? > Yes there is CONFIG_THUMB2_KERNEL, and it works also with LLVM/Clang. However, it sometimes leads to surprising issues, like I just encountered a few days ago: https://lore.kernel.org/linux-pci/20181126161645.8177-1-stefan@agner.ch/ -- Stefan >> >> * I have no idea whether lld names its veneers like this, or even at all