Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
9af2ebbd
K
Kernel
项目概览
openeuler
/
Kernel
大约 1 年 前同步成功
通知
7
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
9af2ebbd
编写于
9月 23, 2010
作者:
T
Tony Lindgren
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'hwmod_2.6.37' of
git://git.pwsan.com/linux-2.6
into omap-for-linus
上级
493c32a0
74ff3a68
变更
9
展开全部
隐藏空白更改
内联
并排
Showing
9 changed file
with
829 addition
and
110 deletion
+829
-110
arch/arm/mach-omap2/Makefile
arch/arm/mach-omap2/Makefile
+2
-2
arch/arm/mach-omap2/omap_hwmod.c
arch/arm/mach-omap2/omap_hwmod.c
+472
-90
arch/arm/mach-omap2/prcm.c
arch/arm/mach-omap2/prcm.c
+27
-2
arch/arm/mach-omap2/prm.h
arch/arm/mach-omap2/prm.h
+17
-1
arch/arm/mach-omap2/prm2xxx_3xxx.c
arch/arm/mach-omap2/prm2xxx_3xxx.c
+110
-0
arch/arm/mach-omap2/prm44xx.c
arch/arm/mach-omap2/prm44xx.c
+116
-0
arch/arm/plat-omap/include/plat/omap_hwmod.h
arch/arm/plat-omap/include/plat/omap_hwmod.h
+41
-14
arch/arm/plat-omap/include/plat/prcm.h
arch/arm/plat-omap/include/plat/prcm.h
+2
-0
arch/arm/plat-omap/omap_device.c
arch/arm/plat-omap/omap_device.c
+42
-1
未找到文件。
arch/arm/mach-omap2/Makefile
浏览文件 @
9af2ebbd
...
...
@@ -5,7 +5,7 @@
# Common support
obj-y
:=
id.o io.o control.o mux.o devices.o serial.o gpmc.o timer-gp.o pm.o
omap-2-3-common
=
irq.o sdrc.o
omap-2-3-common
=
irq.o sdrc.o
prm2xxx_3xxx.o
hwmod-common
=
omap_hwmod.o
\
omap_hwmod_common_data.o
prcm-common
=
prcm.o powerdomain.o
...
...
@@ -15,7 +15,7 @@ clock-common = clock.o clock_common_data.o \
obj-$(CONFIG_ARCH_OMAP2)
+=
$
(
omap-2-3-common
)
$
(
prcm-common
)
$
(
hwmod-common
)
obj-$(CONFIG_ARCH_OMAP3)
+=
$
(
omap-2-3-common
)
$
(
prcm-common
)
$
(
hwmod-common
)
obj-$(CONFIG_ARCH_OMAP4)
+=
$
(
prcm-common
)
$
(
hwmod-common
)
obj-$(CONFIG_ARCH_OMAP4)
+=
$
(
prcm-common
)
prm44xx.o
$
(
hwmod-common
)
obj-$(CONFIG_OMAP_MCBSP)
+=
mcbsp.o
...
...
arch/arm/mach-omap2/omap_hwmod.c
浏览文件 @
9af2ebbd
此差异已折叠。
点击以展开。
arch/arm/mach-omap2/prcm.c
浏览文件 @
9af2ebbd
...
...
@@ -33,6 +33,7 @@
#include "cm.h"
#include "prm.h"
#include "prm-regbits-24xx.h"
#include "prm-regbits-44xx.h"
static
void
__iomem
*
prm_base
;
static
void
__iomem
*
cm_base
;
...
...
@@ -161,8 +162,8 @@ void omap_prcm_arch_reset(char mode, const char *cmd)
prm_set_mod_reg_bits
(
OMAP_RST_DPLL3_MASK
,
prcm_offs
,
OMAP2_RM_RSTCTRL
);
if
(
cpu_is_omap44xx
())
prm_set_mod_reg_bits
(
OMAP
_RST_DPLL3_MASK
,
prcm_offs
,
OMAP4_RM_RSTCTRL
);
prm_set_mod_reg_bits
(
OMAP
4430_RST_GLOBAL_WARM_SW_MASK
,
prcm_offs
,
OMAP4_RM_RSTCTRL
);
}
static
inline
u32
__omap_prcm_read
(
void
__iomem
*
base
,
s16
module
,
u16
reg
)
...
...
@@ -215,6 +216,30 @@ u32 prm_read_mod_bits_shift(s16 domain, s16 idx, u32 mask)
return
v
;
}
/* Read a PRM register, AND it, and shift the result down to bit 0 */
u32
omap4_prm_read_bits_shift
(
void
__iomem
*
reg
,
u32
mask
)
{
u32
v
;
v
=
__raw_readl
(
reg
);
v
&=
mask
;
v
>>=
__ffs
(
mask
);
return
v
;
}
/* Read-modify-write a register in a PRM module. Caller must lock */
u32
omap4_prm_rmw_reg_bits
(
u32
mask
,
u32
bits
,
void
__iomem
*
reg
)
{
u32
v
;
v
=
__raw_readl
(
reg
);
v
&=
~
mask
;
v
|=
bits
;
__raw_writel
(
v
,
reg
);
return
v
;
}
/* Read a register in a CM module */
u32
cm_read_mod_reg
(
s16
module
,
u16
idx
)
{
...
...
arch/arm/mach-omap2/prm.h
浏览文件 @
9af2ebbd
...
...
@@ -5,7 +5,7 @@
* OMAP2/3 Power/Reset Management (PRM) register definitions
*
* Copyright (C) 2007-2009 Texas Instruments, Inc.
* Copyright (C) 20
09
Nokia Corporation
* Copyright (C) 20
10
Nokia Corporation
*
* Written by Paul Walmsley
*
...
...
@@ -246,6 +246,15 @@ static inline u32 prm_clear_mod_reg_bits(u32 bits, s16 module, s16 idx)
return
prm_rmw_mod_reg_bits
(
bits
,
0x0
,
module
,
idx
);
}
/* These omap2_ PRM functions apply to both OMAP2 and 3 */
int
omap2_prm_is_hardreset_asserted
(
s16
prm_mod
,
u8
shift
);
int
omap2_prm_assert_hardreset
(
s16
prm_mod
,
u8
shift
);
int
omap2_prm_deassert_hardreset
(
s16
prm_mod
,
u8
shift
);
int
omap4_prm_is_hardreset_asserted
(
void
__iomem
*
rstctrl_reg
,
u8
shift
);
int
omap4_prm_assert_hardreset
(
void
__iomem
*
rstctrl_reg
,
u8
shift
);
int
omap4_prm_deassert_hardreset
(
void
__iomem
*
rstctrl_reg
,
u8
shift
);
#endif
/*
...
...
@@ -398,4 +407,11 @@ static inline u32 prm_clear_mod_reg_bits(u32 bits, s16 module, s16 idx)
#define OMAP_POWERSTATE_MASK (0x3 << 0)
/*
* MAX_MODULE_HARDRESET_WAIT: Maximum microseconds to wait for an OMAP
* submodule to exit hardreset
*/
#define MAX_MODULE_HARDRESET_WAIT 10000
#endif
arch/arm/mach-omap2/prm2xxx_3xxx.c
0 → 100644
浏览文件 @
9af2ebbd
/*
* OMAP2/3 PRM module functions
*
* Copyright (C) 2010 Texas Instruments, Inc.
* Copyright (C) 2010 Nokia Corporation
* Benoît Cousson
* Paul Walmsley
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*/
#include <linux/kernel.h>
#include <linux/delay.h>
#include <linux/errno.h>
#include <linux/err.h>
#include <plat/common.h>
#include <plat/cpu.h>
#include <plat/prcm.h>
#include "prm.h"
#include "prm-regbits-24xx.h"
#include "prm-regbits-34xx.h"
/**
* omap2_prm_is_hardreset_asserted - read the HW reset line state of
* submodules contained in the hwmod module
* @prm_mod: PRM submodule base (e.g. CORE_MOD)
* @shift: register bit shift corresponding to the reset line to check
*
* Returns 1 if the (sub)module hardreset line is currently asserted,
* 0 if the (sub)module hardreset line is not currently asserted, or
* -EINVAL if called while running on a non-OMAP2/3 chip.
*/
int
omap2_prm_is_hardreset_asserted
(
s16
prm_mod
,
u8
shift
)
{
if
(
!
(
cpu_is_omap24xx
()
||
cpu_is_omap34xx
()))
return
-
EINVAL
;
return
prm_read_mod_bits_shift
(
prm_mod
,
OMAP2_RM_RSTCTRL
,
(
1
<<
shift
));
}
/**
* omap2_prm_assert_hardreset - assert the HW reset line of a submodule
* @prm_mod: PRM submodule base (e.g. CORE_MOD)
* @shift: register bit shift corresponding to the reset line to assert
*
* Some IPs like dsp or iva contain processors that require an HW
* reset line to be asserted / deasserted in order to fully enable the
* IP. These modules may have multiple hard-reset lines that reset
* different 'submodules' inside the IP block. This function will
* place the submodule into reset. Returns 0 upon success or -EINVAL
* upon an argument error.
*/
int
omap2_prm_assert_hardreset
(
s16
prm_mod
,
u8
shift
)
{
u32
mask
;
if
(
!
(
cpu_is_omap24xx
()
||
cpu_is_omap34xx
()))
return
-
EINVAL
;
mask
=
1
<<
shift
;
prm_rmw_mod_reg_bits
(
mask
,
mask
,
prm_mod
,
OMAP2_RM_RSTCTRL
);
return
0
;
}
/**
* omap2_prm_deassert_hardreset - deassert a submodule hardreset line and wait
* @prm_mod: PRM submodule base (e.g. CORE_MOD)
* @shift: register bit shift corresponding to the reset line to deassert
*
* Some IPs like dsp or iva contain processors that require an HW
* reset line to be asserted / deasserted in order to fully enable the
* IP. These modules may have multiple hard-reset lines that reset
* different 'submodules' inside the IP block. This function will
* take the submodule out of reset and wait until the PRCM indicates
* that the reset has completed before returning. Returns 0 upon success or
* -EINVAL upon an argument error, -EEXIST if the submodule was already out
* of reset, or -EBUSY if the submodule did not exit reset promptly.
*/
int
omap2_prm_deassert_hardreset
(
s16
prm_mod
,
u8
shift
)
{
u32
mask
;
int
c
;
if
(
!
(
cpu_is_omap24xx
()
||
cpu_is_omap34xx
()))
return
-
EINVAL
;
mask
=
1
<<
shift
;
/* Check the current status to avoid de-asserting the line twice */
if
(
prm_read_mod_bits_shift
(
prm_mod
,
OMAP2_RM_RSTCTRL
,
mask
)
==
0
)
return
-
EEXIST
;
/* Clear the reset status by writing 1 to the status bit */
prm_rmw_mod_reg_bits
(
0xffffffff
,
mask
,
prm_mod
,
OMAP2_RM_RSTST
);
/* de-assert the reset control line */
prm_rmw_mod_reg_bits
(
mask
,
0
,
prm_mod
,
OMAP2_RM_RSTCTRL
);
/* wait the status to be set */
omap_test_timeout
(
prm_read_mod_bits_shift
(
prm_mod
,
OMAP2_RM_RSTST
,
mask
),
MAX_MODULE_HARDRESET_WAIT
,
c
);
return
(
c
==
MAX_MODULE_HARDRESET_WAIT
)
?
-
EBUSY
:
0
;
}
arch/arm/mach-omap2/prm44xx.c
0 → 100644
浏览文件 @
9af2ebbd
/*
* OMAP4 PRM module functions
*
* Copyright (C) 2010 Texas Instruments, Inc.
* Copyright (C) 2010 Nokia Corporation
* Benoît Cousson
* Paul Walmsley
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*/
#include <linux/kernel.h>
#include <linux/delay.h>
#include <linux/errno.h>
#include <linux/err.h>
#include <plat/common.h>
#include <plat/cpu.h>
#include <plat/prcm.h>
#include "prm.h"
#include "prm-regbits-44xx.h"
/*
* Address offset (in bytes) between the reset control and the reset
* status registers: 4 bytes on OMAP4
*/
#define OMAP4_RST_CTRL_ST_OFFSET 4
/**
* omap4_prm_is_hardreset_asserted - read the HW reset line state of
* submodules contained in the hwmod module
* @rstctrl_reg: RM_RSTCTRL register address for this module
* @shift: register bit shift corresponding to the reset line to check
*
* Returns 1 if the (sub)module hardreset line is currently asserted,
* 0 if the (sub)module hardreset line is not currently asserted, or
* -EINVAL upon parameter error.
*/
int
omap4_prm_is_hardreset_asserted
(
void
__iomem
*
rstctrl_reg
,
u8
shift
)
{
if
(
!
cpu_is_omap44xx
()
||
!
rstctrl_reg
)
return
-
EINVAL
;
return
omap4_prm_read_bits_shift
(
rstctrl_reg
,
(
1
<<
shift
));
}
/**
* omap4_prm_assert_hardreset - assert the HW reset line of a submodule
* @rstctrl_reg: RM_RSTCTRL register address for this module
* @shift: register bit shift corresponding to the reset line to assert
*
* Some IPs like dsp, ipu or iva contain processors that require an HW
* reset line to be asserted / deasserted in order to fully enable the
* IP. These modules may have multiple hard-reset lines that reset
* different 'submodules' inside the IP block. This function will
* place the submodule into reset. Returns 0 upon success or -EINVAL
* upon an argument error.
*/
int
omap4_prm_assert_hardreset
(
void
__iomem
*
rstctrl_reg
,
u8
shift
)
{
u32
mask
;
if
(
!
cpu_is_omap44xx
()
||
!
rstctrl_reg
)
return
-
EINVAL
;
mask
=
1
<<
shift
;
omap4_prm_rmw_reg_bits
(
mask
,
mask
,
rstctrl_reg
);
return
0
;
}
/**
* omap4_prm_deassert_hardreset - deassert a submodule hardreset line and wait
* @rstctrl_reg: RM_RSTCTRL register address for this module
* @shift: register bit shift corresponding to the reset line to deassert
*
* Some IPs like dsp, ipu or iva contain processors that require an HW
* reset line to be asserted / deasserted in order to fully enable the
* IP. These modules may have multiple hard-reset lines that reset
* different 'submodules' inside the IP block. This function will
* take the submodule out of reset and wait until the PRCM indicates
* that the reset has completed before returning. Returns 0 upon success or
* -EINVAL upon an argument error, -EEXIST if the submodule was already out
* of reset, or -EBUSY if the submodule did not exit reset promptly.
*/
int
omap4_prm_deassert_hardreset
(
void
__iomem
*
rstctrl_reg
,
u8
shift
)
{
u32
mask
;
void
__iomem
*
rstst_reg
;
int
c
;
if
(
!
cpu_is_omap44xx
()
||
!
rstctrl_reg
)
return
-
EINVAL
;
rstst_reg
=
rstctrl_reg
+
OMAP4_RST_CTRL_ST_OFFSET
;
mask
=
1
<<
shift
;
/* Check the current status to avoid de-asserting the line twice */
if
(
omap4_prm_read_bits_shift
(
rstctrl_reg
,
mask
)
==
0
)
return
-
EEXIST
;
/* Clear the reset status by writing 1 to the status bit */
omap4_prm_rmw_reg_bits
(
0xffffffff
,
mask
,
rstst_reg
);
/* de-assert the reset control line */
omap4_prm_rmw_reg_bits
(
mask
,
0
,
rstctrl_reg
);
/* wait the status to be set */
omap_test_timeout
(
omap4_prm_read_bits_shift
(
rstst_reg
,
mask
),
MAX_MODULE_HARDRESET_WAIT
,
c
);
return
(
c
==
MAX_MODULE_HARDRESET_WAIT
)
?
-
EBUSY
:
0
;
}
arch/arm/plat-omap/include/plat/omap_hwmod.h
浏览文件 @
9af2ebbd
...
...
@@ -14,19 +14,16 @@
*
* These headers and macros are used to define OMAP on-chip module
* data and their integration with other OMAP modules and Linux.
*
* References:
* - OMAP2420 Multimedia Processor Silicon Revision 2.1.1, 2.2 (SWPU064)
* - OMAP2430 Multimedia Device POP Silicon Revision 2.1 (SWPU090)
* - OMAP34xx Multimedia Device Silicon Revision 3.1 (SWPU108)
* - OMAP4430 Multimedia Device Silicon Revision 1.0 (SWPU140)
* - Open Core Protocol Specification 2.2
* Copious documentation and references can also be found in the
* omap_hwmod code, in arch/arm/mach-omap2/omap_hwmod.c (as of this
* writing).
*
* To do:
* - add interconnect error log structures
* - add pinmuxing
* - init_conn_id_bit (CONNID_BIT_VECTOR)
* - implement default hwmod SMS/SDRC flags?
* - remove unused fields
*
*/
#ifndef __ARCH_ARM_PLAT_OMAP_INCLUDE_MACH_OMAP_HWMOD_H
...
...
@@ -35,6 +32,7 @@
#include <linux/kernel.h>
#include <linux/list.h>
#include <linux/ioport.h>
#include <linux/mutex.h>
#include <plat/cpu.h>
struct
omap_device
;
...
...
@@ -96,7 +94,7 @@ struct omap_hwmod_irq_info {
/**
* struct omap_hwmod_dma_info - DMA channels used by the hwmod
* @name: name of the DMA channel (module local name)
* @dma_
ch: DMA channel
ID
* @dma_
req: DMA request
ID
*
* @name should be something short, e.g., "tx" or "rx". It is for use
* by platform_get_resource_byname(). It is defined locally to the
...
...
@@ -104,7 +102,20 @@ struct omap_hwmod_irq_info {
*/
struct
omap_hwmod_dma_info
{
const
char
*
name
;
u16
dma_ch
;
u16
dma_req
;
};
/**
* struct omap_hwmod_rst_info - IPs reset lines use by hwmod
* @name: name of the reset line (module local name)
* @rst_shift: Offset of the reset bit
*
* @name should be something short, e.g., "cpu0" or "rst". It is defined
* locally to the hwmod.
*/
struct
omap_hwmod_rst_info
{
const
char
*
name
;
u8
rst_shift
;
};
/**
...
...
@@ -237,8 +248,9 @@ struct omap_hwmod_ocp_if {
#define SYSC_HAS_CLOCKACTIVITY (1 << 4)
#define SYSC_HAS_SIDLEMODE (1 << 5)
#define SYSC_HAS_MIDLEMODE (1 << 6)
#define SYSS_
MISSING
(1 << 7)
#define SYSS_
HAS_RESET_STATUS
(1 << 7)
#define SYSC_NO_CACHE (1 << 8)
/* XXX SW flag, belongs elsewhere */
#define SYSC_HAS_RESET_STATUS (1 << 9)
/* omap_hwmod_sysconfig.clockact flags */
#define CLOCKACT_TEST_BOTH 0x0
...
...
@@ -327,10 +339,12 @@ struct omap_hwmod_omap2_prcm {
/**
* struct omap_hwmod_omap4_prcm - OMAP4-specific PRCM data
* @clkctrl_reg: PRCM address of the clock control register
* @rstctrl_reg: adress of the XXX_RSTCTRL register located in the PRM
* @submodule_wkdep_bit: bit shift of the WKDEP range
*/
struct
omap_hwmod_omap4_prcm
{
void
__iomem
*
clkctrl_reg
;
void
__iomem
*
rstctrl_reg
;
u8
submodule_wkdep_bit
;
};
...
...
@@ -352,6 +366,10 @@ struct omap_hwmod_omap4_prcm {
* HWMOD_SET_DEFAULT_CLOCKACT: program CLOCKACTIVITY bits at startup
* HWMOD_NO_IDLEST : this module does not have idle status - this is the case
* only for few initiator modules on OMAP2 & 3.
* HWMOD_CONTROL_OPT_CLKS_IN_RESET: Enable all optional clocks during reset.
* This is needed for devices like DSS that require optional clocks enabled
* in order to complete the reset. Optional clocks will be disabled
* again after the reset.
*/
#define HWMOD_SWSUP_SIDLE (1 << 0)
#define HWMOD_SWSUP_MSTANDBY (1 << 1)
...
...
@@ -360,6 +378,7 @@ struct omap_hwmod_omap4_prcm {
#define HWMOD_NO_OCP_AUTOIDLE (1 << 4)
#define HWMOD_SET_DEFAULT_CLOCKACT (1 << 5)
#define HWMOD_NO_IDLEST (1 << 6)
#define HWMOD_CONTROL_OPT_CLKS_IN_RESET (1 << 7)
/*
* omap_hwmod._int_flags definitions
...
...
@@ -410,7 +429,7 @@ struct omap_hwmod_class {
* @class: struct omap_hwmod_class * to the class of this hwmod
* @od: struct omap_device currently associated with this hwmod (internal use)
* @mpu_irqs: ptr to an array of MPU IRQs (see also mpu_irqs_cnt)
* @sdma_
chs: ptr to an array of SDMA channel IDs (see also sdma_ch
s_cnt)
* @sdma_
reqs: ptr to an array of System DMA request IDs (see sdma_req
s_cnt)
* @prcm: PRCM data pertaining to this hwmod
* @main_clk: main clock: OMAP clock name
* @_clk: pointer to the main struct clk (filled in at runtime)
...
...
@@ -424,7 +443,7 @@ struct omap_hwmod_class {
* @msuspendmux_reg_id: CONTROL_MSUSPENDMUX register ID (1-6)
* @msuspendmux_shift: CONTROL_MSUSPENDMUX register bit shift
* @mpu_irqs_cnt: number of @mpu_irqs
* @sdma_
chs_cnt: number of @sdma_ch
s
* @sdma_
reqs_cnt: number of @sdma_req
s
* @opt_clks_cnt: number of @opt_clks
* @master_cnt: number of @master entries
* @slaves_cnt: number of @slave entries
...
...
@@ -433,6 +452,7 @@ struct omap_hwmod_class {
* @_state: internal-use hwmod state
* @flags: hwmod flags (documented below)
* @omap_chip: OMAP chips this hwmod is present on
* @_mutex: mutex serializing operations on this hwmod
* @node: list node for hwmod list (internal use)
*
* @main_clk refers to this module's "main clock," which for our
...
...
@@ -448,7 +468,8 @@ struct omap_hwmod {
struct
omap_hwmod_class
*
class
;
struct
omap_device
*
od
;
struct
omap_hwmod_irq_info
*
mpu_irqs
;
struct
omap_hwmod_dma_info
*
sdma_chs
;
struct
omap_hwmod_dma_info
*
sdma_reqs
;
struct
omap_hwmod_rst_info
*
rst_lines
;
union
{
struct
omap_hwmod_omap2_prcm
omap2
;
struct
omap_hwmod_omap4_prcm
omap4
;
...
...
@@ -461,6 +482,7 @@ struct omap_hwmod {
void
*
dev_attr
;
u32
_sysc_cache
;
void
__iomem
*
_mpu_rt_va
;
struct
mutex
_mutex
;
struct
list_head
node
;
u16
flags
;
u8
_mpu_port_index
;
...
...
@@ -468,7 +490,8 @@ struct omap_hwmod {
u8
msuspendmux_shift
;
u8
response_lat
;
u8
mpu_irqs_cnt
;
u8
sdma_chs_cnt
;
u8
sdma_reqs_cnt
;
u8
rst_lines_cnt
;
u8
opt_clks_cnt
;
u8
masters_cnt
;
u8
slaves_cnt
;
...
...
@@ -492,6 +515,10 @@ int omap_hwmod_idle(struct omap_hwmod *oh);
int
_omap_hwmod_idle
(
struct
omap_hwmod
*
oh
);
int
omap_hwmod_shutdown
(
struct
omap_hwmod
*
oh
);
int
omap_hwmod_assert_hardreset
(
struct
omap_hwmod
*
oh
,
const
char
*
name
);
int
omap_hwmod_deassert_hardreset
(
struct
omap_hwmod
*
oh
,
const
char
*
name
);
int
omap_hwmod_read_hardreset
(
struct
omap_hwmod
*
oh
,
const
char
*
name
);
int
omap_hwmod_enable_clocks
(
struct
omap_hwmod
*
oh
);
int
omap_hwmod_disable_clocks
(
struct
omap_hwmod
*
oh
);
...
...
arch/arm/plat-omap/include/plat/prcm.h
浏览文件 @
9af2ebbd
...
...
@@ -38,6 +38,8 @@ u32 prm_read_mod_reg(s16 module, u16 idx);
void
prm_write_mod_reg
(
u32
val
,
s16
module
,
u16
idx
);
u32
prm_rmw_mod_reg_bits
(
u32
mask
,
u32
bits
,
s16
module
,
s16
idx
);
u32
prm_read_mod_bits_shift
(
s16
domain
,
s16
idx
,
u32
mask
);
u32
omap4_prm_read_bits_shift
(
void
__iomem
*
reg
,
u32
mask
);
u32
omap4_prm_rmw_reg_bits
(
u32
mask
,
u32
bits
,
void
__iomem
*
reg
);
u32
cm_read_mod_reg
(
s16
module
,
u16
idx
);
void
cm_write_mod_reg
(
u32
val
,
s16
module
,
u16
idx
);
u32
cm_rmw_mod_reg_bits
(
u32
mask
,
u32
bits
,
s16
module
,
s16
idx
);
...
...
arch/arm/plat-omap/omap_device.c
浏览文件 @
9af2ebbd
...
...
@@ -82,6 +82,7 @@
#include <linux/slab.h>
#include <linux/err.h>
#include <linux/io.h>
#include <linux/clk.h>
#include <plat/omap_device.h>
#include <plat/omap_hwmod.h>
...
...
@@ -243,6 +244,44 @@ static inline struct omap_device *_find_by_pdev(struct platform_device *pdev)
return
container_of
(
pdev
,
struct
omap_device
,
pdev
);
}
/**
* _add_optional_clock_alias - Add clock alias for hwmod optional clocks
* @od: struct omap_device *od
*
* For every optional clock present per hwmod per omap_device, this function
* adds an entry in the clocks list of the form <dev-id=dev_name, con-id=role>
* if an entry is already present in it with the form <dev-id=NULL, con-id=role>
*
* The function is called from inside omap_device_build_ss(), after
* omap_device_register.
*
* This allows drivers to get a pointer to its optional clocks based on its role
* by calling clk_get(<dev*>, <role>).
*
* No return value.
*/
static
void
_add_optional_clock_alias
(
struct
omap_device
*
od
,
struct
omap_hwmod
*
oh
)
{
int
i
;
for
(
i
=
0
;
i
<
oh
->
opt_clks_cnt
;
i
++
)
{
struct
omap_hwmod_opt_clk
*
oc
;
int
r
;
oc
=
&
oh
->
opt_clks
[
i
];
if
(
!
oc
->
_clk
)
continue
;
r
=
clk_add_alias
(
oc
->
role
,
dev_name
(
&
od
->
pdev
.
dev
),
(
char
*
)
oc
->
clk
,
&
od
->
pdev
.
dev
);
if
(
r
)
pr_err
(
"omap_device: %s: clk_add_alias for %s failed
\n
"
,
dev_name
(
&
od
->
pdev
.
dev
),
oc
->
role
);
}
}
/* Public functions for use by core code */
...
...
@@ -421,8 +460,10 @@ struct omap_device *omap_device_build_ss(const char *pdev_name, int pdev_id,
else
ret
=
omap_device_register
(
od
);
for
(
i
=
0
;
i
<
oh_cnt
;
i
++
)
for
(
i
=
0
;
i
<
oh_cnt
;
i
++
)
{
hwmods
[
i
]
->
od
=
od
;
_add_optional_clock_alias
(
od
,
hwmods
[
i
]);
}
if
(
ret
)
goto
odbs_exit4
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录