mirror of
https://github.com/Telecominfraproject/OpenCellular.git
synced 2025-12-28 10:45:22 +00:00
This copies the parts of sha256.c that we need from vboot_reference, and removes the explicit dependency on vboot_reference. That dependency was a good idea when we were doing full verified boot in the EC, but is now overkill and makes it harder for others to reuse the EC code. This also lets us call EC functions directly instead of needing vboot_stub.cc; that reduces code size by ~100 bytes. BUG=chrome-os-partner:15579 BRANCH=none TEST=vboot_hash ro, then compare with result of sha256sum build/link/ec.RO.flat Change-Id: I0f236174291df3e7f3c75e960fe9ab32af305a61 Signed-off-by: Randall Spangler <rspangler@chromium.org> Reviewed-on: https://gerrit.chromium.org/gerrit/36589 Reviewed-by: Bill Richardson <wfrichar@chromium.org>
57 lines
1.7 KiB
Makefile
57 lines
1.7 KiB
Makefile
# Copyright (c) 2011 The Chromium OS Authors. All rights reserved.
|
|
# Use of this source code is governed by a BSD-style license that can be
|
|
# found in the LICENSE file.
|
|
#
|
|
# Embedded Controller firmware build system
|
|
#
|
|
|
|
BOARD ?= bds
|
|
|
|
PROJECT?=ec
|
|
|
|
# output directory for build objects
|
|
out?=build/$(BOARD)
|
|
|
|
include Makefile.toolchain
|
|
|
|
# Get CHIP name
|
|
include board/$(BOARD)/build.mk
|
|
|
|
# Transform the configuration into make variables
|
|
includes=include core/$(CORE)/include $(dirs) $(out)
|
|
_tsk_lst:=$(shell echo "CONFIG_TASK_LIST" | $(CPP) -P -Iboard/$(BOARD) -Itest \
|
|
-D"TASK(n, r, d, s)=n" -imacros $(PROJECT).tasklist)
|
|
_tsk_cfg:=$(foreach t,$(_tsk_lst),CONFIG_TASK_$(t))
|
|
_flag_cfg:=$(shell $(CPP) $(CPPFLAGS) -P -dN chip/$(CHIP)/config.h | \
|
|
grep -o "CONFIG_.*") \
|
|
$(shell $(CPP) $(CPPFLAGS) -P -dN board/$(BOARD)/board.h | \
|
|
grep -o "CONFIG_.*")
|
|
$(foreach c,$(_tsk_cfg) $(_flag_cfg),$(eval $(c)=y))
|
|
CPPFLAGS+=$(foreach t,$(_tsk_cfg),-D$(t))
|
|
|
|
# Get build configuration from sub-directories
|
|
-include private/build.mk
|
|
include board/$(BOARD)/build.mk
|
|
include chip/$(CHIP)/build.mk
|
|
include core/$(CORE)/build.mk
|
|
include common/build.mk
|
|
include test/build.mk
|
|
include util/build.mk
|
|
include util/lock/build.mk
|
|
|
|
includes+=$(includes-y)
|
|
|
|
objs_from_dir=$(foreach obj, $($(2)-y), \
|
|
$(out)/$(1)/$(firstword $($(2)-mock-$(PROJECT)-$(obj)) $(obj)))
|
|
|
|
# Get all sources to build
|
|
all-y=$(call objs_from_dir,core/$(CORE),core)
|
|
all-y+=$(call objs_from_dir,chip/$(CHIP),chip)
|
|
all-y+=$(call objs_from_dir,board/$(BOARD),board)
|
|
all-y+=$(call objs_from_dir,private,private)
|
|
all-y+=$(call objs_from_dir,common,common)
|
|
all-y+=$(call objs_from_dir,test,$(PROJECT))
|
|
dirs=core/$(CORE) chip/$(CHIP) board/$(BOARD) private common test util
|
|
|
|
include Makefile.rules
|