xref: /linux/drivers/gpu/drm/i915/Makefile (revision deb879faa9d2f327ac5c079d9d1a1747b79260e3)
1b2441318SGreg Kroah-Hartman# SPDX-License-Identifier: GPL-2.0
2c0e09200SDave Airlie#
3c0e09200SDave Airlie# Makefile for the drm device driver.  This driver provides support for the
4c0e09200SDave Airlie# Direct Rendering Infrastructure (DRI) in XFree86 4.1.0 and higher.
5c0e09200SDave Airlie
6dd3cac0aSJani Nikula# Enable W=1 warnings not enabled in drm subsystem Makefile
72250c7eaSJani Nikulasubdir-ccflags-y += $(call cc-option, -Wformat-truncation)
82250c7eaSJani Nikula
92250c7eaSJani Nikula# Enable -Werror in CI and development
1039bf4de8SChris Wilsonsubdir-ccflags-$(CONFIG_DRM_I915_WERROR) += -Werror
1139bf4de8SChris Wilson
12a4ba1ea6SJani Nikula# Support compiling the display code separately for both i915 and xe
13a4ba1ea6SJani Nikula# drivers. Define I915 when building i915.
14a4ba1ea6SJani Nikulasubdir-ccflags-y += -DI915
15a4ba1ea6SJani Nikula
16ed1fbee3SMaarten Lankhorst# FIXME: Disable tracepoints on i915 for PREEMPT_RT, unfortunately
17ed1fbee3SMaarten Lankhorst# it's an all or nothing flag. You cannot selectively disable
18ed1fbee3SMaarten Lankhorst# only some tracepoints.
19ed1fbee3SMaarten Lankhorstsubdir-ccflags-$(CONFIG_PREEMPT_RT) += -DNOTRACE
20ed1fbee3SMaarten Lankhorst
21b1992c37SMasahiro Yamadasubdir-ccflags-y += -I$(src)
22112ed2d3SChris Wilson
232fae6a86SDaniel Vetter# Please keep these build lists sorted!
242fae6a86SDaniel Vetter
252fae6a86SDaniel Vetter# core driver code
260db5649eSJani Nikulai915-y += \
2716dc224fSChris Wilson	i915_config.o \
280db5649eSJani Nikula	i915_driver.o \
290db5649eSJani Nikula	i915_drm_client.o \
3026f00514SChris Wilson	i915_getparam.o \
31198bca93SJani Nikula	i915_ioctl.o \
32198bca93SJani Nikula	i915_irq.o \
33f7452c7cSChris Wilson	i915_mitigations.o \
3427e21516SMatt Atwood	i915_mmio_range.o \
35708b7df3SDaniel Vetter	i915_module.o \
362fae6a86SDaniel Vetter	i915_params.o \
3742f5551dSChris Wilson	i915_pci.o \
3837d63f8fSChris Wilson	i915_scatterlist.o \
3963bf8301SJani Nikula	i915_switcheroo.o \
402fae6a86SDaniel Vetter	i915_sysfs.o \
41df7d085bSJani Nikula	i915_timer_util.o \
42358c855cSJani Nikula	i915_utils.o \
43d670c78eSJani Nikula	intel_clock_gating.o \
44d58db10eSRaag Jadav	intel_cpu_info.o \
4594b4f3baSChris Wilson	intel_device_info.o \
46232a6ebaSMatthew Auld	intel_memory_region.o \
474dd4375bSJani Nikula	intel_pcode.o \
48d1487389SThomas Hellström	intel_region_ttm.o \
497d3c425fSOscar Mateo	intel_runtime_pm.o \
507eb186bbSJani Nikula	intel_step.o \
51df0566a6SJani Nikula	intel_uncore.o \
5217d70726SJani Nikula	intel_uncore_trace.o \
53fb5f432aSJani Nikula	intel_wakeref.o \
546819b5a6SJani Nikula	vlv_iosf_sb.o \
55fb5f432aSJani Nikula	vlv_suspend.o
56112ed2d3SChris Wilson
57f052febdSJani Nikula# core peripheral code
58f052febdSJani Nikulai915-y += \
59f052febdSJani Nikula	soc/intel_dram.o \
60a13144e2SJani Nikula	soc/intel_gmch.o \
61e6229050SVille Syrjälä	soc/intel_rom.o
62f052febdSJani Nikula
63112ed2d3SChris Wilson# core library code
64112ed2d3SChris Wilsoni915-y += \
65112ed2d3SChris Wilson	i915_memcpy.o \
66112ed2d3SChris Wilson	i915_mm.o \
67112ed2d3SChris Wilson	i915_sw_fence.o \
688e458fe2SChris Wilson	i915_sw_fence_work.o \
69112ed2d3SChris Wilson	i915_syncmap.o \
70112ed2d3SChris Wilson	i915_user_extensions.o
719c065a7dSDaniel Vetter
720db5649eSJani Nikulai915-$(CONFIG_COMPAT) += \
730db5649eSJani Nikula	i915_ioc32.o
74c43c5a88SJani Nikulai915-$(CONFIG_DEBUG_FS) += \
75c43c5a88SJani Nikula	i915_debugfs.o \
7675658332SJani Nikula	i915_debugfs_params.o
770db5649eSJani Nikulai915-$(CONFIG_PERF_EVENTS) += \
780db5649eSJani Nikula	i915_pmu.o
792fae6a86SDaniel Vetter
80112ed2d3SChris Wilson# "Graphics Technology" (aka we talk to the gpu)
81112ed2d3SChris Wilsongt-y += \
82c1f85878SChris Wilson	gt/gen2_engine_cs.o \
83c1f85878SChris Wilson	gt/gen6_engine_cs.o \
842c86e55dSMatthew Auld	gt/gen6_ppgtt.o \
8547f8253dSPrathap Kumar Valsan	gt/gen7_renderclear.o \
86d0d829e5SDaniele Ceraolo Spurio	gt/gen8_engine_cs.o \
872c86e55dSMatthew Auld	gt/gen8_ppgtt.o \
88112ed2d3SChris Wilson	gt/intel_breadcrumbs.o \
89112ed2d3SChris Wilson	gt/intel_context.o \
90b4d3acaaSChris Wilson	gt/intel_context_sseu.o \
91112ed2d3SChris Wilson	gt/intel_engine_cs.o \
92b5e8e954SChris Wilson	gt/intel_engine_heartbeat.o \
9379ffac85SChris Wilson	gt/intel_engine_pm.o \
94750e76b4SChris Wilson	gt/intel_engine_user.o \
9570a2b431SChris Wilson	gt/intel_execlists_submission.o \
962c86e55dSMatthew Auld	gt/intel_ggtt.o \
97f899f786SChris Wilson	gt/intel_ggtt_fencing.o \
9824635c51STvrtko Ursulin	gt/intel_gt.o \
9916e87459SChris Wilson	gt/intel_gt_buffer_pool.o \
1006db31251SAndi Shyti	gt/intel_gt_ccs_mode.o \
1019c878557SChris Wilson	gt/intel_gt_clock_utils.o \
102022f324cSLucas De Marchi	gt/intel_gt_debugfs.o \
10300142bceSLucas De Marchi	gt/intel_gt_engines_debugfs.o \
104cf1c97dcSAndi Shyti	gt/intel_gt_irq.o \
105e7858254SMatt Roper	gt/intel_gt_mcr.o \
10679ffac85SChris Wilson	gt/intel_gt_pm.o \
10723f6a829SLucas De Marchi	gt/intel_gt_pm_debugfs.o \
108d762043fSAndi Shyti	gt/intel_gt_pm_irq.o \
10966101975SChris Wilson	gt/intel_gt_requests.o \
110b770bcfaSAndi Shyti	gt/intel_gt_sysfs.o \
11180cf8af1SAndi Shyti	gt/intel_gt_sysfs_pm.o \
1122c86e55dSMatthew Auld	gt/intel_gtt.o \
1130dc3c562SAndi Shyti	gt/intel_llc.o \
114112ed2d3SChris Wilson	gt/intel_lrc.o \
115cf586021SChris Wilson	gt/intel_migrate.o \
1162871ea85SChris Wilson	gt/intel_mocs.o \
1172c86e55dSMatthew Auld	gt/intel_ppgtt.o \
118c1132367SAndi Shyti	gt/intel_rc6.o \
119f178b897SMatthew Auld	gt/intel_region_lmem.o \
1202006058eSChris Wilson	gt/intel_renderstate.o \
121112ed2d3SChris Wilson	gt/intel_reset.o \
1222871ea85SChris Wilson	gt/intel_ring.o \
1232871ea85SChris Wilson	gt/intel_ring_submission.o \
1243e7abf81SAndi Shyti	gt/intel_rps.o \
125f0e2f00cSMatt Roper	gt/intel_sa_media.o \
126112ed2d3SChris Wilson	gt/intel_sseu.o \
127a00eda7dSDaniele Ceraolo Spurio	gt/intel_sseu_debugfs.o \
128f0c02c1bSTvrtko Ursulin	gt/intel_timeline.o \
129568a2e6fSChris Wilson	gt/intel_tlb.o \
130ee71434eSAravind Iddamsetty	gt/intel_wopcm.o \
1314ec76dbeSChris Wilson	gt/intel_workarounds.o \
132be1cb55aSChris Wilson	gt/shmem_utils.o \
1334ec76dbeSChris Wilson	gt/sysfs_engines.o
134ee71434eSAravind Iddamsetty
1357a5c9223SCasey Bowman# x86 intel-gtt module support
1360db5649eSJani Nikulagt-$(CONFIG_X86) += \
1370db5649eSJani Nikula	gt/intel_ggtt_gmch.o
1382006058eSChris Wilson# autogenerated null render state
1392006058eSChris Wilsongt-y += \
1402006058eSChris Wilson	gt/gen6_renderstate.o \
1412006058eSChris Wilson	gt/gen7_renderstate.o \
1422006058eSChris Wilson	gt/gen8_renderstate.o \
1432006058eSChris Wilson	gt/gen9_renderstate.o
144112ed2d3SChris Wilsoni915-y += $(gt-y)
145112ed2d3SChris Wilson
146112ed2d3SChris Wilson# GEM (Graphics Execution Management) code
14798932149SChris Wilsongem-y += \
1483f43c876SChris Wilson	gem/i915_gem_busy.o \
14910be98a7SChris Wilson	gem/i915_gem_clflush.o \
15010be98a7SChris Wilson	gem/i915_gem_context.o \
151dcaccaf0SMatthew Auld	gem/i915_gem_create.o \
15210be98a7SChris Wilson	gem/i915_gem_dmabuf.o \
153f0e4a063SChris Wilson	gem/i915_gem_domain.o \
15410be98a7SChris Wilson	gem/i915_gem_execbuffer.o \
15510be98a7SChris Wilson	gem/i915_gem_internal.o \
156b908be54SMatthew Auld	gem/i915_gem_lmem.o \
157b414fcd5SChris Wilson	gem/i915_gem_mman.o \
1580db5649eSJani Nikula	gem/i915_gem_object.o \
15996593096SVille Syrjälä	gem/i915_gem_object_frontbuffer.o \
160f033428dSChris Wilson	gem/i915_gem_pages.o \
161f033428dSChris Wilson	gem/i915_gem_phys.o \
16210be98a7SChris Wilson	gem/i915_gem_pm.o \
163232a6ebaSMatthew Auld	gem/i915_gem_region.o \
16410be98a7SChris Wilson	gem/i915_gem_shmem.o \
16510be98a7SChris Wilson	gem/i915_gem_shrinker.o \
16610be98a7SChris Wilson	gem/i915_gem_stolen.o \
167446e2d16SChris Wilson	gem/i915_gem_throttle.o \
16810be98a7SChris Wilson	gem/i915_gem_tiling.o \
169213d5092SThomas Hellström	gem/i915_gem_ttm.o \
1703589fdbdSThomas Hellström	gem/i915_gem_ttm_move.o \
171c56ce956SThomas Hellström	gem/i915_gem_ttm_pm.o \
17210be98a7SChris Wilson	gem/i915_gem_userptr.o \
173d45a1a53SChris Wilson	gem/i915_gem_wait.o \
17410be98a7SChris Wilson	gem/i915_gemfs.o
17564d6c500SChris Wilsoni915-y += \
17698932149SChris Wilson	$(gem-y) \
17764d6c500SChris Wilson	i915_active.o \
17864d6c500SChris Wilson	i915_cmd_parser.o \
17963cf4cadSThomas Hellström	i915_deps.o \
1800db5649eSJani Nikula	i915_gem.o \
181b47eb4a2SChris Wilson	i915_gem_evict.o \
18254cf91dcSChris Wilson	i915_gem_gtt.o \
1835c43ec5dSThomas Hellström	i915_gem_ww.o \
184a446ae2cSLionel Landwerlin	i915_query.o \
185e61e0f51SChris Wilson	i915_request.o \
186e2f3496eSChris Wilson	i915_scheduler.o \
1871c5d22f7SChris Wilson	i915_trace_points.o \
18888be9a0aSMatthew Auld	i915_ttm_buddy_manager.o \
189b42fe9caSJoonas Lahtinen	i915_vma.o \
190ee71434eSAravind Iddamsetty	i915_vma_resource.o
1912fae6a86SDaniel Vetter
19233a732f4SAlex Dai# general-purpose microcontroller (GuC) support
193242c4b91SDaniele Ceraolo Spurioi915-y += \
19415bd4a67SDaniele Ceraolo Spurio	gt/uc/intel_gsc_fw.o \
1958a9bf295SDaniele Ceraolo Spurio	gt/uc/intel_gsc_proxy.o \
196242c4b91SDaniele Ceraolo Spurio	gt/uc/intel_gsc_uc.o \
197561055b8SDaniele Ceraolo Spurio	gt/uc/intel_gsc_uc_debugfs.o \
198459b2606SSuraj Kandpal	gt/uc/intel_gsc_uc_heci_cmd_submit.o\
1990f261b24SDaniele Ceraolo Spurio	gt/uc/intel_guc.o \
2000f261b24SDaniele Ceraolo Spurio	gt/uc/intel_guc_ads.o \
20124492514SAlan Previn	gt/uc/intel_guc_capture.o \
2020f261b24SDaniele Ceraolo Spurio	gt/uc/intel_guc_ct.o \
203293a5548SDaniele Ceraolo Spurio	gt/uc/intel_guc_debugfs.o \
2040f261b24SDaniele Ceraolo Spurio	gt/uc/intel_guc_fw.o \
2058781f051SJohn Harrison	gt/uc/intel_guc_hwconfig.o \
2060f261b24SDaniele Ceraolo Spurio	gt/uc/intel_guc_log.o \
207293a5548SDaniele Ceraolo Spurio	gt/uc/intel_guc_log_debugfs.o \
208216d56c5SVinay Belgaumkar	gt/uc/intel_guc_rc.o \
209dff0fc49SVinay Belgaumkar	gt/uc/intel_guc_slpc.o \
2100f261b24SDaniele Ceraolo Spurio	gt/uc/intel_guc_submission.o \
2110f261b24SDaniele Ceraolo Spurio	gt/uc/intel_huc.o \
212293a5548SDaniele Ceraolo Spurio	gt/uc/intel_huc_debugfs.o \
213242c4b91SDaniele Ceraolo Spurio	gt/uc/intel_huc_fw.o \
214242c4b91SDaniele Ceraolo Spurio	gt/uc/intel_uc.o \
215242c4b91SDaniele Ceraolo Spurio	gt/uc/intel_uc_debugfs.o \
216242c4b91SDaniele Ceraolo Spurio	gt/uc/intel_uc_fw.o
21733a732f4SAlex Dai
2181e3dc1d8STomas Winkler# graphics system controller (GSC) support
2190db5649eSJani Nikulai915-y += \
2200db5649eSJani Nikula	gt/intel_gsc.o
2211e3dc1d8STomas Winkler
222b3b088e2SDale B Stimson# graphics hardware monitoring (HWMON) support
2230db5649eSJani Nikulai915-$(CONFIG_HWMON) += \
2240db5649eSJani Nikula	i915_hwmon.o
225b3b088e2SDale B Stimson
2262fae6a86SDaniel Vetter# modesetting core code
227df0566a6SJani Nikulai915-y += \
228f3b603deSVille Syrjälä	display/hsw_ips.o \
229c3bda715SRodrigo Vivi	display/i9xx_display_sr.o \
230a649c2abSJani Nikula	display/i9xx_plane.o \
2310db5649eSJani Nikula	display/i9xx_wm.o \
2328bdbde7cSAnimesh Manna	display/intel_alpm.o \
233df0566a6SJani Nikula	display/intel_atomic.o \
234df0566a6SJani Nikula	display/intel_audio.o \
235df0566a6SJani Nikula	display/intel_bios.o \
23617cd58a8SJani Nikula	display/intel_bo.o \
237df0566a6SJani Nikula	display/intel_bw.o \
23874ad9ec9SNemesa Garg	display/intel_casf.o \
239df0566a6SJani Nikula	display/intel_cdclk.o \
240f14d81b7SGustavo Sousa	display/intel_cmtg.o \
241df0566a6SJani Nikula	display/intel_color.o \
2423e9b0655SChaitanya Kumar Borah	display/intel_colorop.o \
243*ef105316SChaitanya Kumar Borah	display/intel_color_pipeline.o \
244df0566a6SJani Nikula	display/intel_combo_phy.o \
245df0566a6SJani Nikula	display/intel_connector.o \
246fbf756c3SDave Airlie	display/intel_crtc.o \
2473e29d3b3SJani Nikula	display/intel_crtc_state_dump.o \
24899ce270aSDave Airlie	display/intel_cursor.o \
249ac930babSVille Syrjälä	display/intel_dbuf_bw.o \
250df0566a6SJani Nikula	display/intel_display.o \
251adceb416SJani Nikula	display/intel_display_conversion.o \
25277316e75SJani Nikula	display/intel_display_driver.o \
2532b874a02SJani Nikula	display/intel_display_irq.o \
2548015bee0SJouni Högander	display/intel_display_params.o \
255df0566a6SJani Nikula	display/intel_display_power.o \
256323286c8SImre Deak	display/intel_display_power_map.o \
257ef1e1708SImre Deak	display/intel_display_power_well.o \
25859c6106eSJani Nikula	display/intel_display_reset.o \
259336c0eaeSJani Nikula	display/intel_display_rpm.o \
2606dbbff25SJani Nikula	display/intel_display_rps.o \
2616843cd85SJani Nikula	display/intel_display_snapshot.o \
262cd81a70dSJani Nikula	display/intel_display_utils.o \
26353dd7b1fSMatt Roper	display/intel_display_wa.o \
26432f9402dSAnusha Srivatsa	display/intel_dmc.o \
265765425f5SLuca Coelho	display/intel_dmc_wl.o \
266df0566a6SJani Nikula	display/intel_dpio_phy.o \
2678cf41f31SDave Airlie	display/intel_dpll.o \
268df0566a6SJani Nikula	display/intel_dpll_mgr.o \
269dc6d6158SJani Nikula	display/intel_dpt.o \
2701aba6713SJuha-Pekka Heikkila	display/intel_dpt_common.o \
271a1b63119SJosé Roberto de Souza	display/intel_drrs.o \
27267f3b58fSAnimesh Manna	display/intel_dsb.o \
27398ed3698SAnimesh Manna	display/intel_dsb_buffer.o \
274f837a61fSImre Deak	display/intel_fb.o \
2755f449ed0SJouni Högander	display/intel_fb_bo.o \
276814c8757SDave Airlie	display/intel_fb_pin.o \
277df0566a6SJani Nikula	display/intel_fbc.o \
278777e687aSDave Airlie	display/intel_fdi.o \
279df0566a6SJani Nikula	display/intel_fifo_underrun.o \
280470022b5SVille Syrjälä	display/intel_flipq.o \
281df0566a6SJani Nikula	display/intel_frontbuffer.o \
2820ef1905eSVille Syrjälä	display/intel_global_state.o \
283df0566a6SJani Nikula	display/intel_hdcp.o \
28418fd7f8aSSuraj Kandpal	display/intel_hdcp_gsc.o \
2850f5b1144SSuraj Kandpal	display/intel_hdcp_gsc_message.o \
286df0566a6SJani Nikula	display/intel_hotplug.o \
287da38ba98SJani Nikula	display/intel_hotplug_irq.o \
28803120fefSJani Nikula	display/intel_hti.o \
2898ca0b875SImre Deak	display/intel_link_bw.o \
290b13604c0SJani Nikula	display/intel_load_detect.o \
291df0566a6SJani Nikula	display/intel_lpe_audio.o \
29260ded7ccSImre Deak	display/intel_modeset_lock.o \
2932c7676b6SJani Nikula	display/intel_modeset_setup.o \
2940db5649eSJani Nikula	display/intel_modeset_verify.o \
295df0566a6SJani Nikula	display/intel_overlay.o \
2965f54b219SJani Nikula	display/intel_panic.o \
2976ca37b86SRodrigo Vivi	display/intel_pch.o \
298b2de2d00SVille Syrjälä	display/intel_pch_display.o \
299ae880cd0SVille Syrjälä	display/intel_pch_refclk.o \
300a649c2abSJani Nikula	display/intel_plane.o \
3011cd967c6SDave Airlie	display/intel_plane_initial.o \
3024c4cc7acSMika Kahola	display/intel_pmdemand.o \
303df0566a6SJani Nikula	display/intel_psr.o \
304df0566a6SJani Nikula	display/intel_quirks.o \
3057fb3a1f7SJani Nikula	display/intel_sbi.o \
306bc85328fSImre Deak	display/intel_sprite.o \
307af3004c9SVille Syrjälä	display/intel_sprite_uapi.o \
3084fb87831SJani Nikula	display/intel_tc.o \
30962fe4515SJani Nikula	display/intel_vblank.o \
31000a16d02SDave Airlie	display/intel_vga.o \
31194b49d53SJani Nikula	display/intel_wm.o \
312ba470a99SVille Syrjälä	display/skl_prefill.o \
313714b1cdbSDave Airlie	display/skl_scaler.o \
31442a0d256SVille Syrjälä	display/skl_universal_plane.o \
3158393253bSJani Nikula	display/skl_watermark.o \
3165615e78eSJani Nikula	display/vlv_clock.o \
3178393253bSJani Nikula	display/vlv_sideband.o
318df0566a6SJani Nikulai915-$(CONFIG_ACPI) += \
319df0566a6SJani Nikula	display/intel_acpi.o \
320df0566a6SJani Nikula	display/intel_opregion.o
321df0566a6SJani Nikulai915-$(CONFIG_DRM_FBDEV_EMULATION) += \
32280d20fd9SJouni Högander	display/intel_fbdev.o \
32380d20fd9SJouni Högander	display/intel_fbdev_fb.o
32475658332SJani Nikulai915-$(CONFIG_DEBUG_FS) += \
32575658332SJani Nikula	display/intel_display_debugfs.o \
32675658332SJani Nikula	display/intel_display_debugfs_params.o \
32775658332SJani Nikula	display/intel_pipe_crc.o
3284520f53aSDaniel Vetter
3292fae6a86SDaniel Vetter# modesetting output/encoder code
330379bc100SJani Nikulai915-y += \
331379bc100SJani Nikula	display/dvo_ch7017.o \
332379bc100SJani Nikula	display/dvo_ch7xxx.o \
333379bc100SJani Nikula	display/dvo_ivch.o \
334379bc100SJani Nikula	display/dvo_ns2501.o \
335379bc100SJani Nikula	display/dvo_sil164.o \
336379bc100SJani Nikula	display/dvo_tfp410.o \
337917c2899SVille Syrjälä	display/g4x_dp.o \
33833e9e541SVille Syrjälä	display/g4x_hdmi.o \
339379bc100SJani Nikula	display/icl_dsi.o \
3406cc42fbeSJani Nikula	display/intel_backlight.o \
341379bc100SJani Nikula	display/intel_crt.o \
34251390cc0SRadhakrishna Sripada	display/intel_cx0_phy.o \
343379bc100SJani Nikula	display/intel_ddi.o \
34499092a97SDave Airlie	display/intel_ddi_buf_trans.o \
34569d43981SMatt Roper	display/intel_display_device.o \
346fd2b94a5SJani Nikula	display/intel_display_trace.o \
34789cb0ba4SImre Deak	display/intel_dkl_phy.o \
348379bc100SJani Nikula	display/intel_dp.o \
349aa850fb1SJani Nikula	display/intel_dp_aux.o \
350379bc100SJani Nikula	display/intel_dp_aux_backlight.o \
351d079b7e4SSean Paul	display/intel_dp_hdcp.o \
352379bc100SJani Nikula	display/intel_dp_link_training.o \
353379bc100SJani Nikula	display/intel_dp_mst.o \
354a5b40d4fSJani Nikula	display/intel_dp_test.o \
355379bc100SJani Nikula	display/intel_dsi.o \
356379bc100SJani Nikula	display/intel_dsi_dcs_backlight.o \
357379bc100SJani Nikula	display/intel_dsi_vbt.o \
358379bc100SJani Nikula	display/intel_dvo.o \
3593b3be899SImre Deak	display/intel_encoder.o \
360379bc100SJani Nikula	display/intel_gmbus.o \
361379bc100SJani Nikula	display/intel_hdmi.o \
362379bc100SJani Nikula	display/intel_lspcon.o \
363154ebdb7SSuraj Kandpal	display/intel_lt_phy.o \
364379bc100SJani Nikula	display/intel_lvds.o \
365379bc100SJani Nikula	display/intel_panel.o \
3660f16cd2aSVille Syrjälä	display/intel_pfit.o \
367abad6805SJani Nikula	display/intel_pps.o \
368c33ebdb7SVandita Kulkarni	display/intel_qp_tables.o \
369379bc100SJani Nikula	display/intel_sdvo.o \
37059476420SAnkit Nautiyal	display/intel_snps_hdmi_pll.o \
37129081008SMatt Roper	display/intel_snps_phy.o \
372379bc100SJani Nikula	display/intel_tv.o \
373379bc100SJani Nikula	display/intel_vdsc.o \
3745b0c5945SManasi Navare	display/intel_vrr.o \
375379bc100SJani Nikula	display/vlv_dsi.o \
376379bc100SJani Nikula	display/vlv_dsi_pll.o
3772fae6a86SDaniel Vetter
37891888b5bSImre Deaki915-$(CONFIG_DRM_I915_DP_TUNNEL) += \
37991888b5bSImre Deak	display/intel_dp_tunnel.o
38091888b5bSImre Deak
3810db5649eSJani Nikulai915-y += \
3820db5649eSJani Nikula	i915_perf.o
3835ed7a0cfSMichal Wajdeczko
384c5be8fc9SDaniele Ceraolo Spurio# Protected execution platform (PXP) support. Base support is required for HuC
385c5be8fc9SDaniele Ceraolo Spurioi915-y += \
3860436ac1bSHuang, Sean Z	pxp/intel_pxp.o \
3870db5649eSJani Nikula	pxp/intel_pxp_huc.o \
3880db5649eSJani Nikula	pxp/intel_pxp_tee.o
389c5be8fc9SDaniele Ceraolo Spurio
390c5be8fc9SDaniele Ceraolo Spurioi915-$(CONFIG_DRM_I915_PXP) += \
39195c9e122SHuang, Sean Z	pxp/intel_pxp_cmd.o \
392390cf1b2SDaniele Ceraolo Spurio	pxp/intel_pxp_debugfs.o \
393d6bf74deSAlan Previn	pxp/intel_pxp_gsccs.o \
3942ae09687SHuang, Sean Z	pxp/intel_pxp_irq.o \
3950cfab4cbSHuang, Sean Z	pxp/intel_pxp_pm.o \
396c5be8fc9SDaniele Ceraolo Spurio	pxp/intel_pxp_session.o
3973ad2dd9cSDaniele Ceraolo Spurio
39898a2f411SChris Wilson# Post-mortem debug and GPU hang state capture
3990db5649eSJani Nikulai915-$(CONFIG_DRM_I915_CAPTURE_ERROR) += \
4000db5649eSJani Nikula	i915_gpu_error.o
401953c7f82SChris Wilsoni915-$(CONFIG_DRM_I915_SELFTEST) += \
40257143f2eSThomas Hellström	gem/selftests/i915_gem_client_blt.o \
40310be98a7SChris Wilson	gem/selftests/igt_gem_utils.o \
404953c7f82SChris Wilson	selftests/i915_random.o \
40598dc0454SChris Wilson	selftests/i915_selftest.o \
406f3bc632aSChris Wilson	selftests/igt_atomic.o \
4078d2f6e2fSTvrtko Ursulin	selftests/igt_flush_test.o \
408e4a8c813SChris Wilson	selftests/igt_live_test.o \
4096fedafacSChris Wilson	selftests/igt_mmap.o \
41028d6ccceSTvrtko Ursulin	selftests/igt_reset.o \
411d4e3d455SChris Wilson	selftests/igt_spinner.o \
4120db5649eSJani Nikula	selftests/intel_scheduler_helpers.o \
413d4e3d455SChris Wilson	selftests/librapl.o
41498a2f411SChris Wilson
415cf9d2890SYu Zhang# virtual gpu code
4160db5649eSJani Nikulai915-y += \
4170db5649eSJani Nikula	i915_vgpu.o
418cf9d2890SYu Zhang
4197f0cf301SJani Nikulai915-$(CONFIG_DRM_I915_GVT) += \
4207f0cf301SJani Nikula	intel_gvt.o \
4217f0cf301SJani Nikula	intel_gvt_mmio_table.o
4220ad35fedSZhi Wanginclude $(src)/gvt/Makefile
4230ad35fedSZhi Wang
424c0e09200SDave Airlieobj-$(CONFIG_DRM_I915) += i915.o
4258b750bf7SChristoph Hellwigobj-$(CONFIG_DRM_I915_GVT_KVMGT) += kvmgt.o
426c6d4a099SMasahiro Yamada
427aaee4bbeSJani Nikula# kernel-doc test
428aaee4bbeSJani Nikula#
429aaee4bbeSJani Nikula# Enable locally for CONFIG_DRM_I915_WERROR=y. See also scripts/Makefile.build
430aaee4bbeSJani Nikulaifdef CONFIG_DRM_I915_WERROR
431002621a4SJean Delvare    cmd_checkdoc = PYTHONDONTWRITEBYTECODE=1 $(PYTHON3) $(KERNELDOC) -none -Werror $<
432aaee4bbeSJani Nikulaendif
433aaee4bbeSJani Nikula
434c6d4a099SMasahiro Yamada# header test
435c6d4a099SMasahiro Yamada
436c6d4a099SMasahiro Yamada# exclude some broken headers from the test coverage
437c6d4a099SMasahiro Yamadano-header-test := \
438e056f669SJani Nikula	display/intel_vbt_defs.h
439c6d4a099SMasahiro Yamada
4402047ace9SMasahiro Yamadaalways-$(CONFIG_DRM_I915_WERROR) += \
441c6d4a099SMasahiro Yamada	$(patsubst %.h,%.hdrtest, $(filter-out $(no-header-test), \
442b1992c37SMasahiro Yamada		$(shell cd $(src) && find * -name '*.h')))
443c6d4a099SMasahiro Yamada
444c6d4a099SMasahiro Yamadaquiet_cmd_hdrtest = HDRTEST $(patsubst %.hdrtest,%.h,$@)
445899ff790SJani Nikula      cmd_hdrtest = $(CC) $(filter-out $(CFLAGS_GCOV), $(c_flags)) -S -o /dev/null -x c /dev/null -include $<; \
44683ac5457SJani Nikula		$(srctree)/scripts/kernel-doc -none -Werror $<; touch $@
447c6d4a099SMasahiro Yamada
448c6d4a099SMasahiro Yamada$(obj)/%.hdrtest: $(src)/%.h FORCE
449c6d4a099SMasahiro Yamada	$(call if_changed_dep,hdrtest)
450