Blame Makerules/Target.LINUX.INTEL.X86_64

Packit Service 3470d1
# BEGIN_ICS_COPYRIGHT8 ****************************************
Packit Service 3470d1
# 
Packit Service 3470d1
# Copyright (c) 2015, Intel Corporation
Packit Service 3470d1
# 
Packit Service 3470d1
# Redistribution and use in source and binary forms, with or without
Packit Service 3470d1
# modification, are permitted provided that the following conditions are met:
Packit Service 3470d1
# 
Packit Service 3470d1
#     * Redistributions of source code must retain the above copyright notice,
Packit Service 3470d1
#       this list of conditions and the following disclaimer.
Packit Service 3470d1
#     * Redistributions in binary form must reproduce the above copyright
Packit Service 3470d1
#       notice, this list of conditions and the following disclaimer in the
Packit Service 3470d1
#       documentation and/or other materials provided with the distribution.
Packit Service 3470d1
#     * Neither the name of Intel Corporation nor the names of its contributors
Packit Service 3470d1
#       may be used to endorse or promote products derived from this software
Packit Service 3470d1
#       without specific prior written permission.
Packit Service 3470d1
# 
Packit Service 3470d1
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
Packit Service 3470d1
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
Packit Service 3470d1
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
Packit Service 3470d1
# DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
Packit Service 3470d1
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
Packit Service 3470d1
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
Packit Service 3470d1
# SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
Packit Service 3470d1
# CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
Packit Service 3470d1
# OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
Packit Service 3470d1
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Packit Service 3470d1
# 
Packit Service 3470d1
# END_ICS_COPYRIGHT8   ****************************************
Packit Service 3470d1
# suffixes and commands to build targets for:
Packit Service 3470d1
# BUILD_TARGET_OS=LINUX
Packit Service 3470d1
# BUILD_TARGET_TOOLCHAIN=GNU
Packit Service 3470d1
# BUILD_TARGET=X86_64
Packit Service 3470d1
# Target specific defines for building LINUX target using GNU tools
Packit Service 3470d1
Packit Service 3470d1
SHLIB_VERSION		?= 0.0
Packit Service 3470d1
LIB_PREFIX			= $(BUILDDIR)/lib
Packit Service 3470d1
SHLIB_SUFFIX		= .so
Packit Service 3470d1
SHLIB_VERSION_SUFFIX= .so.$(SHLIB_VERSION)
Packit Service 3470d1
ARLIB_SUFFIX		= .a
Packit Service 3470d1
EXE_SUFFIX			= 
Packit Service 3470d1
OBJ_SUFFIX			= .o
Packit Service 3470d1
ifdef BUILD_26
Packit Service 3470d1
KOBJ_SUFFIX			= .ko
Packit Service 3470d1
else
Packit Service 3470d1
KOBJ_SUFFIX			= .o
Packit Service 3470d1
endif
Packit Service 3470d1
EXP_SUFFIX			= .exp
Packit Service 3470d1
RES_SUFFIX			= .res
Packit Service 3470d1
PRE_SUFFIX			= .pre
Packit Service 3470d1
Packit Service 3470d1
# Paths:
Packit Service 3470d1
# let compiler default inclusion of /usr/include, otherwise g++ builds broken
Packit Service 3470d1
SYS_INCLUDE_DIRS =
Packit Service 3470d1
SYS_LIB_DIRS	 =
Packit Service 3470d1
Packit Service 3470d1
CC			= icc
Packit Service 3470d1
CCC			= icc
Packit Service 3470d1
LD			= xild
Packit Service 3470d1
LINT		= lint
Packit Service 3470d1
AR			= xiar
Packit Service 3470d1
NM			= nm
Packit Service 3470d1
OBJCOPY		= objcopy
Packit Service 3470d1
Packit Service 3470d1
include $(TL_DIR)/Makerules/Defs.GNU
Packit Service 3470d1
Packit Service 3470d1
# for GNU we set an soname on shared libraries
Packit Service 3470d1
SHLIB_SONAME=$(notdir $(CMD_TARGETS_SHLIB))
Packit Service 3470d1
Packit Service 3470d1
# C/C++ compilation
Packit Service 3470d1
# ----------------------------
Packit Service 3470d1
# -fcheck-new does the opposite of what the manual implies.
Packit Service 3470d1
# -fcheck-new DISABLES the run-time test of return value from new
Packit Service 3470d1
CMACH		= -DMWHEINZ -DTARGET_CPU_FAMILY_X86 -Wall -D__X86_64__ -DCPU_LE -Wall
Packit Service 3470d1
CCMACH		= $(CMACH) 
Packit Service 3470d1
CSYS		= -DLINUX -Dlinux -D__LINUX__ 
Packit Service 3470d1
CCSYS		= $(CSYS)
Packit Service 3470d1
CCLIBS		= 
Packit Service 3470d1
release_CCOPT_Flags	=-fast -axSSE4.2
Packit Service 3470d1
debug_CCOPT_Flags	=-axSSE4.2
Packit Service 3470d1
release_COPT_Flags	=-fast -axSSE4.2
Packit Service 3470d1
debug_COPT_Flags	=-axSSE4.2
Packit Service 3470d1
# Assemble the optimization flags based upon desired build configuration.
Packit Service 3470d1
CCOPT		= $($(strip $(BUILD_CONFIG))_CCOPT_Flags)
Packit Service 3470d1
COPT		= $($(strip $(BUILD_CONFIG))_COPT_Flags)
Packit Service 3470d1
release_CCDEBUG_Flags	=
Packit Service 3470d1
release_CDEBUG_Flags	=
Packit Service 3470d1
debug_CCDEBUG_Flags	=-g -DIB_DEBUG -DIB_TRACE $(CCPROJDEBUG) $(CCLOCALDEBUG)
Packit Service 3470d1
debug_CDEBUG_Flags	=-g -DIB_DEBUG -DIB_TRACE $(CPROJDEBUG) $(CLOCALDEBUG)
Packit Service 3470d1
# Assemble the debug flags based upon desired build configuration.
Packit Service 3470d1
CCDEBUG		= $($(strip $(BUILD_CONFIG))_CCDEBUG_Flags)
Packit Service 3470d1
CDEBUG		= $($(strip $(BUILD_CONFIG))_CDEBUG_Flags)
Packit Service 3470d1
Packit Service 3470d1
# Kernel build settings
Packit Service 3470d1
#---------------------------------------------
Packit Service 3470d1
# use CKERNEL and KERNEL_INCLUDE_DIRS to augment CLOCAL, LOCAL_INCLUDE_DIRS when
Packit Service 3470d1
# building a kernel module
Packit Service 3470d1
Packit Service 3470d1
# strict-aliasing - disables optimizations related to unions/casts
Packit Service 3470d1
# no-common - will put globals uninitialized in .bss instead of common
Packit Service 3470d1
# 		hence get link error if multiple declaration
Packit Service 3470d1
# preferred-stack-boundary=2 -align stack to 2^2 byte boundary,
Packit Service 3470d1
#		possible performance penalty for 64 bit data
Packit Service 3470d1
# 		TBD, what does kernel use
Packit Service 3470d1
# -D_I386_PTRACE_H was a workaround for a ptrace.h header file inclusion issue
Packit Service 3470d1
# 		identify where needed and just put in that one makefile
Packit Service 3470d1
# -include picks up special flags for SMP and MODVERSIONS, this allows portable
Packit Service 3470d1
# kernel modules to be built for multiple system types from a single running
Packit Service 3470d1
# system
Packit Service 3470d1
Packit Service 3470d1
ifndef BUILD_26
Packit Service 3470d1
Packit Service 3470d1
CKERNEL=-D_KERNEL -D__KERNEL__ -DMODULE -DEXPORT_SYMTAB -mcmodel=kernel -Wno-trigraphs -mno-red-zone -fno-reorder-blocks -finline-limit=2000 -fno-strict-aliasing -fno-common -msoft-float
Packit Service 3470d1
# omit frame pointer for simple functions
Packit Service 3470d1
# take advantage of pentium pro instructions, default is i386 compatible code
Packit Service 3470d1
Packit Service 3470d1
ifeq "$(BUILD_CONFIG)" "release"
Packit Service 3470d1
CKERNEL+= -fomit-frame-pointer -O2 -fno-strength-reduce
Packit Service 3470d1
else
Packit Service 3470d1
# due to extern inline virt_to_phys in io.h in kernel, we must use at least -O1
Packit Service 3470d1
# COPT will follow CLOCAL in CFLAGS, so it can request a different level
Packit Service 3470d1
# of optimization if needed
Packit Service 3470d1
CKERNEL+= -O1
Packit Service 3470d1
endif
Packit Service 3470d1
Packit Service 3470d1
ifeq "$(GCC_MAJOR_VERSION)" "3"
Packit Service 3470d1
ifeq "$(GCC_MINOR_VERSION)" "3"
Packit Service 3470d1
ifeq "$(BUILD_PLATFORM_OS_VENDOR)" "SuSE"
Packit Service 3470d1
CKERNEL+=-fno-unit-at-a-time
Packit Service 3470d1
endif
Packit Service 3470d1
endif
Packit Service 3470d1
endif
Packit Service 3470d1
Packit Service 3470d1
endif
Packit Service 3470d1
CKERNEL+=-include $(TL_DIR)/Makerules/LINUX/$(BUILD_TARGET).$(BUILD_TARGET_OS_VENDOR).$(BUILD_TARGET_OS_VERSION).h
Packit Service 3470d1
Packit Service 3470d1
# Include directories for kernel
Packit Service 3470d1
KERNELDIR=/lib/modules/$(BUILD_TARGET_OS_VERSION)/build
Packit Service 3470d1
KERNEL_INCLUDE_DIRS=$(KERNELDIR)/include
Packit Service 3470d1
Packit Service 3470d1
# linking
Packit Service 3470d1
# ----------------------------
Packit Service 3470d1
LDMACH		= 
Packit Service 3470d1
LDSYS		=
Packit Service 3470d1
MKSHLIB		= $(CCC) $(CCDEBUG) $(COPT) -shared
Packit Service 3470d1
ifeq "$(strip $(LIBFILES))" ""
Packit Service 3470d1
MKARLIB		= $(AR) crus$(space)
Packit Service 3470d1
else
Packit Service 3470d1
MKARLIB		= $(MAKETOOLS_DIR)/mkarlib.sh $(AR) crus$(space)
Packit Service 3470d1
endif
Packit Service 3470d1
MKPARTIAL	= $(LD) -r -o
Packit Service 3470d1
MKMODULE	= $(LD) -r -o
Packit Service 3470d1
Packit Service 3470d1
LDLIBSRCH	+= $(foreach lib,$(LD_LIB_DIRS),-Xlinker -rpath-link -Xlinker $(lib))
Packit Service 3470d1
SYSLIBS		= -lpthread
Packit Service 3470d1
LDLIBS		= -Xlinker --start-group $(foreach lib,$(LOCALLIBS) $(LOCALDEPLIBS) $(MODLIBS) $(MODDEPLIBS) $(PROJLIBS) $(PROJDEPLIBS),-l$(lib)) $(EXPLICITLIBS) -Xlinker --end-group $(SYSLIBS)
Packit Service 3470d1
Packit Service 3470d1
# libraries for partial link of a kernel loadable module
Packit Service 3470d1
KERNELLIBS		=