Received: by 2002:a25:868d:0:0:0:0:0 with SMTP id z13csp1787333ybk; Thu, 21 May 2020 15:30:35 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw3nNSToTFyobq+pUlhZMUe7F2n/4X1U+ekuCWG0wqQ7O+q+ZKEb38Q0n4NwO+wPOowGpAa X-Received: by 2002:a17:906:aeca:: with SMTP id me10mr5922655ejb.367.1590100235615; Thu, 21 May 2020 15:30:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1590100235; cv=none; d=google.com; s=arc-20160816; b=vDzYbNrFb7JV/gmXGlvQ+xe0GKmBjOc3ykNkjKyBbzo94X7GIz9OREvlhyNU2vQjt7 8oRX89AaWqKVfbVE7e811mjq9aGMJWeftxp2icn7rfdAyfzxhiYfowokgSkpF6PiEjrF 2T5hv9PUBL2aQCvl3pMYAlK1ONJIUgp+kIw5m/TEbWSDYL+3BM7ukpTYR0xg/8tO5zBF 50hVYYcftDaj9jvU3zDTw+VOsU692olLYGglPRViZ7MP+UXF8PtirdRWQXUq9YourZLn iAxzkQwvmqW6+Exy4GXIKuKxHr414Zhj0tY7dkQx0/+D5HCl3dOD0cmTIgpmLX5RwQqV WZAA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:date:references :in-reply-to:subject:cc:to:from; bh=zSnRCDRFFFs3UHduia1lFwXz/0RCie800t+cVucS1E8=; b=TuSgPCAETzrrSDIUUAxUQzT3qMabOyUqZ4wOMCkxFmZ6ytKLPDxBytqLItyY+pfmn7 7+aN/A4QtZVkD+4B4jF2XNbF1Esk1Won9pUrpHor9ve8txArbz84EZInVYlOd5uxXuq2 JAnlyCYQm6Utp6XeXYU0QjGFlvwsiM368O6nyJfeL8l3dVFBI6ZjFIcJoGxoO1CI0i6x MY4WiRS0VO242fcNthA0rIy/F1Lgnr5eeGZ9wQImpAGfQRDO/+LNsNvQiHilCBbnATCz xjHBMfAxDfGePQ2NHkZ/q7wFQHwIudoWEKYhKkZsSz+DYDpSW4HwAuQh5DgL7dntC5id hb7A== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id x25si3813126edi.132.2020.05.21.15.30.11; Thu, 21 May 2020 15:30:35 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730540AbgEUW0w (ORCPT + 99 others); Thu, 21 May 2020 18:26:52 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45266 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728701AbgEUW0w (ORCPT ); Thu, 21 May 2020 18:26:52 -0400 Received: from Galois.linutronix.de (Galois.linutronix.de [IPv6:2a0a:51c0:0:12e:550::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8DC1EC061A0E for ; Thu, 21 May 2020 15:26:52 -0700 (PDT) Received: from p5de0bf0b.dip0.t-ipconnect.de ([93.224.191.11] helo=nanos.tec.linutronix.de) by Galois.linutronix.de with esmtpsa (TLS1.2:DHE_RSA_AES_256_CBC_SHA256:256) (Exim 4.80) (envelope-from ) id 1jbte3-0002iw-16; Fri, 22 May 2020 00:26:31 +0200 Received: by nanos.tec.linutronix.de (Postfix, from userid 1000) id 5E621100CA6; Fri, 22 May 2020 00:26:30 +0200 (CEST) From: Thomas Gleixner To: Kristen Carlson Accardi , keescook@chromium.org, mingo@redhat.com, bp@alien8.de Cc: arjan@linux.intel.com, x86@kernel.org, linux-kernel@vger.kernel.org, kernel-hardening@lists.openwall.com, rick.p.edgecombe@intel.com, Kristen Carlson Accardi Subject: Re: [PATCH v2 0/9] Function Granular KASLR In-Reply-To: <20200521165641.15940-1-kristen@linux.intel.com> References: <20200521165641.15940-1-kristen@linux.intel.com> Date: Fri, 22 May 2020 00:26:30 +0200 Message-ID: <87367sudpl.fsf@nanos.tec.linutronix.de> MIME-Version: 1.0 Content-Type: text/plain X-Linutronix-Spam-Score: -1.0 X-Linutronix-Spam-Level: - X-Linutronix-Spam-Status: No , -1.0 points, 5.0 required, ALL_TRUSTED=-1,SHORTCIRCUIT=-0.0001 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Kristen, Kristen Carlson Accardi writes: sorry for not following this work and a maybe stupid question. > Proposed Improvement > -------------------- > This patch set proposes adding function reordering on top of the existing > KASLR base address randomization. The over-arching objective is incremental > improvement over what we already have. It is designed to work in combination > with the existing solution. The implementation is really pretty simple, and > there are 2 main area where changes occur: > > * Build time > > GCC has had an option to place functions into individual .text sections for > many years now. This option can be used to implement function reordering at > load time. The final compiled vmlinux retains all the section headers, which > can be used to help find the address ranges of each function. Using this > information and an expanded table of relocation addresses, individual text > sections can be suffled immediately after decompression. Some data tables > inside the kernel that have assumptions about order require re-sorting > after being updated when applying relocations. In order to modify these tables, > a few key symbols are excluded from the objcopy symbol stripping process for > use after shuffling the text segments. I understand how this is supposed to work, but I fail to find an explanation how all of this is preserving the text subsections we have, i.e. .kprobes.text, .entry.text ...? I assume that the functions in these subsections are reshuffled within their own randomized address space so that __xxx_text_start and __xxx_text_end markers still make sense, right? I'm surely too tired to figure it out from the patches, but you really want to explain that very detailed for mere mortals who are not deep into this magic as you are. Thanks, tglx