Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp2278068imm; Thu, 20 Sep 2018 10:27:33 -0700 (PDT) X-Google-Smtp-Source: ANB0VdZ3wfUc6lqcQ+RJ+jyFEx1bngSN8n4A/pDmoc3+ZL3TKOelAKBh/31UZE24qe+QhibS3Hrw X-Received: by 2002:a63:db4f:: with SMTP id x15-v6mr36002551pgi.214.1537464453691; Thu, 20 Sep 2018 10:27:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1537464453; cv=none; d=google.com; s=arc-20160816; b=ecYkO37JFxNouJbNIjfQjsnuv+JkwxK2Qc4UrnJNHZNITinPmhhUARoD4Hvqq4Xybp /0HQ3xiznPkOaLY7fs/N02si6BQb5N2WD4z4uYLR+DrM+MgfXvbZlnOzYIDNmLVl/9YW QABQ5PV/2f3bP4v2Ts0BYq5ZkiTJZ/z0nKJYj01pFfjnXvskLvGYP7tHO6idoTmPqfTD fHOcLhe/mBmqykN2JNrbP3mnDMUKysZZTb5jGUTeRYQomA824uwo7jQRVq4PnhQ9Uzkz DWeHUO6ZcUxgqINOqo37xQjWVCo738ZAikQNXAfHh009VfaVsEoBimT4EAreGdH1VfNY kvNw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=Mvn36hofEfpPYpcukR+o6LwbHt1GjireKAgB3TC2U50=; b=XKEuqmV7z27WXonCYbChBrAWkxcsJ/P2DCE4tJFmmw4aM67VO1SFj+PGP6ruxABb0w pl6qp4O07t6ovy4XD+dMhJRPafmN27TSrXmN5X3iOnFZfWemR9xqe3xiYhhzUkmdN9Mn ICksF1IuMc8jZkL8IKTKFkeeRnoHjXyar15YY6TfxHyuUXP9Wv4vcneqBSfByXTShdpD hxAFnDcI7wytbkcR90vqRN4SBl8BXxn58i8nZeTdG2OjxYSnU9SqSFgarOfaXtY+0csx RosYYNzyeGzwkSyehXDIj54sB54jMMx6LBk61KDR5KykFmOpIKFTPi+nDTxvPB+c6WlQ +9yg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=hMTKorav; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 65-v6si26678519pld.451.2018.09.20.10.27.17; Thu, 20 Sep 2018 10:27:33 -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=@gmail.com header.s=20161025 header.b=hMTKorav; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387817AbeITXH5 (ORCPT + 99 others); Thu, 20 Sep 2018 19:07:57 -0400 Received: from mail-wr1-f67.google.com ([209.85.221.67]:45556 "EHLO mail-wr1-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726799AbeITXH5 (ORCPT ); Thu, 20 Sep 2018 19:07:57 -0400 Received: by mail-wr1-f67.google.com with SMTP id 20-v6so10193979wrb.12; Thu, 20 Sep 2018 10:23:24 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=Mvn36hofEfpPYpcukR+o6LwbHt1GjireKAgB3TC2U50=; b=hMTKoravMYNas+nuIcZfBd5dd7yOKW68Ci71HaOf7X5FZqGyzFaHL4U4PkwlucG+0F z8d2vDzAZnst7Y/zNst4Z1aF2Gm1GX1z6aptkTN02ojcM3UMQ4MpMI5wGtS2LIyJQZ1X T88PzgIHUDZpJIZEsD/Hg//k5jcsv49fj8JrzEeoGU3qihfCltnM4WBnNyCct6V1gYue yWV5oWM/tkl2pUqAct+M7QjvE+o1mBnb4U8QnIITOi51CcsMSDL/5qKTBmmhHvCVqXfp 6jgML4mjbIv7iWTj9zBVTbo0gZGeSorm/2LMzUwZvzXDt4uQYQKXuJhgkf+RoE3z13IA syZw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=Mvn36hofEfpPYpcukR+o6LwbHt1GjireKAgB3TC2U50=; b=WhCAmJi5gzoOK2ZOSWiMFjHVBHB4yyKlTmpB7da0NnNg2fuySq1A6QtUB6uUVkIKh/ Y6PEIKzNasZsNN0ya4yq7Uj7Q/36ZnlaEJ+LHEj5gPY45JiHCfhxgncjwmg06VDy+uMR DfahpFohtcDk1Tov8CYMTmCyeGbPw5G2yT9GBzXKs2nxZrtkQ9+IVs+96dCgUGvrqoq6 prTFgMjyBKMRomvbFBu80k3gL2N/dRwAhkGjQMiuhvLVgcs361b/W3SbberE4kSWQd8L 7qk4d/mBDM1GPzKP9A12S8S/7Ogmj/JfPGK0XE+sMzAZq1+3PZj55NGLSSFWZ/oVbA4A VNLA== X-Gm-Message-State: APzg51B9gFrOIUiq80kcmbOEfo2Bx79iRrn4f+c1PUmqrCHaMQgzJGJX IthmPKEYBqrF1ESwsBM+d0U= X-Received: by 2002:adf:fe06:: with SMTP id n6-v6mr35097238wrr.171.1537464204115; Thu, 20 Sep 2018 10:23:24 -0700 (PDT) Received: from localhost.localdomain (62.83.35.8.dyn.user.ono.com. [62.83.35.8]) by smtp.gmail.com with ESMTPSA id q200-v6sm3466562wmd.2.2018.09.20.10.23.21 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 20 Sep 2018 10:23:23 -0700 (PDT) From: Miguel Ojeda To: Greg Kroah-Hartman Cc: linux-kernel@vger.kernel.org, Miguel Ojeda , Andreas Dilger , Masahiro Yamada , Michal Marek , Steven Rostedt , Mauro Carvalho Chehab , Olof Johansson , Konstantin Ryabitsev , "David S . Miller" , Andrey Ryabinin , Kees Cook , Thomas Gleixner , Ingo Molnar , Paul Lawrence , Sandipan Das , Andrey Konovalov , David Woodhouse , Will Deacon , Philippe Ombredanne , Paul Burton , David Rientjes , Willy Tarreau , Martin Sebor , Christopher Li , Jonathan Corbet , Theodore Ts'o , Geert Uytterhoeven , Rasmus Villemoes , Joe Perches , Arnd Bergmann , Dominique Martinet , Stefan Agner , Luc Van Oostenryck , Nick Desaulniers , Andrew Morton , Linus Torvalds , linux-doc@vger.kernel.org, linux-ext4@vger.kernel.org, linux-sparse@vger.kernel.org, linux-kbuild@vger.kernel.org Subject: [PATCH v5 00/15] Compiler Attributes Date: Thu, 20 Sep 2018 19:22:46 +0200 Message-Id: <20180920172301.21868-1-miguel.ojeda.sandonis@gmail.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The Compiler Attributes series is an effort to disentangle the include/linux/compiler*.h headers and bring them up to date. The main idea behind the series is to use feature checking macros (i.e. __has_attribute) instead of compiler version checks (e.g. GCC_VERSION), which are compiler-agnostic (so they can be shared, reducing the size of compiler-specific headers) and version-agnostic. Other related improvements have been performed in the headers as well, which on top of the use of __has_attribute it has amounted to a significant simplification of these headers (e.g. GCC_VERSION is now only guarding 4 non-attribute macros). This series should also help the efforts to support compiling the kernel with clang and icc. A fair amount of documentation and comments have also been added, clarified or removed; and the headers are now more readable, which should help kernel developers in general. The series was triggered due to the move to gcc >= 4.6. In turn, this series has also triggered Sparse to gain the ability to recognize __has_attribute on its own. Finally, the nonstring variable attribute series has been applied on top of this one. You can also fetch it from: https://github.com/ojeda/linux/tree/compiler-attributes-v5 Enjoy! Cheers, Miguel Cc: Andreas Dilger Cc: Masahiro Yamada Cc: Michal Marek Cc: Steven Rostedt Cc: Mauro Carvalho Chehab Cc: Olof Johansson Cc: Konstantin Ryabitsev Cc: David S. Miller Cc: Andrey Ryabinin Cc: Kees Cook Cc: Thomas Gleixner Cc: Ingo Molnar Cc: Paul Lawrence Cc: Sandipan Das Cc: Andrey Konovalov Cc: David Woodhouse Cc: Will Deacon Cc: Philippe Ombredanne Cc: Paul Burton Cc: David Rientjes Cc: Willy Tarreau Cc: Martin Sebor Cc: Christopher Li Cc: Jonathan Corbet Cc: Theodore Ts'o Cc: Geert Uytterhoeven Cc: Rasmus Villemoes Cc: Joe Perches Cc: Arnd Bergmann Cc: Dominique Martinet Cc: Stefan Agner Cc: Luc Van Oostenryck Cc: Nick Desaulniers Cc: Andrew Morton Cc: Greg Kroah-Hartman Cc: Linus Torvalds Cc: linux-doc@vger.kernel.org Cc: linux-ext4@vger.kernel.org Cc: linux-sparse@vger.kernel.org Cc: linux-kbuild@vger.kernel.org v4 -> v5 * Removed the 2 __naked patches, since Greg just applied them to master; and rebased on top of that. The only change in the range-diff is in "Compiler Attributes: always use the extra-underscores syntax" due to the move of __naked to compiler_types.h. * Applied the nonstring series on top of this one (last 4 patches). Rationale: - the nonstring series would anyway be modified again by this one (so it has been rebased after the general cleanup). - ext4's "local" nonstring was merged - easier to manage (and easier to see the end result) The first 2 patches of the last 4 add the warning back at W=1 and add the __nonstring attribute. The other two serve as an example of usage and as a cleanup. * Cc lists removed from each commit; using a single list in the cover letter; and a new, revised list of Cc (wider audience). Miguel Ojeda (15): Compiler Attributes: remove unused attributes Compiler Attributes: always use the extra-underscores syntax Compiler Attributes: remove unneeded tests Compiler Attributes: homogenize __must_be_array Compiler Attributes: remove unneeded sparse (__CHECKER__) tests Compiler Attributes: add missing SPDX ID in compiler_types.h Compiler Attributes: use feature checks instead of version checks Compiler Attributes: KENTRY used twice the "used" attribute Compiler Attributes: remove uses of __attribute__ from compiler.h Compiler Attributes: add Doc/process/programming-language.rst Compiler Attributes: add MAINTAINERS entry Compiler Attributes: add support for __nonstring (gcc >= 8) Compiler Attributes: enable -Wstringop-truncation on W=1 (gcc >= 8) Compiler Attributes: auxdisplay: panel: use __nonstring Compiler Attributes: ext4: remove local __nonstring definition Documentation/process/index.rst | 1 + .../process/programming-language.rst | 45 +++ MAINTAINERS | 5 + drivers/auxdisplay/panel.c | 7 +- fs/ext4/ext4.h | 9 - include/linux/compiler-clang.h | 5 - include/linux/compiler-gcc.h | 70 +---- include/linux/compiler-intel.h | 9 - include/linux/compiler.h | 19 +- include/linux/compiler_attributes.h | 258 ++++++++++++++++++ include/linux/compiler_types.h | 101 +------ scripts/Makefile.extrawarn | 1 + 12 files changed, 341 insertions(+), 189 deletions(-) create mode 100644 Documentation/process/programming-language.rst create mode 100644 include/linux/compiler_attributes.h -- 2.17.1