diff options
author | Pavel Machek <pavel@ucw.cz> | 2009-09-22 19:47:03 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2009-09-23 10:39:50 -0400 |
commit | d480ace08d5b59133575e672a0bd1c97b0f8400f (patch) | |
tree | 3e2e0edd582d7f511544ad87a6095c6227d280aa /drivers/video/msm/mddi_client_dummy.c | |
parent | 689620100172e24fdf0981e9978a9559e8769258 (diff) |
fbdev: framebuffer support for HTC Dream
Add a framebuffer driver for Qualcomm MSM/QSD SoCs, tested on HTC Dream
smartphone (aka T-Mobile G1, aka ADP1).
Brian said:
I did the original quick and dirty version for bringup. Rebecca took
over and (re)wrote the bulk of the driver, getting things stable for
production ship of Dream and Sapphire, and Dima is currently adding
support for later Qualcomm chipsets (QSD8x50, etc).
Signed-off-by: Pavel Machek <pavel@ucw.cz>
Cc: Brian Swetland <swetland@google.com>
Cc: Krzysztof Helt <krzysztof.h1@poczta.fm>
Cc: Rebecca Schultz Zavin <rebecca@android.com>
Cc: Dima Zavin <dima@android.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'drivers/video/msm/mddi_client_dummy.c')
-rw-r--r-- | drivers/video/msm/mddi_client_dummy.c | 97 |
1 files changed, 97 insertions, 0 deletions
diff --git a/drivers/video/msm/mddi_client_dummy.c b/drivers/video/msm/mddi_client_dummy.c new file mode 100644 index 000000000000..ebbae87885b6 --- /dev/null +++ b/drivers/video/msm/mddi_client_dummy.c | |||
@@ -0,0 +1,97 @@ | |||
1 | /* drivers/video/msm_fb/mddi_client_dummy.c | ||
2 | * | ||
3 | * Support for "dummy" mddi client devices which require no | ||
4 | * special initialization code. | ||
5 | * | ||
6 | * Copyright (C) 2007 Google Incorporated | ||
7 | * | ||
8 | * This software is licensed under the terms of the GNU General Public | ||
9 | * License version 2, as published by the Free Software Foundation, and | ||
10 | * may be copied, distributed, and modified under those terms. | ||
11 | * | ||
12 | * This program is distributed in the hope that it will be useful, | ||
13 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
14 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
15 | * GNU General Public License for more details. | ||
16 | */ | ||
17 | |||
18 | #include <linux/module.h> | ||
19 | #include <linux/kernel.h> | ||
20 | #include <linux/platform_device.h> | ||
21 | |||
22 | #include <mach/msm_fb.h> | ||
23 | |||
24 | struct panel_info { | ||
25 | struct platform_device pdev; | ||
26 | struct msm_panel_data panel_data; | ||
27 | }; | ||
28 | |||
29 | static int mddi_dummy_suspend(struct msm_panel_data *panel_data) | ||
30 | { | ||
31 | return 0; | ||
32 | } | ||
33 | |||
34 | static int mddi_dummy_resume(struct msm_panel_data *panel_data) | ||
35 | { | ||
36 | return 0; | ||
37 | } | ||
38 | |||
39 | static int mddi_dummy_blank(struct msm_panel_data *panel_data) | ||
40 | { | ||
41 | return 0; | ||
42 | } | ||
43 | |||
44 | static int mddi_dummy_unblank(struct msm_panel_data *panel_data) | ||
45 | { | ||
46 | return 0; | ||
47 | } | ||
48 | |||
49 | static int mddi_dummy_probe(struct platform_device *pdev) | ||
50 | { | ||
51 | struct msm_mddi_client_data *client_data = pdev->dev.platform_data; | ||
52 | struct panel_info *panel = | ||
53 | kzalloc(sizeof(struct panel_info), GFP_KERNEL); | ||
54 | int ret; | ||
55 | if (!panel) | ||
56 | return -ENOMEM; | ||
57 | platform_set_drvdata(pdev, panel); | ||
58 | panel->panel_data.suspend = mddi_dummy_suspend; | ||
59 | panel->panel_data.resume = mddi_dummy_resume; | ||
60 | panel->panel_data.blank = mddi_dummy_blank; | ||
61 | panel->panel_data.unblank = mddi_dummy_unblank; | ||
62 | panel->panel_data.caps = MSMFB_CAP_PARTIAL_UPDATES; | ||
63 | panel->pdev.name = "msm_panel"; | ||
64 | panel->pdev.id = pdev->id; | ||
65 | platform_device_add_resources(&panel->pdev, | ||
66 | client_data->fb_resource, 1); | ||
67 | panel->panel_data.fb_data = client_data->private_client_data; | ||
68 | panel->pdev.dev.platform_data = &panel->panel_data; | ||
69 | ret = platform_device_register(&panel->pdev); | ||
70 | if (ret) { | ||
71 | kfree(panel); | ||
72 | return ret; | ||
73 | } | ||
74 | return 0; | ||
75 | } | ||
76 | |||
77 | static int mddi_dummy_remove(struct platform_device *pdev) | ||
78 | { | ||
79 | struct panel_info *panel = platform_get_drvdata(pdev); | ||
80 | kfree(panel); | ||
81 | return 0; | ||
82 | } | ||
83 | |||
84 | static struct platform_driver mddi_client_dummy = { | ||
85 | .probe = mddi_dummy_probe, | ||
86 | .remove = mddi_dummy_remove, | ||
87 | .driver = { .name = "mddi_c_dummy" }, | ||
88 | }; | ||
89 | |||
90 | static int __init mddi_client_dummy_init(void) | ||
91 | { | ||
92 | platform_driver_register(&mddi_client_dummy); | ||
93 | return 0; | ||
94 | } | ||
95 | |||
96 | module_init(mddi_client_dummy_init); | ||
97 | |||