]> www.infradead.org Git - users/willy/xarray.git/commitdiff
drm/amdgpu: add asic callback for querying video codec info (v3)
authorAlex Deucher <alexander.deucher@amd.com>
Thu, 7 Jan 2021 22:18:54 +0000 (17:18 -0500)
committerAlex Deucher <alexander.deucher@amd.com>
Fri, 26 Feb 2021 22:23:49 +0000 (17:23 -0500)
This will be used by a new INFO ioctl query to fetch the decode
and encode capabilities from the kernel driver rather than
hardcoding them in mesa.  This gives us more fine grained control
of capabilities using information that is only availabl in the
kernel (e.g., platform limitations or bandwidth restrictions).

v2: reorder the codecs to better align with mesa
v3: add max_pixels_per_frame to handle the portrait case

Reviewed-by: Christian König <christian.koenig@amd.com>
Reviewed-by: Leo Liu <leo.liu@amd.com> (v2)
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/amdgpu.h

index d7efcad65ef774bbb5b5a65b605349ff402396b9..c2cb2f0744f20bba611495240cd718136b5891d3 100644 (file)
@@ -584,6 +584,28 @@ enum amd_reset_method {
        AMD_RESET_METHOD_PCI,
 };
 
+#define AMDGPU_VIDEO_CODEC_TYPE_MPEG2                  0
+#define AMDGPU_VIDEO_CODEC_TYPE_MPEG4                  1
+#define AMDGPU_VIDEO_CODEC_TYPE_VC1                    2
+#define AMDGPU_VIDEO_CODEC_TYPE_MPEG4_AVC              3
+#define AMDGPU_VIDEO_CODEC_TYPE_HEVC                   4
+#define AMDGPU_VIDEO_CODEC_TYPE_JPEG                   5
+#define AMDGPU_VIDEO_CODEC_TYPE_VP9                    6
+#define AMDGPU_VIDEO_CODEC_TYPE_AV1                    7
+
+struct amdgpu_video_codec_info {
+       u32 codec_type;
+       u32 max_width;
+       u32 max_height;
+       u32 max_pixels_per_frame;
+       u32 max_level;
+};
+
+struct amdgpu_video_codecs {
+       const u32 codec_count;
+       const struct amdgpu_video_codec_info *codec_array;
+};
+
 /*
  * ASIC specific functions.
  */
@@ -628,6 +650,9 @@ struct amdgpu_asic_funcs {
        void (*pre_asic_init)(struct amdgpu_device *adev);
        /* enter/exit umd stable pstate */
        int (*update_umd_stable_pstate)(struct amdgpu_device *adev, bool enter);
+       /* query video codecs */
+       int (*query_video_codecs)(struct amdgpu_device *adev, bool encode,
+                                 const struct amdgpu_video_codecs **codecs);
 };
 
 /*
@@ -1222,6 +1247,7 @@ int emu_soc_asic_init(struct amdgpu_device *adev);
 #define amdgpu_asic_pre_asic_init(adev) (adev)->asic_funcs->pre_asic_init((adev))
 #define amdgpu_asic_update_umd_stable_pstate(adev, enter) \
        ((adev)->asic_funcs->update_umd_stable_pstate ? (adev)->asic_funcs->update_umd_stable_pstate((adev), (enter)) : 0)
+#define amdgpu_asic_query_video_codecs(adev, e, c) (adev)->asic_funcs->query_video_codecs((adev), (e), (c))
 
 #define amdgpu_inc_vram_lost(adev) atomic_inc(&((adev)->vram_lost_counter));