|
@@ -13,7 +13,6 @@
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
* GNU General Public License for more details.
|
|
|
*/
|
|
|
-#include <linux/delay.h>
|
|
|
#include <linux/dma-mapping.h>
|
|
|
#include <linux/kernel.h>
|
|
|
#include <linux/init.h>
|
|
@@ -690,56 +689,6 @@ void __init r8a7740_meram_workaround(void)
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-#define ICCR 0x0004
|
|
|
-#define ICSTART 0x0070
|
|
|
-
|
|
|
-#define i2c_read(reg, offset) ioread8(reg + offset)
|
|
|
-#define i2c_write(reg, offset, data) iowrite8(data, reg + offset)
|
|
|
-
|
|
|
-/*
|
|
|
- * r8a7740 chip has lasting errata on I2C I/O pad reset.
|
|
|
- * this is work-around for it.
|
|
|
- */
|
|
|
-static void r8a7740_i2c_workaround(struct platform_device *pdev)
|
|
|
-{
|
|
|
- struct resource *res;
|
|
|
- void __iomem *reg;
|
|
|
-
|
|
|
- res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
|
|
|
- if (unlikely(!res)) {
|
|
|
- pr_err("r8a7740 i2c workaround fail (cannot find resource)\n");
|
|
|
- return;
|
|
|
- }
|
|
|
-
|
|
|
- reg = ioremap(res->start, resource_size(res));
|
|
|
- if (unlikely(!reg)) {
|
|
|
- pr_err("r8a7740 i2c workaround fail (cannot map IO)\n");
|
|
|
- return;
|
|
|
- }
|
|
|
-
|
|
|
- i2c_write(reg, ICCR, i2c_read(reg, ICCR) | 0x80);
|
|
|
- i2c_read(reg, ICCR); /* dummy read */
|
|
|
-
|
|
|
- i2c_write(reg, ICSTART, i2c_read(reg, ICSTART) | 0x10);
|
|
|
- i2c_read(reg, ICSTART); /* dummy read */
|
|
|
-
|
|
|
- udelay(10);
|
|
|
-
|
|
|
- i2c_write(reg, ICCR, 0x01);
|
|
|
- i2c_write(reg, ICSTART, 0x00);
|
|
|
-
|
|
|
- udelay(10);
|
|
|
-
|
|
|
- i2c_write(reg, ICCR, 0x10);
|
|
|
- udelay(10);
|
|
|
- i2c_write(reg, ICCR, 0x00);
|
|
|
- udelay(10);
|
|
|
- i2c_write(reg, ICCR, 0x10);
|
|
|
- udelay(10);
|
|
|
-
|
|
|
- iounmap(reg);
|
|
|
-}
|
|
|
-
|
|
|
void __init r8a7740_add_standard_devices(void)
|
|
|
{
|
|
|
static struct pm_domain_device domain_devices[] __initdata = {
|
|
@@ -766,10 +715,6 @@ void __init r8a7740_add_standard_devices(void)
|
|
|
{ "A3SP", &usb_dma_device },
|
|
|
};
|
|
|
|
|
|
- /* I2C work-around */
|
|
|
- r8a7740_i2c_workaround(&i2c0_device);
|
|
|
- r8a7740_i2c_workaround(&i2c1_device);
|
|
|
-
|
|
|
r8a7740_init_pm_domains();
|
|
|
|
|
|
/* add devices */
|