hotspot/make/linux/makefiles/top.make
author kamg
Wed, 09 Apr 2008 14:22:48 -0400
changeset 338 5cf9f61d76f4
parent 1 hotspot/build/linux/makefiles/top.make@489c9b5090e2
child 670 ddf3e9583f2f
child 1374 4c24294029a9
permissions -rw-r--r--
6583644: Move all managed/SCCS files out of 'build' into 'make' directory Summary: Moved makefiles out of build and build/closed into make/ Reviewed-by: kvn, ohair
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
#
489c9b5090e2 Initial load
duke
parents:
diff changeset
     2
# Copyright 1999-2007 Sun Microsystems, Inc.  All Rights Reserved.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     3
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     4
#
489c9b5090e2 Initial load
duke
parents:
diff changeset
     5
# This code is free software; you can redistribute it and/or modify it
489c9b5090e2 Initial load
duke
parents:
diff changeset
     6
# under the terms of the GNU General Public License version 2 only, as
489c9b5090e2 Initial load
duke
parents:
diff changeset
     7
# published by the Free Software Foundation.
489c9b5090e2 Initial load
duke
parents:
diff changeset
     8
#
489c9b5090e2 Initial load
duke
parents:
diff changeset
     9
# This code is distributed in the hope that it will be useful, but WITHOUT
489c9b5090e2 Initial load
duke
parents:
diff changeset
    10
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    11
# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
489c9b5090e2 Initial load
duke
parents:
diff changeset
    12
# version 2 for more details (a copy is included in the LICENSE file that
489c9b5090e2 Initial load
duke
parents:
diff changeset
    13
# accompanied this code).
489c9b5090e2 Initial load
duke
parents:
diff changeset
    14
#
489c9b5090e2 Initial load
duke
parents:
diff changeset
    15
# You should have received a copy of the GNU General Public License version
489c9b5090e2 Initial load
duke
parents:
diff changeset
    16
# 2 along with this work; if not, write to the Free Software Foundation,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    17
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    18
#
489c9b5090e2 Initial load
duke
parents:
diff changeset
    19
# Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
489c9b5090e2 Initial load
duke
parents:
diff changeset
    20
# CA 95054 USA or visit www.sun.com if you need additional information or
489c9b5090e2 Initial load
duke
parents:
diff changeset
    21
# have any questions.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    22
#  
489c9b5090e2 Initial load
duke
parents:
diff changeset
    23
#
489c9b5090e2 Initial load
duke
parents:
diff changeset
    24
489c9b5090e2 Initial load
duke
parents:
diff changeset
    25
# top.make is included in the Makefile in the build directories.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    26
# It DOES NOT include the vm dependency info in order to be faster.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    27
# It's main job is to implement the incremental form of make lists.
489c9b5090e2 Initial load
duke
parents:
diff changeset
    28
# It also:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    29
#   -builds and runs adlc via adlc.make
489c9b5090e2 Initial load
duke
parents:
diff changeset
    30
#   -generates JVMTI source and docs via jvmti.make (JSR-163)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    31
#   -generate sa-jdi.jar (JDI binding to core files)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    32
489c9b5090e2 Initial load
duke
parents:
diff changeset
    33
# It assumes the following flags are set:
489c9b5090e2 Initial load
duke
parents:
diff changeset
    34
# CFLAGS Platform_file, Src_Dirs, SYSDEFS, AOUT, Obj_Files
489c9b5090e2 Initial load
duke
parents:
diff changeset
    35
489c9b5090e2 Initial load
duke
parents:
diff changeset
    36
# -- D. Ungar (5/97) from a file by Bill Bush
489c9b5090e2 Initial load
duke
parents:
diff changeset
    37
489c9b5090e2 Initial load
duke
parents:
diff changeset
    38
# Don't override the built-in $(MAKE).
489c9b5090e2 Initial load
duke
parents:
diff changeset
    39
# Instead, use "gmake" (or "gnumake") from the command line.  --Rose
489c9b5090e2 Initial load
duke
parents:
diff changeset
    40
#MAKE = gmake
489c9b5090e2 Initial load
duke
parents:
diff changeset
    41
489c9b5090e2 Initial load
duke
parents:
diff changeset
    42
TOPDIR      = $(shell echo `pwd`)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    43
GENERATED   = $(TOPDIR)/../generated
489c9b5090e2 Initial load
duke
parents:
diff changeset
    44
VM          = $(GAMMADIR)/src/share/vm
489c9b5090e2 Initial load
duke
parents:
diff changeset
    45
Plat_File   = $(Platform_file)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    46
CDG         = cd $(GENERATED); 
489c9b5090e2 Initial load
duke
parents:
diff changeset
    47
489c9b5090e2 Initial load
duke
parents:
diff changeset
    48
# Pick up MakeDeps' sources and definitions
338
5cf9f61d76f4 6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents: 1
diff changeset
    49
include $(GAMMADIR)/make/$(Platform_os_family)/makefiles/makedeps.make
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    50
MakeDepsClass = MakeDeps.class
489c9b5090e2 Initial load
duke
parents:
diff changeset
    51
489c9b5090e2 Initial load
duke
parents:
diff changeset
    52
ifdef USE_PRECOMPILED_HEADER
489c9b5090e2 Initial load
duke
parents:
diff changeset
    53
PrecompiledOption = -DUSE_PRECOMPILED_HEADER
489c9b5090e2 Initial load
duke
parents:
diff changeset
    54
UpdatePCH         = $(MAKE) -f vm.make $(PRECOMPILED_HEADER) $(MFLAGS) 
489c9b5090e2 Initial load
duke
parents:
diff changeset
    55
else
489c9b5090e2 Initial load
duke
parents:
diff changeset
    56
UpdatePCH         = \# precompiled header is not used
489c9b5090e2 Initial load
duke
parents:
diff changeset
    57
PrecompiledOption = 
489c9b5090e2 Initial load
duke
parents:
diff changeset
    58
endif
489c9b5090e2 Initial load
duke
parents:
diff changeset
    59
489c9b5090e2 Initial load
duke
parents:
diff changeset
    60
MakeDeps    = $(RUN.JAVA) $(PrecompiledOption) -classpath $(GENERATED) MakeDeps
489c9b5090e2 Initial load
duke
parents:
diff changeset
    61
489c9b5090e2 Initial load
duke
parents:
diff changeset
    62
Include_DBs/GC          = $(VM)/includeDB_gc \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    63
                          $(VM)/includeDB_gc_parallel \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    64
                          $(VM)/gc_implementation/includeDB_gc_parallelScavenge \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    65
                          $(VM)/gc_implementation/includeDB_gc_concurrentMarkSweep \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    66
                          $(VM)/gc_implementation/includeDB_gc_parNew \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    67
                          $(VM)/gc_implementation/includeDB_gc_serial \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    68
                          $(VM)/gc_implementation/includeDB_gc_shared
489c9b5090e2 Initial load
duke
parents:
diff changeset
    69
489c9b5090e2 Initial load
duke
parents:
diff changeset
    70
Include_DBs/CORE        = $(VM)/includeDB_core   $(Include_DBs/GC) \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    71
                          $(VM)/includeDB_jvmti \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    72
                          $(VM)/includeDB_features
489c9b5090e2 Initial load
duke
parents:
diff changeset
    73
Include_DBs/COMPILER1   = $(Include_DBs/CORE) $(VM)/includeDB_compiler1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    74
Include_DBs/COMPILER2   = $(Include_DBs/CORE) $(VM)/includeDB_compiler2
489c9b5090e2 Initial load
duke
parents:
diff changeset
    75
Include_DBs/TIERED      = $(Include_DBs/CORE) $(VM)/includeDB_compiler1 $(VM)/includeDB_compiler2
489c9b5090e2 Initial load
duke
parents:
diff changeset
    76
Include_DBs = $(Include_DBs/$(TYPE))
489c9b5090e2 Initial load
duke
parents:
diff changeset
    77
489c9b5090e2 Initial load
duke
parents:
diff changeset
    78
Cached_plat = $(GENERATED)/platform.current
489c9b5090e2 Initial load
duke
parents:
diff changeset
    79
Cached_db   = $(GENERATED)/includeDB.current
489c9b5090e2 Initial load
duke
parents:
diff changeset
    80
489c9b5090e2 Initial load
duke
parents:
diff changeset
    81
Incremental_Lists = $(Cached_db)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    82
# list generation also creates $(GENERATED)/$(Cached_plat)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    83
489c9b5090e2 Initial load
duke
parents:
diff changeset
    84
489c9b5090e2 Initial load
duke
parents:
diff changeset
    85
AD_Dir   = $(GENERATED)/adfiles
489c9b5090e2 Initial load
duke
parents:
diff changeset
    86
ADLC     = $(AD_Dir)/adlc
489c9b5090e2 Initial load
duke
parents:
diff changeset
    87
AD_Spec  = $(GAMMADIR)/src/cpu/$(Platform_arch)/vm/$(Platform_arch).ad
489c9b5090e2 Initial load
duke
parents:
diff changeset
    88
AD_Src   = $(GAMMADIR)/src/share/vm/adlc
489c9b5090e2 Initial load
duke
parents:
diff changeset
    89
AD_Names = ad_$(Platform_arch).hpp ad_$(Platform_arch).cpp
489c9b5090e2 Initial load
duke
parents:
diff changeset
    90
AD_Files = $(AD_Names:%=$(AD_Dir)/%)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    91
489c9b5090e2 Initial load
duke
parents:
diff changeset
    92
# AD_Files_If_Required/COMPILER1 = ad_stuff
489c9b5090e2 Initial load
duke
parents:
diff changeset
    93
AD_Files_If_Required/COMPILER2 = ad_stuff
489c9b5090e2 Initial load
duke
parents:
diff changeset
    94
AD_Files_If_Required/TIERED = ad_stuff
489c9b5090e2 Initial load
duke
parents:
diff changeset
    95
AD_Files_If_Required = $(AD_Files_If_Required/$(TYPE))
489c9b5090e2 Initial load
duke
parents:
diff changeset
    96
489c9b5090e2 Initial load
duke
parents:
diff changeset
    97
# Wierd argument adjustment for "gnumake -j..."
489c9b5090e2 Initial load
duke
parents:
diff changeset
    98
adjust-mflags   = $(GENERATED)/adjust-mflags
489c9b5090e2 Initial load
duke
parents:
diff changeset
    99
MFLAGS-adjusted = -r `$(adjust-mflags) "$(MFLAGS)" "$(HOTSPOT_BUILD_JOBS)"`
489c9b5090e2 Initial load
duke
parents:
diff changeset
   100
489c9b5090e2 Initial load
duke
parents:
diff changeset
   101
489c9b5090e2 Initial load
duke
parents:
diff changeset
   102
# default target: make makeDeps, update lists, make vm
489c9b5090e2 Initial load
duke
parents:
diff changeset
   103
# done in stages to force sequential order with parallel make
489c9b5090e2 Initial load
duke
parents:
diff changeset
   104
#
489c9b5090e2 Initial load
duke
parents:
diff changeset
   105
489c9b5090e2 Initial load
duke
parents:
diff changeset
   106
default: vm_build_preliminaries the_vm
489c9b5090e2 Initial load
duke
parents:
diff changeset
   107
	@echo All done.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   108
489c9b5090e2 Initial load
duke
parents:
diff changeset
   109
# This is an explicit dependency for the sake of parallel makes.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   110
vm_build_preliminaries:  checks $(Incremental_Lists) $(AD_Files_If_Required) jvmti_stuff sa_stuff
489c9b5090e2 Initial load
duke
parents:
diff changeset
   111
	@# We need a null action here, so implicit rules don't get consulted.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   112
489c9b5090e2 Initial load
duke
parents:
diff changeset
   113
# make makeDeps: (and zap the cached db files to force a nonincremental run)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   114
489c9b5090e2 Initial load
duke
parents:
diff changeset
   115
$(GENERATED)/$(MakeDepsClass): $(MakeDepsSources)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   116
	@$(REMOTE) $(COMPILE.JAVAC) -classpath $(GAMMADIR)/src/share/tools/MakeDeps -g -d $(GENERATED) $(MakeDepsSources)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   117
	@echo Removing $(Incremental_Lists) to force regeneration.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   118
	@rm -f $(Incremental_Lists)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   119
	@$(CDG) echo >$(Cached_plat)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   120
489c9b5090e2 Initial load
duke
parents:
diff changeset
   121
# make incremental_lists, if cached files out of date, run makeDeps
489c9b5090e2 Initial load
duke
parents:
diff changeset
   122
489c9b5090e2 Initial load
duke
parents:
diff changeset
   123
$(Incremental_Lists): $(Include_DBs) $(Plat_File) $(GENERATED)/$(MakeDepsClass)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   124
	$(CDG) cat $(Include_DBs) > $(GENERATED)/includeDB
489c9b5090e2 Initial load
duke
parents:
diff changeset
   125
	$(CDG) if [ ! -r incls ] ; then \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   126
	mkdir incls ; \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   127
	fi
489c9b5090e2 Initial load
duke
parents:
diff changeset
   128
	$(CDG) (echo $(CDG) echo $(MakeDeps) diffs UnixPlatform $(Cached_plat) $(Cached_db) $(Plat_File) $(GENERATED)/includeDB $(MakeDepsOptions)) > makeDeps.sh
489c9b5090e2 Initial load
duke
parents:
diff changeset
   129
	$(CDG) $(REMOTE) sh $(GENERATED)/makeDeps.sh
489c9b5090e2 Initial load
duke
parents:
diff changeset
   130
	$(CDG) cp includeDB    $(Cached_db)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   131
	$(CDG) cp $(Plat_File) $(Cached_plat)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   132
489c9b5090e2 Initial load
duke
parents:
diff changeset
   133
# symbolic target for command lines
489c9b5090e2 Initial load
duke
parents:
diff changeset
   134
lists: $(Incremental_Lists)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   135
	@: lists are now up to date
489c9b5090e2 Initial load
duke
parents:
diff changeset
   136
489c9b5090e2 Initial load
duke
parents:
diff changeset
   137
# make AD files as necessary
489c9b5090e2 Initial load
duke
parents:
diff changeset
   138
ad_stuff: $(Incremental_Lists) $(adjust-mflags)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   139
	@$(MAKE) -f adlc.make $(MFLAGS-adjusted)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   140
489c9b5090e2 Initial load
duke
parents:
diff changeset
   141
# generate JVMTI files from the spec
489c9b5090e2 Initial load
duke
parents:
diff changeset
   142
jvmti_stuff: $(Incremental_Lists) $(adjust-mflags)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   143
	@$(MAKE) -f jvmti.make $(MFLAGS-adjusted)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   144
489c9b5090e2 Initial load
duke
parents:
diff changeset
   145
# generate SA jar files and native header
489c9b5090e2 Initial load
duke
parents:
diff changeset
   146
sa_stuff:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   147
	@$(MAKE) -f sa.make $(MFLAGS-adjusted)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   148
489c9b5090e2 Initial load
duke
parents:
diff changeset
   149
# and the VM: must use other makefile with dependencies included
489c9b5090e2 Initial load
duke
parents:
diff changeset
   150
489c9b5090e2 Initial load
duke
parents:
diff changeset
   151
# We have to go to great lengths to get control over the -jN argument
489c9b5090e2 Initial load
duke
parents:
diff changeset
   152
# to the recursive invocation of vm.make.  The problem is that gnumake
489c9b5090e2 Initial load
duke
parents:
diff changeset
   153
# resets -jN to -j1 for recursive runs.  (How helpful.)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   154
# Note that the user must specify the desired parallelism level via a
489c9b5090e2 Initial load
duke
parents:
diff changeset
   155
# command-line or environment variable name HOTSPOT_BUILD_JOBS.
338
5cf9f61d76f4 6583644: Move all managed/SCCS files out of 'build' into 'make' directory
kamg
parents: 1
diff changeset
   156
$(adjust-mflags): $(GAMMADIR)/make/$(Platform_os_family)/makefiles/adjust-mflags.sh
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   157
	@+rm -f $@ $@+
489c9b5090e2 Initial load
duke
parents:
diff changeset
   158
	@+cat $< > $@+
489c9b5090e2 Initial load
duke
parents:
diff changeset
   159
	@+chmod +x $@+
489c9b5090e2 Initial load
duke
parents:
diff changeset
   160
	@+mv $@+ $@
489c9b5090e2 Initial load
duke
parents:
diff changeset
   161
489c9b5090e2 Initial load
duke
parents:
diff changeset
   162
the_vm: vm_build_preliminaries $(adjust-mflags)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   163
	@$(UpdatePCH)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   164
	@$(MAKE) -f vm.make $(MFLAGS-adjusted)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   165
489c9b5090e2 Initial load
duke
parents:
diff changeset
   166
install: the_vm
489c9b5090e2 Initial load
duke
parents:
diff changeset
   167
	@$(MAKE) -f vm.make install
489c9b5090e2 Initial load
duke
parents:
diff changeset
   168
489c9b5090e2 Initial load
duke
parents:
diff changeset
   169
# next rules support "make foo.[oi]"
489c9b5090e2 Initial load
duke
parents:
diff changeset
   170
489c9b5090e2 Initial load
duke
parents:
diff changeset
   171
%.o %.i %.s:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   172
	$(UpdatePCH) 
489c9b5090e2 Initial load
duke
parents:
diff changeset
   173
	$(MAKE) -f vm.make $(MFLAGS) $@
489c9b5090e2 Initial load
duke
parents:
diff changeset
   174
	#$(MAKE) -f vm.make $@
489c9b5090e2 Initial load
duke
parents:
diff changeset
   175
489c9b5090e2 Initial load
duke
parents:
diff changeset
   176
# this should force everything to be rebuilt
489c9b5090e2 Initial load
duke
parents:
diff changeset
   177
clean: 
489c9b5090e2 Initial load
duke
parents:
diff changeset
   178
	rm -f $(GENERATED)/*.class
489c9b5090e2 Initial load
duke
parents:
diff changeset
   179
	$(MAKE) $(MFLAGS) $(GENERATED)/$(MakeDepsClass)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   180
	$(MAKE) -f vm.make $(MFLAGS) clean
489c9b5090e2 Initial load
duke
parents:
diff changeset
   181
489c9b5090e2 Initial load
duke
parents:
diff changeset
   182
# just in case it doesn't, this should do it
489c9b5090e2 Initial load
duke
parents:
diff changeset
   183
realclean:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   184
	$(MAKE) -f vm.make $(MFLAGS) clean
489c9b5090e2 Initial load
duke
parents:
diff changeset
   185
	rm -fr $(GENERATED)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   186
489c9b5090e2 Initial load
duke
parents:
diff changeset
   187
.PHONY: default vm_build_preliminaries
489c9b5090e2 Initial load
duke
parents:
diff changeset
   188
.PHONY: lists ad_stuff jvmti_stuff sa_stuff the_vm clean realclean
489c9b5090e2 Initial load
duke
parents:
diff changeset
   189
.PHONY: checks check_os_version install