diff options
author | John Ericson <git@JohnEricson.me> | 2019-04-03 09:32:05 -0400 |
---|---|---|
committer | Marge Bot <ben+marge-bot@smart-cactus.org> | 2019-04-30 20:29:31 -0400 |
commit | d37d91e9a444a7822eef1558198d21511558515e (patch) | |
tree | 478d7a0bf63e91ac8901f0c277dbe29136b1665b /hadrian | |
parent | 014ed644eea9037427c1ebeaac16189b00f9dbc7 (diff) | |
download | haskell-d37d91e9a444a7822eef1558198d21511558515e.tar.gz |
Generate settings by make/hadrian instead of configure
This allows it to eventually become stage-specific
Diffstat (limited to 'hadrian')
-rw-r--r-- | hadrian/cfg/system.config.in | 40 | ||||
-rw-r--r-- | hadrian/doc/make.md | 11 | ||||
-rw-r--r-- | hadrian/src/Oracles/Setting.hs | 51 | ||||
-rw-r--r-- | hadrian/src/Rules/BinaryDist.hs | 2 | ||||
-rw-r--r-- | hadrian/src/Rules/Configure.hs | 2 | ||||
-rw-r--r-- | hadrian/src/Rules/Generate.hs | 53 | ||||
-rw-r--r-- | hadrian/src/Rules/SourceDist.hs | 2 |
7 files changed, 156 insertions, 5 deletions
diff --git a/hadrian/cfg/system.config.in b/hadrian/cfg/system.config.in index e3c612e0e2..fbb1f54854 100644 --- a/hadrian/cfg/system.config.in +++ b/hadrian/cfg/system.config.in @@ -108,6 +108,46 @@ conf-ld-linker-args-stage1 = @CONF_LD_LINKER_OPTS_STAGE1@ conf-ld-linker-args-stage2 = @CONF_LD_LINKER_OPTS_STAGE2@ conf-ld-linker-args-stage3 = @CONF_LD_LINKER_OPTS_STAGE3@ +# Settings: +#========== + +# We are in the process of moving the settings file from being entirely +# generated by configure, to generated being by the build system. Many of these +# might become redundant. + +gcc-extra-via-c-opts = @GccExtraViaCOpts@ +ld-has-no-compact-unwind = @LdHasNoCompactUnwind@ +ld-has-build-id = @LdHasBuildId@ +ld-has-filelist = @LdHasFilelist@ +ld-is-gnu-ld = @LdIsGNULd@ +ar-args = @ArArgs@ + +settings-c-compiler-command = @SettingsCCompilerCommand@ +settings-haskell-cpp-command = @SettingsHaskellCPPCommand@ +settings-haskell-cpp-flags = @SettingsHaskellCPPFlags@ +settings-c-compiler-flags = @SettingsCCompilerFlags@ +settings-c-compiler-link-flags = @SettingsCCompilerLinkFlags@ +settings-c-compiler-supports-no-pie = @SettingsCCompilerSupportsNoPie@ +settings-ld-command = @SettingsLdCommand@ +settings-ld-flags = @SettingsLdFlags@ +settings-ar-command = @SettingsArCommand@ +settings-ranlib-command = @SettingsRanlibCommand@ +settings-dll-wrap-command = @SettingsDllWrapCommand@ +settings-windres-command = @SettingsWindresCommand@ +settings-libtool-command = @SettingsLibtoolCommand@ +settings-touch-command = @SettingsTouchCommand@ +settings-clang-command = @SettingsClangCommand@ +settings-llc-command = @SettingsLlcCommand@ +settings-opt-command = @SettingsOptCommand@ + +haskell-target-os = @HaskellTargetOs@ +haskell-target-arch = @HaskellTargetArch@ +target-word-size = @TargetWordSize@ +haskell-have-gnu-nonexec-stack = @HaskellHaveGnuNonexecStack@ +haskell-have-ident-directive = @HaskellHaveIdentDirective@ +haskell-have-subsections-via-symbols = @HaskellHaveSubsectionsViaSymbols@ +haskell-have-rts-linker = @HaskellHaveRTSLinker@ + # Include and library directories: #================================= diff --git a/hadrian/doc/make.md b/hadrian/doc/make.md index c163317a18..ff51f6d7ba 100644 --- a/hadrian/doc/make.md +++ b/hadrian/doc/make.md @@ -163,6 +163,17 @@ time you fire up a build. This is not possible with the Make build system. build _build/stage1/lib/platformConstants ``` +- Generate the `settings` file to be used for stage 1/2 GHC + + ``` sh + # Make + make inplace/lib/settings + + # Hadrian + build _build/stage0/lib/settings + build _build/stage1/lib/settings + ``` + - Build a static library for base with the stage 1 compiler ``` sh diff --git a/hadrian/src/Oracles/Setting.hs b/hadrian/src/Oracles/Setting.hs index 46ae5b5bd0..4c87d53404 100644 --- a/hadrian/src/Oracles/Setting.hs +++ b/hadrian/src/Oracles/Setting.hs @@ -3,7 +3,9 @@ module Oracles.Setting ( getSettingList, anyTargetPlatform, anyTargetOs, anyTargetArch, anyHostOs, ghcWithInterpreter, ghcEnableTablesNextToCode, useLibFFIForAdjustors, ghcCanonVersion, cmdLineLengthLimit, iosHost, osxHost, windowsHost, - hostSupportsRPaths, topDirectory, libsuf, ghcVersionStage + hostSupportsRPaths, topDirectory, libsuf, ghcVersionStage, + SettingsFileSetting (..), + settingsFileSetting ) where import Hadrian.Expression @@ -75,6 +77,31 @@ data SettingList = ConfCcArgs Stage | ConfLdLinkerArgs Stage | HsCppArgs +-- TODO compute solely in Hadrian, removing these variables' definitions +-- from aclocal.m4 whenever they can be calculated from other variables +-- already fed into Hadrian. + +-- | Each 'SettingsFileSetting' is defined by 'FP_SETTINGS' in aclocal.m4. +-- Eventually much of that local can probably be computed just in Hadrian. +data SettingsFileSetting + = SettingsFileSetting_CCompilerCommand + | SettingsFileSetting_HaskellCPPCommand + | SettingsFileSetting_HaskellCPPFlags + | SettingsFileSetting_CCompilerFlags + | SettingsFileSetting_CCompilerLinkFlags + | SettingsFileSetting_CCompilerSupportsNoPie + | SettingsFileSetting_LdCommand + | SettingsFileSetting_LdFlags + | SettingsFileSetting_ArCommand + | SettingsFileSetting_RanlibCommand + | SettingsFileSetting_DllWrapCommand + | SettingsFileSetting_WindresCommand + | SettingsFileSetting_LibtoolCommand + | SettingsFileSetting_TouchCommand + | SettingsFileSetting_ClangCommand + | SettingsFileSetting_LlcCommand + | SettingsFileSetting_OptCommand + -- | Look up the value of a 'Setting' in @cfg/system.config@, tracking the -- result. setting :: Setting -> Action String @@ -127,6 +154,28 @@ settingList key = fmap words $ lookupValueOrError configFile $ case key of ConfLdLinkerArgs stage -> "conf-ld-linker-args-" ++ stageString stage HsCppArgs -> "hs-cpp-args" +-- | Look up the value of a 'SettingList' in @cfg/system.config@, tracking the +-- result. +settingsFileSetting :: SettingsFileSetting -> Action String +settingsFileSetting key = lookupValueOrError configFile $ case key of + SettingsFileSetting_CCompilerCommand -> "settings-c-compiler-command" + SettingsFileSetting_HaskellCPPCommand -> "settings-haskell-cpp-command" + SettingsFileSetting_HaskellCPPFlags -> "settings-haskell-cpp-flags" + SettingsFileSetting_CCompilerFlags -> "settings-c-compiler-flags" + SettingsFileSetting_CCompilerLinkFlags -> "settings-c-compiler-link-flags" + SettingsFileSetting_CCompilerSupportsNoPie -> "settings-c-compiler-supports-no-pie" + SettingsFileSetting_LdCommand -> "settings-ld-command" + SettingsFileSetting_LdFlags -> "settings-ld-flags" + SettingsFileSetting_ArCommand -> "settings-ar-command" + SettingsFileSetting_RanlibCommand -> "settings-ranlib-command" + SettingsFileSetting_DllWrapCommand -> "settings-dll-wrap-command" + SettingsFileSetting_WindresCommand -> "settings-windres-command" + SettingsFileSetting_LibtoolCommand -> "settings-libtool-command" + SettingsFileSetting_TouchCommand -> "settings-touch-command" + SettingsFileSetting_ClangCommand -> "settings-clang-command" + SettingsFileSetting_LlcCommand -> "settings-llc-command" + SettingsFileSetting_OptCommand -> "settings-opt-command" + -- | An expression that looks up the value of a 'Setting' in @cfg/system.config@, -- tracking the result. getSetting :: Setting -> Expr c b String diff --git a/hadrian/src/Rules/BinaryDist.hs b/hadrian/src/Rules/BinaryDist.hs index 3db64ee648..c02d9787f9 100644 --- a/hadrian/src/Rules/BinaryDist.hs +++ b/hadrian/src/Rules/BinaryDist.hs @@ -204,7 +204,7 @@ bindistRules = do bindistInstallFiles :: [FilePath] bindistInstallFiles = [ "config.sub", "config.guess", "install-sh", "mk" -/- "config.mk.in" - , "mk" -/- "install.mk.in", "mk" -/- "project.mk", "settings.in", "README" + , "mk" -/- "install.mk.in", "mk" -/- "project.mk", "README" , "INSTALL" ] -- | This auxiliary function gives us a top-level 'Filepath' that we can 'need' diff --git a/hadrian/src/Rules/Configure.hs b/hadrian/src/Rules/Configure.hs index 8395472a4b..ba67df20a6 100644 --- a/hadrian/src/Rules/Configure.hs +++ b/hadrian/src/Rules/Configure.hs @@ -14,7 +14,7 @@ import qualified System.Info.Extra as System -- | Files generated by running the @configure@ script. configureResults :: [FilePath] configureResults = - [ configFile, "settings", configH, "compiler/ghc.cabal", "rts/rts.cabal"] + [ configFile, configH, "compiler/ghc.cabal", "rts/rts.cabal"] configureRules :: Rules () configureRules = do diff --git a/hadrian/src/Rules/Generate.hs b/hadrian/src/Rules/Generate.hs index ba35e03d9d..b167cd1a00 100644 --- a/hadrian/src/Rules/Generate.hs +++ b/hadrian/src/Rules/Generate.hs @@ -7,6 +7,7 @@ module Rules.Generate ( import Base import Expression import Flavour +import Hadrian.Oracles.TextFile (lookupValueOrError) import Oracles.Flag import Oracles.ModuleFiles import Oracles.Setting @@ -161,7 +162,7 @@ copyRules = do prefix -/- "llvm-targets" <~ return "." prefix -/- "llvm-passes" <~ return "." prefix -/- "platformConstants" <~ (buildRoot <&> (-/- generatedDir)) - prefix -/- "settings" <~ return "." + prefix -/- "settings" <~ (buildRoot <&> (-/- generatedDir)) prefix -/- "template-hsc.h" <~ return (pkgPath hsc2hs) prefix -/- "html//*" <~ return "utils/haddock/haddock-api/resources" @@ -177,6 +178,7 @@ generateRules = do priority 2.0 $ (root -/- generatedDir -/- "ghcautoconf.h") <~ generateGhcAutoconfH priority 2.0 $ (root -/- generatedDir -/- "ghcplatform.h") <~ generateGhcPlatformH priority 2.0 $ (root -/- generatedDir -/- "ghcversion.h") <~ generateGhcVersionH + priority 2.0 $ (root -/- generatedDir -/- "settings") <~ generateSettings -- TODO: simplify, get rid of fake rts context root -/- generatedDir ++ "//*" %> \file -> do @@ -261,6 +263,55 @@ generateGhcPlatformH = do ++ [ "\n#endif /* __GHCPLATFORM_H__ */" ] +generateSettings :: Expr String +generateSettings = do + let flag' = flag >=> \case + True -> pure "YES" + False -> pure "NO" + settings <- (traverse . traverse) expr $ + [ ("GCC extra via C opts", lookupValueOrError configFile "gcc-extra-via-c-opts") + , ("C compiler command", settingsFileSetting SettingsFileSetting_CCompilerCommand) + , ("C compiler flags", settingsFileSetting SettingsFileSetting_CCompilerFlags) + , ("C compiler link flags", settingsFileSetting SettingsFileSetting_CCompilerLinkFlags) + , ("C compiler supports -no-pie", settingsFileSetting SettingsFileSetting_CCompilerSupportsNoPie) + , ("Haskell CPP command", settingsFileSetting SettingsFileSetting_HaskellCPPCommand) + , ("Haskell CPP flags", settingsFileSetting SettingsFileSetting_HaskellCPPFlags) + , ("ld command", settingsFileSetting SettingsFileSetting_LdCommand) + , ("ld flags", settingsFileSetting SettingsFileSetting_LdFlags) + , ("ld supports compact unwind", lookupValueOrError configFile "ld-has-no-compact-unwind") + , ("ld supports build-id", lookupValueOrError configFile "ld-has-build-id") + , ("ld supports filelist", lookupValueOrError configFile "ld-has-filelist") + , ("ld is GNU ld", lookupValueOrError configFile "ld-is-gnu-ld") + , ("ar command", settingsFileSetting SettingsFileSetting_ArCommand) + , ("ar flags", lookupValueOrError configFile "ar-args") + , ("ar supports at file", flag' ArSupportsAtFile) + , ("ranlib command", settingsFileSetting SettingsFileSetting_RanlibCommand) + , ("touch command", settingsFileSetting SettingsFileSetting_TouchCommand) + , ("dllwrap command", settingsFileSetting SettingsFileSetting_DllWrapCommand) + , ("windres command", settingsFileSetting SettingsFileSetting_WindresCommand) + , ("libtool command", settingsFileSetting SettingsFileSetting_LibtoolCommand) + , ("cross compiling", flag' CrossCompiling) + , ("target os", lookupValueOrError configFile "haskell-target-os") + , ("target arch", lookupValueOrError configFile "haskell-target-arch") + , ("target word size", lookupValueOrError configFile "target-word-size") + , ("target has GNU nonexec stack", lookupValueOrError configFile "haskell-have-gnu-nonexec-stack") + , ("target has .ident directive", lookupValueOrError configFile "haskell-have-ident-directive") + , ("target has subsections via symbols", lookupValueOrError configFile "haskell-have-subsections-via-symbols") + , ("target has RTS linker", lookupValueOrError configFile "haskell-have-rts-linker") + , ("Unregisterised", flag' GhcUnregisterised) + , ("LLVM llc command", settingsFileSetting SettingsFileSetting_LlcCommand) + , ("LLVM opt command", settingsFileSetting SettingsFileSetting_OptCommand) + , ("LLVM clang command", settingsFileSetting SettingsFileSetting_ClangCommand) + ] + let showTuple (k, v) = "(" ++ show k ++ ", " ++ show v ++ ")" + pure $ case settings of + [] -> "[]" + s : ss -> unlines $ + ("[" ++ showTuple s) + : ((\s' -> "," ++ showTuple s') <$> ss) + ++ ["]"] + + -- | Generate @Config.hs@ files. generateConfigHs :: Expr String generateConfigHs = do diff --git a/hadrian/src/Rules/SourceDist.hs b/hadrian/src/Rules/SourceDist.hs index 6e56c666b6..e70dc5cd7b 100644 --- a/hadrian/src/Rules/SourceDist.hs +++ b/hadrian/src/Rules/SourceDist.hs @@ -110,4 +110,4 @@ prepareTree dest = do , "ghc.mk" , "install-sh" , "packages" - , "settings.in" ] + ] |