blob: 5ace6cc1b47898dcf36f25fb640d40532becd6ad [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001# SPDX-License-Identifier: GPL-2.0+
Michal Simek84c72042015-01-15 10:01:51 +01002#
Michal Simeke6a9ed02015-11-20 13:17:22 +01003# (C) Copyright 2014 - 2016 Xilinx, Inc.
Michal Simek84c72042015-01-15 10:01:51 +01004# Michal Simek <michal.simek@xilinx.com>
Michal Simek84c72042015-01-15 10:01:51 +01005
6obj-y := zynqmp.o
Michal Simek9755e3d2019-01-21 15:25:02 +01007obj-y += ../common/board.o
Michal Simeke6a9ed02015-11-20 13:17:22 +01008
Luca Ceresoli6da4f672018-06-22 12:40:16 +02009ifneq ($(CONFIG_XILINX_PS_INIT_FILE),"")
10PS_INIT_FILE := $(shell cd $(srctree); readlink -f $(CONFIG_XILINX_PS_INIT_FILE))
11init-objs := ps_init_gpl.o
12spl/board/xilinx/zynqmp/ps_init_gpl.o board/xilinx/zynqmp/ps_init_gpl.o: $(PS_INIT_FILE)
13 $(CC) $(c_flags) -I $(srctree)/$(src) -c -o $@ $^
14endif
Michal Simeke6a9ed02015-11-20 13:17:22 +010015
Luca Ceresoli6da4f672018-06-22 12:40:16 +020016ifeq ($(init-objs),)
17hw-platform-y :=$(shell echo $(CONFIG_DEFAULT_DEVICE_TREE))
Michal Simeke6a9ed02015-11-20 13:17:22 +010018init-objs := $(if $(wildcard $(srctree)/$(src)/$(hw-platform-y)/psu_init_gpl.c),\
19 $(hw-platform-y)/psu_init_gpl.o)
Luca Ceresoli6da4f672018-06-22 12:40:16 +020020endif
Michal Simeke6a9ed02015-11-20 13:17:22 +010021
22ifeq ($(init-objs),)
23ifneq ($(wildcard $(srctree)/$(src)/psu_init_gpl.c),)
24init-objs := psu_init_gpl.o
25$(if $(CONFIG_SPL_BUILD),\
26$(warning Put custom psu_init_gpl.c/h to board/xilinx/zynqmp/custom_hw_platform/))
27endif
28endif
29
Michal Simekfd1b6352017-07-12 13:21:27 +020030ifdef_any_of = $(filter-out undefined,$(foreach v,$(1),$(origin $(v))))
31
32ifneq ($(call ifdef_any_of, CONFIG_ZYNQMP_PSU_INIT_ENABLED CONFIG_SPL_BUILD),)
33obj-y += $(init-objs)
34endif
Michal Simeke6a9ed02015-11-20 13:17:22 +010035
Michal Simekcd228cc2019-07-30 17:07:27 +020036ifdef CONFIG_SPL_BUILD
Luca Ceresolic28a9cf2019-05-21 18:06:43 +020037ifneq ($(CONFIG_ZYNQMP_SPL_PM_CFG_OBJ_FILE),"")
38obj-$(CONFIG_SPL_BUILD) += pm_cfg_obj.o
39$(obj)/pm_cfg_obj.o: $(shell cd $(srctree); readlink -f $(CONFIG_ZYNQMP_SPL_PM_CFG_OBJ_FILE)) FORCE
40endif
Michal Simekcd228cc2019-07-30 17:07:27 +020041endif
Luca Ceresolic28a9cf2019-05-21 18:06:43 +020042
Siva Durga Prasad Paladugud1f4e392018-04-19 12:37:09 +053043obj-$(CONFIG_MMC_SDHCI_ZYNQ) += tap_delays.o
44
Siva Durga Prasad Paladuguc436bf92018-02-28 13:26:53 +053045ifndef CONFIG_SPL_BUILD
46obj-$(CONFIG_CMD_ZYNQMP) += cmds.o
47endif
48
Michal Simeke6a9ed02015-11-20 13:17:22 +010049# Suppress "warning: function declaration isn't a prototype"
50CFLAGS_REMOVE_psu_init_gpl.o := -Wstrict-prototypes
51
52# To include xil_io.h
53CFLAGS_psu_init_gpl.o := -I$(srctree)/$(src)
Michal Simekb6f40482016-07-14 11:13:04 +020054
55# To suppress "warning: cast to pointer from integer of different size"
56CFLAGS_psu_init_gpl.o += -Wno-int-to-pointer-cast