1a6ea06f5SAlexei Fedorov# 2a6ea06f5SAlexei Fedorov# Copyright (c) 2013-2020, Arm Limited and Contributors. All rights reserved. 3a6ea06f5SAlexei Fedorov# 4a6ea06f5SAlexei Fedorov# SPDX-License-Identifier: BSD-3-Clause 5a6ea06f5SAlexei Fedorov# 6a6ea06f5SAlexei Fedorov 7a6ea06f5SAlexei Fedorov# Default configuration values 8a6ea06f5SAlexei FedorovGICV3_IMPL ?= GIC500 9a6ea06f5SAlexei FedorovGICV3_IMPL_GIC600_MULTICHIP ?= 0 10a6ea06f5SAlexei FedorovGICV3_OVERRIDE_DISTIF_PWR_OPS ?= 0 11*8f3ad766SAlexei FedorovGIC_EXT_INTID ?= 0 12a6ea06f5SAlexei Fedorov 13*8f3ad766SAlexei FedorovGICV3_SOURCES += drivers/arm/gic/v3/gicv3_main.c \ 14a6ea06f5SAlexei Fedorov drivers/arm/gic/v3/gicv3_helpers.c \ 15a6ea06f5SAlexei Fedorov drivers/arm/gic/v3/gicdv3_helpers.c \ 16a6ea06f5SAlexei Fedorov drivers/arm/gic/v3/gicrv3_helpers.c 17a6ea06f5SAlexei Fedorov 18a6ea06f5SAlexei Fedorovifeq (${GICV3_OVERRIDE_DISTIF_PWR_OPS}, 0) 19a6ea06f5SAlexei FedorovGICV3_SOURCES += drivers/arm/gic/v3/arm_gicv3_common.c 20a6ea06f5SAlexei Fedorovendif 21a6ea06f5SAlexei Fedorov 22a6ea06f5SAlexei Fedorov# Either GIC-600 or GIC-500 can be selected at one time 23a6ea06f5SAlexei Fedorovifeq (${GICV3_IMPL}, GIC600) 24a6ea06f5SAlexei Fedorov# GIC-600 sources 25a6ea06f5SAlexei FedorovGICV3_SOURCES += drivers/arm/gic/v3/gic600.c 26a6ea06f5SAlexei Fedorovifeq (${GICV3_IMPL_GIC600_MULTICHIP}, 1) 27a6ea06f5SAlexei FedorovGICV3_SOURCES += drivers/arm/gic/v3/gic600_multichip.c 28a6ea06f5SAlexei Fedorovendif 29a6ea06f5SAlexei Fedorovelse ifeq (${GICV3_IMPL}, GIC500) 30a6ea06f5SAlexei Fedorov# GIC-500 sources 31a6ea06f5SAlexei FedorovGICV3_SOURCES += drivers/arm/gic/v3/gic500.c 32a6ea06f5SAlexei Fedorovelse 33a6ea06f5SAlexei Fedorov$(error "Incorrect GICV3_IMPL value ${GICV3_IMPL}") 34a6ea06f5SAlexei Fedorovendif 35*8f3ad766SAlexei Fedorov 36*8f3ad766SAlexei Fedorov# Set support for extended PPI and SPI range 37*8f3ad766SAlexei Fedorov$(eval $(call assert_boolean,GIC_EXT_INTID)) 38*8f3ad766SAlexei Fedorov$(eval $(call add_define,GIC_EXT_INTID)) 39