Received: by 10.192.165.148 with SMTP id m20csp4915258imm; Tue, 1 May 2018 06:12:08 -0700 (PDT) X-Google-Smtp-Source: AB8JxZrlRBMhYB9lJAp/Pk/na1rZwKXmlTAUjVuk4Sa2slkGwyKAeO3xnu3WljjwYZRL6rIu42Vk X-Received: by 2002:a63:b746:: with SMTP id w6-v6mr8217944pgt.215.1525180328632; Tue, 01 May 2018 06:12:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525180328; cv=none; d=google.com; s=arc-20160816; b=07xrPs6lDHb1HpgVAphVCAkH3MxhsRp83/6nBYUYQP8lPD0Bv8not4oonSEqwkAzfF gseHvXabZt7YHcVKSypOJ+TdfsYQE+kYGdOGdvRw340kWCcLCAPodHBYD8u2UIXUFHKW iWcMAwJHhdzY/pq0E06787UK0Wotkk/abB6KVoyEBtPLGn24sEdD87qx1RFX8quoSxeT gcS25RGXZ0eCcd2p2dPOk8HvCV6DQ+xRGjW/zX3JwKWBBqu48wPI3zw3kac0FLL6GenT x+pBPwcKwOHR/llYUhvBW59UB+WdFbrPJCbwzufzIQwFrcBiOR9rwXtxi4wZ79Fcu+Ao Nf0Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=8LXWgymaPCxluRm8ysjat0riDu8IgvC6aoNju+ZxKWg=; b=FouhJ/AY2to2uyOxDG0w4F2JYFlRGjKRz6y7S5tuySD6ME7SgNmWttlOU+xITYuZgI b7Z4Z4XB8r2+EbxCQc6MLe7Imf7BP6TcsGVp0mfUagYRiIpfFZvLx/VGQIFyWdjaUwCP Gkn5WVIX1WFLc3SKA4oYe0oOkiVZ8VTV+hAUaTbneNCJ5amkPb7NLji76f2P3FwBSr/A BlclCWrcprBMXFMAcl0+/cUWfLY42usFTU7y63zBDNzwkJPu1kHIb2MXTSs+Dqlr6NT9 mhEKrHPtLKlWybCzJX0gh2LFffp42uctnBF1OQEVV29oQUO8goirquVS+jgaHlB5dQtS LcBw== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x12si9136864pfn.254.2018.05.01.06.11.54; Tue, 01 May 2018 06:12:08 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755607AbeEANLY (ORCPT + 99 others); Tue, 1 May 2018 09:11:24 -0400 Received: from mga06.intel.com ([134.134.136.31]:65261 "EHLO mga06.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755388AbeEANLA (ORCPT ); Tue, 1 May 2018 09:11:00 -0400 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga006.jf.intel.com ([10.7.209.51]) by orsmga104.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 01 May 2018 06:10:59 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.49,351,1520924400"; d="scan'208";a="38382575" Received: from gvt-dell.bj.intel.com (HELO gvt-dell-host.bj.intel.com) ([10.238.154.59]) by orsmga006.jf.intel.com with ESMTP; 01 May 2018 06:10:56 -0700 From: changbin.du@intel.com To: yamada.masahiro@socionext.com, michal.lkml@markovi.net, tglx@linutronix.de, mingo@redhat.com, akpm@linux-foundation.org Cc: x86@kernel.org, lgirdwood@gmail.com, broonie@kernel.org, arnd@arndb.de, linux-kbuild@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arch@vger.kernel.org, Changbin Du Subject: [PATCH 4/5] kernel hacking: new config DEBUG_EXPERIENCE to apply GCC -Og optimization Date: Tue, 1 May 2018 21:00:13 +0800 Message-Id: <1525179614-14571-5-git-send-email-changbin.du@intel.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1525179614-14571-1-git-send-email-changbin.du@intel.com> References: <1525179614-14571-1-git-send-email-changbin.du@intel.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Changbin Du This will apply GCC '-Og' optimization level get supported from GCC 4.8. This optimization level offers a reasonable level of optimization while maintaining fast compilation and a good debugging experience. It is similar to '-O1' while perfer keeping debug ability over runtime speed. If enabling this option break your kernel, you should either disable this or find a fix (mostly in the arch code). Currently this option has only be tested in qemu x86_64 guest. This option can satisfy people who was searching for a method to disable compiler optimizations so to achieve better kernel debugging experience with kgdb or qemu. The main problem of '-Og' is we must not use __attribute__((error(smg))). The compiler will report error though the call to error function still can be optimize out. So we must fallback to array tricky. Comparison of vmlinux size: a bit smaller. w/o CONFIG_DEBUG_EXPERIENCE $ size vmlinux text data bss dec hex filename 22665554 9709674 2920908 35296136 21a9388 vmlinux w/ CONFIG_DEBUG_EXPERIENCE $ size vmlinux text data bss dec hex filename 21499032 10102758 2920908 34522698 20ec64a vmlinux Comparison of system performance: a bit drop. w/o CONFIG_DEBUG_EXPERIENCE $ time make -j4 real 6m43.619s user 19m5.160s sys 2m20.287s w/ CONFIG_DEBUG_EXPERIENCE $ time make -j4 real 6m55.054s user 19m11.129s sys 2m36.345s Signed-off-by: Changbin Du --- Makefile | 4 ++++ include/linux/compiler-gcc.h | 2 +- include/linux/compiler.h | 2 +- lib/Kconfig.debug | 21 +++++++++++++++++++++ 4 files changed, 27 insertions(+), 2 deletions(-) diff --git a/Makefile b/Makefile index eb694f6..6a10469 100644 --- a/Makefile +++ b/Makefile @@ -639,6 +639,9 @@ KBUILD_CFLAGS += $(call cc-disable-warning, format-truncation) KBUILD_CFLAGS += $(call cc-disable-warning, format-overflow) KBUILD_CFLAGS += $(call cc-disable-warning, int-in-bool-context) +ifdef CONFIG_DEBUG_EXPERIENCE +KBUILD_CFLAGS += $(call cc-option, -Og) +else ifdef CONFIG_CC_OPTIMIZE_FOR_SIZE KBUILD_CFLAGS += $(call cc-option,-Oz,-Os) KBUILD_CFLAGS += $(call cc-disable-warning,maybe-uninitialized,) @@ -649,6 +652,7 @@ else KBUILD_CFLAGS += -O2 endif endif +endif KBUILD_CFLAGS += $(call cc-ifversion, -lt, 0409, \ $(call cc-disable-warning,maybe-uninitialized,)) diff --git a/include/linux/compiler-gcc.h b/include/linux/compiler-gcc.h index b4bf73f..b8b3832 100644 --- a/include/linux/compiler-gcc.h +++ b/include/linux/compiler-gcc.h @@ -192,7 +192,7 @@ #define __UNIQUE_ID(prefix) __PASTE(__PASTE(__UNIQUE_ID_, prefix), __COUNTER__) -#ifndef __CHECKER__ +#if !defined(__CHECKER__) && !defined(CONFIG_DEBUG_EXPERIENCE) # define __compiletime_warning(message) __attribute__((warning(message))) # define __compiletime_error(message) __attribute__((error(message))) #endif /* __CHECKER__ */ diff --git a/include/linux/compiler.h b/include/linux/compiler.h index ab4711c..952cc7f 100644 --- a/include/linux/compiler.h +++ b/include/linux/compiler.h @@ -301,7 +301,7 @@ unsigned long read_word_at_a_time(const void *addr) * sparse see a constant array size without breaking compiletime_assert on old * versions of GCC (e.g. 4.2.4), so hide the array from sparse altogether. */ -# ifndef __CHECKER__ +# if !defined(__CHECKER__) && !defined(CONFIG_DEBUG_EXPERIENCE) # define __compiletime_error_fallback(condition) \ do { ((void)sizeof(char[1 - 2 * condition])); } while (0) # endif diff --git a/lib/Kconfig.debug b/lib/Kconfig.debug index 90f35ad..2432e77d 100644 --- a/lib/Kconfig.debug +++ b/lib/Kconfig.debug @@ -211,6 +211,27 @@ config NO_AUTO_INLINE Use only if you want to debug the kernel. +config DEBUG_EXPERIENCE + bool "Optimize for better debugging experience (-Og)" + default n + select NO_AUTO_INLINE + depends on !CC_OPTIMIZE_FOR_SIZE + help + This will apply GCC '-Og' optimization level get supported from + GCC 4.8. This optimization level offers a reasonable level of + optimization while maintaining fast compilation and a good + debugging experience. It is similar to '-O1' while perfer keeping + debug ability over runtime speed. The overall performance will + drop a bit. + + If enabling this option break your kernel, you should either + disable this or find a fix (mostly in the arch code). Currently + this option has only be tested in qemu x86_64 guest. + + Use only if you want to debug the kernel, especially if you want + to have better kernel debugging experience with gdb facilities + like kgdb and qemu. + config ENABLE_WARN_DEPRECATED bool "Enable __deprecated logic" default y -- 2.7.4