hotspot/make/linux/makefiles/top.make
author twisti
Wed, 11 Aug 2010 05:51:21 -0700
changeset 6187 4fa7845f7c14
parent 5547 f4b087cbb361
child 7397 5b173b4ca846
permissions -rw-r--r--
6976186: integrate Shark HotSpot changes Summary: Shark is a JIT compiler for Zero that uses the LLVM compiler infrastructure. Reviewed-by: kvn, twisti Contributed-by: Gary Benson <gbenson@redhat.com>
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
     1
#
6187
4fa7845f7c14 6976186: integrate Shark HotSpot changes
twisti
parents: 5547
diff changeset
     2
# Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
1
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
#
5547
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 4013
diff changeset
    19
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 4013
diff changeset
    20
# or visit www.oracle.com if you need additional information or have any
f4b087cbb361 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 4013
diff changeset
    21
# questions.
1
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.
3818
75004bf9026c 6873059: Explicitly use -source 6 -target 6 when compiling with the boot jdk
andrew
parents: 1552
diff changeset
    27
# Its main job is to implement the incremental form of make lists.
1
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 \
1374
4c24294029a9 6711316: Open source the Garbage-First garbage collector
ysr
parents: 338
diff changeset
    67
                          $(VM)/gc_implementation/includeDB_gc_g1     \
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    68
                          $(VM)/gc_implementation/includeDB_gc_serial \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    69
                          $(VM)/gc_implementation/includeDB_gc_shared
489c9b5090e2 Initial load
duke
parents:
diff changeset
    70
489c9b5090e2 Initial load
duke
parents:
diff changeset
    71
Include_DBs/CORE        = $(VM)/includeDB_core   $(Include_DBs/GC) \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    72
                          $(VM)/includeDB_jvmti \
489c9b5090e2 Initial load
duke
parents:
diff changeset
    73
                          $(VM)/includeDB_features
489c9b5090e2 Initial load
duke
parents:
diff changeset
    74
Include_DBs/COMPILER1   = $(Include_DBs/CORE) $(VM)/includeDB_compiler1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    75
Include_DBs/COMPILER2   = $(Include_DBs/CORE) $(VM)/includeDB_compiler2
489c9b5090e2 Initial load
duke
parents:
diff changeset
    76
Include_DBs/TIERED      = $(Include_DBs/CORE) $(VM)/includeDB_compiler1 $(VM)/includeDB_compiler2
4013
b154310845de 6890308: integrate zero assembler hotspot changes
never
parents: 3818
diff changeset
    77
Include_DBs/ZERO        = $(Include_DBs/CORE) $(VM)/includeDB_zero
6187
4fa7845f7c14 6976186: integrate Shark HotSpot changes
twisti
parents: 5547
diff changeset
    78
Include_DBs/SHARK       = $(Include_DBs/ZERO) $(VM)/includeDB_shark
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    79
Include_DBs = $(Include_DBs/$(TYPE))
489c9b5090e2 Initial load
duke
parents:
diff changeset
    80
489c9b5090e2 Initial load
duke
parents:
diff changeset
    81
Cached_plat = $(GENERATED)/platform.current
489c9b5090e2 Initial load
duke
parents:
diff changeset
    82
Cached_db   = $(GENERATED)/includeDB.current
489c9b5090e2 Initial load
duke
parents:
diff changeset
    83
489c9b5090e2 Initial load
duke
parents:
diff changeset
    84
Incremental_Lists = $(Cached_db)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    85
# list generation also creates $(GENERATED)/$(Cached_plat)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    86
489c9b5090e2 Initial load
duke
parents:
diff changeset
    87
489c9b5090e2 Initial load
duke
parents:
diff changeset
    88
AD_Dir   = $(GENERATED)/adfiles
489c9b5090e2 Initial load
duke
parents:
diff changeset
    89
ADLC     = $(AD_Dir)/adlc
1552
45c617d33fa6 6767659: Conversion from i486 to x86 missed some entries in makefiles
kvn
parents: 1388
diff changeset
    90
AD_Spec  = $(GAMMADIR)/src/cpu/$(Platform_arch)/vm/$(Platform_arch_model).ad
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    91
AD_Src   = $(GAMMADIR)/src/share/vm/adlc
1552
45c617d33fa6 6767659: Conversion from i486 to x86 missed some entries in makefiles
kvn
parents: 1388
diff changeset
    92
AD_Names = ad_$(Platform_arch_model).hpp ad_$(Platform_arch_model).cpp
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
    93
AD_Files = $(AD_Names:%=$(AD_Dir)/%)
489c9b5090e2 Initial load
duke
parents:
diff changeset
    94
489c9b5090e2 Initial load
duke
parents:
diff changeset
    95
# AD_Files_If_Required/COMPILER1 = ad_stuff
489c9b5090e2 Initial load
duke
parents:
diff changeset
    96
AD_Files_If_Required/COMPILER2 = ad_stuff
489c9b5090e2 Initial load
duke
parents:
diff changeset
    97
AD_Files_If_Required/TIERED = ad_stuff
489c9b5090e2 Initial load
duke
parents:
diff changeset
    98
AD_Files_If_Required = $(AD_Files_If_Required/$(TYPE))
489c9b5090e2 Initial load
duke
parents:
diff changeset
    99
489c9b5090e2 Initial load
duke
parents:
diff changeset
   100
# Wierd argument adjustment for "gnumake -j..."
489c9b5090e2 Initial load
duke
parents:
diff changeset
   101
adjust-mflags   = $(GENERATED)/adjust-mflags
489c9b5090e2 Initial load
duke
parents:
diff changeset
   102
MFLAGS-adjusted = -r `$(adjust-mflags) "$(MFLAGS)" "$(HOTSPOT_BUILD_JOBS)"`
489c9b5090e2 Initial load
duke
parents:
diff changeset
   103
489c9b5090e2 Initial load
duke
parents:
diff changeset
   104
489c9b5090e2 Initial load
duke
parents:
diff changeset
   105
# default target: make makeDeps, update lists, make vm
489c9b5090e2 Initial load
duke
parents:
diff changeset
   106
# done in stages to force sequential order with parallel make
489c9b5090e2 Initial load
duke
parents:
diff changeset
   107
#
489c9b5090e2 Initial load
duke
parents:
diff changeset
   108
489c9b5090e2 Initial load
duke
parents:
diff changeset
   109
default: vm_build_preliminaries the_vm
489c9b5090e2 Initial load
duke
parents:
diff changeset
   110
	@echo All done.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   111
489c9b5090e2 Initial load
duke
parents:
diff changeset
   112
# This is an explicit dependency for the sake of parallel makes.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   113
vm_build_preliminaries:  checks $(Incremental_Lists) $(AD_Files_If_Required) jvmti_stuff sa_stuff
489c9b5090e2 Initial load
duke
parents:
diff changeset
   114
	@# We need a null action here, so implicit rules don't get consulted.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   115
489c9b5090e2 Initial load
duke
parents:
diff changeset
   116
# make makeDeps: (and zap the cached db files to force a nonincremental run)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   117
489c9b5090e2 Initial load
duke
parents:
diff changeset
   118
$(GENERATED)/$(MakeDepsClass): $(MakeDepsSources)
3818
75004bf9026c 6873059: Explicitly use -source 6 -target 6 when compiling with the boot jdk
andrew
parents: 1552
diff changeset
   119
	@$(REMOTE) $(COMPILE.JAVAC) -classpath $(GAMMADIR)/src/share/tools/MakeDeps -d $(GENERATED) $(MakeDepsSources)
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   120
	@echo Removing $(Incremental_Lists) to force regeneration.
489c9b5090e2 Initial load
duke
parents:
diff changeset
   121
	@rm -f $(Incremental_Lists)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   122
	@$(CDG) echo >$(Cached_plat)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   123
489c9b5090e2 Initial load
duke
parents:
diff changeset
   124
# make incremental_lists, if cached files out of date, run makeDeps
489c9b5090e2 Initial load
duke
parents:
diff changeset
   125
489c9b5090e2 Initial load
duke
parents:
diff changeset
   126
$(Incremental_Lists): $(Include_DBs) $(Plat_File) $(GENERATED)/$(MakeDepsClass)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   127
	$(CDG) cat $(Include_DBs) > $(GENERATED)/includeDB
489c9b5090e2 Initial load
duke
parents:
diff changeset
   128
	$(CDG) if [ ! -r incls ] ; then \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   129
	mkdir incls ; \
489c9b5090e2 Initial load
duke
parents:
diff changeset
   130
	fi
489c9b5090e2 Initial load
duke
parents:
diff changeset
   131
	$(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
   132
	$(CDG) $(REMOTE) sh $(GENERATED)/makeDeps.sh
489c9b5090e2 Initial load
duke
parents:
diff changeset
   133
	$(CDG) cp includeDB    $(Cached_db)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   134
	$(CDG) cp $(Plat_File) $(Cached_plat)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   135
489c9b5090e2 Initial load
duke
parents:
diff changeset
   136
# symbolic target for command lines
489c9b5090e2 Initial load
duke
parents:
diff changeset
   137
lists: $(Incremental_Lists)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   138
	@: lists are now up to date
489c9b5090e2 Initial load
duke
parents:
diff changeset
   139
489c9b5090e2 Initial load
duke
parents:
diff changeset
   140
# make AD files as necessary
489c9b5090e2 Initial load
duke
parents:
diff changeset
   141
ad_stuff: $(Incremental_Lists) $(adjust-mflags)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   142
	@$(MAKE) -f adlc.make $(MFLAGS-adjusted)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   143
489c9b5090e2 Initial load
duke
parents:
diff changeset
   144
# generate JVMTI files from the spec
489c9b5090e2 Initial load
duke
parents:
diff changeset
   145
jvmti_stuff: $(Incremental_Lists) $(adjust-mflags)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   146
	@$(MAKE) -f jvmti.make $(MFLAGS-adjusted)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   147
489c9b5090e2 Initial load
duke
parents:
diff changeset
   148
# generate SA jar files and native header
489c9b5090e2 Initial load
duke
parents:
diff changeset
   149
sa_stuff:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   150
	@$(MAKE) -f sa.make $(MFLAGS-adjusted)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   151
489c9b5090e2 Initial load
duke
parents:
diff changeset
   152
# and the VM: must use other makefile with dependencies included
489c9b5090e2 Initial load
duke
parents:
diff changeset
   153
489c9b5090e2 Initial load
duke
parents:
diff changeset
   154
# We have to go to great lengths to get control over the -jN argument
489c9b5090e2 Initial load
duke
parents:
diff changeset
   155
# to the recursive invocation of vm.make.  The problem is that gnumake
489c9b5090e2 Initial load
duke
parents:
diff changeset
   156
# resets -jN to -j1 for recursive runs.  (How helpful.)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   157
# Note that the user must specify the desired parallelism level via a
489c9b5090e2 Initial load
duke
parents:
diff changeset
   158
# 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
   159
$(adjust-mflags): $(GAMMADIR)/make/$(Platform_os_family)/makefiles/adjust-mflags.sh
1
489c9b5090e2 Initial load
duke
parents:
diff changeset
   160
	@+rm -f $@ $@+
489c9b5090e2 Initial load
duke
parents:
diff changeset
   161
	@+cat $< > $@+
489c9b5090e2 Initial load
duke
parents:
diff changeset
   162
	@+chmod +x $@+
489c9b5090e2 Initial load
duke
parents:
diff changeset
   163
	@+mv $@+ $@
489c9b5090e2 Initial load
duke
parents:
diff changeset
   164
489c9b5090e2 Initial load
duke
parents:
diff changeset
   165
the_vm: vm_build_preliminaries $(adjust-mflags)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   166
	@$(UpdatePCH)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   167
	@$(MAKE) -f vm.make $(MFLAGS-adjusted)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   168
489c9b5090e2 Initial load
duke
parents:
diff changeset
   169
install: the_vm
489c9b5090e2 Initial load
duke
parents:
diff changeset
   170
	@$(MAKE) -f vm.make install
489c9b5090e2 Initial load
duke
parents:
diff changeset
   171
489c9b5090e2 Initial load
duke
parents:
diff changeset
   172
# next rules support "make foo.[oi]"
489c9b5090e2 Initial load
duke
parents:
diff changeset
   173
489c9b5090e2 Initial load
duke
parents:
diff changeset
   174
%.o %.i %.s:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   175
	$(UpdatePCH) 
489c9b5090e2 Initial load
duke
parents:
diff changeset
   176
	$(MAKE) -f vm.make $(MFLAGS) $@
489c9b5090e2 Initial load
duke
parents:
diff changeset
   177
	#$(MAKE) -f vm.make $@
489c9b5090e2 Initial load
duke
parents:
diff changeset
   178
489c9b5090e2 Initial load
duke
parents:
diff changeset
   179
# this should force everything to be rebuilt
489c9b5090e2 Initial load
duke
parents:
diff changeset
   180
clean: 
489c9b5090e2 Initial load
duke
parents:
diff changeset
   181
	rm -f $(GENERATED)/*.class
489c9b5090e2 Initial load
duke
parents:
diff changeset
   182
	$(MAKE) $(MFLAGS) $(GENERATED)/$(MakeDepsClass)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   183
	$(MAKE) -f vm.make $(MFLAGS) clean
489c9b5090e2 Initial load
duke
parents:
diff changeset
   184
489c9b5090e2 Initial load
duke
parents:
diff changeset
   185
# just in case it doesn't, this should do it
489c9b5090e2 Initial load
duke
parents:
diff changeset
   186
realclean:
489c9b5090e2 Initial load
duke
parents:
diff changeset
   187
	$(MAKE) -f vm.make $(MFLAGS) clean
489c9b5090e2 Initial load
duke
parents:
diff changeset
   188
	rm -fr $(GENERATED)
489c9b5090e2 Initial load
duke
parents:
diff changeset
   189
489c9b5090e2 Initial load
duke
parents:
diff changeset
   190
.PHONY: default vm_build_preliminaries
489c9b5090e2 Initial load
duke
parents:
diff changeset
   191
.PHONY: lists ad_stuff jvmti_stuff sa_stuff the_vm clean realclean
489c9b5090e2 Initial load
duke
parents:
diff changeset
   192
.PHONY: checks check_os_version install