diff options
author | Paul Walmsley <paul@pwsan.com> | 2010-07-26 18:34:33 -0400 |
---|---|---|
committer | Paul Walmsley <paul@pwsan.com> | 2010-07-26 18:34:33 -0400 |
commit | db2a60bf2527209b42e6f512d5892089a835ceaa (patch) | |
tree | 98436f3f27ada90324110c6fd3e3256162ec7b34 /arch/arm/mach-omap2 | |
parent | 08072acf3a23febd1b676f1d908c6c0b9ddf167c (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')
-rw-r--r-- | arch/arm/mach-omap2/omap_hwmod.c | 33 |
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 | ||
1070 | u32 omap_hwmod_readl(struct omap_hwmod *oh, u16 reg_offs) | 1070 | u32 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 | ||
1075 | void omap_hwmod_writel(u32 v, struct omap_hwmod *oh, u16 reg_offs) | 1075 | void 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 | ||
1080 | int omap_hwmod_set_slave_idlemode(struct omap_hwmod *oh, u8 idlemode) | 1080 | int 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 | */ | ||
1555 | void __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) |