diff options
| author | Bruno Prémont <bonbons@linux-vserver.org> | 2010-06-30 16:36:31 -0400 |
|---|---|---|
| committer | Jiri Kosina <jkosina@suse.cz> | 2010-07-11 16:57:17 -0400 |
| commit | a7c9a0aa175aee8a66301264bff2a5ff014ca0e7 (patch) | |
| tree | 45ead753fcbbd064b64f7f09e291ffb230d5e033 | |
| parent | 6dc398acf944e768a62aa5eed925633e0a3dad0e (diff) | |
HID: picolcd: fix deferred_io init/cleanup to fb ordering
Adjust ordering if framebuffer (un)registration and defio init/cleanup
to match the correct order (init defio, register FB ... unregister FB,
cleanup defio)
Acked-by: Jaya Kumar <jayakumar.lkml@gmail.com>
Signed-off-by: Bruno Prémont <bonbons@linux-vserver.org>
Signed-off-by: Jiri Kosina <jkosina@suse.cz>
| -rw-r--r-- | drivers/hid/hid-picolcd.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/hid/hid-picolcd.c b/drivers/hid/hid-picolcd.c index 7aabf65c48ef..839a5ac0ad82 100644 --- a/drivers/hid/hid-picolcd.c +++ b/drivers/hid/hid-picolcd.c | |||
| @@ -707,18 +707,19 @@ static int picolcd_init_framebuffer(struct picolcd_data *data) | |||
| 707 | dev_err(dev, "failed to create sysfs attributes\n"); | 707 | dev_err(dev, "failed to create sysfs attributes\n"); |
| 708 | goto err_cleanup; | 708 | goto err_cleanup; |
| 709 | } | 709 | } |
| 710 | fb_deferred_io_init(info); | ||
| 710 | data->fb_info = info; | 711 | data->fb_info = info; |
| 711 | error = register_framebuffer(info); | 712 | error = register_framebuffer(info); |
| 712 | if (error) { | 713 | if (error) { |
| 713 | dev_err(dev, "failed to register framebuffer\n"); | 714 | dev_err(dev, "failed to register framebuffer\n"); |
| 714 | goto err_sysfs; | 715 | goto err_sysfs; |
| 715 | } | 716 | } |
| 716 | fb_deferred_io_init(info); | ||
| 717 | /* schedule first output of framebuffer */ | 717 | /* schedule first output of framebuffer */ |
| 718 | schedule_delayed_work(&info->deferred_work, 0); | 718 | schedule_delayed_work(&info->deferred_work, 0); |
| 719 | return 0; | 719 | return 0; |
| 720 | 720 | ||
| 721 | err_sysfs: | 721 | err_sysfs: |
| 722 | fb_deferred_io_cleanup(info); | ||
| 722 | device_remove_file(dev, &dev_attr_fb_update_rate); | 723 | device_remove_file(dev, &dev_attr_fb_update_rate); |
| 723 | err_cleanup: | 724 | err_cleanup: |
| 724 | data->fb_vbitmap = NULL; | 725 | data->fb_vbitmap = NULL; |
| @@ -747,7 +748,6 @@ static void picolcd_exit_framebuffer(struct picolcd_data *data) | |||
| 747 | data->fb_bpp = 0; | 748 | data->fb_bpp = 0; |
| 748 | data->fb_info = NULL; | 749 | data->fb_info = NULL; |
| 749 | device_remove_file(&data->hdev->dev, &dev_attr_fb_update_rate); | 750 | device_remove_file(&data->hdev->dev, &dev_attr_fb_update_rate); |
| 750 | fb_deferred_io_cleanup(info); | ||
| 751 | unregister_framebuffer(info); | 751 | unregister_framebuffer(info); |
| 752 | vfree(fb_bitmap); | 752 | vfree(fb_bitmap); |
| 753 | kfree(fb_vbitmap); | 753 | kfree(fb_vbitmap); |
