Makefile 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456
  1. # SPDX-License-Identifier: GPL-2.0
  2. #
  3. # Makefile for the drm device driver. This driver provides support for the
  4. # Direct Rendering Infrastructure (DRI) in XFree86 4.1.0 and higher.
  5. # Enable W=1 warnings not enabled in drm subsystem Makefile
  6. subdir-ccflags-y += $(call cc-option, -Wformat-truncation)
  7. # Enable -Werror in CI and development
  8. subdir-ccflags-$(CONFIG_DRM_I915_WERROR) += -Werror
  9. # Support compiling the display code separately for both i915 and xe
  10. # drivers. Define I915 when building i915.
  11. subdir-ccflags-y += -DI915
  12. # FIXME: Disable tracepoints on i915 for PREEMPT_RT, unfortunately
  13. # it's an all or nothing flag. You cannot selectively disable
  14. # only some tracepoints.
  15. subdir-ccflags-$(CONFIG_PREEMPT_RT) += -DNOTRACE
  16. subdir-ccflags-y += -I$(src)
  17. # Please keep these build lists sorted!
  18. # core driver code
  19. i915-y += \
  20. i915_config.o \
  21. i915_driver.o \
  22. i915_drm_client.o \
  23. i915_edram.o \
  24. i915_freq.o \
  25. i915_getparam.o \
  26. i915_gmch.o \
  27. i915_ioctl.o \
  28. i915_irq.o \
  29. i915_mitigations.o \
  30. i915_mmio_range.o \
  31. i915_module.o \
  32. i915_params.o \
  33. i915_pci.o \
  34. i915_scatterlist.o \
  35. i915_switcheroo.o \
  36. i915_sysfs.o \
  37. i915_timer_util.o \
  38. i915_utils.o \
  39. intel_clock_gating.o \
  40. intel_cpu_info.o \
  41. intel_device_info.o \
  42. intel_memory_region.o \
  43. intel_pcode.o \
  44. intel_region_ttm.o \
  45. intel_runtime_pm.o \
  46. intel_step.o \
  47. intel_uncore.o \
  48. intel_uncore_trace.o \
  49. intel_wakeref.o \
  50. vlv_iosf_sb.o \
  51. vlv_suspend.o
  52. # core library code
  53. i915-y += \
  54. i915_memcpy.o \
  55. i915_mm.o \
  56. i915_sw_fence.o \
  57. i915_sw_fence_work.o \
  58. i915_syncmap.o \
  59. i915_user_extensions.o
  60. i915-$(CONFIG_COMPAT) += \
  61. i915_ioc32.o
  62. i915-$(CONFIG_DEBUG_FS) += \
  63. i915_debugfs.o \
  64. i915_debugfs_params.o
  65. i915-$(CONFIG_PERF_EVENTS) += \
  66. i915_pmu.o
  67. # core display adaptation
  68. i915-y += \
  69. i915_display_pc8.o \
  70. i915_hdcp_gsc.o \
  71. i915_initial_plane.o \
  72. i915_panic.o
  73. # "Graphics Technology" (aka we talk to the gpu)
  74. gt-y += \
  75. gt/gen2_engine_cs.o \
  76. gt/gen6_engine_cs.o \
  77. gt/gen6_ppgtt.o \
  78. gt/gen7_renderclear.o \
  79. gt/gen8_engine_cs.o \
  80. gt/gen8_ppgtt.o \
  81. gt/intel_breadcrumbs.o \
  82. gt/intel_context.o \
  83. gt/intel_context_sseu.o \
  84. gt/intel_engine_cs.o \
  85. gt/intel_engine_heartbeat.o \
  86. gt/intel_engine_pm.o \
  87. gt/intel_engine_user.o \
  88. gt/intel_execlists_submission.o \
  89. gt/intel_ggtt.o \
  90. gt/intel_ggtt_fencing.o \
  91. gt/intel_gt.o \
  92. gt/intel_gt_buffer_pool.o \
  93. gt/intel_gt_ccs_mode.o \
  94. gt/intel_gt_clock_utils.o \
  95. gt/intel_gt_debugfs.o \
  96. gt/intel_gt_engines_debugfs.o \
  97. gt/intel_gt_irq.o \
  98. gt/intel_gt_mcr.o \
  99. gt/intel_gt_pm.o \
  100. gt/intel_gt_pm_debugfs.o \
  101. gt/intel_gt_pm_irq.o \
  102. gt/intel_gt_requests.o \
  103. gt/intel_gt_sysfs.o \
  104. gt/intel_gt_sysfs_pm.o \
  105. gt/intel_gtt.o \
  106. gt/intel_llc.o \
  107. gt/intel_lrc.o \
  108. gt/intel_migrate.o \
  109. gt/intel_mocs.o \
  110. gt/intel_ppgtt.o \
  111. gt/intel_rc6.o \
  112. gt/intel_region_lmem.o \
  113. gt/intel_renderstate.o \
  114. gt/intel_reset.o \
  115. gt/intel_ring.o \
  116. gt/intel_ring_submission.o \
  117. gt/intel_rps.o \
  118. gt/intel_sa_media.o \
  119. gt/intel_sseu.o \
  120. gt/intel_sseu_debugfs.o \
  121. gt/intel_timeline.o \
  122. gt/intel_tlb.o \
  123. gt/intel_wopcm.o \
  124. gt/intel_workarounds.o \
  125. gt/shmem_utils.o \
  126. gt/sysfs_engines.o
  127. # x86 intel-gtt module support
  128. gt-$(CONFIG_X86) += \
  129. gt/intel_ggtt_gmch.o
  130. # autogenerated null render state
  131. gt-y += \
  132. gt/gen6_renderstate.o \
  133. gt/gen7_renderstate.o \
  134. gt/gen8_renderstate.o \
  135. gt/gen9_renderstate.o
  136. i915-y += $(gt-y)
  137. # GEM (Graphics Execution Management) code
  138. gem-y += \
  139. gem/i915_gem_busy.o \
  140. gem/i915_gem_clflush.o \
  141. gem/i915_gem_context.o \
  142. gem/i915_gem_create.o \
  143. gem/i915_gem_dmabuf.o \
  144. gem/i915_gem_domain.o \
  145. gem/i915_gem_execbuffer.o \
  146. gem/i915_gem_internal.o \
  147. gem/i915_gem_lmem.o \
  148. gem/i915_gem_mman.o \
  149. gem/i915_gem_object.o \
  150. gem/i915_gem_object_frontbuffer.o \
  151. gem/i915_gem_pages.o \
  152. gem/i915_gem_phys.o \
  153. gem/i915_gem_pm.o \
  154. gem/i915_gem_region.o \
  155. gem/i915_gem_shmem.o \
  156. gem/i915_gem_shrinker.o \
  157. gem/i915_gem_stolen.o \
  158. gem/i915_gem_throttle.o \
  159. gem/i915_gem_tiling.o \
  160. gem/i915_gem_ttm.o \
  161. gem/i915_gem_ttm_move.o \
  162. gem/i915_gem_ttm_pm.o \
  163. gem/i915_gem_userptr.o \
  164. gem/i915_gem_wait.o
  165. i915-y += \
  166. $(gem-y) \
  167. i915_active.o \
  168. i915_cmd_parser.o \
  169. i915_deps.o \
  170. i915_gem.o \
  171. i915_gem_evict.o \
  172. i915_gem_gtt.o \
  173. i915_gem_ww.o \
  174. i915_query.o \
  175. i915_request.o \
  176. i915_scheduler.o \
  177. i915_trace_points.o \
  178. i915_ttm_buddy_manager.o \
  179. i915_vma.o \
  180. i915_vma_resource.o
  181. # general-purpose microcontroller (GuC) support
  182. i915-y += \
  183. gt/uc/intel_gsc_fw.o \
  184. gt/uc/intel_gsc_proxy.o \
  185. gt/uc/intel_gsc_uc.o \
  186. gt/uc/intel_gsc_uc_debugfs.o \
  187. gt/uc/intel_gsc_uc_heci_cmd_submit.o\
  188. gt/uc/intel_guc.o \
  189. gt/uc/intel_guc_ads.o \
  190. gt/uc/intel_guc_capture.o \
  191. gt/uc/intel_guc_ct.o \
  192. gt/uc/intel_guc_debugfs.o \
  193. gt/uc/intel_guc_fw.o \
  194. gt/uc/intel_guc_hwconfig.o \
  195. gt/uc/intel_guc_log.o \
  196. gt/uc/intel_guc_log_debugfs.o \
  197. gt/uc/intel_guc_rc.o \
  198. gt/uc/intel_guc_slpc.o \
  199. gt/uc/intel_guc_submission.o \
  200. gt/uc/intel_huc.o \
  201. gt/uc/intel_huc_debugfs.o \
  202. gt/uc/intel_huc_fw.o \
  203. gt/uc/intel_uc.o \
  204. gt/uc/intel_uc_debugfs.o \
  205. gt/uc/intel_uc_fw.o
  206. # graphics system controller (GSC) support
  207. i915-y += \
  208. gt/intel_gsc.o
  209. # graphics hardware monitoring (HWMON) support
  210. i915-$(CONFIG_HWMON) += \
  211. i915_hwmon.o
  212. # modesetting core code
  213. i915-y += \
  214. display/hsw_ips.o \
  215. display/i9xx_display_sr.o \
  216. display/i9xx_plane.o \
  217. display/i9xx_wm.o \
  218. display/intel_alpm.o \
  219. display/intel_atomic.o \
  220. display/intel_audio.o \
  221. display/intel_bios.o \
  222. display/intel_bo.o \
  223. display/intel_bw.o \
  224. display/intel_casf.o \
  225. display/intel_cdclk.o \
  226. display/intel_cmtg.o \
  227. display/intel_color.o \
  228. display/intel_colorop.o \
  229. display/intel_color_pipeline.o \
  230. display/intel_combo_phy.o \
  231. display/intel_connector.o \
  232. display/intel_crtc.o \
  233. display/intel_crtc_state_dump.o \
  234. display/intel_cursor.o \
  235. display/intel_dbuf_bw.o \
  236. display/intel_display.o \
  237. display/intel_display_conversion.o \
  238. display/intel_display_driver.o \
  239. display/intel_display_irq.o \
  240. display/intel_display_params.o \
  241. display/intel_display_power.o \
  242. display/intel_display_power_map.o \
  243. display/intel_display_power_well.o \
  244. display/intel_display_reset.o \
  245. display/intel_display_rpm.o \
  246. display/intel_display_rps.o \
  247. display/intel_display_snapshot.o \
  248. display/intel_display_utils.o \
  249. display/intel_display_wa.o \
  250. display/intel_dmc.o \
  251. display/intel_dmc_wl.o \
  252. display/intel_dpio_phy.o \
  253. display/intel_dpll.o \
  254. display/intel_dpll_mgr.o \
  255. display/intel_dpt.o \
  256. display/intel_dpt_common.o \
  257. display/intel_dram.o \
  258. display/intel_drrs.o \
  259. display/intel_dsb.o \
  260. display/intel_dsb_buffer.o \
  261. display/intel_fb.o \
  262. display/intel_fb_bo.o \
  263. display/intel_fb_pin.o \
  264. display/intel_fbc.o \
  265. display/intel_fdi.o \
  266. display/intel_fifo_underrun.o \
  267. display/intel_flipq.o \
  268. display/intel_frontbuffer.o \
  269. display/intel_global_state.o \
  270. display/intel_hdcp.o \
  271. display/intel_hdcp_gsc_message.o \
  272. display/intel_hotplug.o \
  273. display/intel_hotplug_irq.o \
  274. display/intel_hti.o \
  275. display/intel_initial_plane.o \
  276. display/intel_link_bw.o \
  277. display/intel_load_detect.o \
  278. display/intel_lpe_audio.o \
  279. display/intel_modeset_lock.o \
  280. display/intel_modeset_setup.o \
  281. display/intel_modeset_verify.o \
  282. display/intel_overlay.o \
  283. display/intel_parent.o \
  284. display/intel_pch.o \
  285. display/intel_pch_display.o \
  286. display/intel_pch_refclk.o \
  287. display/intel_plane.o \
  288. display/intel_pmdemand.o \
  289. display/intel_psr.o \
  290. display/intel_quirks.o \
  291. display/intel_rom.o \
  292. display/intel_sbi.o \
  293. display/intel_sprite.o \
  294. display/intel_sprite_uapi.o \
  295. display/intel_tc.o \
  296. display/intel_vblank.o \
  297. display/intel_vga.o \
  298. display/intel_wm.o \
  299. display/skl_prefill.o \
  300. display/skl_scaler.o \
  301. display/skl_universal_plane.o \
  302. display/skl_watermark.o \
  303. display/vlv_clock.o \
  304. display/vlv_sideband.o
  305. i915-$(CONFIG_ACPI) += \
  306. display/intel_acpi.o \
  307. display/intel_opregion.o
  308. i915-$(CONFIG_DRM_FBDEV_EMULATION) += \
  309. display/intel_fbdev.o \
  310. display/intel_fbdev_fb.o
  311. i915-$(CONFIG_DEBUG_FS) += \
  312. display/intel_display_debugfs.o \
  313. display/intel_display_debugfs_params.o \
  314. display/intel_pipe_crc.o
  315. # modesetting output/encoder code
  316. i915-y += \
  317. display/dvo_ch7017.o \
  318. display/dvo_ch7xxx.o \
  319. display/dvo_ivch.o \
  320. display/dvo_ns2501.o \
  321. display/dvo_sil164.o \
  322. display/dvo_tfp410.o \
  323. display/g4x_dp.o \
  324. display/g4x_hdmi.o \
  325. display/icl_dsi.o \
  326. display/intel_backlight.o \
  327. display/intel_crt.o \
  328. display/intel_cx0_phy.o \
  329. display/intel_ddi.o \
  330. display/intel_ddi_buf_trans.o \
  331. display/intel_display_device.o \
  332. display/intel_display_trace.o \
  333. display/intel_dkl_phy.o \
  334. display/intel_dp.o \
  335. display/intel_dp_aux.o \
  336. display/intel_dp_aux_backlight.o \
  337. display/intel_dp_hdcp.o \
  338. display/intel_dp_link_training.o \
  339. display/intel_dp_mst.o \
  340. display/intel_dp_test.o \
  341. display/intel_dsi.o \
  342. display/intel_dsi_dcs_backlight.o \
  343. display/intel_dsi_vbt.o \
  344. display/intel_dvo.o \
  345. display/intel_encoder.o \
  346. display/intel_gmbus.o \
  347. display/intel_hdmi.o \
  348. display/intel_lspcon.o \
  349. display/intel_lt_phy.o \
  350. display/intel_lvds.o \
  351. display/intel_panel.o \
  352. display/intel_pfit.o \
  353. display/intel_pps.o \
  354. display/intel_qp_tables.o \
  355. display/intel_sdvo.o \
  356. display/intel_snps_hdmi_pll.o \
  357. display/intel_snps_phy.o \
  358. display/intel_tv.o \
  359. display/intel_vdsc.o \
  360. display/intel_vrr.o \
  361. display/vlv_dsi.o \
  362. display/vlv_dsi_pll.o
  363. i915-$(CONFIG_DRM_I915_DP_TUNNEL) += \
  364. display/intel_dp_tunnel.o
  365. i915-$(CONFIG_DRM_I915_GVT) += \
  366. display/intel_gvt_api.o
  367. i915-y += \
  368. i915_perf.o
  369. # Protected execution platform (PXP) support. Base support is required for HuC
  370. i915-y += \
  371. pxp/intel_pxp.o \
  372. pxp/intel_pxp_huc.o \
  373. pxp/intel_pxp_tee.o
  374. i915-$(CONFIG_DRM_I915_PXP) += \
  375. pxp/intel_pxp_cmd.o \
  376. pxp/intel_pxp_debugfs.o \
  377. pxp/intel_pxp_gsccs.o \
  378. pxp/intel_pxp_irq.o \
  379. pxp/intel_pxp_pm.o \
  380. pxp/intel_pxp_session.o
  381. # Post-mortem debug and GPU hang state capture
  382. i915-$(CONFIG_DRM_I915_CAPTURE_ERROR) += \
  383. i915_gpu_error.o
  384. i915-$(CONFIG_DRM_I915_SELFTEST) += \
  385. gem/selftests/i915_gem_client_blt.o \
  386. gem/selftests/igt_gem_utils.o \
  387. selftests/i915_random.o \
  388. selftests/i915_selftest.o \
  389. selftests/igt_atomic.o \
  390. selftests/igt_flush_test.o \
  391. selftests/igt_live_test.o \
  392. selftests/igt_mmap.o \
  393. selftests/igt_reset.o \
  394. selftests/igt_spinner.o \
  395. selftests/intel_scheduler_helpers.o \
  396. selftests/librapl.o
  397. # virtual gpu code
  398. i915-y += \
  399. i915_vgpu.o
  400. i915-$(CONFIG_DRM_I915_GVT) += \
  401. intel_gvt.o \
  402. intel_gvt_mmio_table.o
  403. include $(src)/gvt/Makefile
  404. obj-$(CONFIG_DRM_I915) += i915.o
  405. obj-$(CONFIG_DRM_I915_GVT_KVMGT) += kvmgt.o
  406. # kernel-doc test
  407. #
  408. # Enable locally for CONFIG_DRM_I915_WERROR=y. See also scripts/Makefile.build
  409. ifdef CONFIG_DRM_I915_WERROR
  410. cmd_checkdoc = PYTHONDONTWRITEBYTECODE=1 $(PYTHON3) $(KERNELDOC) -none -Werror $<
  411. endif
  412. # header test
  413. # exclude some broken headers from the test coverage
  414. no-header-test := \
  415. display/intel_vbt_defs.h
  416. always-$(CONFIG_DRM_I915_WERROR) += \
  417. $(patsubst %.h,%.hdrtest, $(filter-out $(no-header-test), \
  418. $(shell cd $(src) && find * -name '*.h')))
  419. quiet_cmd_hdrtest = HDRTEST $(patsubst %.hdrtest,%.h,$@)
  420. cmd_hdrtest = $(CC) $(filter-out $(CFLAGS_GCOV), $(c_flags)) -S -o /dev/null -x c /dev/null -include $<; \
  421. $(KERNELDOC) -none -Werror $<; touch $@
  422. $(obj)/%.hdrtest: $(src)/%.h FORCE
  423. $(call if_changed_dep,hdrtest)