[PATCH v2] drm/amd/amdgpu: Add Descriptions to Process Isolation and Cleaner Shader Sysfs Functions
Alex Deucher
alexdeucher at gmail.com
Thu Dec 5 15:56:01 UTC 2024
On Thu, Dec 5, 2024 at 10:30 AM Srinivasan Shanmugam
<srinivasan.shanmugam at amd.com> wrote:
>
> This update adds explanations to key functions related to process
> isolation and cleaner shader execution sysfs interfaces.
>
> - `amdgpu_gfx_set_run_cleaner_shader`: Describes how to manually run a
> cleaner shader, which clears the Local Data Store (LDS) and General
> Purpose Registers (GPRs) to ensure data isolation between GPU workloads.
>
> - `amdgpu_gfx_get_enforce_isolation`: Describes how to query the current
> settings of the 'enforce_isolation' feature for each GPU partition.
>
> - `amdgpu_gfx_set_enforce_isolation`: Describes how to enable or disable
> process isolation for GPU partitions through the sysfs interface.
>
> Cc: Christian König <christian.koenig at amd.com>
> Cc: Alex Deucher <alexander.deucher at amd.com>
> Signed-off-by: Srinivasan Shanmugam <srinivasan.shanmugam at amd.com>
> Suggested-by: Alex Deucher <alexander.deucher at amd.com>
Reviewed-by: Alex Deucher <alexander.deucher at amd.com>
> ---
> v2:
> - Incorporated feedbacks for function descriptions (Alex)
>
> drivers/gpu/drm/amd/amdgpu/amdgpu_gfx.c | 45 +++++++++++++++++++++++++
> 1 file changed, 45 insertions(+)
>
> diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_gfx.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_gfx.c
> index e54f42e3797e..7e2ad7818903 100644
> --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_gfx.c
> +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_gfx.c
> @@ -1484,6 +1484,24 @@ static int amdgpu_gfx_run_cleaner_shader(struct amdgpu_device *adev, int xcp_id)
> return 0;
> }
>
> +/**
> + * amdgpu_gfx_set_run_cleaner_shader - Execute the AMDGPU GFX Cleaner Shader
> + * @dev: The device structure
> + * @attr: The device attribute structure
> + * @buf: The buffer containing the input data
> + * @count: The size of the input data
> + *
> + * Provides the sysfs interface to manually run a cleaner shader, which is
> + * used to clear the GPU state between different tasks. Writing a value to the
> + * 'run_cleaner_shader' sysfs file triggers the cleaner shader execution.
> + * The value written corresponds to the partition index on multi-partition
> + * devices. On single-partition devices, the value should be '0'.
> + *
> + * The cleaner shader clears the Local Data Store (LDS) and General Purpose
> + * Registers (GPRs) to ensure data isolation between GPU workloads.
> + *
> + * Return: The number of bytes written to the sysfs file.
> + */
> static ssize_t amdgpu_gfx_set_run_cleaner_shader(struct device *dev,
> struct device_attribute *attr,
> const char *buf,
> @@ -1532,6 +1550,19 @@ static ssize_t amdgpu_gfx_set_run_cleaner_shader(struct device *dev,
> return count;
> }
>
> +/**
> + * amdgpu_gfx_get_enforce_isolation - Query AMDGPU GFX Enforce Isolation Settings
> + * @dev: The device structure
> + * @attr: The device attribute structure
> + * @buf: The buffer to store the output data
> + *
> + * Provides the sysfs read interface to get the current settings of the 'enforce_isolation'
> + * feature for each GPU partition. Reading from the 'enforce_isolation'
> + * sysfs file returns the isolation settings for all partitions, where '0'
> + * indicates disabled and '1' indicates enabled.
> + *
> + * Return: The number of bytes read from the sysfs file.
> + */
> static ssize_t amdgpu_gfx_get_enforce_isolation(struct device *dev,
> struct device_attribute *attr,
> char *buf)
> @@ -1555,6 +1586,20 @@ static ssize_t amdgpu_gfx_get_enforce_isolation(struct device *dev,
> return size;
> }
>
> +/**
> + * amdgpu_gfx_set_enforce_isolation - Control AMDGPU GFX Enforce Isolation
> + * @dev: The device structure
> + * @attr: The device attribute structure
> + * @buf: The buffer containing the input data
> + * @count: The size of the input data
> + *
> + * This function allows control over the 'enforce_isolation' feature, which
> + * serializes access to the graphics engine. Writing '1' or '0' to the
> + * 'enforce_isolation' sysfs file enables or disables process isolation for
> + * each partition. The input should specify the setting for all partitions.
> + *
> + * Return: The number of bytes written to the sysfs file.
> + */
> static ssize_t amdgpu_gfx_set_enforce_isolation(struct device *dev,
> struct device_attribute *attr,
> const char *buf, size_t count)
> --
> 2.34.1
>
More information about the amd-gfx
mailing list