mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-13 02:56:09 +07:00
drm/amd/display : add high part address calculation for underlay
Currently the high part of the address structure is not populated in case of luma and chroma. This patch adds this calculation. Signed-off-by: Shirish S <shirish.s@amd.com> Reviewed-by: Alex Deucher <alexander.deucher@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
3b21b6d239
commit
4d3e00dad8
@ -1771,6 +1771,7 @@ static int fill_plane_attributes_from_fb(struct amdgpu_device *adev,
|
|||||||
{
|
{
|
||||||
uint64_t tiling_flags;
|
uint64_t tiling_flags;
|
||||||
uint64_t fb_location = 0;
|
uint64_t fb_location = 0;
|
||||||
|
uint64_t chroma_addr = 0;
|
||||||
unsigned int awidth;
|
unsigned int awidth;
|
||||||
const struct drm_framebuffer *fb = &amdgpu_fb->base;
|
const struct drm_framebuffer *fb = &amdgpu_fb->base;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
@ -1833,9 +1834,13 @@ static int fill_plane_attributes_from_fb(struct amdgpu_device *adev,
|
|||||||
plane_state->address.type = PLN_ADDR_TYPE_VIDEO_PROGRESSIVE;
|
plane_state->address.type = PLN_ADDR_TYPE_VIDEO_PROGRESSIVE;
|
||||||
plane_state->address.video_progressive.luma_addr.low_part
|
plane_state->address.video_progressive.luma_addr.low_part
|
||||||
= lower_32_bits(fb_location);
|
= lower_32_bits(fb_location);
|
||||||
|
plane_state->address.video_progressive.luma_addr.high_part
|
||||||
|
= upper_32_bits(fb_location);
|
||||||
|
chroma_addr = fb_location + (u64)(awidth * fb->height);
|
||||||
plane_state->address.video_progressive.chroma_addr.low_part
|
plane_state->address.video_progressive.chroma_addr.low_part
|
||||||
= lower_32_bits(fb_location) +
|
= lower_32_bits(chroma_addr);
|
||||||
(awidth * fb->height);
|
plane_state->address.video_progressive.chroma_addr.high_part
|
||||||
|
= upper_32_bits(chroma_addr);
|
||||||
plane_state->plane_size.video.luma_size.x = 0;
|
plane_state->plane_size.video.luma_size.x = 0;
|
||||||
plane_state->plane_size.video.luma_size.y = 0;
|
plane_state->plane_size.video.luma_size.y = 0;
|
||||||
plane_state->plane_size.video.luma_size.width = awidth;
|
plane_state->plane_size.video.luma_size.width = awidth;
|
||||||
|
Loading…
Reference in New Issue
Block a user