Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp332227iob; Tue, 3 May 2022 19:04:01 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyKWAl9rNc/z5S4C2iPy64aoDdqjGTYEVNj7BR/mkd2aueS/DGNSYEnmXEJwCoQOP7xaY7X X-Received: by 2002:a17:906:2991:b0:6cf:1fd4:39a3 with SMTP id x17-20020a170906299100b006cf1fd439a3mr18350223eje.21.1651629841047; Tue, 03 May 2022 19:04:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1651629841; cv=none; d=google.com; s=arc-20160816; b=Xq521ugb4BQ1jtMx/UQL6vDxXRiUQ4D47b1TTwddjXxGBkEtM+tgLS77PIbhK7iPZc ZLI9Wblp1Phaj2bJ7bVxy2JY4sSxTW9YVaRaCMj4HlD6BBl0D6Gw1BM5Ih142QTj8s+3 h4cVGs8XLBeoQLIjVb5ruIzyTOZqEaJ2j26+1BZDlr42c+Ud5E3iNyyyLK040ZwKVflh aoR/Rd8XYcXG+O6eBKHtcG/MPLBdFknPQenxZ746U1VAmV0DdRGlXeB98DCLnqPumpaf LKYFcsJMOy0lrsyS+UQiItYcRnWbi/hg04N8T/ZUqZk6PdS3XjXbNL+c6LLolr2luzMm Epqg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=jw8bm6qCSYy6P6VWUeZnWl92t/l9H4EI5gAHlpwVuZA=; b=MlczQAnqiWviqhi9JJAWEqkEif/JJ48Z7L5P/lCP0YuLDZUvp+i+ErtQlBrodlBJmf 3n/tAC50IXZkm6eEOOLbhmkDoOlSIP3IeAyRdGYiobeAmD2aSfQgWjbQ6RxYFKfscqYr ocTXj0XcoOOJWMWUo7tlDDdiO255nG36lCNubupUy0Y7NjH7zAjk7DMGymSjppmoTpab +vF0xcw8JpvQ3CcrhWgxpVvPZYzFdN4RH1JZ0OtCpYZkmRO3ZPkvccbtVRtp58sC02D1 VdbCsfoPfJBeZjen+MG2yYSohnzt7Y3yzLvQgkrGE9W9ndZEYS9mx679eufiiI4UvL0u H2BA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=kt6TKIb3; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id 23-20020a170906309700b006e8a89461c8si15494304ejv.902.2022.05.03.19.03.37; Tue, 03 May 2022 19:04:01 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=kt6TKIb3; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236358AbiECU6o (ORCPT + 99 others); Tue, 3 May 2022 16:58:44 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:32934 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236339AbiECU6m (ORCPT ); Tue, 3 May 2022 16:58:42 -0400 Received: from mail-pj1-x102b.google.com (mail-pj1-x102b.google.com [IPv6:2607:f8b0:4864:20::102b]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id EBA3633E04 for ; Tue, 3 May 2022 13:55:08 -0700 (PDT) Received: by mail-pj1-x102b.google.com with SMTP id iq10so16410144pjb.0 for ; Tue, 03 May 2022 13:55:08 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=jw8bm6qCSYy6P6VWUeZnWl92t/l9H4EI5gAHlpwVuZA=; b=kt6TKIb3spJG6f46eBQBOofeRVyb/ToPb9O6thHh0PamzgM1zvWRbVz5kiNssVNFBZ Ve6UEn/QrqYtA3goKXOZjwlYELzP7vNMxkNOI3gmDQDOLN7ZzrhXgX5O2r/TFkh+7xxP G36udorrUQIVhMwU9srG5RrlZ1tUaiM6B/Xd0= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=jw8bm6qCSYy6P6VWUeZnWl92t/l9H4EI5gAHlpwVuZA=; b=xhk0P4VA4yc6vZxz5ZUMJxAwZCjL6W83KQKjO8wukRAL3WfJeR7PsofjkL9x1Tc70U TUMYt0u5ztxJ3aoo7lMUhTFGgFwfk7pajrlbtU4wqNsOJe/mkgU9uQicGb/3Ee4kPlat YwXSZo4+0EyyS3yt+cPKqSTy2TD+kNDuQo9TuWSbEheUZO0Q3b7hdiC5gh9dSZdcGKin i5YwyGAXltl2jzfO2UN7Uhtzs38o6u4MYS/OtInRyQKxFOiI/W+FE5mOIKz7/uzJgSX4 cwuwV2ovSM3UaXiXyNLzNg1S1nzpw0LZT46ogMe+d4xUaluseqY7jKpknCiScG04bhog jJdQ== X-Gm-Message-State: AOAM5339g9wvgZzN4BNIrvJnZjSEeIyYcsmVFV+bVTwHpvzrCagX6Obl EeVZN7FhpPJA8AW+WbgUU/n2ZQ== X-Received: by 2002:a17:902:bf06:b0:14d:8c72:96c6 with SMTP id bi6-20020a170902bf0600b0014d8c7296c6mr18218018plb.156.1651611308496; Tue, 03 May 2022 13:55:08 -0700 (PDT) Received: from www.outflux.net (smtp.outflux.net. [198.145.64.163]) by smtp.gmail.com with ESMTPSA id z9-20020a1709027e8900b0015e8d4eb2d1sm6806192pla.283.2022.05.03.13.55.07 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 03 May 2022 13:55:08 -0700 (PDT) From: Kees Cook To: Bill Wendling Cc: Kees Cook , Masahiro Yamada , Nick Desaulniers , David Howells , Jeff Layton , linux-kernel@vger.kernel.org, linux-kbuild@vger.kernel.org, linux-hardening@vger.kernel.org, llvm@lists.linux.dev Subject: [PATCH 0/6] randstruct: Enable Clang support Date: Tue, 3 May 2022 13:54:57 -0700 Message-Id: <20220503205503.3054173-1-keescook@chromium.org> X-Mailer: git-send-email 2.32.0 MIME-Version: 1.0 X-Developer-Signature: v=1; a=openpgp-sha256; l=2263; h=from:subject; bh=X6EU4DNXnTBgSHB25uvB/YQy33D9lwDWmQXpLxpRzXs=; b=owEBbQKS/ZANAwAKAYly9N/cbcAmAcsmYgBicZalCEa9KZwdrR1ffYy76FhePPL8ViJcDNFJlqIM 9nd88byJAjMEAAEKAB0WIQSlw/aPIp3WD3I+bhOJcvTf3G3AJgUCYnGWpQAKCRCJcvTf3G3AJrpDD/ 4+NYBcLmsDxx+YqOPNtZQwIIUoAslvLe7/qL+HjN1AqimNDYdEtWnARl/cEtEtcuunXDDHpAlbDcfC y3KI7dGI78viVuwe1glQ8FbUqDElLxBdQ/OUt2WgQQ9QhGDfKa4vOki1GcsKv5j2rbZ7k5a5vTBdx/ wkRgyLrxCGZWEC3UygQhTrnab2RmOZaBMw57mxjmMqRb/AvYGqgqMnWahl2yubL3tqQMiMxjluDeQI 91ZKeTYtj75MsB5GezmxZAcPHow+o9sP56AjpL7y+uEk1zYZmk3mw0DS4TYPJe52wHPLlsTDwLyToF MXELE+YyqVQs6MoZN68VJmh6tahuhP4/SzgkfdRFrjIQSBFXon7Am04S2kRrXSHQFdGfnJyTnydrRp jW2IrDXX3BINAqjxObarMqzgDaaoSQAxhApaann26UVr8SU3bTzvzcYyfn/mnKG9iFep54gLQDgWfP gTwewKETf/GlCllJIEucaQmzcbbcjbsj2YI3IBbnf+TX46CuToYZRQi91fs6BVPb58VZLIPyOPwf/n 4LEDEtlJdnwDHXganksJt8QU8vqvk2f1Ord4lwn6ZLRsE/92OK5Tn7UdvY9VhEF5yqk5j7edplw6O+ q3aTuiKQm1VwEiIqSS7kQcAqYUq2CiuerfufKKYbN8YFZKfIGAyGwIRd5OhA== X-Developer-Key: i=keescook@chromium.org; a=openpgp; fpr=A5C3F68F229DD60F723E6E138972F4DFDC6DC026 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.7 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, This enables Clang's recently added structure layout randomization support, similar to the existing kernel-specific GCC plugin. The general Makefile and Kconfig changes are mainly mechanical (moving options around), but the random seed generation changes are a bit fiddly because it needs to be created very early. I think I did this reasonably, but I'd love some more eyes on it. Thanks! -Kees Kees Cook (6): netfs: Eliminate Clang randstruct warning sancov: Split plugin build from plugin CFLAGS randstruct: Reorganize Kconfigs and attribute macros randstruct: Split randstruct Makefile and CFLAGS randstruct: Move seed generation into scripts/basic/ randstruct: Enable Clang support Documentation/dontdiff | 1 + Documentation/kbuild/reproducible-builds.rst | 8 +-- Makefile | 1 + arch/arm/vdso/Makefile | 2 +- arch/arm64/kernel/vdso/Makefile | 3 +- arch/riscv/Kconfig | 2 +- arch/sparc/vdso/Makefile | 3 +- arch/x86/entry/vdso/Makefile | 3 +- arch/x86/mm/pti.c | 2 +- include/linux/compiler-gcc.h | 8 --- include/linux/compiler_types.h | 14 ++-- include/linux/netfs.h | 4 +- include/linux/vermagic.h | 10 +-- kernel/panic.c | 2 +- scripts/Makefile.gcc-plugins | 22 +++--- scripts/Makefile.randstruct | 17 +++++ scripts/basic/.gitignore | 1 + scripts/basic/Makefile | 11 +++ scripts/gcc-plugins/Kconfig | 38 ---------- scripts/gcc-plugins/Makefile | 15 ++-- scripts/gcc-plugins/gen-random-seed.sh | 9 --- scripts/gen-randstruct-seed.sh | 7 ++ security/Kconfig.hardening | 73 ++++++++++++++++++++ 23 files changed, 159 insertions(+), 97 deletions(-) create mode 100644 scripts/Makefile.randstruct delete mode 100755 scripts/gcc-plugins/gen-random-seed.sh create mode 100755 scripts/gen-randstruct-seed.sh -- 2.32.0