Received: by 2002:a25:6193:0:0:0:0:0 with SMTP id v141csp5282954ybb; Tue, 24 Mar 2020 14:25:52 -0700 (PDT) X-Google-Smtp-Source: ADFU+vvd5VrEm6o5ZZG3uJg0JzeN4uxnbsjP1nMTxesEDSo5AHvy3EwvDs9xxu5ICJ0cmZhg6bJ+ X-Received: by 2002:a05:6830:16cc:: with SMTP id l12mr90378otr.234.1585085151966; Tue, 24 Mar 2020 14:25:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1585085151; cv=none; d=google.com; s=arc-20160816; b=VkJrrZkudRfFL0Acu9HwvRT2K9iF+6hu2jcviqPu4WzOZGfOVFeypQLoM8mL+jeme+ MgmvumNMapYPJq56yxsgIf3I5dca/e56OGBrOWizrXgSG6s4kFYJu+yxozyslnG/7dG3 jpaGDRHqtH2SKtKgd04ndxg951w3eFAihWAaiI4ddT9rujokwti6s1931Xo0RSTkSJG3 Gs6oKCrRLemD7KEbf7VrExMKfHpjhhnORnrfvYBH0GU5vmuIFt7cPBRFvIweJGQQXX0T 3+xVls8WMQQwP6roqMY2h4YOnWkMuZLhsUd+mwS+SJiXtEtT2F6YkCUqLRSNoN2bua5M FEcQ== 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:mime-version :user-agent:references:in-reply-to:date:cc:to:from:subject :message-id:ironport-sdr:ironport-sdr; bh=XgIZIHKmeBdDPDPDfVYmz7WHUzA6iTlycrzuNUXaX1A=; b=tn5RTomwWD45HvdKMHTJnz3puzs05fdOl5gWY1ci0/TKBsTxH89CldXVIpT3wVEqRf Cj7b9GNLgMrkhzMMVIyW6MvYvc/TCQzVrz2uZZRc0SooP+fM2TaXzJKEKcgJxNadlP24 m3eVzOMDk7G3/HALdmsRF4XRPU80nIvfbgXh6/lK2Bz3tpx2uitzioCooDFyDqH9F9LX H6OuXdwWhrsUI4Rg80CWCrmk9GsJH237eyyTnTqQnQHVruaF9nFn5JbcwLddd+1rqG89 NzUH+LT9XV9rlaLNq/T21/OV2IVm7wcJ2bKXOWenVAnIAgTEuHglyDMro3pHwx99BOSH gVcA== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w203si8988256oie.193.2020.03.24.14.25.32; Tue, 24 Mar 2020 14:25:51 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727753AbgCXVZM (ORCPT + 99 others); Tue, 24 Mar 2020 17:25:12 -0400 Received: from mga04.intel.com ([192.55.52.120]:51063 "EHLO mga04.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727023AbgCXVZL (ORCPT ); Tue, 24 Mar 2020 17:25:11 -0400 IronPort-SDR: aTiYPWRRZI44Mc9Jr8IYnfPbtBwcjtHEpAYFsDNqxT8hv0toer9TnbxMdFS9mQZ8jKq4ZyAt2u Bkd9UBNui91w== X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga002.jf.intel.com ([10.7.209.21]) by fmsmga104.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 24 Mar 2020 14:25:11 -0700 IronPort-SDR: mN5mW36bByfx8u23caSwnMSwzlVG0gkUNRt7tD/10fEzNJJZ2RY/DgvZQ40y7vKwPOVR487G31 vY7WdAYs8ORA== X-IronPort-AV: E=Sophos;i="5.72,301,1580803200"; d="scan'208";a="265298598" Received: from kcaccard-mobl.amr.corp.intel.com (HELO kcaccard-mobl1.jf.intel.com) ([10.251.4.28]) by orsmga002-auth.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 24 Mar 2020 14:25:09 -0700 Message-ID: Subject: Re: [RFC PATCH 05/11] x86: Makefile: Add build and config option for CONFIG_FG_KASLR From: Kristen Carlson Accardi To: Arvind Sankar Cc: tglx@linutronix.de, mingo@redhat.com, bp@alien8.de, hpa@zytor.com, arjan@linux.intel.com, keescook@chromium.org, rick.p.edgecombe@intel.com, x86@kernel.org, linux-kernel@vger.kernel.org, kernel-hardening@lists.openwall.com Date: Tue, 24 Mar 2020 14:24:51 -0700 In-Reply-To: <20200225175544.GA1385238@rani.riverdale.lan> References: <20200205223950.1212394-1-kristen@linux.intel.com> <20200205223950.1212394-6-kristen@linux.intel.com> <20200225175544.GA1385238@rani.riverdale.lan> Content-Type: text/plain; charset="UTF-8" User-Agent: Evolution 3.30.5 (3.30.5-1.fc29) MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, 2020-02-25 at 12:55 -0500, Arvind Sankar wrote: > On Wed, Feb 05, 2020 at 02:39:44PM -0800, Kristen Carlson Accardi > wrote: > > Allow user to select CONFIG_FG_KASLR if dependencies are met. > > Change > > the make file to build with -ffunction-sections if CONFIG_FG_KASLR > > > > Signed-off-by: Kristen Carlson Accardi > > --- > > Makefile | 4 ++++ > > arch/x86/Kconfig | 13 +++++++++++++ > > 2 files changed, 17 insertions(+) > > > > diff --git a/Makefile b/Makefile > > index c50ef91f6136..41438a921666 100644 > > --- a/Makefile > > +++ b/Makefile > > @@ -846,6 +846,10 @@ ifdef CONFIG_LIVEPATCH > > KBUILD_CFLAGS += $(call cc-option, -flive-patching=inline-clone) > > endif > > > > +ifdef CONFIG_FG_KASLR > > +KBUILD_CFLAGS += -ffunction-sections > > +endif > > + > > With -ffunction-sections I get a few unreachable code warnings from > objtool. > > arch/x86/kernel/dumpstack.o: warning: objtool: show_iret_regs()+0x10: > unreachable instruction > fs/sysfs/dir.o: warning: objtool: sysfs_create_mount_point()+0x4f: > unreachable instruction > kernel/time/clocksource.o: warning: objtool: > __clocksource_register_scale()+0x21: unreachable instruction > drivers/tty/sysrq.o: warning: objtool: sysrq_filter()+0x2ef: > unreachable instruction > arch/x86/mm/fault.o: warning: objtool: pgtable_bad()+0x3f: > unreachable instruction > drivers/acpi/pci_root.o: warning: objtool: > acpi_pci_osc_control_set()+0x123: unreachable instruction > drivers/rtc/class.o: warning: objtool: > devm_rtc_device_register()+0x40: unreachable instruction > kernel/power/process.o: warning: objtool: > freeze_processes.cold()+0x0: unreachable instruction > drivers/pnp/quirks.o: warning: objtool: quirk_awe32_resources()+0x42: > unreachable instruction > drivers/acpi/utils.o: warning: objtool: acpi_evaluate_dsm()+0xf1: > unreachable instruction > kernel/reboot.o: warning: objtool: __do_sys_reboot()+0x1b6: > unreachable instruction > kernel/power/swap.o: warning: objtool: swsusp_read()+0x185: > unreachable instruction > drivers/hid/hid-core.o: warning: objtool: hid_hw_start()+0x38: > unreachable instruction > drivers/acpi/battery.o: warning: objtool: > sysfs_add_battery.cold()+0x1a: unreachable instruction > arch/x86/kernel/cpu/mce/core.o: warning: objtool: > do_machine_check.cold()+0x33: unreachable instruction > drivers/pcmcia/cistpl.o: warning: objtool: pccard_store_cis()+0x4e: > unreachable instruction > drivers/gpu/vga/vgaarb.o: warning: objtool: pci_notify()+0x35: > unreachable instruction > arch/x86/kernel/tsc.o: warning: objtool: > determine_cpu_tsc_frequencies()+0x45: unreachable instruction > drivers/pcmcia/yenta_socket.o: warning: objtool: > ti1250_override()+0x50: unreachable instruction > fs/proc/proc_sysctl.o: warning: objtool: > sysctl_print_dir.isra.0()+0x19: unreachable instruction > drivers/iommu/intel-iommu.o: warning: objtool: > intel_iommu_init()+0x4f4: unreachable instruction > net/mac80211/ibss.o: warning: objtool: > ieee80211_ibss_work.cold()+0x157: unreachable instruction > drivers/net/ethernet/intel/e1000/e1000_main.o: warning: objtool: > e1000_clean.cold()+0x0: unreachable instruction > net/core/skbuff.o: warning: objtool: skb_dump.cold()+0x3fd: > unreachable instruction I'm still working on a solution, but the issue here is that any .cold function is going to be in a different section than the related function, and when objtool is searching for instructions in find_insn(), it assumes that it must be in the same section as the caller.