firmware: sysfb: Add sysfb_disable() helper function

This can be used by subsystems to unregister a platform device registered
by sysfb and also to disable future platform device registration in sysfb.
Suggested-by: default avatarDaniel Vetter <daniel.vetter@ffwll.ch>
Signed-off-by: default avatarJavier Martinez Canillas <javierm@redhat.com>
Reviewed-by: default avatarDaniel Vetter <daniel.vetter@ffwll.ch>
Link: https://patchwork.freedesktop.org/patch/msgid/20220607182338.344270-3-javierm@redhat.com
parent 0949ee75
...@@ -13,6 +13,12 @@ EDD Interfaces ...@@ -13,6 +13,12 @@ EDD Interfaces
.. kernel-doc:: drivers/firmware/edd.c .. kernel-doc:: drivers/firmware/edd.c
:internal: :internal:
Generic System Framebuffers Interface
-------------------------------------
.. kernel-doc:: drivers/firmware/sysfb.c
:export:
Intel Stratix10 SoC Service Layer Intel Stratix10 SoC Service Layer
--------------------------------- ---------------------------------
Some features of the Intel Stratix10 SoC require a level of privilege Some features of the Intel Stratix10 SoC require a level of privilege
......
...@@ -34,21 +34,59 @@ ...@@ -34,21 +34,59 @@
#include <linux/screen_info.h> #include <linux/screen_info.h>
#include <linux/sysfb.h> #include <linux/sysfb.h>
static struct platform_device *pd;
static DEFINE_MUTEX(disable_lock);
static bool disabled;
static bool sysfb_unregister(void)
{
if (IS_ERR_OR_NULL(pd))
return false;
platform_device_unregister(pd);
pd = NULL;
return true;
}
/**
* sysfb_disable() - disable the Generic System Framebuffers support
*
* This disables the registration of system framebuffer devices that match the
* generic drivers that make use of the system framebuffer set up by firmware.
*
* It also unregisters a device if this was already registered by sysfb_init().
*
* Context: The function can sleep. A @disable_lock mutex is acquired to serialize
* against sysfb_init(), that registers a system framebuffer device.
*/
void sysfb_disable(void)
{
mutex_lock(&disable_lock);
sysfb_unregister();
disabled = true;
mutex_unlock(&disable_lock);
}
EXPORT_SYMBOL_GPL(sysfb_disable);
static __init int sysfb_init(void) static __init int sysfb_init(void)
{ {
struct screen_info *si = &screen_info; struct screen_info *si = &screen_info;
struct simplefb_platform_data mode; struct simplefb_platform_data mode;
struct platform_device *pd;
const char *name; const char *name;
bool compatible; bool compatible;
int ret; int ret = 0;
mutex_lock(&disable_lock);
if (disabled)
goto unlock_mutex;
/* try to create a simple-framebuffer device */ /* try to create a simple-framebuffer device */
compatible = sysfb_parse_mode(si, &mode); compatible = sysfb_parse_mode(si, &mode);
if (compatible) { if (compatible) {
pd = sysfb_create_simplefb(si, &mode); pd = sysfb_create_simplefb(si, &mode);
if (!IS_ERR(pd)) if (!IS_ERR(pd))
return 0; goto unlock_mutex;
} }
/* if the FB is incompatible, create a legacy framebuffer device */ /* if the FB is incompatible, create a legacy framebuffer device */
...@@ -60,8 +98,10 @@ static __init int sysfb_init(void) ...@@ -60,8 +98,10 @@ static __init int sysfb_init(void)
name = "platform-framebuffer"; name = "platform-framebuffer";
pd = platform_device_alloc(name, 0); pd = platform_device_alloc(name, 0);
if (!pd) if (!pd) {
return -ENOMEM; ret = -ENOMEM;
goto unlock_mutex;
}
sysfb_apply_efi_quirks(pd); sysfb_apply_efi_quirks(pd);
...@@ -73,9 +113,11 @@ static __init int sysfb_init(void) ...@@ -73,9 +113,11 @@ static __init int sysfb_init(void)
if (ret) if (ret)
goto err; goto err;
return 0; goto unlock_mutex;
err: err:
platform_device_put(pd); platform_device_put(pd);
unlock_mutex:
mutex_unlock(&disable_lock);
return ret; return ret;
} }
......
...@@ -55,6 +55,18 @@ struct efifb_dmi_info { ...@@ -55,6 +55,18 @@ struct efifb_dmi_info {
int flags; int flags;
}; };
#ifdef CONFIG_SYSFB
void sysfb_disable(void);
#else /* CONFIG_SYSFB */
static inline void sysfb_disable(void)
{
}
#endif /* CONFIG_SYSFB */
#ifdef CONFIG_EFI #ifdef CONFIG_EFI
extern struct efifb_dmi_info efifb_dmi_list[]; extern struct efifb_dmi_info efifb_dmi_list[];
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment