git://git.onelab.eu
/
linux-2.6.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
fedora core 6 1.2949 + vserver 2.2.0
[linux-2.6.git]
/
drivers
/
video
/
s1d13xxxfb.c
diff --git
a/drivers/video/s1d13xxxfb.c
b/drivers/video/s1d13xxxfb.c
index
b637c38
..
a5333c1
100644
(file)
--- a/
drivers/video/s1d13xxxfb.c
+++ b/
drivers/video/s1d13xxxfb.c
@@
-28,9
+28,8
@@
* more details.
*/
* more details.
*/
-#include <linux/config.h>
#include <linux/module.h>
#include <linux/module.h>
-#include <linux/device.h>
+#include <linux/
platform_
device.h>
#include <linux/delay.h>
#include <linux/types.h>
#include <linux/delay.h>
#include <linux/types.h>
@@
-67,12
+66,18
@@
static struct fb_fix_screeninfo __devinitdata s1d13xxxfb_fix = {
static inline u8
s1d13xxxfb_readreg(struct s1d13xxxfb_par *par, u16 regno)
{
static inline u8
s1d13xxxfb_readreg(struct s1d13xxxfb_par *par, u16 regno)
{
+#if defined(CONFIG_PLAT_M32700UT) || defined(CONFIG_PLAT_OPSPUT) || defined(CONFIG_PLAT_MAPPI3)
+ regno=((regno & 1) ? (regno & ~1L) : (regno + 1));
+#endif
return readb(par->regs + regno);
}
static inline void
s1d13xxxfb_writereg(struct s1d13xxxfb_par *par, u16 regno, u8 value)
{
return readb(par->regs + regno);
}
static inline void
s1d13xxxfb_writereg(struct s1d13xxxfb_par *par, u16 regno, u8 value)
{
+#if defined(CONFIG_PLAT_M32700UT) || defined(CONFIG_PLAT_OPSPUT) || defined(CONFIG_PLAT_MAPPI3)
+ regno=((regno & 1) ? (regno & ~1L) : (regno + 1));
+#endif
writeb(value, par->regs + regno);
}
writeb(value, par->regs + regno);
}
@@
-259,7
+264,11
@@
s1d13xxxfb_setcolreg(u_int regno, u_int red, u_int green, u_int blue,
dbg("s1d13xxxfb_setcolreg: pseudo %d, val %08x\n",
regno, pseudo_val);
dbg("s1d13xxxfb_setcolreg: pseudo %d, val %08x\n",
regno, pseudo_val);
+#if defined(CONFIG_PLAT_MAPPI)
+ ((u32 *)info->pseudo_palette)[regno] = cpu_to_le16(pseudo_val);
+#else
((u32 *)info->pseudo_palette)[regno] = pseudo_val;
((u32 *)info->pseudo_palette)[regno] = pseudo_val;
+#endif
break;
case FB_VISUAL_PSEUDOCOLOR:
break;
case FB_VISUAL_PSEUDOCOLOR:
@@
-378,7
+387,6
@@
static struct fb_ops s1d13xxxfb_fbops = {
.fb_fillrect = cfb_fillrect,
.fb_copyarea = cfb_copyarea,
.fb_imageblit = cfb_imageblit,
.fb_fillrect = cfb_fillrect,
.fb_copyarea = cfb_copyarea,
.fb_imageblit = cfb_imageblit,
- .fb_cursor = soft_cursor
};
static int s1d13xxxfb_width_tab[2][4] __devinitdata = {
};
static int s1d13xxxfb_width_tab[2][4] __devinitdata = {
@@
-493,11
+501,10
@@
s1d13xxxfb_fetch_hw_state(struct fb_info *info)
}
}
-static int
__devexit
-s1d13xxxfb_remove(struct
device *
dev)
+static int
+s1d13xxxfb_remove(struct
platform_device *p
dev)
{
{
- struct fb_info *info = dev_get_drvdata(dev);
- struct platform_device *pdev = to_platform_device(dev);
+ struct fb_info *info = platform_get_drvdata(pdev);
struct s1d13xxxfb_par *par = NULL;
if (info) {
struct s1d13xxxfb_par *par = NULL;
if (info) {
@@
-525,9
+532,8
@@
s1d13xxxfb_remove(struct device *dev)
}
static int __devinit
}
static int __devinit
-s1d13xxxfb_probe(struct
device *
dev)
+s1d13xxxfb_probe(struct
platform_device *p
dev)
{
{
- struct platform_device *pdev = to_platform_device(dev);
struct s1d13xxxfb_par *default_par;
struct fb_info *info;
struct s1d13xxxfb_pdata *pdata = NULL;
struct s1d13xxxfb_par *default_par;
struct fb_info *info;
struct s1d13xxxfb_pdata *pdata = NULL;
@@
-539,8
+545,8
@@
s1d13xxxfb_probe(struct device *dev)
printk(KERN_INFO "Epson S1D13XXX FB Driver\n");
/* enable platform-dependent hardware glue, if any */
printk(KERN_INFO "Epson S1D13XXX FB Driver\n");
/* enable platform-dependent hardware glue, if any */
- if (
dev->
platform_data)
- pdata =
dev->
platform_data;
+ if (
pdev->dev.
platform_data)
+ pdata =
pdev->dev.
platform_data;
if (pdata && pdata->platform_init_video)
pdata->platform_init_video();
if (pdata && pdata->platform_init_video)
pdata->platform_init_video();
@@
-563,14
+569,14
@@
s1d13xxxfb_probe(struct device *dev)
if (!request_mem_region(pdev->resource[0].start,
pdev->resource[0].end - pdev->resource[0].start +1, "s1d13xxxfb mem")) {
if (!request_mem_region(pdev->resource[0].start,
pdev->resource[0].end - pdev->resource[0].start +1, "s1d13xxxfb mem")) {
- dev_dbg(dev, "request_mem_region failed\n");
+ dev_dbg(
&pdev->
dev, "request_mem_region failed\n");
ret = -EBUSY;
goto bail;
}
if (!request_mem_region(pdev->resource[1].start,
pdev->resource[1].end - pdev->resource[1].start +1, "s1d13xxxfb regs")) {
ret = -EBUSY;
goto bail;
}
if (!request_mem_region(pdev->resource[1].start,
pdev->resource[1].end - pdev->resource[1].start +1, "s1d13xxxfb regs")) {
- dev_dbg(dev, "request_mem_region failed\n");
+ dev_dbg(
&pdev->
dev, "request_mem_region failed\n");
ret = -EBUSY;
goto bail;
}
ret = -EBUSY;
goto bail;
}
@@
-581,6
+587,7
@@
s1d13xxxfb_probe(struct device *dev)
goto bail;
}
goto bail;
}
+ platform_set_drvdata(pdev, info);
default_par = info->par;
default_par->regs = ioremap_nocache(pdev->resource[1].start,
pdev->resource[1].end - pdev->resource[1].start +1);
default_par = info->par;
default_par->regs = ioremap_nocache(pdev->resource[1].start,
pdev->resource[1].end - pdev->resource[1].start +1);
@@
-631,23
+638,21
@@
s1d13xxxfb_probe(struct device *dev)
goto bail;
}
goto bail;
}
- dev_set_drvdata(&pdev->dev, info);
-
printk(KERN_INFO "fb%d: %s frame buffer device\n",
info->node, info->fix.id);
return 0;
bail:
printk(KERN_INFO "fb%d: %s frame buffer device\n",
info->node, info->fix.id);
return 0;
bail:
- s1d13xxxfb_remove(dev);
+ s1d13xxxfb_remove(
p
dev);
return ret;
}
#ifdef CONFIG_PM
return ret;
}
#ifdef CONFIG_PM
-static int s1d13xxxfb_suspend(struct
device *dev, u32 state, u32 level
)
+static int s1d13xxxfb_suspend(struct
platform_device *dev, pm_message_t state
)
{
{
- struct fb_info *info =
dev
_get_drvdata(dev);
+ struct fb_info *info =
platform
_get_drvdata(dev);
struct s1d13xxxfb_par *s1dfb = info->par;
struct s1d13xxxfb_pdata *pdata = NULL;
struct s1d13xxxfb_par *s1dfb = info->par;
struct s1d13xxxfb_pdata *pdata = NULL;
@@
-655,8
+660,8
@@
static int s1d13xxxfb_suspend(struct device *dev, u32 state, u32 level)
lcd_enable(s1dfb, 0);
crt_enable(s1dfb, 0);
lcd_enable(s1dfb, 0);
crt_enable(s1dfb, 0);
- if (dev->platform_data)
- pdata = dev->platform_data;
+ if (dev->
dev.
platform_data)
+ pdata = dev->
dev.
platform_data;
#if 0
if (!s1dfb->disp_save)
#if 0
if (!s1dfb->disp_save)
@@
-692,15
+697,12
@@
static int s1d13xxxfb_suspend(struct device *dev, u32 state, u32 level)
return 0;
}
return 0;
}
-static int s1d13xxxfb_resume(struct
device *dev, u32 level
)
+static int s1d13xxxfb_resume(struct
platform_device *dev
)
{
{
- struct fb_info *info =
dev
_get_drvdata(dev);
+ struct fb_info *info =
platform
_get_drvdata(dev);
struct s1d13xxxfb_par *s1dfb = info->par;
struct s1d13xxxfb_pdata *pdata = NULL;
struct s1d13xxxfb_par *s1dfb = info->par;
struct s1d13xxxfb_pdata *pdata = NULL;
- if (level != RESUME_ENABLE)
- return 0;
-
/* awaken the chip */
s1d13xxxfb_writereg(s1dfb, S1DREG_PS_CNF, 0x10);
/* awaken the chip */
s1d13xxxfb_writereg(s1dfb, S1DREG_PS_CNF, 0x10);
@@
-708,8
+710,8
@@
static int s1d13xxxfb_resume(struct device *dev, u32 level)
while ((s1d13xxxfb_readreg(s1dfb, S1DREG_PS_STATUS) & 0x01))
udelay(10);
while ((s1d13xxxfb_readreg(s1dfb, S1DREG_PS_STATUS) & 0x01))
udelay(10);
- if (dev->platform_data)
- pdata = dev->platform_data;
+ if (dev->
dev.
platform_data)
+ pdata = dev->
dev.
platform_data;
if (s1dfb->regs_save) {
/* will write RO regs, *should* get away with it :) */
if (s1dfb->regs_save) {
/* will write RO regs, *should* get away with it :) */
@@
-735,15
+737,16
@@
static int s1d13xxxfb_resume(struct device *dev, u32 level)
}
#endif /* CONFIG_PM */
}
#endif /* CONFIG_PM */
-static struct device_driver s1d13xxxfb_driver = {
- .name = S1D_DEVICENAME,
- .bus = &platform_bus_type,
+static struct platform_driver s1d13xxxfb_driver = {
.probe = s1d13xxxfb_probe,
.remove = s1d13xxxfb_remove,
#ifdef CONFIG_PM
.suspend = s1d13xxxfb_suspend,
.probe = s1d13xxxfb_probe,
.remove = s1d13xxxfb_remove,
#ifdef CONFIG_PM
.suspend = s1d13xxxfb_suspend,
- .resume = s1d13xxxfb_resume
+ .resume = s1d13xxxfb_resume
,
#endif
#endif
+ .driver = {
+ .name = S1D_DEVICENAME,
+ },
};
};
@@
-753,14
+756,14
@@
s1d13xxxfb_init(void)
if (fb_get_options("s1d13xxxfb", NULL))
return -ENODEV;
if (fb_get_options("s1d13xxxfb", NULL))
return -ENODEV;
- return driver_register(&s1d13xxxfb_driver);
+ return
platform_
driver_register(&s1d13xxxfb_driver);
}
static void __exit
s1d13xxxfb_exit(void)
{
}
static void __exit
s1d13xxxfb_exit(void)
{
- driver_unregister(&s1d13xxxfb_driver);
+
platform_
driver_unregister(&s1d13xxxfb_driver);
}
module_init(s1d13xxxfb_init);
}
module_init(s1d13xxxfb_init);