aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-omap2/omap_hwmod.c
diff options
context:
space:
mode:
authorPaul Walmsley <paul@pwsan.com>2010-07-26 18:34:33 -0400
committerPaul Walmsley <paul@pwsan.com>2010-07-26 18:34:33 -0400
commitdb2a60bf2527209b42e6f512d5892089a835ceaa (patch)
tree98436f3f27ada90324110c6fd3e3256162ec7b34 /arch/arm/mach-omap2/omap_hwmod.c
parent08072acf3a23febd1b676f1d908c6c0b9ddf167c (diff)
OMAP: hwmod/device: add omap_{device,hwmod}_get_mpu_rt_va
Add omap_device_get_mpu_rt_va(). This is intended to be used by device drivers (currently, via a struct platform_data function pointer) to retrieve their corresponding device's virtual base address that the MPU should use to access the device. This is needed because the omap_hwmod code does its own ioremap(), in order to gain access to the module's OCP_SYSCONFIG register. Add omap_hwmod_get_mpu_rt_va(). omap_device_get_mpu_rt_va() calls this function to do the real work. While here, rename struct omap_hwmod._rt_va to struct omap_hwmod._mpu_rt_va, to reinforce that it refers to the MPU's register target virtual address base (as opposed to, for example, the L3's). In the future, this belongs as a function in an omap_bus, so it is not necessary to call this through a platform_data function pointer. The use-case for this function was originally presented by Santosh Shilimkar <santosh.shilimkar@ti.com>. Signed-off-by: Paul Walmsley <paul@pwsan.com> Cc: Santosh Shilimkar <santosh.shilimkar@ti.com>
Diffstat (limited to 'arch/arm/mach-omap2/omap_hwmod.c')
-rw-r--r--arch/arm/mach-omap2/omap_hwmod.c33
1 files changed, 28 insertions, 5 deletions
diff --git a/arch/arm/mach-omap2/omap_hwmod.c b/arch/arm/mach-omap2/omap_hwmod.c
index b2c8e8760c80..ec0be6d32232 100644
--- a/arch/arm/mach-omap2/omap_hwmod.c
+++ b/arch/arm/mach-omap2/omap_hwmod.c
@@ -1,7 +1,7 @@
1/* 1/*
2 * omap_hwmod implementation for OMAP2/3/4 2 * omap_hwmod implementation for OMAP2/3/4
3 * 3 *
4 * Copyright (C) 2009 Nokia Corporation 4 * Copyright (C) 2009-2010 Nokia Corporation
5 * 5 *
6 * Paul Walmsley, Benoît Cousson, Kevin Hilman 6 * Paul Walmsley, Benoît Cousson, Kevin Hilman
7 * 7 *
@@ -1069,12 +1069,12 @@ static int _setup(struct omap_hwmod *oh, void *data)
1069 1069
1070u32 omap_hwmod_readl(struct omap_hwmod *oh, u16 reg_offs) 1070u32 omap_hwmod_readl(struct omap_hwmod *oh, u16 reg_offs)
1071{ 1071{
1072 return __raw_readl(oh->_rt_va + reg_offs); 1072 return __raw_readl(oh->_mpu_rt_va + reg_offs);
1073} 1073}
1074 1074
1075void omap_hwmod_writel(u32 v, struct omap_hwmod *oh, u16 reg_offs) 1075void omap_hwmod_writel(u32 v, struct omap_hwmod *oh, u16 reg_offs)
1076{ 1076{
1077 __raw_writel(v, oh->_rt_va + reg_offs); 1077 __raw_writel(v, oh->_mpu_rt_va + reg_offs);
1078} 1078}
1079 1079
1080int omap_hwmod_set_slave_idlemode(struct omap_hwmod *oh, u8 idlemode) 1080int omap_hwmod_set_slave_idlemode(struct omap_hwmod *oh, u8 idlemode)
@@ -1131,7 +1131,7 @@ int omap_hwmod_register(struct omap_hwmod *oh)
1131 ms_id = _find_mpu_port_index(oh); 1131 ms_id = _find_mpu_port_index(oh);
1132 if (!IS_ERR_VALUE(ms_id)) { 1132 if (!IS_ERR_VALUE(ms_id)) {
1133 oh->_mpu_port_index = ms_id; 1133 oh->_mpu_port_index = ms_id;
1134 oh->_rt_va = _find_mpu_rt_base(oh, oh->_mpu_port_index); 1134 oh->_mpu_rt_va = _find_mpu_rt_base(oh, oh->_mpu_port_index);
1135 } else { 1135 } else {
1136 oh->_int_flags |= _HWMOD_NO_MPU_PORT; 1136 oh->_int_flags |= _HWMOD_NO_MPU_PORT;
1137 } 1137 }
@@ -1283,7 +1283,7 @@ int omap_hwmod_unregister(struct omap_hwmod *oh)
1283 pr_debug("omap_hwmod: %s: unregistering\n", oh->name); 1283 pr_debug("omap_hwmod: %s: unregistering\n", oh->name);
1284 1284
1285 mutex_lock(&omap_hwmod_mutex); 1285 mutex_lock(&omap_hwmod_mutex);
1286 iounmap(oh->_rt_va); 1286 iounmap(oh->_mpu_rt_va);
1287 list_del(&oh->node); 1287 list_del(&oh->node);
1288 mutex_unlock(&omap_hwmod_mutex); 1288 mutex_unlock(&omap_hwmod_mutex);
1289 1289
@@ -1544,6 +1544,29 @@ struct powerdomain *omap_hwmod_get_pwrdm(struct omap_hwmod *oh)
1544} 1544}
1545 1545
1546/** 1546/**
1547 * omap_hwmod_get_mpu_rt_va - return the module's base address (for the MPU)
1548 * @oh: struct omap_hwmod *
1549 *
1550 * Returns the virtual address corresponding to the beginning of the
1551 * module's register target, in the address range that is intended to
1552 * be used by the MPU. Returns the virtual address upon success or NULL
1553 * upon error.
1554 */
1555void __iomem *omap_hwmod_get_mpu_rt_va(struct omap_hwmod *oh)
1556{
1557 if (!oh)
1558 return NULL;
1559
1560 if (oh->_int_flags & _HWMOD_NO_MPU_PORT)
1561 return NULL;
1562
1563 if (oh->_state == _HWMOD_STATE_UNKNOWN)
1564 return NULL;
1565
1566 return oh->_mpu_rt_va;
1567}
1568
1569/**
1547 * omap_hwmod_add_initiator_dep - add sleepdep from @init_oh to @oh 1570 * omap_hwmod_add_initiator_dep - add sleepdep from @init_oh to @oh
1548 * @oh: struct omap_hwmod * 1571 * @oh: struct omap_hwmod *
1549 * @init_oh: struct omap_hwmod * (initiator) 1572 * @init_oh: struct omap_hwmod * (initiator)