This patch starts to add support for the VI APU in the KQ (kernel queue) module. Because most (more than 90%) of the KQ code is shared among AMD's APUs, we chose a design that performs most/all the code in the shared KQ file (kfd_kernel_queue.c). If there is H/W specific code to be executed, than it is written in an asic-specific extension function for that H/W. That asic-specific extension function is called from the shared function at the appropriate time. This requires that for every asic-specific extension function that is implemented in a specific ASIC, there will be an equivalent implementation in ALL ASICs, even if those implementations are just stubs. That way we achieve: - Maintainability: by having one copy of most of the code, we only need to fix bugs at one locations - Readability: very clear what is the shared code and what is done per ASIC - Extensibility: very easy to add new H/W specific files/functions Signed-off-by: Ben Goz <ben.goz@amd.com> Signed-off-by: Oded Gabbay <oded.gabbay@amd.com> Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
18 lines
623 B
Makefile
18 lines
623 B
Makefile
#
|
|
# Makefile for Heterogenous System Architecture support for AMD GPU devices
|
|
#
|
|
|
|
ccflags-y := -Iinclude/drm -Idrivers/gpu/drm/amd/include/
|
|
|
|
amdkfd-y := kfd_module.o kfd_device.o kfd_chardev.o kfd_topology.o \
|
|
kfd_pasid.o kfd_doorbell.o kfd_flat_memory.o \
|
|
kfd_process.o kfd_queue.o kfd_mqd_manager.o \
|
|
kfd_mqd_manager_cik.o kfd_mqd_manager_vi.o \
|
|
kfd_kernel_queue.o kfd_kernel_queue_cik.o \
|
|
kfd_kernel_queue_vi.o kfd_packet_manager.o \
|
|
kfd_process_queue_manager.o kfd_device_queue_manager.o \
|
|
kfd_device_queue_manager_cik.o kfd_device_queue_manager_vi.o \
|
|
kfd_interrupt.o
|
|
|
|
obj-$(CONFIG_HSA_AMD) += amdkfd.o
|