linux_dsm_epyc7002/drivers/gpu/drm/i915
Tvrtko Ursulin e46c2e99f6 drm/i915: Expose RPCS (SSEU) configuration to userspace (Gen11 only)
We want to allow userspace to reconfigure the subslice configuration on a
per context basis.

This is required for the functional requirement of shutting down non-VME
enabled sub-slices on Gen11 parts.

To do so, we expose a context parameter to allow adjustment of the RPCS
register stored within the context image (and currently not accessible via
LRI).

If the context is adjusted before first use or whilst idle, the adjustment
is for "free"; otherwise if the context is active we queue a request to do
so (using the kernel context), following all other activity by that
context, which is also marked as barrier for all following submission
against the same context.

Since the overhead of device re-configuration during context switching can
be significant, especially in multi-context workloads, we limit this new
uAPI to only support the Gen11 VME use case. In this use case either the
device is fully enabled, and exactly one slice and half of the subslices
are enabled.

Example usage:

	struct drm_i915_gem_context_param_sseu sseu = { };
	struct drm_i915_gem_context_param arg = {
		.param = I915_CONTEXT_PARAM_SSEU,
		.ctx_id = gem_context_create(fd),
		.size = sizeof(sseu),
		.value = to_user_pointer(&sseu)
	};

	/* Query device defaults. */
	gem_context_get_param(fd, &arg);

	/* Set VME configuration on a 1x6x8 part. */
	sseu.slice_mask = 0x1;
	sseu.subslice_mask = 0xe0;
	gem_context_set_param(fd, &arg);

v2: Fix offset of CTX_R_PWR_CLK_STATE in intel_lr_context_set_sseu()
    (Lionel)

v3: Add ability to program this per engine (Chris)

v4: Move most get_sseu() into i915_gem_context.c (Lionel)

v5: Validate sseu configuration against the device's capabilities (Lionel)

v6: Change context powergating settings through MI_SDM on kernel context
    (Chris)

v7: Synchronize the requests following a powergating setting change using
    a global dependency (Chris)
    Iterate timelines through dev_priv.gt.active_rings (Tvrtko)
    Disable RPCS configuration setting for non capable users
    (Lionel/Tvrtko)

v8: s/union intel_sseu/struct intel_sseu/ (Lionel)
    s/dev_priv/i915/ (Tvrtko)
    Change uapi class/instance fields to u16 (Tvrtko)
    Bump mask fields to 64bits (Lionel)
    Don't return EPERM when dynamic sseu is disabled (Tvrtko)

v9: Import context image into kernel context's ppgtt only when
    reconfiguring powergated slice/subslices (Chris)
    Use aliasing ppgtt when needed (Michel)

Tvrtko Ursulin:

v10:
 * Update for upstream changes.
 * Request submit needs a RPM reference.
 * Reject on !FULL_PPGTT for simplicity.
 * Pull out get/set param to helpers for readability and less indent.
 * Use i915_request_await_dma_fence in add_global_barrier to skip waits
   on the same timeline and avoid GEM_BUG_ON.
 * No need to explicitly assign a NULL pointer to engine in legacy mode.
 * No need to move gen8_make_rpcs up.
 * Factored out global barrier as prep patch.
 * Allow to only CAP_SYS_ADMIN if !Gen11.

v11:
 * Remove engine vfunc in favour of local helper. (Chris Wilson)
 * Stop retiring requests before updates since it is not needed
   (Chris Wilson)
 * Implement direct CPU update path for idle contexts. (Chris Wilson)
 * Left side dependency needs only be on the same context timeline.
   (Chris Wilson)
 * It is sufficient to order the timeline. (Chris Wilson)
 * Reject !RCS configuration attempts with -ENODEV for now.

v12:
 * Rebase for make_rpcs.

v13:
 * Centralize SSEU normalization to make_rpcs.
 * Type width checking (uAPI <-> implementation).
 * Gen11 restrictions uAPI checks.
 * Gen11 subslice count differences handling.
 Chris Wilson:
 * args->size handling fixes.
 * Update context image from GGTT.
 * Postpone context image update to pinning.
 * Use i915_gem_active_raw instead of last_request_on_engine.

v14:
 * Add activity tracker on intel_context to fix the lifetime issues
   and simplify the code. (Chris Wilson)

v15:
 * Fix context pin leak if no space in ring by simplifying the
   context pinning sequence.

v16:
 * Rebase for context get/set param locking changes.
 * Just -ENODEV on !Gen11. (Joonas)

v17:
 * Fix one Gen11 subslice enablement rule.
 * Handle error from i915_sw_fence_await_sw_fence_gfp. (Chris Wilson)

v18:
 * Update commit message. (Joonas)
 * Restrict uAPI to VME use case. (Joonas)

v19:
 * Rebase.

v20:
 * Rebase for ce->active_tracker.

v21:
 * Rebase for IS_GEN changes.

v22:
 * Reserve uAPI for flags straight away. (Chris Wilson)

v23:
 * Rebase for RUNTIME_INFO.

v24:
 * Added some headline docs for the uapi usage. (Joonas/Chris)

v25:
 * Renamed class/instance to engine_class/engine_instance to avoid clash
   with C++ keyword. (Tony Ye)

v26:
 * Rebased for runtime pm api changes.

v27:
 * Rebased for intel_context_init.
 * Wrap commit msg to 75.

v28:
 (Chris Wilson)
 * Use i915_gem_ggtt.
 * Use i915_request_await_dma_fence to show a better example.

v29:
 * i915_timeline_set_barrier can now fail. (Chris Wilson)

v30:
 * Capture some acks.

v31:
 * Drop the WARN_ON from use controllable paths. (Chris Wilson)
 * Use overflows_type for all checks.

Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=100899
Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=107634
Issue: https://github.com/intel/media-driver/issues/267
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: Lionel Landwerlin <lionel.g.landwerlin@intel.com>
Cc: Dmitry Rogozhkin <dmitry.v.rogozhkin@intel.com>
Cc: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
Cc: Zhipeng Gong <zhipeng.gong@intel.com>
Cc: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
Cc: Tony Ye <tony.ye@intel.com>
Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk>
Reviewed-by: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
Acked-by: Timo Aaltonen <timo.aaltonen@canonical.com>
Acked-by: Takashi Iwai <tiwai@suse.de>
Acked-by: Stéphane Marchesin <marcheu@chromium.org>
Link: https://patchwork.freedesktop.org/patch/msgid/20190205095032.22673-4-tvrtko.ursulin@linux.intel.com
2019-02-05 11:32:03 +00:00
..
gvt Merge tag 'gvt-next-2019-02-01' of https://github.com/intel/gvt-linux into drm-intel-next-queued 2019-02-01 09:03:24 -08:00
selftests drm/i915: Add timeline barrier support 2019-02-05 11:32:03 +00:00
dvo_ch7xxx.c
dvo_ch7017.c
dvo_ivch.c
dvo_ns2501.c
dvo_sil164.c
dvo_tfp410.c
dvo.h drm/i915: drop all drmP.h includes 2019-01-09 10:26:36 +02:00
i915_cmd_parser.c
i915_debugfs.c drm/i915: Drop fake breadcrumb irq 2019-01-29 21:45:30 +00:00
i915_drv.c drm/i915: Pull all the reset functionality together into i915_reset.c 2019-01-16 22:45:31 +00:00
i915_drv.h drm/i915: Record the sseu configuration per-context & engine 2019-02-05 11:31:27 +00:00
i915_fixed.h
i915_gem_batch_pool.c
i915_gem_batch_pool.h
i915_gem_clflush.c
i915_gem_clflush.h
i915_gem_context.c drm/i915: Expose RPCS (SSEU) configuration to userspace (Gen11 only) 2019-02-05 11:32:03 +00:00
i915_gem_context.h drm/i915: Expose RPCS (SSEU) configuration to userspace (Gen11 only) 2019-02-05 11:32:03 +00:00
i915_gem_dmabuf.c drm/i915: drop all drmP.h includes 2019-01-09 10:26:36 +02:00
i915_gem_evict.c drm/i915: Pull VM lists under the VM mutex. 2019-01-28 16:24:13 +00:00
i915_gem_execbuffer.c drm/i915: Identify active requests 2019-01-29 19:59:59 +00:00
i915_gem_fence_reg.c drm/i915: small isolated c99 types to kernel types switch 2019-01-17 09:02:00 +02:00
i915_gem_fence_reg.h drm/i915: Remove GPU reset dependence on struct_mutex 2019-01-25 14:27:22 +00:00
i915_gem_gtt.c drm/i915: Pull VM lists under the VM mutex. 2019-01-28 16:24:13 +00:00
i915_gem_gtt.h drm/i915: Enlarge vma->pin_count 2019-01-28 19:07:01 +00:00
i915_gem_internal.c drm/i915: drop all drmP.h includes 2019-01-09 10:26:36 +02:00
i915_gem_object.c
i915_gem_object.h drm/i915: Move vma lookup to its own lock 2019-01-28 16:24:16 +00:00
i915_gem_render_state.c
i915_gem_render_state.h
i915_gem_shrinker.c drm/i915: Pull VM lists under the VM mutex. 2019-01-28 16:24:13 +00:00
i915_gem_stolen.c drm/i915: Pull VM lists under the VM mutex. 2019-01-28 16:24:13 +00:00
i915_gem_tiling.c drm/i915: drop all drmP.h includes 2019-01-09 10:26:36 +02:00
i915_gem_userptr.c drm/i915/userptr: Fix error handling of mutex_lock_killable() 2019-01-16 08:31:41 +00:00
i915_gem.c drm/i915: Identify active requests 2019-01-29 19:59:59 +00:00
i915_gem.h
i915_gemfs.c
i915_gemfs.h
i915_gpu_error.c drm/i915: Drop fake breadcrumb irq 2019-01-29 21:45:30 +00:00
i915_gpu_error.h drm/i915: Drop fake breadcrumb irq 2019-01-29 21:45:30 +00:00
i915_ioc32.c drm/i915: drop all drmP.h includes 2019-01-09 10:26:36 +02:00
i915_irq.c drm/i915: Replace global breadcrumbs with per-context interrupt tracking 2019-01-29 21:45:22 +00:00
i915_memcpy.c
i915_mm.c
i915_oa_bdw.c
i915_oa_bdw.h
i915_oa_bxt.c
i915_oa_bxt.h
i915_oa_cflgt2.c
i915_oa_cflgt2.h
i915_oa_cflgt3.c
i915_oa_cflgt3.h
i915_oa_chv.c
i915_oa_chv.h
i915_oa_cnl.c
i915_oa_cnl.h
i915_oa_glk.c
i915_oa_glk.h
i915_oa_hsw.c
i915_oa_hsw.h
i915_oa_icl.c
i915_oa_icl.h
i915_oa_kblgt2.c
i915_oa_kblgt2.h
i915_oa_kblgt3.c
i915_oa_kblgt3.h
i915_oa_sklgt2.c
i915_oa_sklgt2.h
i915_oa_sklgt3.c
i915_oa_sklgt3.h
i915_oa_sklgt4.c
i915_oa_sklgt4.h
i915_params.c drm/i915: Enable fastboot by default on Skylake and newer 2019-01-29 10:41:58 +01:00
i915_params.h drm/i915: Enable fastboot by default on Skylake and newer 2019-01-29 10:41:58 +01:00
i915_pci.c drm/i915/cfl: Adding another PCI Device ID. 2019-01-31 08:53:59 -08:00
i915_perf.c drm/i915/perf: lock powergating configuration to default when active 2019-02-05 11:31:52 +00:00
i915_pmu.c drm/i915: Syntatic sugar for using intel_runtime_pm 2019-01-14 16:18:25 +00:00
i915_pmu.h
i915_pvinfo.h
i915_query.c Merge drm/drm-next into drm-intel-next-queued 2019-01-08 10:50:22 +02:00
i915_query.h
i915_reg.h drm/i915/icl: restore WaEnableFloatBlendOptimization 2019-02-01 08:39:53 +00:00
i915_request.c drm/i915: Add timeline barrier support 2019-02-05 11:32:03 +00:00
i915_request.h drm/i915: Replace global breadcrumbs with per-context interrupt tracking 2019-01-29 21:45:22 +00:00
i915_reset.c drm/i915: Replace global breadcrumbs with per-context interrupt tracking 2019-01-29 21:45:22 +00:00
i915_reset.h drm/i915: Remove GPU reset dependence on struct_mutex 2019-01-25 14:27:22 +00:00
i915_scheduler.c drm/i915: Replace global breadcrumbs with per-context interrupt tracking 2019-01-29 21:45:22 +00:00
i915_scheduler.h
i915_selftest.h drm/i915/selftests: Apply a subtest filter 2019-01-29 19:59:57 +00:00
i915_suspend.c drm/i915: drop all drmP.h includes 2019-01-09 10:26:36 +02:00
i915_sw_fence.c drm-misc-next for 5.1: 2019-01-10 05:58:52 +10:00
i915_sw_fence.h
i915_syncmap.c
i915_syncmap.h
i915_sysfs.c drm/i915: Syntatic sugar for using intel_runtime_pm 2019-01-14 16:18:25 +00:00
i915_timeline.c drm/i915: Add timeline barrier support 2019-02-05 11:32:03 +00:00
i915_timeline.h drm/i915: Add timeline barrier support 2019-02-05 11:32:03 +00:00
i915_trace_points.c
i915_trace.h drm/i915: Remove the intel_engine_notify tracepoint 2019-01-29 21:45:21 +00:00
i915_utils.h
i915_vgpu.c
i915_vgpu.h
i915_vma.c drm/i915: Move vma lookup to its own lock 2019-01-28 16:24:16 +00:00
i915_vma.h drm/i915: Enlarge vma->pin_count 2019-01-28 19:07:01 +00:00
icl_dsi.c drm/i915/backlight: Restore backlight on resume, v3. 2019-01-24 13:02:08 +01:00
intel_acpi.c drm/i915: drop all drmP.h includes 2019-01-09 10:26:36 +02:00
intel_atomic_plane.c drm/i915: Clean up intel_plane_atomic_check_with_state() 2019-01-25 21:26:08 +02:00
intel_atomic.c drm/i915: small isolated c99 types to kernel types switch 2019-01-17 09:02:00 +02:00
intel_audio.c drm/i915: Markup paired operations on display power domains 2019-01-14 16:18:30 +00:00
intel_bios.c drm/i915/icl: Add TypeC ports only if VBT is present 2019-01-31 16:28:33 +02:00
intel_bios.h
intel_breadcrumbs.c drm/i915: Drop fake breadcrumb irq 2019-01-29 21:45:30 +00:00
intel_cdclk.c drm/i915/cdclk: switch to kernel types 2019-01-17 09:02:06 +02:00
intel_color.c drm/i915: Apply LUT validation checks to platforms more accurately (v3) 2019-01-30 17:09:45 -08:00
intel_combo_phy.c
intel_connector.c Merge drm/drm-next into drm-intel-next-queued 2019-01-22 14:51:36 -08:00
intel_crt.c drm/i915/crt: switch to kernel types 2019-01-17 09:02:06 +02:00
intel_csr.c drm/i915/csr: switch to kernel types 2019-01-21 11:09:16 +02:00
intel_ddi.c drm/i915/icl: remove dpll from clk_sel 2019-01-29 14:35:06 -08:00
intel_device_info.c drm/i915: Fixup kerneldoc for intel_device_info_runtime_init 2019-01-07 09:56:17 +00:00
intel_device_info.h drm/i915: Apply LUT validation checks to platforms more accurately (v3) 2019-01-30 17:09:45 -08:00
intel_display.c drm/i915: Enable fastboot by default on VLV and CHV 2019-02-01 10:15:06 +01:00
intel_display.h drm/i915: start moving runtime device info to a separate struct 2019-01-02 12:46:29 +02:00
intel_dp_aux_backlight.c
intel_dp_link_training.c drm/i915/dp: switch to kernel types 2019-01-17 09:02:06 +02:00
intel_dp_mst.c Merge drm/drm-next into drm-intel-next-queued 2019-01-22 14:51:36 -08:00
intel_dp.c drm/i915/backlight: Restore backlight on resume, v3. 2019-01-24 13:02:08 +01:00
intel_dpio_phy.c drm/i915: small isolated c99 types to kernel types switch 2019-01-17 09:02:00 +02:00
intel_dpll_mgr.c drm/i915: Pick the first unused PLL once again 2019-01-31 09:46:02 +02:00
intel_dpll_mgr.h drm/i915/icl: use tc_port in MG_PLL macros 2019-01-29 14:35:02 -08:00
intel_drv.h drm/i915/tv: Use the scanline counter for timestamps on i965gm TV output 2019-01-28 15:53:32 +02:00
intel_dsi_dcs_backlight.c
intel_dsi_vbt.c drm/i915/intel_dsi_vbt: Add support for PMIC MIPI sequences 2019-01-09 10:35:05 +01:00
intel_dsi.c
intel_dsi.h drm/i915/dsi: Fix pipe_bpp for handling for 6 bpc pixel-formats 2019-01-21 10:45:23 +01:00
intel_dvo.c drm/i915: Pass down rc in intel_encoder->compute_config() 2019-01-16 12:49:58 +02:00
intel_engine_cs.c drm/i915: Replace global breadcrumbs with per-context interrupt tracking 2019-01-29 21:45:22 +00:00
intel_fbc.c drm/i915: small isolated c99 types to kernel types switch 2019-01-17 09:02:00 +02:00
intel_fbdev.c drm/i915/fb: Track rpm wakerefs 2019-01-14 16:18:16 +00:00
intel_fifo_underrun.c drm/i915: small isolated c99 types to kernel types switch 2019-01-17 09:02:00 +02:00
intel_frontbuffer.c drm/i915: drop all drmP.h includes 2019-01-09 10:26:36 +02:00
intel_frontbuffer.h
intel_gpu_commands.h drm/i915: Compute the HWS offsets explicitly 2019-01-25 12:53:15 +00:00
intel_guc_ads.c
intel_guc_ads.h
intel_guc_ct.c
intel_guc_ct.h
intel_guc_fw.c drm/i915: Downgrade scare message for unknown HuC firmware 2019-01-08 22:41:09 +00:00
intel_guc_fw.h
intel_guc_fwif.h
intel_guc_log.c drm/i915: Syntatic sugar for using intel_runtime_pm 2019-01-14 16:18:25 +00:00
intel_guc_log.h
intel_guc_reg.h
intel_guc_submission.c drm/i915/execlists: Suppress preempting self 2019-01-29 20:00:05 +00:00
intel_guc_submission.h
intel_guc.c
intel_guc.h drm/i915: Pull all the reset functionality together into i915_reset.c 2019-01-16 22:45:31 +00:00
intel_gvt.c drm/i915: Enable gfx virtualization for Coffeelake platform 2019-01-10 11:38:34 +08:00
intel_gvt.h
intel_hangcheck.c drm/i915: Drop fake breadcrumb irq 2019-01-29 21:45:30 +00:00
intel_hdcp.c drm/i915: small isolated c99 types to kernel types switch 2019-01-17 09:02:00 +02:00
intel_hdmi.c Merge drm/drm-next into drm-intel-next-queued 2019-01-22 14:51:36 -08:00
intel_hotplug.c drm/i915/hotplug: Track temporary rpm wakeref 2019-01-14 16:18:18 +00:00
intel_huc_fw.c drm/i915: Downgrade scare message for unknown HuC firmware 2019-01-08 22:41:09 +00:00
intel_huc_fw.h
intel_huc.c drm/i915: Syntatic sugar for using intel_runtime_pm 2019-01-14 16:18:25 +00:00
intel_huc.h
intel_i2c.c drm/i915: Markup paired operations on display power domains 2019-01-14 16:18:30 +00:00
intel_lpe_audio.c
intel_lrc_reg.h
intel_lrc.c drm/i915: Expose RPCS (SSEU) configuration to userspace (Gen11 only) 2019-02-05 11:32:03 +00:00
intel_lrc.h drm/i915/perf: lock powergating configuration to default when active 2019-02-05 11:31:52 +00:00
intel_lspcon.c Merge drm/drm-next into drm-intel-next-queued 2019-01-22 14:51:36 -08:00
intel_lvds.c drm/i915/backlight: Restore backlight on resume, v3. 2019-01-24 13:02:08 +01:00
intel_mocs.c drm/i915/icl: Define MOCS table for Icelake 2019-01-24 19:34:34 -08:00
intel_mocs.h drm/i915: drop all drmP.h includes 2019-01-09 10:26:36 +02:00
intel_opregion.c drm/i915: drop all drmP.h includes 2019-01-09 10:26:36 +02:00
intel_opregion.h
intel_overlay.c drm/i915: Remove GPU reset dependence on struct_mutex 2019-01-25 14:27:22 +00:00
intel_panel.c drm/i915/backlight: Fix backlight takeover on LPT, v3. 2019-01-24 13:02:48 +01:00
intel_pipe_crc.c drm/i915: small isolated c99 types to kernel types switch 2019-01-17 09:02:00 +02:00
intel_pm.c drm/i915: Don't use the second dbuf slice on icl 2019-01-31 09:00:08 +02:00
intel_psr.c drm/i915/psr: Allow PSR2 to be enabled when debugfs asks 2019-01-22 16:33:10 -08:00
intel_quirks.c
intel_renderstate_gen6.c
intel_renderstate_gen7.c
intel_renderstate_gen8.c
intel_renderstate_gen9.c
intel_renderstate.h
intel_ringbuffer.c drm/i915: Replace global breadcrumbs with per-context interrupt tracking 2019-01-29 21:45:22 +00:00
intel_ringbuffer.h drm/i915: Allow normal clients to always preempt idle priority clients 2019-02-04 09:47:28 +00:00
intel_runtime_pm.c drm/i915: small isolated c99 types to kernel types switch 2019-01-17 09:02:00 +02:00
intel_sdvo_regs.h
intel_sdvo.c drm/i915/sdvo: switch to kernel types 2019-01-23 10:02:43 +02:00
intel_sideband.c
intel_sprite.c drm/i915: Fix skl srckey mask bits 2019-01-29 18:44:56 +02:00
intel_tv.c drm/i915/tv: Bypass the vertical filter if possible 2019-01-29 23:27:31 +02:00
intel_uc_fw.c drm/i915: Downgrade scare message for unknown HuC firmware 2019-01-08 22:41:09 +00:00
intel_uc_fw.h
intel_uc.c drm/i915: Pull all the reset functionality together into i915_reset.c 2019-01-16 22:45:31 +00:00
intel_uc.h drm/i915/uc: add dev_priv parameter to intel_uc_is_using_* functions 2018-12-31 15:27:23 +02:00
intel_uncore.c drm/i915: Pull all the reset functionality together into i915_reset.c 2019-01-16 22:45:31 +00:00
intel_uncore.h
intel_vbt_defs.h
intel_vdsc.c drm/i915: Markup paired operations on display power domains 2019-01-14 16:18:30 +00:00
intel_wopcm.c drm/i915/uc: add dev_priv parameter to intel_uc_is_using_* functions 2018-12-31 15:27:23 +02:00
intel_wopcm.h
intel_workarounds.c drm/i915/icl: restore WaEnableFloatBlendOptimization 2019-02-01 08:39:53 +00:00
intel_workarounds.h
Kconfig
Kconfig.debug drm/i915: Track all held rpm wakerefs 2019-01-14 16:17:50 +00:00
Makefile drm/i915: Disable -Wuninitialized 2019-01-26 17:07:58 +00:00
vlv_dsi_pll.c drm/i915/dsi: Fix pipe_bpp for handling for 6 bpc pixel-formats 2019-01-21 10:45:23 +01:00
vlv_dsi.c drm/i915/backlight: Restore backlight on resume, v3. 2019-01-24 13:02:08 +01:00