blob: 0c7b0b881d5bd59aa223f055b8e3cf27c2f67ed3 [file] [log] [blame]
Don Garrett0fc95942012-01-24 18:36:03 -08001# Copyright (c) 2012 The Chromium OS Authors. All rights reserved.
Gaurav Shah322536d2010-01-28 15:01:23 -08002# Use of this source code is governed by a BSD-style license that can be
3# found in the LICENSE file.
4
Gabe Black0aedbe12012-12-20 00:26:59 -08005ifneq ($(V),1)
6Q := @
7endif
8
Che-Liang Chiou0a0e8d02010-11-30 09:30:45 +08009export FIRMWARE_ARCH
Che-Liang Chiou8511f782011-04-22 16:01:38 +080010export MOCK_TPM
Gabe Black0aedbe12012-12-20 00:26:59 -080011export Q
Che-Liang Chiou0a0e8d02010-11-30 09:30:45 +080012
Simon Glass6d696e52011-11-14 13:46:33 -080013# This Makefile normally builds in a 'build' subdir, but use
14#
15# make BUILD=<dir>
16#
17# to put the output somewhere else
18
Simon Glassb265c342011-11-16 15:09:51 -080019#
20# Provide default CC and CFLAGS for firmware builds; if you have any -D flags,
21# please add them after this point (e.g., -DVBOOT_DEBUG).
Che-Liang Chiou74359b72011-06-21 15:25:51 -070022#
Che-Liang Chiou6b0003c2011-10-14 11:11:28 +080023# TODO(crosbug.com/16808) We hard-code u-boot's compiler flags here just
24# temporarily. As we are still investigating which flags are necessary for
25# maintaining a compatible ABI, etc. between u-boot and vboot_reference.
Che-Liang Chiou74359b72011-06-21 15:25:51 -070026#
Simon Glassb265c342011-11-16 15:09:51 -080027# As a first step, this makes the setting of CC and CFLAGS here optional, to
28# permit a calling script or Makefile to set these.
Che-Liang Chiou74359b72011-06-21 15:25:51 -070029#
Simon Glassb265c342011-11-16 15:09:51 -080030# Flag ordering: arch, then -f, then -m, then -W
31DEBUG_FLAGS := $(if ${DEBUG},-g -O0,-Os)
32COMMON_FLAGS := -nostdinc -pipe \
33 -ffreestanding -fno-builtin -fno-stack-protector \
34 -Werror -Wall -Wstrict-prototypes $(DEBUG_FLAGS)
35
Che-Liang Chiou7604a7d2011-06-21 17:40:34 -070036ifeq ($(FIRMWARE_ARCH), arm)
Simon Glassb265c342011-11-16 15:09:51 -080037CC ?= armv7a-cros-linux-gnueabi-gcc
38CFLAGS ?= -march=armv5 \
39 -fno-common -ffixed-r8 \
Doug Andersond50b27d2012-05-11 12:08:02 -070040 -mfloat-abi=hard -marm -mabi=aapcs-linux -mno-thumb-interwork \
Simon Glassb265c342011-11-16 15:09:51 -080041 $(COMMON_FLAGS)
Che-Liang Chiou74359b72011-06-21 15:25:51 -070042endif
Che-Liang Chiou7604a7d2011-06-21 17:40:34 -070043ifeq ($(FIRMWARE_ARCH), i386)
Simon Glassb265c342011-11-16 15:09:51 -080044CC ?= i686-pc-linux-gnu-gcc
45# Drop -march=i386 to permit use of SSE instructions
46CFLAGS ?= \
47 -ffunction-sections -fvisibility=hidden -fno-strict-aliasing \
48 -fomit-frame-pointer -fno-toplevel-reorder -fno-dwarf2-cfi-asm \
49 -mpreferred-stack-boundary=2 -mregparm=3 \
50 $(COMMON_FLAGS)
Che-Liang Chiou34be8272011-01-27 16:44:36 +080051endif
Simon Glass8e85e982011-11-22 13:54:50 -080052ifeq ($(FIRMWARE_ARCH), x86_64)
53CFLAGS ?= $(COMMON_FLAGS) \
54 -fvisibility=hidden -fno-strict-aliasing -fomit-frame-pointer
55endif
Che-Liang Chiou34be8272011-01-27 16:44:36 +080056
Simon Glassb265c342011-11-16 15:09:51 -080057CC ?= gcc
58CXX ?= g++
59
Mike Frysinger121f3db2012-06-07 12:13:57 -040060PKG_CONFIG ?= pkg-config
61ifneq ($(filter-out -static,$(LDFLAGS)),$(LDFLAGS))
62PKG_CONFIG += --static
63endif
64
Randall Spangler287beae2011-04-11 12:46:40 -070065# Fix compiling directly on host (outside of emake)
66ifeq ($(ARCH),)
67export ARCH=amd64
68endif
69
Che-Liang Chiou34be8272011-01-27 16:44:36 +080070ifeq ($(FIRMWARE_ARCH),)
Bill Richardsonf4729192012-05-02 23:30:16 -070071CFLAGS += -DCHROMEOS_ENVIRONMENT -Wall -Werror
Che-Liang Chiou34be8272011-01-27 16:44:36 +080072endif
73
74ifneq (${DEBUG},)
75CFLAGS += -DVBOOT_DEBUG
vbendebb2b0fcc2010-07-15 15:09:47 -070076endif
Che-Liang Chiou0a0e8d02010-11-30 09:30:45 +080077
vbendebb2b0fcc2010-07-15 15:09:47 -070078ifeq (${DISABLE_NDEBUG},)
79CFLAGS += -DNDEBUG
80endif
81
Mike Frysinger121f3db2012-06-07 12:13:57 -040082export CC CXX PKG_CONFIG CFLAGS
Simon Glassb265c342011-11-16 15:09:51 -080083
Gaurav Shah7ca31f32010-02-16 19:04:11 -080084export TOP = $(shell pwd)
Randall Spangler620c38c2010-06-17 14:45:22 -070085export FWDIR=$(TOP)/firmware
Randall Spanglerd1836442010-06-10 09:59:04 -070086export HOSTDIR=$(TOP)/host
Che-Liang Chiou0a0e8d02010-11-30 09:30:45 +080087ifeq ($(FIRMWARE_ARCH),)
Randall Spanglerd0dae7a2010-06-21 18:25:31 -070088export INCLUDES = -I$(FWDIR)/include -I$(FWDIR)/stub/include
Che-Liang Chiou0a0e8d02010-11-30 09:30:45 +080089else
90export INCLUDES = -I$(FWDIR)/include -I$(FWDIR)/arch/$(FIRMWARE_ARCH)/include
91endif
Gaurav Shah322536d2010-01-28 15:01:23 -080092
Simon Glass6d696e52011-11-14 13:46:33 -080093export BUILD ?= ${TOP}/build
vbendeb70e95092010-06-14 15:41:27 -070094export FWLIB = ${BUILD}/vboot_fw.a
Che-Liang Chiou89678602010-11-09 08:33:36 +080095export HOSTLIB = ${BUILD}/vboot_host.a
Don Garretted5fcc02012-02-14 12:47:57 -080096export DUMPKERNELCONFIGLIB = ${BUILD}/libdump_kernel_config.a
Bill Richardson0b8f35c2010-05-26 09:18:38 -070097
Che-Liang Chiou0a0e8d02010-11-30 09:30:45 +080098ifeq ($(FIRMWARE_ARCH),)
Randall Spangler39f66112010-07-14 09:10:23 -070099SUBDIRS = firmware host utility cgpt tests tests/tpm_lite
Che-Liang Chiou0a0e8d02010-11-30 09:30:45 +0800100else
101SUBDIRS = firmware
102endif
Gaurav Shah322536d2010-01-28 15:01:23 -0800103
104all:
Gabe Black0aedbe12012-12-20 00:26:59 -0800105 $(Q)set -e; \
vbendeb70e95092010-06-14 15:41:27 -0700106 for d in $(shell find ${SUBDIRS} -name '*.c' -exec dirname {} \; |\
107 sort -u); do \
108 newdir=${BUILD}/$$d; \
109 if [ ! -d $$newdir ]; then \
110 mkdir -p $$newdir; \
111 fi; \
Luigi Semenzato5896b962010-08-25 07:16:03 -0700112 done; \
Simon Glass6d696e52011-11-14 13:46:33 -0800113 [ -z "$(FIRMWARE_ARCH)" ] && $(MAKE) -C utility update_tlcl_structures; \
Gaurav Shah322536d2010-01-28 15:01:23 -0800114 for i in $(SUBDIRS); do \
Mike Frysinger121f3db2012-06-07 12:13:57 -0400115 $(MAKE) -C $$i; \
Gaurav Shah322536d2010-01-28 15:01:23 -0800116 done
117
Jay Srinivasan5fac7572012-02-23 10:59:01 -0800118libcgpt_cc:
Gabe Black0aedbe12012-12-20 00:26:59 -0800119 $(Q)mkdir -p ${BUILD}/cgpt ${BUILD}/firmware/lib/cgptlib ${BUILD}/firmware/stub
120 $(Q)$(MAKE) -C cgpt libcgpt_cc
Jay Srinivasan5fac7572012-02-23 10:59:01 -0800121
122cgptmanager_tests: libcgpt_cc
Gabe Black0aedbe12012-12-20 00:26:59 -0800123 $(Q)mkdir -p ${BUILD}/tests
124 $(Q)$(MAKE) -C tests cgptmanager_tests
Jay Srinivasan5fac7572012-02-23 10:59:01 -0800125
126libdump_kernel_config:
Gabe Black0aedbe12012-12-20 00:26:59 -0800127 $(Q)mkdir -p ${BUILD}/utility
128 $(Q)$(MAKE) -C utility $(DUMPKERNELCONFIGLIB)
Jay Srinivasan250549d2012-02-16 17:40:45 -0800129
Gaurav Shah322536d2010-01-28 15:01:23 -0800130clean:
Gabe Black0aedbe12012-12-20 00:26:59 -0800131 $(Q)/bin/rm -rf ${BUILD}
Bill Richardson371df8b2010-05-27 14:19:47 -0700132
133install:
Gabe Black0aedbe12012-12-20 00:26:59 -0800134 $(Q)$(MAKE) -C utility install
135 $(Q)$(MAKE) -C cgpt install
Gaurav Shahe6421982010-06-03 07:49:32 -0700136
137runtests:
Gabe Black0aedbe12012-12-20 00:26:59 -0800138 $(Q)$(MAKE) -C tests runtests
Luigi Semenzato18b814d2010-07-08 17:17:02 -0700139
Jay Srinivasan250549d2012-02-16 17:40:45 -0800140runcgptmanagertests:
Gabe Black0aedbe12012-12-20 00:26:59 -0800141 $(Q)$(MAKE) -C tests runcgptmanagertests
Jay Srinivasan250549d2012-02-16 17:40:45 -0800142
Luigi Semenzato18b814d2010-07-08 17:17:02 -0700143rbtest:
Gabe Black0aedbe12012-12-20 00:26:59 -0800144 $(Q)$(MAKE) -C tests rbtest
Bill Richardson856e0722011-02-07 15:39:45 -0800145
146runbmptests:
Gabe Black0aedbe12012-12-20 00:26:59 -0800147 $(Q)$(MAKE) -C tests runbmptests