diff options
Diffstat (limited to 'drivers/firmware/sysfb.c')
| -rw-r--r-- | drivers/firmware/sysfb.c | 19 | 
1 files changed, 13 insertions, 6 deletions
| diff --git a/drivers/firmware/sysfb.c b/drivers/firmware/sysfb.c index 921f61507ae8..02a07d3d0d40 100644 --- a/drivers/firmware/sysfb.c +++ b/drivers/firmware/sysfb.c @@ -39,6 +39,8 @@ static struct platform_device *pd;  static DEFINE_MUTEX(disable_lock);  static bool disabled; +static struct device *sysfb_parent_dev(const struct screen_info *si); +  static bool sysfb_unregister(void)  {  	if (IS_ERR_OR_NULL(pd)) @@ -52,6 +54,7 @@ static bool sysfb_unregister(void)  /**   * sysfb_disable() - disable the Generic System Framebuffers support + * @dev:	the device to check if non-NULL   *   * This disables the registration of system framebuffer devices that match the   * generic drivers that make use of the system framebuffer set up by firmware. @@ -61,17 +64,21 @@ static bool sysfb_unregister(void)   * 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) +void sysfb_disable(struct device *dev)  { +	struct screen_info *si = &screen_info; +  	mutex_lock(&disable_lock); -	sysfb_unregister(); -	disabled = true; +	if (!dev || dev == sysfb_parent_dev(si)) { +		sysfb_unregister(); +		disabled = true; +	}  	mutex_unlock(&disable_lock);  }  EXPORT_SYMBOL_GPL(sysfb_disable);  #if defined(CONFIG_PCI) -static __init bool sysfb_pci_dev_is_enabled(struct pci_dev *pdev) +static bool sysfb_pci_dev_is_enabled(struct pci_dev *pdev)  {  	/*  	 * TODO: Try to integrate this code into the PCI subsystem @@ -87,13 +94,13 @@ static __init bool sysfb_pci_dev_is_enabled(struct pci_dev *pdev)  	return true;  }  #else -static __init bool sysfb_pci_dev_is_enabled(struct pci_dev *pdev) +static bool sysfb_pci_dev_is_enabled(struct pci_dev *pdev)  {  	return false;  }  #endif -static __init struct device *sysfb_parent_dev(const struct screen_info *si) +static struct device *sysfb_parent_dev(const struct screen_info *si)  {  	struct pci_dev *pdev; | 
