hotspot/make/linux/makefiles/ppc64.make
author mduigou
Mon, 14 Jul 2014 18:24:08 +0000
changeset 25639 61be16de0fd5
parent 23532 7e8719ce96ea
child 35594 cc13089c6327
permissions -rw-r--r--
8046765: makefiles should use parameterized $(CP) and $(MV) rather than explicit commands Reviewed-by: kvn, dholmes
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
22818
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
     1
#
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
     2
# Copyright (c) 2004, 2013, Oracle and/or its affiliates. All rights reserved.
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
     3
# Copyright 2012, 2013 SAP AG. All rights reserved.
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
     4
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
     5
#
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
     6
# This code is free software; you can redistribute it and/or modify it
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
     7
# under the terms of the GNU General Public License version 2 only, as
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
     8
# published by the Free Software Foundation.
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
     9
#
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    10
# This code is distributed in the hope that it will be useful, but WITHOUT
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    11
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    12
# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    13
# version 2 for more details (a copy is included in the LICENSE file that
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    14
# accompanied this code).
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    15
#
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    16
# You should have received a copy of the GNU General Public License version
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    17
# 2 along with this work; if not, write to the Free Software Foundation,
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    18
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    19
#
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    20
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    21
# or visit www.oracle.com if you need additional information or have any
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    22
# questions.
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    23
#
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    24
#
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    25
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    26
# make c code know it is on a 64 bit platform.
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    27
CFLAGS += -D_LP64=1
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    28
23532
7e8719ce96ea 8036767: PPC64: Support for little endian execution model
kvn
parents: 22818
diff changeset
    29
ifeq ($(origin OPENJDK_TARGET_CPU_ENDIAN),undefined)
7e8719ce96ea 8036767: PPC64: Support for little endian execution model
kvn
parents: 22818
diff changeset
    30
  # This can happen during hotspot standalone build. Set endianness from
7e8719ce96ea 8036767: PPC64: Support for little endian execution model
kvn
parents: 22818
diff changeset
    31
  # uname. We assume build and target machines are the same.
7e8719ce96ea 8036767: PPC64: Support for little endian execution model
kvn
parents: 22818
diff changeset
    32
  OPENJDK_TARGET_CPU_ENDIAN:=$(if $(filter ppc64le,$(shell uname -m)),little,big)
7e8719ce96ea 8036767: PPC64: Support for little endian execution model
kvn
parents: 22818
diff changeset
    33
endif
22818
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    34
23532
7e8719ce96ea 8036767: PPC64: Support for little endian execution model
kvn
parents: 22818
diff changeset
    35
ifeq ($(filter $(OPENJDK_TARGET_CPU_ENDIAN),big little),)
7e8719ce96ea 8036767: PPC64: Support for little endian execution model
kvn
parents: 22818
diff changeset
    36
  $(error OPENJDK_TARGET_CPU_ENDIAN value should be 'big' or 'little')
7e8719ce96ea 8036767: PPC64: Support for little endian execution model
kvn
parents: 22818
diff changeset
    37
endif
22818
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    38
23532
7e8719ce96ea 8036767: PPC64: Support for little endian execution model
kvn
parents: 22818
diff changeset
    39
ifeq ($(OPENJDK_TARGET_CPU_ENDIAN),big)
7e8719ce96ea 8036767: PPC64: Support for little endian execution model
kvn
parents: 22818
diff changeset
    40
  # fixes `relocation truncated to fit' error for gcc 4.1.
7e8719ce96ea 8036767: PPC64: Support for little endian execution model
kvn
parents: 22818
diff changeset
    41
  CFLAGS += -mminimal-toc
22818
34cd99df9940 8019922: PPC64 (part 8): Implement Linux/PPC64 support in HotSpot makefiles
simonis
parents:
diff changeset
    42
23532
7e8719ce96ea 8036767: PPC64: Support for little endian execution model
kvn
parents: 22818
diff changeset
    43
  # finds use ppc64 instructions, but schedule for power5
7e8719ce96ea 8036767: PPC64: Support for little endian execution model
kvn
parents: 22818
diff changeset
    44
  CFLAGS += -mcpu=powerpc64 -mtune=power5 -minsert-sched-nops=regroup_exact -mno-multiple -mno-string
7e8719ce96ea 8036767: PPC64: Support for little endian execution model
kvn
parents: 22818
diff changeset
    45
else
7e8719ce96ea 8036767: PPC64: Support for little endian execution model
kvn
parents: 22818
diff changeset
    46
  # Little endian machine uses ELFv2 ABI.
7e8719ce96ea 8036767: PPC64: Support for little endian execution model
kvn
parents: 22818
diff changeset
    47
  CFLAGS += -DVM_LITTLE_ENDIAN -DABI_ELFv2
7e8719ce96ea 8036767: PPC64: Support for little endian execution model
kvn
parents: 22818
diff changeset
    48
7e8719ce96ea 8036767: PPC64: Support for little endian execution model
kvn
parents: 22818
diff changeset
    49
  # Use Power8, this is the first CPU to support PPC64 LE with ELFv2 ABI.
7e8719ce96ea 8036767: PPC64: Support for little endian execution model
kvn
parents: 22818
diff changeset
    50
  CFLAGS += -mcpu=power7 -mtune=power8 -minsert-sched-nops=regroup_exact -mno-multiple -mno-string
7e8719ce96ea 8036767: PPC64: Support for little endian execution model
kvn
parents: 22818
diff changeset
    51
endif