[PATCH] drm/fbdev-generic: optimize out a redundant assignment clause
Lucas De Marchi
lucas.demarchi at intel.com
Thu Mar 30 07:11:21 UTC 2023
On Thu, Mar 30, 2023 at 08:57:36AM +0200, Thomas Zimmermann wrote:
>Hi
>
>Am 30.03.23 um 06:17 schrieb Lucas De Marchi:
>>On Wed, Mar 29, 2023 at 11:04:17AM +0200, Thomas Zimmermann wrote:
>>>(cc'ing Lucas)
>>>
>>>Hi
>>>
>>>Am 25.03.23 um 08:46 schrieb Sui Jingfeng:
>>>> The assignment already done in drm_client_buffer_vmap(),
>>>> just trival clean, no functional change.
>>>>
>>>>Signed-off-by: Sui Jingfeng <15330273260 at 189.cn>
>>>>---
>>>> drivers/gpu/drm/drm_fbdev_generic.c | 5 ++---
>>>> 1 file changed, 2 insertions(+), 3 deletions(-)
>>>>
>>>>diff --git a/drivers/gpu/drm/drm_fbdev_generic.c
>>>>b/drivers/gpu/drm/drm_fbdev_generic.c
>>>>index 4d6325e91565..1da48e71c7f1 100644
>>>>--- a/drivers/gpu/drm/drm_fbdev_generic.c
>>>>+++ b/drivers/gpu/drm/drm_fbdev_generic.c
>>>>@@ -282,7 +282,7 @@ static int drm_fbdev_damage_blit(struct
>>>>drm_fb_helper *fb_helper,
>>>> struct drm_clip_rect *clip)
>>>> {
>>>> struct drm_client_buffer *buffer = fb_helper->buffer;
>>>>- struct iosys_map map, dst;
>>>>+ struct iosys_map map;
>>>> int ret;
>>>> /*
>>>>@@ -302,8 +302,7 @@ static int drm_fbdev_damage_blit(struct
>>>>drm_fb_helper *fb_helper,
>>>> if (ret)
>>>> goto out;
>>>>- dst = map;
>>>>- drm_fbdev_damage_blit_real(fb_helper, clip, &dst);
>>>>+ drm_fbdev_damage_blit_real(fb_helper, clip, &map);
>>>
>>>I see what you're doing and it's probably correct in this case.
>>>
>>>But there's a larger issue with this iosys interfaces. Sometimes
>>>the address has to be modified (see calls of iosys_map_incr()).
>>>That can prevent incorrect uses of the mapping in other places,
>>>especially in unmap code.
>>
>>using a initializer for the cases it's needed IMO would make these kind
>>of problems go away, because then the intent is explicit
>>
>>>
>>>I think it would make sense to consider a separate structure for
>>>the I/O location. The buffer as a whole would still be represented
>>>by struct iosys_map. And that new structure, let's call it struct
>>>iosys_ptr, would point to an actual location within the buffer's
>>
>>sounds fine to me, but I'd have to take a deeper look later (or when
>>someone writes the patch). It seems we'd replicate almost the entire
>>API to just accomodate the 2 structs. And the different types will lead
>>to confusion when one or the other should be used
>
>I think we can split the current interface onto two categories:
>mapping and I/O. The former would use iosys_map and the latter would
>use iosys_ptr. And we'd need a helper that turns gets a ptr for a
>given map.
>
>If I find the tine, I'll probably type up a patch.
yeah, a split would make it better rather than just make iosys_ptr
replace the current cases where we copy the struct. In this case most
places passing a buffer around in the same driver would migrate to
iosys_ptr.
thanks
Lucas De Marchi
>
>Best regards
>Thomas
>
>>
>>thanks
>>Lucas De Marchi
>>
>>>memory range. A few locations and helpers would need changes, but
>>>there are not so many callers that it's an issue. This would also
>>>allow for a few debugging tests that ensure that iosys_ptr always
>>>operates within the bounds of an iosys_map.
>>>
>>>I've long considered this idea, but there was no pressure to work
>>>on it. Maybe now.
>>>
>>>Best regards
>>>Thomas
>>>
>>>> drm_client_buffer_vunmap(buffer);
>>>
>>>--
>>>Thomas Zimmermann
>>>Graphics Driver Developer
>>>SUSE Software Solutions Germany GmbH
>>>Maxfeldstr. 5, 90409 Nürnberg, Germany
>>>(HRB 36809, AG Nürnberg)
>>>Geschäftsführer: Ivo Totev
>>
>>
>>
>
>--
>Thomas Zimmermann
>Graphics Driver Developer
>SUSE Software Solutions Germany GmbH
>Maxfeldstr. 5, 90409 Nürnberg, Germany
>(HRB 36809, AG Nürnberg)
>Geschäftsführer: Ivo Totev
More information about the dri-devel
mailing list