########################################################################### ###
#@File           Makefile
#@Title
#@Copyright     Copyright (c) Innosilicon Technology Ltd. All Rights Reserved
#@Description
#@License       Dual MIT/GPLv2
#
# The contents of this file are subject to the MIT license as set out below.
#
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions:
#
# The above copyright notice and this permission notice shall be included in
# all copies or substantial portions of the Software.
#
# Alternatively, the contents of this file may be used under the terms of
# the GNU General Public License Version 2 ("GPL") in which case the provisions
# of GPL are applicable instead of those above.
#
# If you wish to allow use of your version of this file only under the terms of
# GPL, and not to allow others to use your version of this file under the terms
# of the MIT license, indicate your decision by deleting the provisions above
# and replace them with the notice and other provisions required by GPL as set
# out in the file called "GPL-COPYING" included in this distribution. If you do
# not delete the provisions above, a recipient may use your version of this file
# under the terms of either the MIT license or GPL.
#
# This License is also included in this distribution in the file called
# "MIT-COPYING".
#
# EXCEPT AS OTHERWISE STATED IN A NEGOTIATED AGREEMENT: (A) THE SOFTWARE IS
# PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
# BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
# PURPOSE AND NONINFRINGEMENT; AND (B) IN NO EVENT SHALL THE AUTHORS OR
# COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
# IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
# CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
### ###########################################################################

subdir-ccflags-y += \
	-I$(srctree)/$(src)/efuse \
	-I$(srctree)/$(src)/hal \
	-I$(srctree)/$(src)/pcie \
	-I$(srctree)/$(src)/../innodpu \
	-I$(srctree)/$(src)/../innosrvkm/kernel/drivers/staging/innosilicon \
	-I$(srctree)/$(src)/../innosrvkm/include/system/rgx_innogpu/soc \
	-I$(srctree)/$(src)/../innosrvkm/include \
	-I$(srctree)/$(src)/../innosrvkm/include/system/rgx_innogpu \
	-I$(srctree)/$(src)/../innodma/dmac \
	-I$(srctree)/$(src)/../innodma \
	-I$(srctree)/$(src)/../innosrvkm/include/volcanic/system/rgx_tc

       cpy_hal_regif.o = :
 quiet_cpy_hal_regif.o = echo '  CPY     $@'
silent_cpy_hal_regif.o = :

$(srctree)/$(src)/hal/hal_regif.o:
ifeq (,$(wildcard $(srctree)/$(src)/hal/hal_regif.c))
	@$($(quiet)cpy_hal_regif.o)

  ifeq ($(CONFIG_X86),y)
	$(Q)cp -f $(srctree)/$(src)/hal/hal_regif.o.x86.hex $(srctree)/$(src)/hal/hal_regif.o
  else ifeq ($(CONFIG_ARM),y)
	$(Q)cp -f $(srctree)/$(src)/hal/hal_regif.o.arm.hex $(srctree)/$(src)/hal/hal_regif.o
  else ifeq ($(CONFIG_ARM64),y)
	$(Q)cp -f $(srctree)/$(src)/hal/hal_regif.o.arm64.hex $(srctree)/$(src)/hal/hal_regif.o
  else ifeq ($(CONFIG_LOONGARCH),y)
	$(Q)cp -f $(srctree)/$(src)/hal/hal_regif.o.loongarch.hex $(srctree)/$(src)/hal/hal_regif.o
  else ifeq ($(CONFIG_RISCV),y)
	$(Q)cp -f $(srctree)/$(src)/hal/hal_regif.o.riscv.hex $(srctree)/$(src)/hal/hal_regif.o
  else ifeq ($(CONFIG_SW64),y)
	$(Q)cp -f $(srctree)/$(src)/hal/hal_regif.o.sw_64.hex $(srctree)/$(src)/hal/hal_regif.o
  endif
# else
#      $(CC) $(a_flags) $(subdir-ccflags-y) -c -o $(srctree)/$(src)/hal/hal_regif.o $(srctree)/$(src)/hal/hal_regif.c
endif

# efuse
# hal
# pcie
innogpu-objs += \
	efuse/efuse.o \
	efuse/innodpu_pmbus_cmd.o \
	hal/hal.o \
	hal/hal_irq.o \
	hal/hal_vram.o \
	hal/hal_regif.o \
	pcie/innogpu.o \
	pcie/innogpu_pci_drv.o \
	pcie/inno_system_pll.o

obj-$(CONFIG_GPU_INNO_INNOSILICON_PCI) += innogpu.o
