VirtualBox

source: vbox/trunk/src/VBox/Devices/EFI/Firmware/Config.kmk@ 74900

Last change on this file since 74900 was 72800, checked in by vboxsync, 7 years ago

EFI: Added make variable VBOX_BLD_PYTHON_2X for specifying a 2.x python for use with EFI.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 7.2 KB
Line 
1# $Id: Config.kmk 72800 2018-07-02 16:19:11Z vboxsync $
2## @file
3# kBuild configuration for the VBox EFI firmware.
4#
5# Note! kBuild is only used for the build tools, the rest is handled by the
6# very custom EFI build system.
7#
8
9#
10# Copyright (C) 2013-2017 Oracle Corporation
11#
12# This file is part of VirtualBox Open Source Edition (OSE), as
13# available from http://www.virtualbox.org. This file is free software;
14# you can redistribute it and/or modify it under the terms of the GNU
15# General Public License (GPL) as published by the Free Software
16# Foundation, in version 2 as it comes in the "COPYING" file of the
17# VirtualBox OSE distribution. VirtualBox OSE is distributed in the
18# hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
19#
20# The contents of this file may alternatively be used under the terms
21# of the Common Development and Distribution License Version 1.0
22# (CDDL) only, as it comes in the "COPYING.CDDL" file of the
23# VirtualBox OSE distribution, in which case the provisions of the
24# CDDL are applicable instead of those of the GPL.
25#
26# You may elect to license modified versions of this file under the
27# terms and conditions of either the GPL or the CDDL or both.
28#
29
30VBOX_EFI_FIRMWARE_CONFIG_KMK_INCLUDED = 1
31
32# Include the next configure file above us.
33ifndef VBOX_DEVICES_CONFIG_KMK_INCLUDED
34 include $(PATH_ROOT)/src/VBox/Devices/Config.kmk
35endif
36
37#
38# Globals.
39#
40VBOX_PATH_EFI_FIRMWARE = $(PATH_ROOT)/src/VBox/Devices/EFI/Firmware
41VBOX_PATH_STAGE_EFI_BLDPROGS = $(PATH_STAGE)/EfiBldProgs
42VBOX_EFI_BUILD_TARGET = $(if-expr $(intersects release profile, $(KBUILD_TYPE)),RELEASE,DEBUG)
43VBOX_EFI_OUTPUT_SUBDIR = $(VBOX_EFI_BUILD_TARGET)_$(VBOX_EFI_TOOL_CHAIN)
44
45# VBox Yasm command
46VBOX_YASMCMD ?= $(firstword $(wildcard $(KBUILD_DEVTOOLS_HST)/bin/yasm$(HOSTSUFF_EXE)) yasm$(HOSTSUFF_EXE))
47
48# EFI requires python v2.x, so provide a way to select that while using 3.x for the rest of VBox.
49ifndef VBOX_BLD_PYTHON_2X
50 VBOX_BLD_PYTHON_2X = $(VBOX_BLD_PYTHON)
51endif
52
53#
54# Decide which tool chain to use for the EFI binaries.
55# Note! We're using our own stripped down tools_def.txt: vbox-tools_def.txt.
56#
57ifeq ($(KBUILD_HOST),win)
58 VBOX_EFI_TOOL_CHAIN := VS2010
59else
60 VBOX_EFI_TOOL_CHAIN = UNIXGCC
61 if !defined(VBOX_PATH_PREFIX_MINGW32) && !defined(VBOX_PATH_PREFIX_MINGW64)
62 $(info Requires VBOX_PATH_PREFIX_MINGW32 and/or VBOX_PATH_PREFIX_MINGW64 to point something mingw like or there must be some mingw like in the PATH.)
63 $(info )
64 $(info Recent Fedora: sudo yum install mingw64-gcc mingw64-gcc-c++ mingw64-binutils mingw32-gcc mingw32-gcc-c++ mingw32-binutils)
65 $(info )
66 $(info Newer Debian and forks: sudo apt-get install binutils-mingw-w64 gcc-mingw-w64 g++-mingw-w64 )
67 $(info Older Debian and forks: sudo apt-get install mingw32-binutils mingw32 mingw32-runtime )
68 $(info )
69 $(info Gentoo: crossdev -S -P -v -t i686-pc-mingw32 && crossdev -S -P -v -t x86_64-pc-mingw32)
70 $(info )
71 $(error Needs mingw32/64)
72 endif
73endif
74
75
76#
77# Make a build program template of our own.
78#
79TEMPLATE_VBoxEfiBldProg = EFI build program.
80TEMPLATE_VBoxEfiBldProg_EXTENDS = VBoxBldProg
81TEMPLATE_VBoxEfiBldProg_INST = EfiBldProgs/
82TEMPLATE_VBoxEfiBldProg_INSTTYPE = stage
83TEMPLATE_VBoxEfiBldProg_DEFS.win = $(TEMPLATE_VBoxBldProg_DEFS.win) \
84 __STDC_VERSION__=199409L
85TEMPLATE_VBoxEfiBldProg_CFLAGS.win = $(TEMPLATE_VBoxBldProg_CFLAGS.win)
86TEMPLATE_VBoxEfiBldProg_CFLAGS.win += -wd4100 # warning C4100: '_text' : unreferenced formal parameter
87TEMPLATE_VBoxEfiBldProg_CFLAGS.win += -wd4189 # warning C4189: 'zzpf' : local variable is initialized but not referenced
88TEMPLATE_VBoxEfiBldProg_CFLAGS.win += -wd4255 # warning C4255: 'AllocateMemory' : no function prototype given: converting '()' to '(void)'
89TEMPLATE_VBoxEfiBldProg_CFLAGS.win += -wd4267 # warning C4267: '=' : conversion from 'size_t' to 'UINT32', possible loss of data
90TEMPLATE_VBoxEfiBldProg_CFLAGS.win += -wd4287 # warning C4287: '>' : unsigned/negative constant mismatch
91TEMPLATE_VBoxEfiBldProg_CFLAGS.win += -wd4334 # warning C4334: '<<' : result of 32-bit shift implicitly converted to 64 bits (was 64-bit shift intended?)
92TEMPLATE_VBoxEfiBldProg_CFLAGS.win += -wd4555 # warning C4555: expression has no effect; expected expression with side-effect
93TEMPLATE_VBoxEfiBldProg_CFLAGS.win += -wd4701 # warning C4701: potentially uninitialized local variable 'save_line' used
94TEMPLATE_VBoxEfiBldProg_CFLAGS.win += -wd4702 # warning C4702: unreachable code
95TEMPLATE_VBoxEfiBldProg_CXXFLAGS.win = $(TEMPLATE_VBoxBldProg_CXXFLAGS.win)
96TEMPLATE_VBoxEfiBldProg_CXXFLAGS.win += -wd4101 # warning C4101: 'LineBuf' : unreferenced local variable
97TEMPLATE_VBoxEfiBldProg_CXXFLAGS.win += -wd4102 # warning C4102: 'fail' : unreferenced label
98TEMPLATE_VBoxEfiBldProg_CXXFLAGS.win += -wd4189 # warning C4189: 'zzpf' : local variable is initialized but not referenced
99TEMPLATE_VBoxEfiBldProg_CXXFLAGS.win += -wd4267 # warning C4267: '=' : conversion from 'size_t' to 'UINT32', possible loss of data
100TEMPLATE_VBoxEfiBldProg_CXXFLAGS.win += -wd4370 # warning C4370: 'ANTLRParser' : layout of class has changed from a previous version of the compiler due to better packing
101TEMPLATE_VBoxEfiBldProg_CXXFLAGS.win += -wd4555 # warning C4555: expression has no effect; expected expression with side-effect
102TEMPLATE_VBoxEfiBldProg_CXXFLAGS.win += -wd4701 # warning C4701: potentially uninitialized local variable 'save_line' used
103TEMPLATE_VBoxEfiBldProg_CXXFLAGS.win += -wd4702 # warning C4702: unreachable code
104
105TEMPLATE_VBoxEfiBldProg_INCS = $(TEMPLATE_VBoxBldProg_INCS) \
106 $(VBOX_PATH_EFI_FIRMWARE)/BaseTools/Source/C/Include/IndustryStandard \
107 $(VBOX_PATH_EFI_FIRMWARE)/BaseTools/Source/C/Common \
108 $(VBOX_PATH_EFI_FIRMWARE)/BaseTools/Source/C/Include \
109 $(VBOX_PATH_EFI_FIRMWARE)/BaseTools/Source/C
110
111TEMPLATE_VBoxEfiBldProg_INCS.x86 = $(TEMPLATE_VBoxBldProg_INCS.x86) \
112 $(VBOX_PATH_EFI_FIRMWARE)/BaseTools/Source/C/Include/IA32
113
114TEMPLATE_VBoxEfiBldProg_INCS.amd64 = $(TEMPLATE_VBoxBldProg_INCS.amd64) \
115 $(VBOX_PATH_EFI_FIRMWARE)/BaseTools/Source/C/Include/X64
116
117TEMPLATE_VBoxEfiBldProg_LIBS = \
118 $(VBOX_PATH_STAGE_EFI_BLDPROGS)/EfiBldCommonLib$(VBOX_SUFF_LIB) \
119 $(TEMPLATE_VBoxBldProg_LIBS)
120ifn1of ($(KBUILD_HOST),win) # This stuff isn't up to our standard at all! :/
121 TEMPLATE_VBoxEfiBldProg_CFLAGS = $(filter-out -pedantic,$(TEMPLATE_VBoxBldProg_CFLAGS)) \
122 -Wno-sign-compare -Wno-missing-prototypes -Wno-strict-prototypes \
123 -Wno-implicit-function-declaration -Wno-missing-declarations -Wno-shadow -Wno-format \
124 -Wno-empty-body -Wno-unused-parameter -Wno-unused-variable -Wno-unused-label
125 TEMPLATE_VBoxEfiBldProg_CXXFLAGS = $(filter-out -pedantic,$(TEMPLATE_VBoxBldProg_CXXFLAGS)) \
126 -Wno-all -Wno-shadow -Wno-empty-body -Wno-unused-parameter -Wno-unused-variable \
127 -Wno-unused-label
128endif
129
130
131# There isn't a BLDLIBRARIES target group, so we have to override the build
132# target for libraries used by build programs and keep them in LIBRARIES.
133TEMPLATE_VBoxEfiBldLib = Library for an EFI build program.
134TEMPLATE_VBoxEfiBldLib_EXTENDS = VBoxEfiBldProg
135TEMPLATE_VBoxEfiBldLib_BLD_TRG := $(KBUILD_HOST)
136TEMPLATE_VBoxEfiBldLib_BLD_TRG_ARCH := $(KBUILD_HOST_ARCH)
137TEMPLATE_VBoxEfiBldLib_BLD_TRG_CPU := $(KBUILD_HOST_CPU)
138
139
140#
141# The debug info suffix.
142#
143if1of ($(KBUILD_TARGET), win)
144 VBOX_EFI_DBG_SUFF := .pdb
145else
146 VBOX_EFI_DBG_SUFF := .debug
147endif
148
149include $(VBOX_PATH_EFI_FIRMWARE)/EfiModules.kmk
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette