Commit e6816a8d authored by David Herrmann's avatar David Herrmann Committed by H. Peter Anvin

fbdev: efifb: bind to efi-framebuffer

Instead of creating a dummy device, we now bind to the efi-fb device
which is provided by x86 initialization code.
Signed-off-by: default avatarDavid Herrmann <dh.herrmann@gmail.com>
Link: http://lkml.kernel.org/r/1375445127-15480-8-git-send-email-dh.herrmann@gmail.comSigned-off-by: default avatarH. Peter Anvin <hpa@linux.intel.com>
parent 2e5155ec
...@@ -96,7 +96,7 @@ void vga_set_default_device(struct pci_dev *pdev) ...@@ -96,7 +96,7 @@ void vga_set_default_device(struct pci_dev *pdev)
default_vga = pdev; default_vga = pdev;
} }
static int __init efifb_setup(char *options) static int efifb_setup(char *options)
{ {
char *this_opt; char *this_opt;
int i; int i;
...@@ -153,13 +153,28 @@ static int __init efifb_setup(char *options) ...@@ -153,13 +153,28 @@ static int __init efifb_setup(char *options)
return 0; return 0;
} }
static int __init efifb_probe(struct platform_device *dev) static int efifb_probe(struct platform_device *dev)
{ {
struct fb_info *info; struct fb_info *info;
int err; int err;
unsigned int size_vmode; unsigned int size_vmode;
unsigned int size_remap; unsigned int size_remap;
unsigned int size_total; unsigned int size_total;
char *option = NULL;
if (screen_info.orig_video_isVGA != VIDEO_TYPE_EFI)
return -ENODEV;
if (fb_get_options("efifb", &option))
return -ENODEV;
efifb_setup(option);
/* We don't get linelength from UGA Draw Protocol, only from
* EFI Graphics Protocol. So if it's not in DMI, and it's not
* passed in from the user, we really can't use the framebuffer.
*/
if (!screen_info.lfb_linelength)
return -ENODEV;
if (!screen_info.lfb_depth) if (!screen_info.lfb_depth)
screen_info.lfb_depth = 32; screen_info.lfb_depth = 32;
...@@ -324,50 +339,11 @@ static int __init efifb_probe(struct platform_device *dev) ...@@ -324,50 +339,11 @@ static int __init efifb_probe(struct platform_device *dev)
static struct platform_driver efifb_driver = { static struct platform_driver efifb_driver = {
.driver = { .driver = {
.name = "efifb", .name = "efi-framebuffer",
.owner = THIS_MODULE,
}, },
.probe = efifb_probe,
}; };
static struct platform_device efifb_device = { module_platform_driver(efifb_driver);
.name = "efifb",
};
static int __init efifb_init(void)
{
int ret;
char *option = NULL;
if (screen_info.orig_video_isVGA != VIDEO_TYPE_EFI)
return -ENODEV;
if (fb_get_options("efifb", &option))
return -ENODEV;
efifb_setup(option);
/* We don't get linelength from UGA Draw Protocol, only from
* EFI Graphics Protocol. So if it's not in DMI, and it's not
* passed in from the user, we really can't use the framebuffer.
*/
if (!screen_info.lfb_linelength)
return -ENODEV;
ret = platform_device_register(&efifb_device);
if (ret)
return ret;
/*
* This is not just an optimization. We will interfere
* with a real driver if we get reprobed, so don't allow
* it.
*/
ret = platform_driver_probe(&efifb_driver, efifb_probe);
if (ret) {
platform_device_unregister(&efifb_device);
return ret;
}
return ret;
}
module_init(efifb_init);
MODULE_LICENSE("GPL"); MODULE_LICENSE("GPL");
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