11a09120fSAlex Deucher# 21a09120fSAlex Deucher# Copyright 2017 Advanced Micro Devices, Inc. 31a09120fSAlex Deucher# 41a09120fSAlex Deucher# Permission is hereby granted, free of charge, to any person obtaining a 51a09120fSAlex Deucher# copy of this software and associated documentation files (the "Software"), 61a09120fSAlex Deucher# to deal in the Software without restriction, including without limitation 71a09120fSAlex Deucher# the rights to use, copy, modify, merge, publish, distribute, sublicense, 81a09120fSAlex Deucher# and/or sell copies of the Software, and to permit persons to whom the 91a09120fSAlex Deucher# Software is furnished to do so, subject to the following conditions: 101a09120fSAlex Deucher# 111a09120fSAlex Deucher# The above copyright notice and this permission notice shall be included in 121a09120fSAlex Deucher# all copies or substantial portions of the Software. 131a09120fSAlex Deucher# 141a09120fSAlex Deucher# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 151a09120fSAlex Deucher# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 161a09120fSAlex Deucher# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 171a09120fSAlex Deucher# THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR 181a09120fSAlex Deucher# OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 191a09120fSAlex Deucher# ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR 201a09120fSAlex Deucher# OTHER DEALINGS IN THE SOFTWARE. 211a09120fSAlex Deucher# 22d38ceaf9SAlex Deucher# 23d38ceaf9SAlex Deucher# Makefile for the drm device driver. This driver provides support for the 24d38ceaf9SAlex Deucher# Direct Rendering Infrastructure (DRI) in XFree86 4.1.0 and higher. 25d38ceaf9SAlex Deucher 2643068cb7SMasahiro YamadaFULL_AMD_PATH=$(srctree)/$(src)/.. 274562236bSHarry WentlandDISPLAY_FOLDER_NAME=display 284562236bSHarry WentlandFULL_AMD_DISPLAY_PATH = $(FULL_AMD_PATH)/$(DISPLAY_FOLDER_NAME) 29288912cbSJammy Zhou 30248a1d6fSMasahiro Yamadaccflags-y := -I$(FULL_AMD_PATH)/include/asic_reg \ 31288912cbSJammy Zhou -I$(FULL_AMD_PATH)/include \ 32288912cbSJammy Zhou -I$(FULL_AMD_PATH)/amdgpu \ 33e098bc96SEvan Quan -I$(FULL_AMD_PATH)/pm/inc \ 344562236bSHarry Wentland -I$(FULL_AMD_PATH)/acp/include \ 354562236bSHarry Wentland -I$(FULL_AMD_DISPLAY_PATH) \ 364562236bSHarry Wentland -I$(FULL_AMD_DISPLAY_PATH)/include \ 374562236bSHarry Wentland -I$(FULL_AMD_DISPLAY_PATH)/dc \ 3804d5e276SAmber Lin -I$(FULL_AMD_DISPLAY_PATH)/amdgpu_dm \ 3904d5e276SAmber Lin -I$(FULL_AMD_PATH)/amdkfd 40d38ceaf9SAlex Deucher 41d38ceaf9SAlex Deucheramdgpu-y := amdgpu_drv.o 42d38ceaf9SAlex Deucher 43d38ceaf9SAlex Deucher# add KMS driver 44d38ceaf9SAlex Deucheramdgpu-y += amdgpu_device.o amdgpu_kms.o \ 45d38ceaf9SAlex Deucher amdgpu_atombios.o atombios_crtc.o amdgpu_connectors.o \ 46d38ceaf9SAlex Deucher atom.o amdgpu_fence.o amdgpu_ttm.o amdgpu_object.o amdgpu_gart.o \ 47d38ceaf9SAlex Deucher amdgpu_encoders.o amdgpu_display.o amdgpu_i2c.o \ 48d38ceaf9SAlex Deucher amdgpu_fb.o amdgpu_gem.o amdgpu_ring.o \ 49d38ceaf9SAlex Deucher amdgpu_cs.o amdgpu_bios.o amdgpu_benchmark.o amdgpu_test.o \ 50e098bc96SEvan Quan atombios_dp.o amdgpu_afmt.o amdgpu_trace_points.o \ 512f4b9400SChunming Zhou atombios_encoders.o amdgpu_sa.o atombios_i2c.o \ 522fbd6f94SChristian König amdgpu_dma_buf.o amdgpu_vm.o amdgpu_ib.o amdgpu_pll.o \ 53bb990bb0SChristian König amdgpu_ucode.o amdgpu_bo_list.o amdgpu_ctx.o amdgpu_sync.o \ 54b453e42aSFelix Kuehling amdgpu_gtt_mgr.o amdgpu_preempt_mgr.o amdgpu_vram_mgr.o amdgpu_virt.o \ 55b453e42aSFelix Kuehling amdgpu_atomfirmware.o amdgpu_vf_error.o amdgpu_sched.o \ 56b453e42aSFelix Kuehling amdgpu_debugfs.o amdgpu_ids.o amdgpu_gmc.o amdgpu_mmhub.o \ 57b453e42aSFelix Kuehling amdgpu_xgmi.o amdgpu_csa.o amdgpu_ras.o amdgpu_vm_cpu.o \ 58128a01f4SArnd Bergmann amdgpu_vm_sdma.o amdgpu_discovery.o amdgpu_ras_eeprom.o amdgpu_nbio.o \ 5919ae3330SJohn Clements amdgpu_umc.o smu_v11_0_i2c.o amdgpu_fru_eeprom.o amdgpu_rap.o \ 6000e3a289SAlex Deucher amdgpu_fw_attestation.o amdgpu_securedisplay.o amdgpu_hdp.o \ 61*3907c492SJohn Clements amdgpu_eeprom.o amdgpu_mca.o 62d155bef0SArnd Bergmann 6387444254SRoy Sunamdgpu-$(CONFIG_PROC_FS) += amdgpu_fdinfo.o 6487444254SRoy Sun 65d155bef0SArnd Bergmannamdgpu-$(CONFIG_PERF_EVENTS) += amdgpu_pmu.o 66d38ceaf9SAlex Deucher 67aaa36a97SAlex Deucher# add asic specific block 68e098bc96SEvan Quanamdgpu-$(CONFIG_DRM_AMDGPU_CIK)+= cik.o cik_ih.o \ 69bc4b539eSAlex Deucher dce_v8_0.o gfx_v7_0.o cik_sdma.o uvd_v4_2.o vce_v2_0.o 70a2e73f56SAlex Deucher 71e098bc96SEvan Quanamdgpu-$(CONFIG_DRM_AMDGPU_SI)+= si.o gmc_v6_0.o gfx_v6_0.o si_ih.o si_dma.o dce_v6_0.o \ 7274df08fdSSonny Jiang uvd_v3_1.o 73a036db18SKen Wang 74aaa36a97SAlex Deucheramdgpu-y += \ 758ee273e5SFeifei Xu vi.o mxgpu_vi.o nbio_v6_1.o soc15.o emu_soc.o mxgpu_ai.o nbio_v7_0.o vega10_reg_init.o \ 76e78705ecSLe Ma vega20_reg_init.o nbio_v7_4.o nbio_v2_3.o nv.o navi10_reg_init.o navi14_reg_init.o \ 77a7e91bd7SHuang Rui arct_reg_init.o navi12_reg_init.o mxgpu_nv.o sienna_cichlid_reg_init.o vangogh_reg_init.o \ 78fd5b4b44SChengming Gui nbio_v7_2.o dimgrey_cavefish_reg_init.o hdp_v4_0.o hdp_v5_0.o aldebaran_reg_init.o aldebaran.o \ 7970839197STao Zhou beige_goby_reg_init.o yellow_carp_reg_init.o cyan_skillfish_reg_init.o 80aaa36a97SAlex Deucher 81d99605eaSHawking Zhang# add DF block 82d99605eaSHawking Zhangamdgpu-y += \ 8313b58150SFeifei Xu df_v1_7.o \ 8413b58150SFeifei Xu df_v3_6.o 85d99605eaSHawking Zhang 86aaa36a97SAlex Deucher# add GMC block 87aaa36a97SAlex Deucheramdgpu-y += \ 88e42d8526SAlex Deucher gmc_v7_0.o \ 89e60f8db5SAlex Xie gmc_v8_0.o \ 902cb2ea1eSLe Ma gfxhub_v1_0.o mmhub_v1_0.o gmc_v9_0.o gfxhub_v1_1.o mmhub_v9_4.o \ 91f37945d5SLe Ma gfxhub_v2_0.o mmhub_v2_0.o gmc_v10_0.o gfxhub_v2_1.o mmhub_v2_3.o \ 92f37945d5SLe Ma mmhub_v1_7.o 93aaa36a97SAlex Deucher 949884c2b1SHawking Zhang# add UMC block 959884c2b1SHawking Zhangamdgpu-y += \ 961696bf35SHawking Zhang umc_v6_0.o umc_v6_1.o umc_v6_7.o umc_v8_7.o 979884c2b1SHawking Zhang 98d38ceaf9SAlex Deucher# add IH block 99d38ceaf9SAlex Deucheramdgpu-y += \ 100d38ceaf9SAlex Deucher amdgpu_irq.o \ 101aaa36a97SAlex Deucher amdgpu_ih.o \ 102aaa36a97SAlex Deucher iceland_ih.o \ 103aaa36a97SAlex Deucher tonga_ih.o \ 104282aae55SKen Wang cz_ih.o \ 105edc61147SHawking Zhang vega10_ih.o \ 106bebd4c79SHawking Zhang vega20_ih.o \ 107edc61147SHawking Zhang navi10_ih.o 108d38ceaf9SAlex Deucher 1090e5ca0d1SHuang Rui# add PSP block 1100e5ca0d1SHuang Ruiamdgpu-y += \ 1110e5ca0d1SHuang Rui amdgpu_psp.o \ 112fd341dc5SHuang Rui psp_v3_1.o \ 113654f761cSFeifei Xu psp_v10_0.o \ 1146a7a0bdbSAaron Liu psp_v11_0.o \ 115e330a68fSLang Yu psp_v11_0_8.o \ 116742d3c61SHawking Zhang psp_v12_0.o \ 117742d3c61SHawking Zhang psp_v13_0.o 1180e5ca0d1SHuang Rui 119aaa36a97SAlex Deucher# add DCE block 120aaa36a97SAlex Deucheramdgpu-y += \ 121aaa36a97SAlex Deucher dce_v10_0.o \ 122c6e14f40SEmily Deng dce_v11_0.o \ 123733ee71aSRyan Taylor amdgpu_vkms.o 124d38ceaf9SAlex Deucher 125d38ceaf9SAlex Deucher# add GFX block 126d38ceaf9SAlex Deucheramdgpu-y += \ 127aaa36a97SAlex Deucher amdgpu_gfx.o \ 12888dfc9a3SLikun Gao amdgpu_rlc.o \ 129b1023571SKen Wang gfx_v8_0.o \ 130a644d85aSHawking Zhang gfx_v9_0.o \ 1314c461d89SDennis Li gfx_v9_4.o \ 13216171a25SJonathan Kim gfx_v9_4_2.o \ 133a644d85aSHawking Zhang gfx_v10_0.o 134aaa36a97SAlex Deucher 135aaa36a97SAlex Deucher# add async DMA block 136aaa36a97SAlex Deucheramdgpu-y += \ 137bb7743bcSHuang Rui amdgpu_sdma.o \ 138aaa36a97SAlex Deucher sdma_v2_4.o \ 1392130f89cSKen Wang sdma_v3_0.o \ 140fef6e24cSHawking Zhang sdma_v4_0.o \ 1412fdb91a2SHawking Zhang sdma_v4_4.o \ 142157e72e8SLikun Gao sdma_v5_0.o \ 143157e72e8SLikun Gao sdma_v5_2.o 144d38ceaf9SAlex Deucher 145886f82aaSJack Xiao# add MES block 146886f82aaSJack Xiaoamdgpu-y += \ 147886f82aaSJack Xiao mes_v10_1.o 148886f82aaSJack Xiao 149d38ceaf9SAlex Deucher# add UVD block 150d38ceaf9SAlex Deucheramdgpu-y += \ 151aaa36a97SAlex Deucher amdgpu_uvd.o \ 152aaa36a97SAlex Deucher uvd_v5_0.o \ 15309bfb891SLeo Liu uvd_v6_0.o \ 15409bfb891SLeo Liu uvd_v7_0.o 155d38ceaf9SAlex Deucher 156d38ceaf9SAlex Deucher# add VCE block 157d38ceaf9SAlex Deucheramdgpu-y += \ 158aaa36a97SAlex Deucher amdgpu_vce.o \ 159c1dc356aSLeo Liu vce_v3_0.o \ 160c1dc356aSLeo Liu vce_v4_0.o 161d38ceaf9SAlex Deucher 1629d9cc9b8SLeo Liu# add VCN and JPEG block 16395d0906fSLeo Liuamdgpu-y += \ 16488b5af70SLeo Liu amdgpu_vcn.o \ 1651b61de45SLeo Liu vcn_v1_0.o \ 16628c17d72SLeo Liu vcn_v2_0.o \ 1679d9cc9b8SLeo Liu vcn_v2_5.o \ 168cf14826cSLeo Liu vcn_v3_0.o \ 169bb0db70fSLeo Liu amdgpu_jpeg.o \ 1706ac27241SLeo Liu jpeg_v1_0.o \ 17114f43e8fSLeo Liu jpeg_v2_0.o \ 172dfd57dbfSLeo Liu jpeg_v2_5.o \ 173dfd57dbfSLeo Liu jpeg_v3_0.o 17495d0906fSLeo Liu 175367adb2aSJack Xiao# add ATHUB block 176367adb2aSJack Xiaoamdgpu-y += \ 177bee7b51aSLe Ma athub_v1_0.o \ 17845d76eebSLikun Gao athub_v2_0.o \ 17945d76eebSLikun Gao athub_v2_1.o 180367adb2aSJack Xiao 18109aac699SHawking Zhang# add SMUIO block 18209aac699SHawking Zhangamdgpu-y += \ 183d1ffa512SHawking Zhang smuio_v9_0.o \ 1841deb9853SLikun Gao smuio_v11_0.o \ 1852e8c66d6SHawking Zhang smuio_v11_0_6.o \ 1862e8c66d6SHawking Zhang smuio_v13_0.o 18709aac699SHawking Zhang 188e071dce3SLijo Lazar# add reset block 189e071dce3SLijo Lazaramdgpu-y += \ 190e071dce3SLijo Lazar amdgpu_reset.o 191e071dce3SLijo Lazar 192*3907c492SJohn Clements# add MCA block 193*3907c492SJohn Clementsamdgpu-y += \ 194*3907c492SJohn Clements mca_v3_0.o 195*3907c492SJohn Clements 196130e0371SOded Gabbay# add amdkfd interfaces 197fcdfa432SOded Gabbayamdgpu-y += amdgpu_amdkfd.o 198fcdfa432SOded Gabbay 199e071dce3SLijo Lazar 200fcdfa432SOded Gabbayifneq ($(CONFIG_HSA_AMD),) 20104d5e276SAmber LinAMDKFD_PATH := ../amdkfd 20204d5e276SAmber Lininclude $(FULL_AMD_PATH)/amdkfd/Makefile 20304d5e276SAmber Linamdgpu-y += $(AMDKFD_FILES) 204130e0371SOded Gabbayamdgpu-y += \ 205d8d019ccSFelix Kuehling amdgpu_amdkfd_fence.o \ 206a46a2cd1SFelix Kuehling amdgpu_amdkfd_gpuvm.o \ 207d5a114a6SFelix Kuehling amdgpu_amdkfd_gfx_v8.o \ 2086bdadb20SHawking Zhang amdgpu_amdkfd_gfx_v9.o \ 2093e205a08SOak Zeng amdgpu_amdkfd_arcturus.o \ 2105073506cSJonathan Kim amdgpu_amdkfd_aldebaran.o \ 2113a2f0c81SYong Zhao amdgpu_amdkfd_gfx_v10.o \ 2123a2f0c81SYong Zhao amdgpu_amdkfd_gfx_v10_3.o 213130e0371SOded Gabbay 214fcdfa432SOded Gabbayifneq ($(CONFIG_DRM_AMDGPU_CIK),) 215fcdfa432SOded Gabbayamdgpu-y += amdgpu_amdkfd_gfx_v7.o 216fcdfa432SOded Gabbayendif 217fcdfa432SOded Gabbay 218fcdfa432SOded Gabbayendif 219fcdfa432SOded Gabbay 220d03846afSChunming Zhou# add cgs 221d03846afSChunming Zhouamdgpu-y += amdgpu_cgs.o 222d03846afSChunming Zhou 223b80d8475SAlex Deucher# GPU scheduler 2241b1f42d8SLucas Stachamdgpu-y += amdgpu_job.o 225b80d8475SAlex Deucher 226a8fe58ceSMaruthi Bayyavarapu# ACP componet 227a8fe58ceSMaruthi Bayyavarapuifneq ($(CONFIG_DRM_AMD_ACP),) 228a8fe58ceSMaruthi Bayyavarapuamdgpu-y += amdgpu_acp.o 229a8fe58ceSMaruthi Bayyavarapu 230a8fe58ceSMaruthi BayyavarapuAMDACPPATH := ../acp 231a8fe58ceSMaruthi Bayyavarapuinclude $(FULL_AMD_PATH)/acp/Makefile 232a8fe58ceSMaruthi Bayyavarapu 233a8fe58ceSMaruthi Bayyavarapuamdgpu-y += $(AMD_ACP_FILES) 234a8fe58ceSMaruthi Bayyavarapuendif 235a8fe58ceSMaruthi Bayyavarapu 236d38ceaf9SAlex Deucheramdgpu-$(CONFIG_COMPAT) += amdgpu_ioc32.o 237d38ceaf9SAlex Deucheramdgpu-$(CONFIG_VGA_SWITCHEROO) += amdgpu_atpx_handler.o 238d38ceaf9SAlex Deucheramdgpu-$(CONFIG_ACPI) += amdgpu_acpi.o 2392c5a51f5SPhilip Yangamdgpu-$(CONFIG_HMM_MIRROR) += amdgpu_mn.o 240d38ceaf9SAlex Deucher 241e098bc96SEvan Quaninclude $(FULL_AMD_PATH)/pm/Makefile 2421f7371b2SAlex Deucher 2431f7371b2SAlex Deucheramdgpu-y += $(AMD_POWERPLAY_FILES) 2441f7371b2SAlex Deucher 2454562236bSHarry Wentlandifneq ($(CONFIG_DRM_AMD_DC),) 2464562236bSHarry Wentland 2474562236bSHarry WentlandRELATIVE_AMD_DISPLAY_PATH = ../$(DISPLAY_FOLDER_NAME) 2484562236bSHarry Wentlandinclude $(FULL_AMD_DISPLAY_PATH)/Makefile 2494562236bSHarry Wentland 2504562236bSHarry Wentlandamdgpu-y += $(AMD_DISPLAY_FILES) 2514562236bSHarry Wentland 2524562236bSHarry Wentlandendif 2534562236bSHarry Wentland 254d38ceaf9SAlex Deucherobj-$(CONFIG_DRM_AMDGPU)+= amdgpu.o 255