Re: [PATCH] drm/fb_helper: Allow leaking fbdev smem_start

2018-09-24 Thread Daniel Vetter
On Mon, Sep 24, 2018 at 10:44:05AM +0200, Neil Armstrong wrote:
> Hi Maxime, Daniel,
> 
> On 22/09/2018 10:56, Daniel Vetter wrote:
> > On Fri, Sep 21, 2018 at 04:07:40PM +0200, Maxime Ripard wrote:
> >> Hi,
> >>
> >> On Thu, Sep 20, 2018 at 03:04:12PM +0200, Neil Armstrong wrote:
> >>> Since "drm/fb: Stop leaking physical address", the default behaviour of
> >>> the DRM fbdev emulation is to set the smem_base to 0 and pass the new
> >>> FBINFO_HIDE_SMEM_START flag.
> >>>
> >>> The main reason is to avoid leaking physical addresse to user-space, and
> >>> it follows a general move over the kernel code to avoid user-space to
> >>> manipulate physical addresses and then use some other mechanisms like
> >>> dma-buf to transfer physical buffer handles over multiple subsystems.
> >>>
> >>> But, a lot of devices depends on closed sources binaries to enable
> >>> OpenGL hardware acceleration that uses this smem_start value to
> >>> pass physical addresses to out-of-tree modules in order to render
> >>> into these physical adresses. These should use dma-buf buffers allocated
> >>> from the DRM display device instead and stop relying on fbdev 
> >>> overallocation
> >>> to gather DMA memory (some HW vendors delivers GBM and Wayland capable
> >>> binaries, but older unsupported devices won't have these new binaries
> >>> and are doomed until an Open Source solution like Lima finalizes).
> >>>
> >>> Since these devices heavily depends on this kind of software and because
> >>> the smem_start population was available for years, it's a breakage to
> >>> stop leaking smem_start without any alternative solutions.
> >>>
> >>> This patch adds a Kconfig depending on the EXPERT config and an unsafe
> >>> kernel module parameter tainting the kernel when enabled.
> >>>
> >>> A clear comment and Kconfig help text was added to clarify why and when
> >>> this patch should be reverted, but in the meantime it's a necessary
> >>> feature to keep.
> >>>
> >>> Cc: Dave Airlie 
> >>> Cc: Daniel Vetter 
> >>> Cc: Bartlomiej Zolnierkiewicz 
> >>> Cc: Noralf Trønnes 
> >>> Cc: Maxime Ripard 
> >>> Cc: Eric Anholt 
> >>> Cc: Lucas Stach 
> >>> Cc: Rob Clark 
> >>> Cc: Ben Skeggs 
> >>> Cc: Christian König 
> >>> Signed-off-by: Neil Armstrong 
> >>> ---
> >>>  drivers/gpu/drm/Kconfig | 15 +++
> >>>  drivers/gpu/drm/drm_fb_helper.c | 33 +++--
> >>>  2 files changed, 46 insertions(+), 2 deletions(-)
> >>>
> >>> diff --git a/drivers/gpu/drm/Kconfig b/drivers/gpu/drm/Kconfig
> >>> index 8871b3f..b07c298 100644
> >>> --- a/drivers/gpu/drm/Kconfig
> >>> +++ b/drivers/gpu/drm/Kconfig
> >>> @@ -110,6 +110,21 @@ config DRM_FBDEV_OVERALLOC
> >>> is 100. Typical values for double buffering will be 200,
> >>> triple buffering 300.
> >>>  
> >>> +config DRM_FBDEV_LEAK_PHYS_SMEM
> >>> + bool "Shamelessly allow leaking of fbdev physical address (DANGEROUS)"
> >>> + depends on DRM_FBDEV_EMULATION && EXPERT
> >>> + default n
> >>> + help
> >>> +   In order to keep user-space compatibility, we want in certain
> >>> +   use-cases to keep leaking the fbdev physical address to the
> >>> +   user-space program handling the fbdev buffer.
> >>> +   This option is a shame and should be removed as soon as possible
> >>> +   and be considered as a broken and legacy behaviour from a modern
> >>> +   fbdev device driver.
> > 
> > s/shame/not supported by upstream developers/
> 
> Ack
> 
> > 
> > And maybe add "Please send any bug reports when using this to your
> > proprietary software vendor that requires this."
> 
> It's (somehow) on the following line :
> 
> >>> +   If in doubt, say "N" or spread the word to your closed source
> >>> +   library vendor.
> 
> I will make it even scarier !
> 
> > 
> > I'd also be in favour of just calling this the ARM Mali blob on
> > $affected_devices. Makes it easier for people to find the magic knob
> > they're looking for, if they're unlucky enough to have such a soc.
> 
> I'm not sure it's only for Mali... Anyway I'll add "Mali" to help
> people findind it.
> 
> > 
> >>> +
> >>> +   If in doubt, say "N" or spread the word to your closed source
> >>> +   library vendor.
> >>> +
> >>>  config DRM_LOAD_EDID_FIRMWARE
> >>>   bool "Allow to specify an EDID data set instead of probing for it"
> >>>   depends on DRM
> >>> diff --git a/drivers/gpu/drm/drm_fb_helper.c 
> >>> b/drivers/gpu/drm/drm_fb_helper.c
> >>> index bf2190c..a354944 100644
> >>> --- a/drivers/gpu/drm/drm_fb_helper.c
> >>> +++ b/drivers/gpu/drm/drm_fb_helper.c
> >>> @@ -56,6 +56,25 @@ MODULE_PARM_DESC(drm_fbdev_overalloc,
> >>>"Overallocation of the fbdev buffer (%) [default="
> >>>__MODULE_STRING(CONFIG_DRM_FBDEV_OVERALLOC) "]");
> >>>  
> >>> +/*
> >>> + * In order to keep user-space compatibility, we want in certain 
> >>> use-cases
> >>> + * to keep leaking the fbdev physical address to the user-space program
> >>> + * handling the fbdev buffer.
> >>> + * This is a bad habit essentially 

Re: [PATCH] drm/fb_helper: Allow leaking fbdev smem_start

2018-09-24 Thread Neil Armstrong
Hi Maxime, Daniel,

On 22/09/2018 10:56, Daniel Vetter wrote:
> On Fri, Sep 21, 2018 at 04:07:40PM +0200, Maxime Ripard wrote:
>> Hi,
>>
>> On Thu, Sep 20, 2018 at 03:04:12PM +0200, Neil Armstrong wrote:
>>> Since "drm/fb: Stop leaking physical address", the default behaviour of
>>> the DRM fbdev emulation is to set the smem_base to 0 and pass the new
>>> FBINFO_HIDE_SMEM_START flag.
>>>
>>> The main reason is to avoid leaking physical addresse to user-space, and
>>> it follows a general move over the kernel code to avoid user-space to
>>> manipulate physical addresses and then use some other mechanisms like
>>> dma-buf to transfer physical buffer handles over multiple subsystems.
>>>
>>> But, a lot of devices depends on closed sources binaries to enable
>>> OpenGL hardware acceleration that uses this smem_start value to
>>> pass physical addresses to out-of-tree modules in order to render
>>> into these physical adresses. These should use dma-buf buffers allocated
>>> from the DRM display device instead and stop relying on fbdev overallocation
>>> to gather DMA memory (some HW vendors delivers GBM and Wayland capable
>>> binaries, but older unsupported devices won't have these new binaries
>>> and are doomed until an Open Source solution like Lima finalizes).
>>>
>>> Since these devices heavily depends on this kind of software and because
>>> the smem_start population was available for years, it's a breakage to
>>> stop leaking smem_start without any alternative solutions.
>>>
>>> This patch adds a Kconfig depending on the EXPERT config and an unsafe
>>> kernel module parameter tainting the kernel when enabled.
>>>
>>> A clear comment and Kconfig help text was added to clarify why and when
>>> this patch should be reverted, but in the meantime it's a necessary
>>> feature to keep.
>>>
>>> Cc: Dave Airlie 
>>> Cc: Daniel Vetter 
>>> Cc: Bartlomiej Zolnierkiewicz 
>>> Cc: Noralf Trønnes 
>>> Cc: Maxime Ripard 
>>> Cc: Eric Anholt 
>>> Cc: Lucas Stach 
>>> Cc: Rob Clark 
>>> Cc: Ben Skeggs 
>>> Cc: Christian König 
>>> Signed-off-by: Neil Armstrong 
>>> ---
>>>  drivers/gpu/drm/Kconfig | 15 +++
>>>  drivers/gpu/drm/drm_fb_helper.c | 33 +++--
>>>  2 files changed, 46 insertions(+), 2 deletions(-)
>>>
>>> diff --git a/drivers/gpu/drm/Kconfig b/drivers/gpu/drm/Kconfig
>>> index 8871b3f..b07c298 100644
>>> --- a/drivers/gpu/drm/Kconfig
>>> +++ b/drivers/gpu/drm/Kconfig
>>> @@ -110,6 +110,21 @@ config DRM_FBDEV_OVERALLOC
>>>   is 100. Typical values for double buffering will be 200,
>>>   triple buffering 300.
>>>  
>>> +config DRM_FBDEV_LEAK_PHYS_SMEM
>>> +   bool "Shamelessly allow leaking of fbdev physical address (DANGEROUS)"
>>> +   depends on DRM_FBDEV_EMULATION && EXPERT
>>> +   default n
>>> +   help
>>> + In order to keep user-space compatibility, we want in certain
>>> + use-cases to keep leaking the fbdev physical address to the
>>> + user-space program handling the fbdev buffer.
>>> + This option is a shame and should be removed as soon as possible
>>> + and be considered as a broken and legacy behaviour from a modern
>>> + fbdev device driver.
> 
> s/shame/not supported by upstream developers/

Ack

> 
> And maybe add "Please send any bug reports when using this to your
> proprietary software vendor that requires this."

It's (somehow) on the following line :

>>> + If in doubt, say "N" or spread the word to your closed source
>>> + library vendor.

I will make it even scarier !

> 
> I'd also be in favour of just calling this the ARM Mali blob on
> $affected_devices. Makes it easier for people to find the magic knob
> they're looking for, if they're unlucky enough to have such a soc.

I'm not sure it's only for Mali... Anyway I'll add "Mali" to help
people findind it.

> 
>>> +
>>> + If in doubt, say "N" or spread the word to your closed source
>>> + library vendor.
>>> +
>>>  config DRM_LOAD_EDID_FIRMWARE
>>> bool "Allow to specify an EDID data set instead of probing for it"
>>> depends on DRM
>>> diff --git a/drivers/gpu/drm/drm_fb_helper.c 
>>> b/drivers/gpu/drm/drm_fb_helper.c
>>> index bf2190c..a354944 100644
>>> --- a/drivers/gpu/drm/drm_fb_helper.c
>>> +++ b/drivers/gpu/drm/drm_fb_helper.c
>>> @@ -56,6 +56,25 @@ MODULE_PARM_DESC(drm_fbdev_overalloc,
>>>  "Overallocation of the fbdev buffer (%) [default="
>>>  __MODULE_STRING(CONFIG_DRM_FBDEV_OVERALLOC) "]");
>>>  
>>> +/*
>>> + * In order to keep user-space compatibility, we want in certain use-cases
>>> + * to keep leaking the fbdev physical address to the user-space program
>>> + * handling the fbdev buffer.
>>> + * This is a bad habit essentially kept into closed source opengl driver
>>> + * that should really be moved into open-source upstream projects instead
>>> + * of using legacy physical addresses in user space to communicate with
>>> + * other out-of-tree kernel modules.
>>> + *
>>> + * This module_param 

Re: [PATCH] drm/fb_helper: Allow leaking fbdev smem_start

2018-09-22 Thread Daniel Vetter
On Fri, Sep 21, 2018 at 04:07:40PM +0200, Maxime Ripard wrote:
> Hi,
> 
> On Thu, Sep 20, 2018 at 03:04:12PM +0200, Neil Armstrong wrote:
> > Since "drm/fb: Stop leaking physical address", the default behaviour of
> > the DRM fbdev emulation is to set the smem_base to 0 and pass the new
> > FBINFO_HIDE_SMEM_START flag.
> > 
> > The main reason is to avoid leaking physical addresse to user-space, and
> > it follows a general move over the kernel code to avoid user-space to
> > manipulate physical addresses and then use some other mechanisms like
> > dma-buf to transfer physical buffer handles over multiple subsystems.
> > 
> > But, a lot of devices depends on closed sources binaries to enable
> > OpenGL hardware acceleration that uses this smem_start value to
> > pass physical addresses to out-of-tree modules in order to render
> > into these physical adresses. These should use dma-buf buffers allocated
> > from the DRM display device instead and stop relying on fbdev overallocation
> > to gather DMA memory (some HW vendors delivers GBM and Wayland capable
> > binaries, but older unsupported devices won't have these new binaries
> > and are doomed until an Open Source solution like Lima finalizes).
> > 
> > Since these devices heavily depends on this kind of software and because
> > the smem_start population was available for years, it's a breakage to
> > stop leaking smem_start without any alternative solutions.
> > 
> > This patch adds a Kconfig depending on the EXPERT config and an unsafe
> > kernel module parameter tainting the kernel when enabled.
> > 
> > A clear comment and Kconfig help text was added to clarify why and when
> > this patch should be reverted, but in the meantime it's a necessary
> > feature to keep.
> > 
> > Cc: Dave Airlie 
> > Cc: Daniel Vetter 
> > Cc: Bartlomiej Zolnierkiewicz 
> > Cc: Noralf Trønnes 
> > Cc: Maxime Ripard 
> > Cc: Eric Anholt 
> > Cc: Lucas Stach 
> > Cc: Rob Clark 
> > Cc: Ben Skeggs 
> > Cc: Christian König 
> > Signed-off-by: Neil Armstrong 
> > ---
> >  drivers/gpu/drm/Kconfig | 15 +++
> >  drivers/gpu/drm/drm_fb_helper.c | 33 +++--
> >  2 files changed, 46 insertions(+), 2 deletions(-)
> > 
> > diff --git a/drivers/gpu/drm/Kconfig b/drivers/gpu/drm/Kconfig
> > index 8871b3f..b07c298 100644
> > --- a/drivers/gpu/drm/Kconfig
> > +++ b/drivers/gpu/drm/Kconfig
> > @@ -110,6 +110,21 @@ config DRM_FBDEV_OVERALLOC
> >   is 100. Typical values for double buffering will be 200,
> >   triple buffering 300.
> >  
> > +config DRM_FBDEV_LEAK_PHYS_SMEM
> > +   bool "Shamelessly allow leaking of fbdev physical address (DANGEROUS)"
> > +   depends on DRM_FBDEV_EMULATION && EXPERT
> > +   default n
> > +   help
> > + In order to keep user-space compatibility, we want in certain
> > + use-cases to keep leaking the fbdev physical address to the
> > + user-space program handling the fbdev buffer.
> > + This option is a shame and should be removed as soon as possible
> > + and be considered as a broken and legacy behaviour from a modern
> > + fbdev device driver.

s/shame/not supported by upstream developers/

And maybe add "Please send any bug reports when using this to your
proprietary software vendor that requires this."

I'd also be in favour of just calling this the ARM Mali blob on
$affected_devices. Makes it easier for people to find the magic knob
they're looking for, if they're unlucky enough to have such a soc.

> > +
> > + If in doubt, say "N" or spread the word to your closed source
> > + library vendor.
> > +
> >  config DRM_LOAD_EDID_FIRMWARE
> > bool "Allow to specify an EDID data set instead of probing for it"
> > depends on DRM
> > diff --git a/drivers/gpu/drm/drm_fb_helper.c 
> > b/drivers/gpu/drm/drm_fb_helper.c
> > index bf2190c..a354944 100644
> > --- a/drivers/gpu/drm/drm_fb_helper.c
> > +++ b/drivers/gpu/drm/drm_fb_helper.c
> > @@ -56,6 +56,25 @@ MODULE_PARM_DESC(drm_fbdev_overalloc,
> >  "Overallocation of the fbdev buffer (%) [default="
> >  __MODULE_STRING(CONFIG_DRM_FBDEV_OVERALLOC) "]");
> >  
> > +/*
> > + * In order to keep user-space compatibility, we want in certain use-cases
> > + * to keep leaking the fbdev physical address to the user-space program
> > + * handling the fbdev buffer.
> > + * This is a bad habit essentially kept into closed source opengl driver
> > + * that should really be moved into open-source upstream projects instead
> > + * of using legacy physical addresses in user space to communicate with
> > + * other out-of-tree kernel modules.
> > + *
> > + * This module_param *should* be removed as soon as possible and be
> > + * considered as a broken and legacy behaviour from a modern fbdev device.
> > + */
> > +#if IS_ENABLED(CONFIG_DRM_FBDEV_LEAK_PHYS_SMEM)
> > +static bool drm_leak_fbdev_smem = false;
> > +module_param_unsafe(drm_leak_fbdev_smem, bool, 0600);
> > +MODULE_PARM_DESC(fbdev_emulation,
> > +   

Re: [PATCH] drm/fb_helper: Allow leaking fbdev smem_start

2018-09-21 Thread Maxime Ripard
Hi,

On Thu, Sep 20, 2018 at 03:04:12PM +0200, Neil Armstrong wrote:
> Since "drm/fb: Stop leaking physical address", the default behaviour of
> the DRM fbdev emulation is to set the smem_base to 0 and pass the new
> FBINFO_HIDE_SMEM_START flag.
> 
> The main reason is to avoid leaking physical addresse to user-space, and
> it follows a general move over the kernel code to avoid user-space to
> manipulate physical addresses and then use some other mechanisms like
> dma-buf to transfer physical buffer handles over multiple subsystems.
> 
> But, a lot of devices depends on closed sources binaries to enable
> OpenGL hardware acceleration that uses this smem_start value to
> pass physical addresses to out-of-tree modules in order to render
> into these physical adresses. These should use dma-buf buffers allocated
> from the DRM display device instead and stop relying on fbdev overallocation
> to gather DMA memory (some HW vendors delivers GBM and Wayland capable
> binaries, but older unsupported devices won't have these new binaries
> and are doomed until an Open Source solution like Lima finalizes).
> 
> Since these devices heavily depends on this kind of software and because
> the smem_start population was available for years, it's a breakage to
> stop leaking smem_start without any alternative solutions.
> 
> This patch adds a Kconfig depending on the EXPERT config and an unsafe
> kernel module parameter tainting the kernel when enabled.
> 
> A clear comment and Kconfig help text was added to clarify why and when
> this patch should be reverted, but in the meantime it's a necessary
> feature to keep.
> 
> Cc: Dave Airlie 
> Cc: Daniel Vetter 
> Cc: Bartlomiej Zolnierkiewicz 
> Cc: Noralf Trønnes 
> Cc: Maxime Ripard 
> Cc: Eric Anholt 
> Cc: Lucas Stach 
> Cc: Rob Clark 
> Cc: Ben Skeggs 
> Cc: Christian König 
> Signed-off-by: Neil Armstrong 
> ---
>  drivers/gpu/drm/Kconfig | 15 +++
>  drivers/gpu/drm/drm_fb_helper.c | 33 +++--
>  2 files changed, 46 insertions(+), 2 deletions(-)
> 
> diff --git a/drivers/gpu/drm/Kconfig b/drivers/gpu/drm/Kconfig
> index 8871b3f..b07c298 100644
> --- a/drivers/gpu/drm/Kconfig
> +++ b/drivers/gpu/drm/Kconfig
> @@ -110,6 +110,21 @@ config DRM_FBDEV_OVERALLOC
> is 100. Typical values for double buffering will be 200,
> triple buffering 300.
>  
> +config DRM_FBDEV_LEAK_PHYS_SMEM
> + bool "Shamelessly allow leaking of fbdev physical address (DANGEROUS)"
> + depends on DRM_FBDEV_EMULATION && EXPERT
> + default n
> + help
> +   In order to keep user-space compatibility, we want in certain
> +   use-cases to keep leaking the fbdev physical address to the
> +   user-space program handling the fbdev buffer.
> +   This option is a shame and should be removed as soon as possible
> +   and be considered as a broken and legacy behaviour from a modern
> +   fbdev device driver.
> +
> +   If in doubt, say "N" or spread the word to your closed source
> +   library vendor.
> +
>  config DRM_LOAD_EDID_FIRMWARE
>   bool "Allow to specify an EDID data set instead of probing for it"
>   depends on DRM
> diff --git a/drivers/gpu/drm/drm_fb_helper.c b/drivers/gpu/drm/drm_fb_helper.c
> index bf2190c..a354944 100644
> --- a/drivers/gpu/drm/drm_fb_helper.c
> +++ b/drivers/gpu/drm/drm_fb_helper.c
> @@ -56,6 +56,25 @@ MODULE_PARM_DESC(drm_fbdev_overalloc,
>"Overallocation of the fbdev buffer (%) [default="
>__MODULE_STRING(CONFIG_DRM_FBDEV_OVERALLOC) "]");
>  
> +/*
> + * In order to keep user-space compatibility, we want in certain use-cases
> + * to keep leaking the fbdev physical address to the user-space program
> + * handling the fbdev buffer.
> + * This is a bad habit essentially kept into closed source opengl driver
> + * that should really be moved into open-source upstream projects instead
> + * of using legacy physical addresses in user space to communicate with
> + * other out-of-tree kernel modules.
> + *
> + * This module_param *should* be removed as soon as possible and be
> + * considered as a broken and legacy behaviour from a modern fbdev device.
> + */
> +#if IS_ENABLED(CONFIG_DRM_FBDEV_LEAK_PHYS_SMEM)
> +static bool drm_leak_fbdev_smem = false;
> +module_param_unsafe(drm_leak_fbdev_smem, bool, 0600);
> +MODULE_PARM_DESC(fbdev_emulation,
> +  "Allow unsafe leaking fbdev physical smem address 
> [default=false]");
> +#endif
> +
>  static LIST_HEAD(kernel_fb_helper_list);
>  static DEFINE_MUTEX(kernel_fb_helper_lock);
>  
> @@ -2673,8 +2692,12 @@ __drm_fb_helper_initial_config_and_unlock(struct 
> drm_fb_helper *fb_helper,
>  
>   info = fb_helper->fbdev;
>   info->var.pixclock = 0;
> - /* don't leak any physical addresses to userspace */
> - info->flags |= FBINFO_HIDE_SMEM_START;
> + /* Shamelessly allow physical address leaking to userspace */
> +#if IS_ENABLED(CONFIG_DRM_FBDEV_LEAK_PHYS_SMEM)
> +

[PATCH] drm/fb_helper: Allow leaking fbdev smem_start

2018-09-20 Thread Neil Armstrong
Since "drm/fb: Stop leaking physical address", the default behaviour of
the DRM fbdev emulation is to set the smem_base to 0 and pass the new
FBINFO_HIDE_SMEM_START flag.

The main reason is to avoid leaking physical addresse to user-space, and
it follows a general move over the kernel code to avoid user-space to
manipulate physical addresses and then use some other mechanisms like
dma-buf to transfer physical buffer handles over multiple subsystems.

But, a lot of devices depends on closed sources binaries to enable
OpenGL hardware acceleration that uses this smem_start value to
pass physical addresses to out-of-tree modules in order to render
into these physical adresses. These should use dma-buf buffers allocated
from the DRM display device instead and stop relying on fbdev overallocation
to gather DMA memory (some HW vendors delivers GBM and Wayland capable
binaries, but older unsupported devices won't have these new binaries
and are doomed until an Open Source solution like Lima finalizes).

Since these devices heavily depends on this kind of software and because
the smem_start population was available for years, it's a breakage to
stop leaking smem_start without any alternative solutions.

This patch adds a Kconfig depending on the EXPERT config and an unsafe
kernel module parameter tainting the kernel when enabled.

A clear comment and Kconfig help text was added to clarify why and when
this patch should be reverted, but in the meantime it's a necessary
feature to keep.

Cc: Dave Airlie 
Cc: Daniel Vetter 
Cc: Bartlomiej Zolnierkiewicz 
Cc: Noralf Trønnes 
Cc: Maxime Ripard 
Cc: Eric Anholt 
Cc: Lucas Stach 
Cc: Rob Clark 
Cc: Ben Skeggs 
Cc: Christian König 
Signed-off-by: Neil Armstrong 
---
 drivers/gpu/drm/Kconfig | 15 +++
 drivers/gpu/drm/drm_fb_helper.c | 33 +++--
 2 files changed, 46 insertions(+), 2 deletions(-)

diff --git a/drivers/gpu/drm/Kconfig b/drivers/gpu/drm/Kconfig
index 8871b3f..b07c298 100644
--- a/drivers/gpu/drm/Kconfig
+++ b/drivers/gpu/drm/Kconfig
@@ -110,6 +110,21 @@ config DRM_FBDEV_OVERALLOC
  is 100. Typical values for double buffering will be 200,
  triple buffering 300.
 
+config DRM_FBDEV_LEAK_PHYS_SMEM
+   bool "Shamelessly allow leaking of fbdev physical address (DANGEROUS)"
+   depends on DRM_FBDEV_EMULATION && EXPERT
+   default n
+   help
+ In order to keep user-space compatibility, we want in certain
+ use-cases to keep leaking the fbdev physical address to the
+ user-space program handling the fbdev buffer.
+ This option is a shame and should be removed as soon as possible
+ and be considered as a broken and legacy behaviour from a modern
+ fbdev device driver.
+
+ If in doubt, say "N" or spread the word to your closed source
+ library vendor.
+
 config DRM_LOAD_EDID_FIRMWARE
bool "Allow to specify an EDID data set instead of probing for it"
depends on DRM
diff --git a/drivers/gpu/drm/drm_fb_helper.c b/drivers/gpu/drm/drm_fb_helper.c
index bf2190c..a354944 100644
--- a/drivers/gpu/drm/drm_fb_helper.c
+++ b/drivers/gpu/drm/drm_fb_helper.c
@@ -56,6 +56,25 @@ MODULE_PARM_DESC(drm_fbdev_overalloc,
 "Overallocation of the fbdev buffer (%) [default="
 __MODULE_STRING(CONFIG_DRM_FBDEV_OVERALLOC) "]");
 
+/*
+ * In order to keep user-space compatibility, we want in certain use-cases
+ * to keep leaking the fbdev physical address to the user-space program
+ * handling the fbdev buffer.
+ * This is a bad habit essentially kept into closed source opengl driver
+ * that should really be moved into open-source upstream projects instead
+ * of using legacy physical addresses in user space to communicate with
+ * other out-of-tree kernel modules.
+ *
+ * This module_param *should* be removed as soon as possible and be
+ * considered as a broken and legacy behaviour from a modern fbdev device.
+ */
+#if IS_ENABLED(CONFIG_DRM_FBDEV_LEAK_PHYS_SMEM)
+static bool drm_leak_fbdev_smem = false;
+module_param_unsafe(drm_leak_fbdev_smem, bool, 0600);
+MODULE_PARM_DESC(fbdev_emulation,
+"Allow unsafe leaking fbdev physical smem address 
[default=false]");
+#endif
+
 static LIST_HEAD(kernel_fb_helper_list);
 static DEFINE_MUTEX(kernel_fb_helper_lock);
 
@@ -2673,8 +2692,12 @@ __drm_fb_helper_initial_config_and_unlock(struct 
drm_fb_helper *fb_helper,
 
info = fb_helper->fbdev;
info->var.pixclock = 0;
-   /* don't leak any physical addresses to userspace */
-   info->flags |= FBINFO_HIDE_SMEM_START;
+   /* Shamelessly allow physical address leaking to userspace */
+#if IS_ENABLED(CONFIG_DRM_FBDEV_LEAK_PHYS_SMEM)
+   if (!drm_leak_fbdev_smem)
+#endif
+   /* don't leak any physical addresses to userspace */
+   info->flags |= FBINFO_HIDE_SMEM_START;
 
/* Need to drop locks to avoid recursive deadlock in
 *