#endif
static int
-omap_i2c_probe(struct device *dev)
+omap_i2c_probe(struct platform_device *pdev)
{
- struct platform_device *pdev = to_platform_device(dev);
struct omap_i2c_dev *omap_i2c_dev;
struct i2c_adapter *adap;
struct resource *mem, *irq;
if (own < 1 || own > 0x7f)
own = DEFAULT_OWN;
- omap_i2c_dev = kmalloc(sizeof(struct omap_i2c_dev), GFP_KERNEL);
+ omap_i2c_dev = kzalloc(sizeof(struct omap_i2c_dev), GFP_KERNEL);
if (!omap_i2c_dev) {
r = -ENOMEM;
goto do_release_region;
}
- memset(omap_i2c_dev, 0, sizeof(struct omap_i2c_dev));
- omap_i2c_dev->dev = dev;
+ omap_i2c_dev->dev = &pdev->dev;
omap_i2c_dev->irq = irq->start;
omap_i2c_dev->base = (void __iomem *)IO_ADDRESS(mem->start);
- dev_set_drvdata(omap_i2c_dev->dev, omap_i2c_dev);
+ platform_set_drvdata(pdev, omap_i2c_dev);
init_waitqueue_head(&omap_i2c_dev->cmd_wait);
if ((r = omap_i2c_24xx_get_clocks(omap_i2c_dev, pdev->id)) != 0)
adap->class = I2C_CLASS_HWMON;
strncpy(adap->name, "OMAP I2C adapter", sizeof(adap->name));
adap->algo = &omap_i2c_algo;
- adap->dev.parent = dev;
+ adap->dev.parent = &pdev->dev;
/* i2c device drivers may be active on return from add_adapter() */
r = i2c_add_adapter(adap);
if (r) {
}
static int
-omap_i2c_remove(struct device *dev)
+omap_i2c_remove(struct platform_device *pdev)
{
- struct platform_device *pdev = to_platform_device(dev);
- struct omap_i2c_dev *omap_i2c_dev = dev_get_drvdata(dev);
+ struct omap_i2c_dev *omap_i2c_dev = platform_get_drvdata(pdev);
struct resource *mem;
omap_i2c_write(omap_i2c_dev, 0, OMAP_I2C_CON);
return 0;
}
-static struct device_driver omap_i2c_driver = {
- .name = (char *)driver_name,
- .bus = &platform_bus_type,
+static struct platform_driver omap_i2c_driver = {
.probe = omap_i2c_probe,
.remove = omap_i2c_remove,
+ .driver = {
+ .name = (char *)driver_name,
+ },
};
/* i2c may be needed to bring up other drivers */
static int __init
omap_i2c_init_driver(void)
{
- return driver_register(&omap_i2c_driver);
+ return platform_driver_register(&omap_i2c_driver);
}
subsys_initcall(omap_i2c_init_driver);
static void __exit omap_i2c_exit_driver(void)
{
- driver_unregister(&omap_i2c_driver);
+ platform_driver_unregister(&omap_i2c_driver);
}
module_exit(omap_i2c_exit_driver);