1 # -----------------------------------------------------------------------------
3 # (c) 2009 The University of Glasgow
5 # This file is part of the GHC build system.
7 # To understand how the build system works and how to modify it, see
8 # http://hackage.haskell.org/trac/ghc/wiki/Building/Architecture
9 # http://hackage.haskell.org/trac/ghc/wiki/Building/Modifying
11 # -----------------------------------------------------------------------------
15 # * remove old Makefiles, add new stubs for building in subdirs
17 # * docs/docbook-cheat-sheet/Makefile
18 # * docs/ext-core/Makefile
20 # * docs/storage-mgmt/Makefile
22 # * rts/dotnet/Makefile
24 # * add Makefiles for the rest of the utils/ programs that aren't built
25 # by default (need to exclude them from 'make all' too)
29 # * per-source-file dependencies instead of one .depend file?
30 # * eliminate undefined variables, and use --warn-undefined-variables?
31 # * put outputs from different ways in different subdirs of distdir/build,
32 # then we don't have to use -osuf/-hisuf. We would have to install
33 # them in different places too, so we'd need ghc-pkg support for packages
35 # * make PACKAGES generated by './configure' or './boot'?
36 # * we should use a directory of package.conf files rather than a single
37 # file for the inplace package database, so that we can express
38 # dependencies more accurately. Otherwise it's possible to get into
39 # a state where the package database is out of date, and the build
40 # system doesn't know.
42 # Approximate build order.
44 # The actual build order is defined by dependencies, and the phase
45 # ordering used to ensure correct ordering of makefile-generation; see
46 # http://hackage.haskell.org/trac/ghc/wiki/Building/Architecture/Idiom/PhaseOrdering
48 # * With bootstrapping compiler:
49 # o Build utils/ghc-cabal
50 # o Build utils/ghc-pkg
51 # o Build utils/hsc2hs
53 # o configure, generate package-data.mk and inplace-pkg-info
54 # o register each package into inplace/lib/package.conf
56 # * With bootstrapping compiler:
57 # o Build libraries/{filepath,hpc,extensible-exceptions,Cabal}
58 # o Build compiler (stage 1)
62 # o Build utils/* (except haddock)
63 # o Build compiler (stage 2)
65 # o Build utils/haddock
66 # o Build compiler (stage 3) (optional)
71 .PHONY: default all haddock
73 # We need second expansion for the way we handle directories, so that
75 # expands to the directory of a rule that uses a % pattern.
80 # Catch make if it runs away into an infinite loop
81 ifeq "$(MAKE_RESTARTS)" ""
82 else ifeq "$(MAKE_RESTARTS)" "1"
83 else ifeq "$(MAKE_RESTARTS)" "2"
85 $(error Make has restarted itself $(MAKE_RESTARTS) times; is there a makefile bug?)
88 ifneq "$(CLEANING)" "YES"
92 # -----------------------------------------------------------------------------
96 space=$(nothing) $(nothing)
99 # Cancel all suffix rules. Ideally we'd like to have 'make -r' turned on
100 # by default, because that disables all the implicit rules, but there doesn't
101 # seem to be a good way to do that. This turns off all the old-style suffix
102 # rules, which does half the job and speeds up make quite a bit:
105 # -----------------------------------------------------------------------------
108 # to see the effective value used for a Makefile variable, do
109 # make show VALUE=MY_VALUE
113 @echo '$(VALUE)="$($(VALUE))"'
115 # -----------------------------------------------------------------------------
116 # Include subsidiary build-system bits
120 ifeq "$(findstring clean,$(MAKECMDGOALS))" ""
122 ifeq "$(ProjectVersion)" ""
123 $(error Please run ./configure first)
129 # (Optional) build-specific configuration
130 include mk/custom-settings.mk
132 ifeq "$(findstring clean,$(MAKECMDGOALS))" ""
133 ifeq "$(GhcLibWays)" ""
134 $(error $$(GhcLibWays) is empty, it must contain at least one way)
138 # -----------------------------------------------------------------------------
139 # Utility definitions
141 include rules/trace.mk
142 include rules/make-command.mk
144 # -----------------------------------------------------------------------------
145 # Macros for standard targets
147 include rules/all-target.mk
148 include rules/clean-target.mk
150 # -----------------------------------------------------------------------------
153 $(eval $(call clean-target,inplace,,inplace/bin inplace/lib))
155 # -----------------------------------------------------------------------------
156 # Whether to build dependencies or not
158 # When we're just doing 'make clean' or 'make show', then we don't need
159 # to build dependencies.
161 ifneq "$(findstring clean,$(MAKECMDGOALS))" ""
162 NO_INCLUDE_DEPS = YES
163 NO_INCLUDE_PKGDATA = YES
165 ifneq "$(findstring bootstrapping-files,$(MAKECMDGOALS))" ""
166 NO_INCLUDE_DEPS = YES
167 NO_INCLUDE_PKGDATA = YES
169 ifeq "$(findstring show,$(MAKECMDGOALS))" "show"
170 NO_INCLUDE_DEPS = YES
171 # We want package-data.mk for show
174 # -----------------------------------------------------------------------------
177 include rules/way-prelims.mk
179 $(foreach way,$(ALL_WAYS),\
180 $(eval $(call way-prelims,$(way))))
182 # -----------------------------------------------------------------------------
185 include rules/distdir-way-opts.mk
187 # -----------------------------------------------------------------------------
188 # Finding source files and object files
190 include rules/hs-sources.mk
191 include rules/c-sources.mk
192 include rules/includes-sources.mk
193 include rules/hs-objs.mk
194 include rules/c-objs.mk
195 include rules/cmm-objs.mk
197 # -----------------------------------------------------------------------------
200 # Suffix rules cause "make clean" to fail on Windows (trac #3233)
201 # so we don't make any when cleaning.
202 ifneq "$(CLEANING)" "YES"
204 include rules/hs-suffix-rules-srcdir.mk
205 include rules/hs-suffix-rules.mk
206 include rules/hi-rule.mk
208 $(foreach way,$(ALL_WAYS),\
209 $(eval $(call hi-rule,$(way))))
211 include rules/c-suffix-rules.mk
212 include rules/cmm-suffix-rules.mk
216 # -----------------------------------------------------------------------------
217 # Building package-data.mk files from .cabal files
219 include rules/package-config.mk
221 # -----------------------------------------------------------------------------
222 # Building dependencies
224 include rules/build-dependencies.mk
225 include rules/include-dependencies.mk
227 # -----------------------------------------------------------------------------
228 # Build package-data.mk files
230 include rules/build-package-data.mk
232 # -----------------------------------------------------------------------------
233 # Build and install a program
235 include rules/build-prog.mk
236 include rules/shell-wrapper.mk
238 # -----------------------------------------------------------------------------
239 # Build a perl script
241 include rules/build-perl.mk
243 # -----------------------------------------------------------------------------
246 include rules/build-package.mk
247 include rules/build-package-way.mk
248 include rules/haddock.mk
249 include rules/tags-package.mk
250 include rules/extra-packages.mk
252 # -----------------------------------------------------------------------------
253 # Registering hand-written package descriptions (used in libffi and rts)
255 include rules/manual-package-config.mk
257 # -----------------------------------------------------------------------------
260 include rules/docbook.mk
262 # -----------------------------------------------------------------------------
265 include rules/bindist.mk
267 # -----------------------------------------------------------------------------
270 # Don't try to delete directories:
273 # Create build directories on demand. NB. the | below: this indicates
274 # that $(MKDIRHIER) is an order-only dependency, which means that this
275 # rule fires after building mkdirhier, but we won't try to recreate
276 # directories if mkdirhier changes.
280 # -----------------------------------------------------------------------------
283 # --------------------------------
284 # Properties of packages
285 # These lists say "if this package is built, here's a property it has"
286 # They do not say "this package will be built"; see $(PACKAGES_xx) for that
288 # Packages that are built but not installed
289 INTREE_ONLY_PACKAGES := haskeline mtl terminfo utf8-string xhtml
291 DPH_PACKAGES := dph/dph-base dph/dph-prim-interface dph/dph-prim-seq \
292 dph/dph-common dph/dph-prim-par dph/dph-par dph/dph-seq \
295 # Packages that, if present, must be built by the stage2 compiler,
296 # because they use TH and/or annotations, or depend on other stage2
298 STAGE2_PACKAGES := $(DPH_PACKAGES) haskell98 haskell2010 random
299 # Packages that we shouldn't build if we don't have TH (e.g. because
300 # we're building a profiled compiler):
301 TH_PACKAGES := $(DPH_PACKAGES)
303 # Packages that are built by stage0, in addition to stage1. These
304 # packages are dependencies of GHC, that we do not assume the stage0
305 # compiler already has installed (or up-to-date enough).
307 # We assume that the stage0 compiler has a suitable bytestring package,
308 # so we don't have to include it below.
309 STAGE0_PACKAGES = Cabal hpc extensible-exceptions binary bin-package-db
311 # These packages are installed, but are installed hidden
312 # Why install them at all? Because the 'ghc' package depends on them
313 HIDDEN_PACKAGES = binary
315 # $(EXTRA_PACKAGES) is another classification, of packages built but
317 # It is set in rules/extra-package.mk,
318 # by $(call extra-packages) a little further down
322 # --------------------------------
324 # The lists of packages that we *actually* going to build in each stage:
326 # $(STAGE0_PACKAGE) does double duty; it really is the list of packages
327 # we build the bootstrap compiler in stage 0
329 # $(PACKAGES) A list of directories relative to libraries/ containing
330 # packages that will be built by stage1, in dependency
333 # $(PACKAGES_STAGE2) Ditto, for stage2.
336 define addPackageGeneral
337 # args: $1 = PACKAGES variable, $2 = package, $3 = condition
341 ifeq "$$(CLEANING)" "YES"
351 define addPackage # args: $1 = package, $2 = condition
352 ifneq "$(filter $1,$(TH_PACKAGES)) $(GhcProfiled)" "$1 YES"
353 ifeq "$(filter $1,$(STAGE2_PACKAGES))" "$1"
354 $(call addPackageGeneral,PACKAGES_STAGE2,$1,$2)
356 $(call addPackageGeneral,PACKAGES,$1,$2)
361 $(eval $(call addPackage,ghc-prim))
362 ifeq "$(CLEANING)" "YES"
363 $(eval $(call addPackage,integer-gmp))
364 $(eval $(call addPackage,integer-simple))
366 $(eval $(call addPackage,$(INTEGER_LIBRARY)))
368 $(eval $(call addPackage,base))
369 $(eval $(call addPackage,filepath))
370 $(eval $(call addPackage,array))
371 $(eval $(call addPackage,bytestring))
372 $(eval $(call addPackage,containers))
374 $(eval $(call addPackage,Win32,($$(Windows),YES)))
375 $(eval $(call addPackage,unix,($$(Windows),NO)))
377 $(eval $(call addPackage,old-locale))
378 $(eval $(call addPackage,old-time))
379 $(eval $(call addPackage,time))
380 $(eval $(call addPackage,directory))
381 $(eval $(call addPackage,process))
382 $(eval $(call addPackage,random))
383 $(eval $(call addPackage,extensible-exceptions))
384 $(eval $(call addPackage,haskell98))
385 $(eval $(call addPackage,haskell2010))
386 $(eval $(call addPackage,hpc))
387 $(eval $(call addPackage,pretty))
388 $(eval $(call addPackage,template-haskell))
389 $(eval $(call addPackage,Cabal))
390 $(eval $(call addPackage,binary))
391 $(eval $(call addPackage,bin-package-db))
392 $(eval $(call addPackage,mtl))
393 $(eval $(call addPackage,utf8-string))
394 $(eval $(call addPackage,xhtml))
395 $(eval $(call addPackage,terminfo,($$(Windows),NO)))
396 $(eval $(call addPackage,haskeline))
398 $(eval $(call extra-packages))
400 # -------------------------------------------
401 # Dependencies between package-data.mk files
403 # We cannot run ghc-cabal to configure a package until we have
404 # configured and registered all of its dependencies. So the following
405 # hack forces all the configure steps to happen in exactly the following order:
407 # $(PACKAGES) ghc(stage2) $(PACKAGES_STAGE2)
409 # Ideally we should use the correct dependencies here to allow more
410 # parallelism, but we don't know the dependencies until we've
411 # generated the pacakge-data.mk files.
413 libraries/$1/$2/package-data.mk : $$(GHC_PKG_INPLACE) $$(fixed_pkg_prev)
414 fixed_pkg_prev:=libraries/$1/$2/package-data.mk
417 ifneq "$(BINDIST)" "YES"
419 $(foreach pkg,$(PACKAGES),$(eval $(call fixed_pkg_dep,$(pkg),dist-install)))
421 # the GHC package doesn't live in libraries/, so we add its dependency manually:
422 compiler/stage2/package-data.mk: $(fixed_pkg_prev)
423 fixed_pkg_prev:=compiler/stage2/package-data.mk
425 # and continue with PACKAGES_STAGE2, which depend on GHC:
426 $(foreach pkg,$(PACKAGES_STAGE2),$(eval $(call fixed_pkg_dep,$(pkg),dist-install)))
428 ghc/stage1/package-data.mk: compiler/stage1/package-data.mk
429 ghc/stage2/package-data.mk: compiler/stage2/package-data.mk
430 # haddock depends on ghc and some libraries, but depending on GHC's
431 # package-data.mk is sufficient, as that in turn depends on all the
433 utils/haddock/dist/package-data.mk: compiler/stage2/package-data.mk
434 utils/ghc-pwd/dist/package-data.mk: compiler/stage2/package-data.mk
435 utils/ghc-cabal/dist-install/package-data.mk: compiler/stage2/package-data.mk
437 utils/ghc-pkg/dist-install/package-data.mk: compiler/stage2/package-data.mk
438 utils/hsc2hs/dist-install/package-data.mk: compiler/stage2/package-data.mk
439 utils/compare_sizes/dist/package-data.mk: compiler/stage2/package-data.mk
440 utils/runghc/dist/package-data.mk: compiler/stage2/package-data.mk
442 # add the final two package.conf dependencies: ghc-prim depends on RTS,
443 # and RTS depends on libffi.
444 libraries/ghc-prim/dist-install/package-data.mk : rts/package.conf.inplace
445 rts/package.conf.inplace : libffi/package.conf.inplace
448 # --------------------------------
449 # Misc package-related settings
451 BOOT_PKG_CONSTRAINTS := $(foreach p,$(STAGE0_PACKAGES),--constraint "$p == $(shell grep -i "^Version:" libraries/$p/$p.cabal | sed "s/[^0-9.]//g")")
453 # The actual .a and .so/.dll files: needed for dependencies.
454 ALL_STAGE1_LIBS = $(foreach lib,$(PACKAGES),$(libraries/$(lib)_dist-install_v_LIB))
455 ifeq "$(BuildSharedLibs)" "YES"
456 ALL_STAGE1_LIBS += $(foreach lib,$(PACKAGES),$(libraries/$(lib)_dist-install_dyn_LIB))
458 BOOT_LIBS = $(foreach lib,$(STAGE0_PACKAGES),$(libraries/$(lib)_dist-boot_v_LIB))
460 OTHER_LIBS = libffi/dist-install/build/libHSffi$(v_libsuf) libffi/dist-install/build/HSffi.o
461 ifeq "$(BuildSharedLibs)" "YES"
462 OTHER_LIBS += libffi/dist-install/build/libHSffi$(dyn_libsuf)
465 # ----------------------------------------
466 # Special magic for the ghc-prim package
468 # We want the ghc-prim package to include the GHC.Prim module when it
469 # is registered, but not when it is built, because GHC.Prim is not a
470 # real source module, it is built-in to GHC. The old build system did
471 # this using Setup.hs, but we can't do that here, so we have a flag to
472 # enable GHC.Prim in the .cabal file (so that the ghc-prim package
473 # remains compatible with the old build system for the time being).
474 # GHC.Prim module in the ghc-prim package with a flag:
476 libraries/ghc-prim_CONFIGURE_OPTS += --flag=include-ghc-prim
478 # And then we strip it out again before building the package:
479 define libraries/ghc-prim_PACKAGE_MAGIC
480 libraries/ghc-prim_dist-install_MODULES := $$(filter-out GHC.Prim,$$(libraries/ghc-prim_dist-install_MODULES))
483 PRIMOPS_TXT = $(GHC_COMPILER_DIR)/prelude/primops.txt
485 libraries/ghc-prim/dist-install/build/GHC/PrimopWrappers.hs : $(GENPRIMOP_INPLACE) $(PRIMOPS_TXT) | $$(dir $$@)/.
486 "$(GENPRIMOP_INPLACE)" --make-haskell-wrappers <$(PRIMOPS_TXT) >$@
488 # Required so that Haddock documents the primops.
489 libraries/ghc-prim_dist-install_EXTRA_HADDOCK_SRCS = libraries/ghc-prim/dist-install/build/autogen/GHC/Prim.hs
491 # ----------------------------------------
492 # Special magic for the integer package
494 ifneq "$(CLEANING)" "YES"
495 ifeq "$(INTEGER_LIBRARY)" "integer-gmp"
496 libraries/base_dist-install_CONFIGURE_OPTS += --flags=-integer-simple
497 else ifeq "$(INTEGER_LIBRARY)" "integer-simple"
498 libraries/base_dist-install_CONFIGURE_OPTS += --flags=integer-simple
500 $(error Unknown integer library: $(INTEGER_LIBRARY))
504 # ----------------------------------------------
505 # Checking packages with 'cabal check'
508 ifeq "$(CHECK_PACKAGES)" "YES"
513 # These packages don't pass the Cabal checks because hs-source-dirs
514 # points outside the source directory. This isn't a real problem in
515 # these cases, so we just skip checking them.
516 # NB. these must come before we include the ghc.mk files below, because
517 # they disable the relevant rules.
518 CHECKED_libraries/dph/dph-seq = YES
519 CHECKED_libraries/dph/dph-par = YES
520 # In compiler's case, include-dirs points outside of the source tree
521 CHECKED_compiler = YES
523 # -----------------------------------------------------------------------------
524 # Include build instructions from all subdirs
526 ifneq "$(BINDIST)" "YES"
538 ifneq "$(GhcUnregisterised)" "YES"
544 ifneq "$(BINDIST)" "YES"
558 ifneq "$(BINDIST)" "YES"
564 ifneq "$(CLEANING)" "YES"
566 $(patsubst %, libraries/%, $(PACKAGES))
569 ifeq "$(INTEGER_LIBRARY)" "integer-gmp"
570 BUILD_DIRS += libraries/integer-gmp/gmp
571 else ifneq "$(findstring clean,$(MAKECMDGOALS))" ""
572 BUILD_DIRS += libraries/integer-gmp/gmp
588 ifeq "$(Windows)" "YES"
593 ifneq "$(BINDIST)" "YES"
595 utils/mkUserGuidePart
598 BUILD_DIRS += utils/count_lines
599 BUILD_DIRS += utils/compare_sizes
601 ifneq "$(CLEANING)" "YES"
602 # After compiler/, because these packages depend on it
604 $(patsubst %, libraries/%, $(PACKAGES_STAGE2))
607 # ----------------------------------------------
608 # Actually include all the sub-ghc.mk's
610 include $(patsubst %, %/ghc.mk, $(BUILD_DIRS))
612 # A useful pseudo-target (must be after the include above, because it needs
613 # the value of things like $(libraries/base_dist-install_v_LIB).
615 stage1_libs : $(ALL_STAGE1_LIBS)
617 # ----------------------------------------------
618 # Per-package compiler flags
620 # If you want to add per-package compiler flags, this
621 # is the place to do it. Do it like this for package <pkg>
623 # libraries/<pkg>_dist-boot_HC_OPTS += -Wwarn
624 # libraries/<pkg>_dist-install_HC_OPTS += -Wwarn
626 # Add $(GhcLibHcOpts) to all package builds
627 $(foreach pkg,$(PACKAGES) $(PACKAGES_STAGE2),$(eval libraries/$(pkg)_dist-install_HC_OPTS += $$(GhcLibHcOpts)))
629 # Add $(GhcBootLibHcOpts) to all stage0 package builds
630 $(foreach pkg,$(STAGE0_PACKAGES),$(eval libraries/$(pkg)_dist-boot_HC_OPTS += $$(GhcBootLibHcOpts)))
632 # -----------------------------------------------
633 # Haddock-related bits
635 # Don't run Haddock for the package that will not be installed
636 $(foreach p,$(INTREE_ONLY_PACKAGES),$(eval libraries/$p_dist-install_DO_HADDOCK = NO))
637 # We don't haddock the bootstrapping libraries
638 $(foreach p,$(STAGE0_PACKAGES),$(eval libraries/$p_dist-boot_DO_HADDOCK = NO))
640 # Build the Haddock contents and index
641 ifeq "$(HADDOCK_DOCS)" "YES"
642 libraries/index.html: inplace/bin/haddock$(exeext) $(ALL_HADDOCK_FILES)
643 cd libraries && sh gen_contents_index --inplace
645 $(eval $(call all-target,library_doc_index,libraries/index.html))
647 INSTALL_LIBRARY_DOCS += libraries/*.html libraries/*.gif libraries/*.css libraries/*.js
648 CLEAN_FILES += libraries/doc-index* libraries/haddock*.css \
649 libraries/haddock*.js libraries/index*.html libraries/*.gif
652 # -----------------------------------------------------------------------------
653 # Bootstrapping libraries
655 # We need to build a few libraries with the installed GHC, since GHC itself
656 # and some of the tools depend on them:
658 ifneq "$(BINDIST)" "YES"
660 ifneq "$(BOOTSTRAPPING_CONF)" ""
661 ifeq "$(wildcard $(BOOTSTRAPPING_CONF))" ""
662 $(shell echo "[]" >$(BOOTSTRAPPING_CONF))
666 $(eval $(call clean-target,$(BOOTSTRAPPING_CONF),,$(BOOTSTRAPPING_CONF)))
668 # These three libraries do not depend on each other, so we can build
671 $(eval $(call build-package,libraries/hpc,dist-boot,0))
672 $(eval $(call build-package,libraries/extensible-exceptions,dist-boot,0))
673 $(eval $(call build-package,libraries/Cabal,dist-boot,0))
674 $(eval $(call build-package,libraries/binary,dist-boot,0))
675 $(eval $(call build-package,libraries/bin-package-db,dist-boot,0))
677 # register the boot packages in strict sequence, because running
678 # multiple ghc-pkgs in parallel doesn't work (registrations may get
681 $(foreach pkg,$(STAGE0_PACKAGES),$(eval $(call fixed_pkg_dep,$(pkg),dist-boot)))
683 compiler/stage1/package-data.mk : $(fixed_pkg_prev)
685 # Make sure we have all the GHCi libs by the time we've built
686 # ghc-stage2. DPH includes a bit of Template Haskell which needs the
687 # GHCI libs, and we don't have a better way to express that dependency.
689 GHCI_LIBS = $(foreach lib,$(PACKAGES),$(libraries/$(lib)_dist-install_GHCI_LIB)) \
690 $(compiler_stage2_GHCI_LIB)
692 ifeq "$(UseArchivesForGhci)" "NO"
693 ghc/stage2/build/tmp/$(ghc_stage2_PROG) : $(GHCI_LIBS)
696 ifeq "$(UseArchivesForGhci)" "YES"
702 # Deps for TH uses in libraries
703 $(foreach way, $(GhcLibWays),$(eval \
704 libraries/vector/dist-install/build/Data/Vector/Fusion/Stream/Monadic.$($(way)_osuf): \
705 $(libraries/primitive_dist-install_$(GHCI_lib_way)_LIB) \
709 # -----------------------------------------------------------------------------
710 # Creating a local mingw copy on Windows
712 ifeq "$(Windows)" "YES"
714 install : install_mingw
715 .PHONY: install_mingw
716 install_mingw : $(INPLACE_MINGW)
717 "$(CP)" -Rp $(INPLACE_MINGW) $(prefix)
719 install : install_perl
721 install_perl : $(INPLACE_PERL)
722 "$(CP)" -Rp $(INPLACE_PERL) $(prefix)
726 ifneq "$(BINDIST)" "YES"
727 $(ghc-prim-$(libraries/ghc-prim_dist-install_VERSION)_HADDOCK_FILE): \
728 libraries/ghc-prim/dist-install/build/autogen/GHC/Prim.hs
731 libraries/ghc-prim/dist-install/build/autogen/GHC/Prim.hs: \
732 $(PRIMOPS_TXT) $(GENPRIMOP_INPLACE) \
734 "$(GENPRIMOP_INPLACE)" --make-haskell-source < $< > $@
742 # -----------------------------------------------------------------------------
745 install: install_packages install_libs install_libexecs install_headers \
746 install_libexec_scripts install_bins install_topdirs
747 ifeq "$(HADDOCK_DOCS)" "YES"
748 install: install_docs
751 install_bins: $(INSTALL_BINS)
752 $(call INSTALL_DIR,"$(DESTDIR)$(bindir)")
753 for i in $(INSTALL_BINS); do \
754 $(call INSTALL_PROGRAM,$(INSTALL_BIN_OPTS),$$i,"$(DESTDIR)$(bindir)") ; \
757 install_libs: $(INSTALL_LIBS)
758 $(call INSTALL_DIR,"$(DESTDIR)$(ghclibdir)")
759 for i in $(INSTALL_LIBS); do \
762 $(call INSTALL_DATA,$(INSTALL_OPTS),$$i,"$(DESTDIR)$(ghclibdir)"); \
763 $(RANLIB) $(DESTDIR)$(ghclibdir)/`basename $$i` ;; \
765 $(call INSTALL_DATA,-s $(INSTALL_OPTS),$$i,"$(DESTDIR)$(ghclibdir)") ;; \
767 $(call INSTALL_SHLIB,$(INSTALL_OPTS),$$i,"$(DESTDIR)$(ghclibdir)") ;; \
769 $(call INSTALL_SHLIB,$(INSTALL_OPTS),$$i,"$(DESTDIR)$(ghclibdir)");; \
771 $(call INSTALL_DATA,$(INSTALL_OPTS),$$i,"$(DESTDIR)$(ghclibdir)"); \
775 install_libexec_scripts: $(INSTALL_LIBEXEC_SCRIPTS)
776 ifeq "$(INSTALL_LIBEXEC_SCRIPTS)" ""
779 $(call INSTALL_DIR,"$(DESTDIR)$(ghclibexecdir)")
780 for i in $(INSTALL_LIBEXEC_SCRIPTS); do \
781 $(call INSTALL_SCRIPT,$(INSTALL_OPTS),$$i,"$(DESTDIR)$(ghclibexecdir)"); \
785 install_libexecs: $(INSTALL_LIBEXECS)
786 ifeq "$(INSTALL_LIBEXECS)" ""
789 $(call INSTALL_DIR,"$(DESTDIR)$(ghclibexecdir)")
790 for i in $(INSTALL_LIBEXECS); do \
791 $(call INSTALL_PROGRAM,$(INSTALL_BIN_OPTS),$$i,"$(DESTDIR)$(ghclibexecdir)"); \
793 # We rename ghc-stage2, so that the right program name is used in error
795 "$(MV)" "$(DESTDIR)$(ghclibexecdir)/ghc-stage2" "$(DESTDIR)$(ghclibexecdir)/ghc"
798 install_topdirs: $(INSTALL_TOPDIRS)
799 $(call INSTALL_DIR,"$(DESTDIR)$(topdir)")
800 for i in $(INSTALL_TOPDIRS); do \
801 $(call INSTALL_PROGRAM,$(INSTALL_BIN_OPTS),$$i,"$(DESTDIR)$(topdir)"); \
804 install_headers: $(INSTALL_HEADERS)
805 $(call INSTALL_DIR,"$(DESTDIR)$(ghcheaderdir)")
806 for i in $(INSTALL_HEADERS); do \
807 $(call INSTALL_HEADER,$(INSTALL_OPTS),$$i,"$(DESTDIR)$(ghcheaderdir)"); \
810 install_docs: $(INSTALL_DOCS)
811 $(call INSTALL_DIR,"$(DESTDIR)$(docdir)")
812 ifneq "$(INSTALL_DOCS)" ""
813 for i in $(INSTALL_DOCS); do \
814 $(call INSTALL_DOC,$(INSTALL_OPTS),$$i,"$(DESTDIR)$(docdir)"); \
817 $(call INSTALL_DIR,"$(DESTDIR)$(docdir)/html")
818 $(call INSTALL_DOC,$(INSTALL_OPTS),docs/index.html,"$(DESTDIR)$(docdir)/html")
819 ifneq "$(INSTALL_LIBRARY_DOCS)" ""
820 $(call INSTALL_DIR,"$(DESTDIR)$(docdir)/html/libraries")
821 for i in $(INSTALL_LIBRARY_DOCS); do \
822 $(call INSTALL_DOC,$(INSTALL_OPTS),$$i,"$(DESTDIR)$(docdir)/html/libraries/"); \
824 $(call INSTALL_DATA,$(INSTALL_OPTS),libraries/prologue.txt,"$(DESTDIR)$(docdir)/html/libraries/")
825 $(call INSTALL_SCRIPT,$(INSTALL_OPTS),libraries/gen_contents_index,"$(DESTDIR)$(docdir)/html/libraries/")
827 ifneq "$(INSTALL_HTML_DOC_DIRS)" ""
828 for i in $(INSTALL_HTML_DOC_DIRS); do \
829 $(call INSTALL_DIR,"$(DESTDIR)$(docdir)/html/`basename $$i`"); \
830 $(call INSTALL_DOC,$(INSTALL_OPTS),$$i/*,"$(DESTDIR)$(docdir)/html/`basename $$i`"); \
834 INSTALLED_PACKAGE_CONF=$(DESTDIR)$(topdir)/package.conf.d
836 # Install packages in the right order, so that ghc-pkg doesn't complain.
837 # Also, install ghc-pkg first.
838 ifeq "$(Windows)" "NO"
839 INSTALLED_GHC_REAL=$(DESTDIR)$(ghclibexecdir)/ghc
840 INSTALLED_GHC_PKG_REAL=$(DESTDIR)$(ghclibexecdir)/ghc-pkg
842 INSTALLED_GHC_REAL=$(DESTDIR)$(bindir)/ghc.exe
843 INSTALLED_GHC_PKG_REAL=$(DESTDIR)$(bindir)/ghc-pkg.exe
846 INSTALLED_PKG_DIRS := $(addprefix libraries/,$(PACKAGES)) \
848 $(addprefix libraries/,$(PACKAGES_STAGE2))
849 ifeq "$(InstallExtraPackages)" "NO"
850 INSTALLED_PKG_DIRS := $(filter-out $(addprefix libraries/,$(EXTRA_PACKAGES)),\
851 $(INSTALLED_PKG_DIRS))
853 INSTALLED_PKG_DIRS := $(filter-out $(addprefix libraries/,$(INTREE_ONLY_PACKAGES)),\
854 $(INSTALLED_PKG_DIRS))
856 # Set the INSTALL_DISTDIR_p for each package; compiler is special
857 $(foreach p,$(filter-out compiler,$(INSTALLED_PKG_DIRS)),\
858 $(eval INSTALL_DISTDIR_$p = dist-install))
859 INSTALL_DISTDIR_compiler = stage2
861 # Now we can do the installation
862 install_packages: install_libexecs
863 install_packages: libffi/package.conf.install rts/package.conf.install
864 $(call INSTALL_DIR,"$(DESTDIR)$(topdir)")
865 "$(RM)" $(RM_OPTS_REC) "$(INSTALLED_PACKAGE_CONF)"
866 $(call INSTALL_DIR,"$(INSTALLED_PACKAGE_CONF)")
867 "$(INSTALLED_GHC_PKG_REAL)" --force --global-conf "$(INSTALLED_PACKAGE_CONF)" update libffi/package.conf.install
868 "$(INSTALLED_GHC_PKG_REAL)" --force --global-conf "$(INSTALLED_PACKAGE_CONF)" update rts/package.conf.install
869 $(foreach p, $(INSTALLED_PKG_DIRS), \
870 $(call make-command, \
871 "$(GHC_CABAL_INPLACE)" install \
872 "$(INSTALLED_GHC_REAL)" \
873 "$(INSTALLED_GHC_PKG_REAL)" \
875 "$(DESTDIR)$(topdir)" \
876 $p $(INSTALL_DISTDIR_$p) \
880 '$(docdir)/html/libraries' \
881 $(RelocatableBuild)))
882 $(foreach p, $(HIDDEN_PACKAGES), \
883 $(call make-command, \
884 "$(INSTALLED_GHC_PKG_REAL)" \
885 --global-conf "$(INSTALLED_PACKAGE_CONF)" hide $p))
887 # -----------------------------------------------------------------------------
888 # Binary distributions
890 ifneq "$(CLEANING)" "YES"
891 # This rule seems to hold some files open on Windows which prevents
892 # cleaning, perhaps due to the $(wildcard).
894 $(eval $(call bindist,.,\
898 configure config.sub config.guess install-sh \
903 $(INPLACE_BIN)/mkdirhier \
904 utils/ghc-cabal/dist-install/build/tmp/ghc-cabal \
905 utils/ghc-pwd/dist/build/tmp/ghc-pwd \
906 $(BINDIST_WRAPPERS) \
907 $(BINDIST_PERL_SOURCES) \
911 $(includes_H_CONFIG) \
912 $(includes_H_PLATFORM) \
913 $(includes_H_FILES) \
914 includes/ghcconfig.h \
915 includes/rts/Config.h \
917 $(INSTALL_LIBEXECS) \
918 $(INSTALL_LIBEXEC_SCRIPTS) \
921 $(INSTALL_MANPAGES) \
923 $(INSTALL_LIBRARY_DOCS) \
924 $(addsuffix /*,$(INSTALL_HTML_DOC_DIRS)) \
926 compiler/stage2/doc \
927 $(wildcard libraries/*/dist-install/doc/) \
928 $(wildcard libraries/*/*/dist-install/doc/) \
929 $(filter-out extra-gcc-opts,$(INSTALL_LIBS)) \
930 $(filter-out %/project.mk mk/config.mk %/mk/install.mk,$(MAKEFILE_LIST)) \
934 libraries/gen_contents_index \
935 libraries/prologue.txt \
936 $(wildcard libraries/dph/LICENSE \
937 libraries/dph/ghc-packages \
938 libraries/dph/ghc-packages2 \
939 libraries/dph/ghc-stage2-package) \
942 # mk/project.mk gets an absolute path, so we manually include it in
943 # the bindist with a relative path
945 BIN_DIST_MK = $(BIN_DIST_PREP_DIR)/bindist.mk
947 unix-binary-dist-prep:
948 "$(RM)" $(RM_OPTS_REC) bindistprep/
949 "$(MKDIRHIER)" $(BIN_DIST_PREP_DIR)
950 set -e; for i in packages LICENSE compiler ghc rts libraries utils docs libffi includes driver mk rules Makefile aclocal.m4 config.sub config.guess install-sh extra-gcc-opts.in ghc.mk inplace distrib/configure.ac distrib/README distrib/INSTALL; do ln -s ../../$$i $(BIN_DIST_PREP_DIR)/; done
951 echo "HADDOCK_DOCS = $(HADDOCK_DOCS)" >> $(BIN_DIST_MK)
952 echo "LATEX_DOCS = $(LATEX_DOCS)" >> $(BIN_DIST_MK)
953 echo "BUILD_DOCBOOK_HTML = $(BUILD_DOCBOOK_HTML)" >> $(BIN_DIST_MK)
954 echo "BUILD_DOCBOOK_PS = $(BUILD_DOCBOOK_PS)" >> $(BIN_DIST_MK)
955 echo "BUILD_DOCBOOK_PDF = $(BUILD_DOCBOOK_PDF)" >> $(BIN_DIST_MK)
956 echo "BUILD_MAN = $(BUILD_MAN)" >> $(BIN_DIST_MK)
957 echo "GHC_CABAL_INPLACE = utils/ghc-cabal/dist-install/build/tmp/ghc-cabal" >> $(BIN_DIST_MK)
958 cd $(BIN_DIST_PREP_DIR) && autoreconf
959 "$(RM)" $(RM_OPTS) $(BIN_DIST_PREP_TAR)
960 # h means "follow symlinks", e.g. if aclocal.m4 is a symlink to a source
961 # tree then we want to include the real file, not a symlink to it
962 cd bindistprep && "$(TAR_CMD)" hcf - -T ../$(BIN_DIST_LIST) | bzip2 -c > ../$(BIN_DIST_PREP_TAR_BZ2)
964 windows-binary-dist-prep:
965 "$(RM)" $(RM_OPTS_REC) bindistprep/
966 $(MAKE) prefix=$(TOP)/$(BIN_DIST_PREP_DIR) install
967 cd bindistprep && "$(TAR_CMD)" cf - $(BIN_DIST_NAME) | bzip2 -c > ../$(BIN_DIST_PREP_TAR_BZ2)
970 ifeq "$(ISCC_CMD)" ""
971 @echo No ISCC_CMD, so not making installer
973 "$(ISCC_CMD)" /O. /Fbindistprep/$(WINDOWS_INSTALLER_BASE) - < distrib/ghc.iss
976 # tryTimes tries to run its third argument multiple times, until it
977 # succeeds. Don't call it directly; call try10Times instead.
978 # The first and second argument to tryTimes are lists of values.
979 # The length of the first argument is the number of times we have
980 # already tried. The length of the second argument is the number more
982 tryTimes = $(if $2, \
983 { echo 'Try $(words x $1): $3' ; $3 ; } || \
984 $(call tryTimes,x $1,$(wordlist 2,$(words $2),$2),$3), \
987 # Try to run the argument 10 times. If all 10 fail, fail.
988 try10Times = $(call tryTimes,,x x x x x x x x x x,$1) { echo Failed; false; }
990 .PHONY: publish-binary-dist
992 $(call try10Times,$(PublishCp) $(BIN_DIST_TAR_BZ2) $(PublishLocation)/dist)
993 ifeq "$(mingw32_TARGET_OS)" "1"
994 $(call try10Times,$(PublishCp) $(WINDOWS_INSTALLER) $(PublishLocation)/dist)
997 ifeq "$(mingw32_TARGET_OS)" "1"
998 DOCDIR_TO_PUBLISH = bindisttest/"install dir"/doc
1000 DOCDIR_TO_PUBLISH = bindisttest/"install dir"/share/doc/ghc
1003 .PHONY: publish-docs
1005 $(call try10Times,$(PublishCp) -r $(DOCDIR_TO_PUBLISH)/* $(PublishLocation)/docs)
1007 # -----------------------------------------------------------------------------
1008 # Source distributions
1016 # A source dist is built from a complete build tree, because we
1017 # require some extra files not contained in a darcs checkout: the
1018 # output from Happy and Alex, for example.
1020 # The steps performed by 'make dist' are as follows:
1021 # - create a complete link-tree of the current build tree in /tmp
1022 # - run 'make distclean' on that tree
1023 # - remove a bunch of other files that we know shouldn't be in the dist
1024 # - tar up first the extralibs package, then the main source package
1027 # Directory in which we're going to build the src dist
1029 SRC_DIST_NAME=ghc-$(ProjectVersion)
1030 SRC_DIST_DIR=$(TOP)/$(SRC_DIST_NAME)
1033 # Files to include in source distributions
1035 SRC_DIST_DIRS = mk rules docs distrib bindisttest libffi includes utils docs rts compiler ghc driver libraries ghc-tarballs
1037 configure.ac config.guess config.sub configure \
1038 aclocal.m4 README ANNOUNCE HACKING LICENSE Makefile install-sh \
1039 ghc.spec.in ghc.spec extra-gcc-opts.in VERSION \
1040 boot boot-pkgs packages ghc.mk
1042 SRC_DIST_TARBALL = $(SRC_DIST_NAME)-src.tar.bz2
1045 echo $(ProjectVersion) >VERSION
1050 # $(call sdist_file,compiler,stage2,cmm,Foo/Bar,CmmLex,x)
1051 # to copy the generated file that replaces compiler/cmm/Foo/Bar/CmmLex.x, where
1052 # "stage2" is the dist dir.
1054 "$(CP)" $1/$2/build/$4/$5.hs $(SRC_DIST_DIR)/$1/$3/$4
1055 mv $(SRC_DIST_DIR)/$1/$3/$4/$5.$6 $(SRC_DIST_DIR)/$1/$3/$4/$5.$6.source
1060 "$(RM)" $(RM_OPTS_REC) $(SRC_DIST_DIR)
1061 "$(RM)" $(RM_OPTS) $(SRC_DIST_TARBALL)
1062 mkdir $(SRC_DIST_DIR)
1063 cd $(SRC_DIST_DIR) && for i in $(SRC_DIST_DIRS); do mkdir $$i; ( cd $$i && lndir $(TOP)/$$i ); done
1064 cd $(SRC_DIST_DIR) && for i in $(SRC_DIST_FILES); do $(LN_S) $(TOP)/$$i .; done
1065 cd $(SRC_DIST_DIR) && $(MAKE) distclean
1066 rm -rf $(SRC_DIST_DIR)/libraries/tarballs/
1067 rm -rf $(SRC_DIST_DIR)/libraries/stamp/
1068 $(call sdist_file,compiler,stage2,cmm,,CmmLex,x)
1069 $(call sdist_file,compiler,stage2,cmm,,CmmParse,y)
1070 $(call sdist_file,compiler,stage2,parser,,Lexer,x)
1071 $(call sdist_file,compiler,stage2,parser,,Parser,y.pp)
1072 $(call sdist_file,compiler,stage2,parser,,ParserCore,y)
1073 $(call sdist_file,utils/hpc,dist,,,HpcParser,y)
1074 $(call sdist_file,utils/genprimopcode,dist,,,Lexer,x)
1075 $(call sdist_file,utils/genprimopcode,dist,,,Parser,y)
1076 $(call sdist_file,utils/haddock,dist,src,Haddock,Lex,x)
1077 $(call sdist_file,utils/haddock,dist,src,Haddock,Parse,y)
1078 cd $(SRC_DIST_DIR) && "$(RM)" $(RM_OPTS_REC) compiler/stage[123] mk/build.mk
1079 cd $(SRC_DIST_DIR) && "$(FIND)" $(SRC_DIST_DIRS) \( -name _darcs -o -name SRC -o -name "autom4te*" -o -name "*~" -o -name ".cvsignore" -o -name "\#*" -o -name ".\#*" -o -name "log" -o -name "*-SAVE" -o -name "*.orig" -o -name "*.rej" -o -name "*-darcs-backup*" \) -print | "$(XARGS)" $(XARGS_OPTS) "$(RM)" $(RM_OPTS_REC)
1083 "$(TAR_CMD)" chf - $(SRC_DIST_NAME) 2>$src_log | bzip2 >$(TOP)/$(SRC_DIST_TARBALL)
1085 sdist-manifest : $(SRC_DIST_TARBALL)
1086 tar tjf $(SRC_DIST_TARBALL) | sed "s|^ghc-$(ProjectVersion)/||" | sort >sdist-manifest
1088 # Upload the distribution(s)
1089 # Retrying is to work around buggy firewalls that corrupt large file transfers
1091 ifneq "$(PublishLocation)" ""
1093 $(call try10Times,$(PublishCp) $(SRC_DIST_TARBALL) $(PublishLocation)/dist)
1096 ifeq "$(BootingFromHc)" "YES"
1097 # In a normal build we use GHC to compile C files (see
1098 # rules/c-suffix-rules.mk), which passes a number of its own options
1099 # to the C compiler. So when bootstrapping we have to provide these
1100 # flags explicitly to C compilations.
1101 SRC_CC_OPTS += -DNO_REGS -DUSE_MINIINTERPRETER
1102 SRC_CC_OPTS += -D__GLASGOW_HASKELL__=$(ProjectVersionInt)
1103 SRC_CC_OPTS += -I$(GHC_INCLUDE_DIR)
1106 # -----------------------------------------------------------------------------
1107 # sdisting libraries
1109 # Use manually, with e.g.:
1110 # make sdist_directory
1113 inplace/bin/ghc-cabal sdist libraries/$* dist-install
1115 # -----------------------------------------------------------------------------
1120 CLEAN_FILES += libraries/bootstrapping.conf
1121 CLEAN_FILES += libraries/integer-gmp/cbits/GmpDerivedConstants.h
1122 CLEAN_FILES += libraries/integer-gmp/cbits/mkGmpDerivedConstants
1124 clean : clean_files clean_libraries
1128 "$(RM)" $(RM_OPTS) $(CLEAN_FILES)
1130 .PHONY: clean_libraries
1131 clean_libraries: $(patsubst %,clean_libraries/%_dist-install,$(PACKAGES) $(PACKAGES_STAGE2))
1132 clean_libraries: $(patsubst %,clean_libraries/%_dist-boot,$(STAGE0_PACKAGES))
1135 "$(RM)" $(RM_OPTS_REC) $(patsubst %, libraries/%/dist, $(PACKAGES) $(PACKAGES_STAGE2))
1136 "$(RM)" $(RM_OPTS) $(patsubst %, libraries/%/*.buildinfo, $(PACKAGES) $(PACKAGES_STAGE2))
1138 # We have to define a clean target for each library manually, because the
1139 # libraries/*/ghc.mk files are not included when we're cleaning.
1140 ifeq "$(CLEANING)" "YES"
1141 $(foreach lib,$(PACKAGES) $(PACKAGES_STAGE2),\
1142 $(eval $(call clean-target,libraries/$(lib),dist-install,libraries/$(lib)/dist-install)))
1145 clean : clean_bindistprep
1146 .PHONY: clean_bindistprep
1148 "$(RM)" $(RM_OPTS_REC) bindistprep/
1151 "$(RM)" $(RM_OPTS) config.cache config.status config.log mk/config.h mk/stamp-h
1152 "$(RM)" $(RM_OPTS) mk/config.mk mk/are-validating.mk mk/project.mk
1153 "$(RM)" $(RM_OPTS) mk/config.mk.old mk/project.mk.old
1154 "$(RM)" $(RM_OPTS) extra-gcc-opts docs/users_guide/ug-book.xml
1155 "$(RM)" $(RM_OPTS) compiler/ghc.cabal compiler/ghc.cabal.old
1156 "$(RM)" $(RM_OPTS) ghc/ghc-bin.cabal
1157 "$(RM)" $(RM_OPTS) libraries/base/include/HsBaseConfig.h
1158 "$(RM)" $(RM_OPTS) libraries/directory/include/HsDirectoryConfig.h
1159 "$(RM)" $(RM_OPTS) libraries/process/include/HsProcessConfig.h
1160 "$(RM)" $(RM_OPTS) libraries/unix/include/HsUnixConfig.h
1161 "$(RM)" $(RM_OPTS) libraries/old-time/include/HsTimeConfig.h
1162 "$(RM)" $(RM_OPTS_REC) utils/ghc-pwd/dist
1163 "$(RM)" $(RM_OPTS_REC) inplace
1165 "$(RM)" $(RM_OPTS) $(patsubst %, libraries/%/config.log, $(PACKAGES) $(PACKAGES_STAGE2))
1166 "$(RM)" $(RM_OPTS) $(patsubst %, libraries/%/config.status, $(PACKAGES) $(PACKAGES_STAGE2))
1167 "$(RM)" $(RM_OPTS) $(patsubst %, libraries/%/include/Hs*Config.h, $(PACKAGES) $(PACKAGES_STAGE2))
1168 "$(RM)" $(RM_OPTS_REC) $(patsubst %, libraries/%/autom4te.cache, $(PACKAGES) $(PACKAGES_STAGE2))
1170 maintainer-clean : distclean
1171 "$(RM)" $(RM_OPTS) configure mk/config.h.in
1172 "$(RM)" $(RM_OPTS_REC) autom4te.cache libraries/*/autom4te.cache
1173 "$(RM)" $(RM_OPTS) ghc.spec
1174 "$(RM)" $(RM_OPTS) $(patsubst %, libraries/%/GNUmakefile, \
1175 $(PACKAGES) $(PACKAGES_STAGE2))
1176 "$(RM)" $(RM_OPTS) $(patsubst %, libraries/%/ghc.mk, $(PACKAGES) $(PACKAGES_STAGE2))
1177 "$(RM)" $(RM_OPTS) $(patsubst %, libraries/%/configure, \
1178 $(PACKAGES) $(PACKAGES_STAGE2))
1179 "$(RM)" $(RM_OPTS) libraries/base/include/HsBaseConfig.h.in
1180 "$(RM)" $(RM_OPTS) libraries/directory/include/HsDirectoryConfig.h.in
1181 "$(RM)" $(RM_OPTS) libraries/process/include/HsProcessConfig.h.in
1182 "$(RM)" $(RM_OPTS) libraries/unix/include/HsUnixConfig.h.in
1183 "$(RM)" $(RM_OPTS) libraries/old-time/include/HsTimeConfig.h.in
1185 .PHONY: all_libraries
1187 .PHONY: bootstrapping-files
1188 bootstrapping-files: $(OTHER_LIBS)
1189 bootstrapping-files: includes/ghcautoconf.h
1190 bootstrapping-files: includes/DerivedConstants.h
1191 bootstrapping-files: includes/GHCConstants.h
1195 # -----------------------------------------------------------------------------
1196 # Numbered phase targets
1198 .PHONY: phase_0_builds
1199 phase_0_builds: $(utils/hsc2hs_dist_depfile_haskell)
1200 phase_0_builds: $(utils/hsc2hs_dist_depfile_c_asm)
1201 phase_0_builds: $(utils/genprimopcode_dist_depfile_haskell)
1202 phase_0_builds: $(utils/genprimopcode_dist_depfile_c_asm)
1204 .PHONY: phase_1_builds
1205 phase_1_builds: $(PACKAGE_DATA_MKS)