[PATCH] drm/arm/hdlcd: Take over EFI framebuffer properly
Robin Murphy
robin.murphy at arm.com
Tue Jun 14 14:06:16 PDT 2022
On 2022-06-14 14:48, Thomas Zimmermann wrote:
> Hi
>
> Am 14.06.22 um 15:04 schrieb Robin Murphy:
>> The Arm Juno board EDK2 port has provided an EFI GOP display via HDLCD0
>> for some time now, which works nicely as an early framebuffer. However,
>> once the HDLCD driver probes and takes over the hardware, it should
>> take over the logical framebuffer as well, otherwise the now-defunct GOP
>> device hangs about and virtual console output inevitably disappears into
>> the wrong place most of the time.
>>
>> Signed-off-by: Robin Murphy <robin.murphy at arm.com>
>> ---
>> drivers/gpu/drm/arm/hdlcd_drv.c | 2 ++
>> 1 file changed, 2 insertions(+)
>>
>> diff --git a/drivers/gpu/drm/arm/hdlcd_drv.c
>> b/drivers/gpu/drm/arm/hdlcd_drv.c
>> index af59077a5481..a5d04884658b 100644
>> --- a/drivers/gpu/drm/arm/hdlcd_drv.c
>> +++ b/drivers/gpu/drm/arm/hdlcd_drv.c
>> @@ -331,6 +331,8 @@ static int hdlcd_drm_bind(struct device *dev)
>> goto err_vblank;
>> }
>> + drm_fb_helper_remove_conflicting_framebuffers(NULL, "hdlcd", false);
>> +
>
> In addition to what Javier said, it appears to be too late to call this
> function. If anything her etouches hardware, you might accidentally
> interfere with the EFI-related driver. Rather call it at the top of
> ldlcd_drm_bind().
OK, thanks for the info. I mostly just copied the pattern from the
simplest-looking other users (sun4i, tegra, vc4) who all seemed to call
it fairly late, and indeed naively it seemed logical not to do it *too*
early when there's more chance we might fail to bind and leave the user
with no framebuffer at all. In particular, waiting until we've bound the
HDMI encoder seems like a good idea in the case of the Juno board (which
is the only real HDLCD user), as the I2C bus often gets stuck if the
System Control Processor is having a bad day. I also don't believe
there's anything here that would affect efifb more than the fact that
once the DRM CRTC is alive we simply stop scanning out from the region
of memory that efifb is managing, but if it's considered good practice
to do this early then I can certainly make that change too.
Cheers,
Robin.
More information about the linux-arm-kernel
mailing list