aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/mach-omap2/omap_hwmod.c
diff options
context:
space:
mode:
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)