Linux Kernel
3.7.1
Main Page
Related Pages
Modules
Namespaces
Data Structures
Files
File List
Globals
•
All
Data Structures
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Macros
Groups
Pages
arch
arm
mach-tegra
pmc.c
Go to the documentation of this file.
1
/*
2
* Copyright (C) 2012 NVIDIA CORPORATION. All rights reserved.
3
*
4
* This program is free software; you can redistribute it and/or modify it
5
* under the terms and conditions of the GNU General Public License,
6
* version 2, as published by the Free Software Foundation.
7
*
8
* This program is distributed in the hope it will be useful, but WITHOUT
9
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
10
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
11
* more details.
12
*
13
* You should have received a copy of the GNU General Public License
14
* along with this program. If not, see <http://www.gnu.org/licenses/>.
15
*
16
*/
17
18
#include <linux/kernel.h>
19
#include <
linux/io.h
>
20
#include <
linux/of.h
>
21
22
#include <
mach/iomap.h
>
23
24
#define PMC_CTRL 0x0
25
#define PMC_CTRL_INTR_LOW (1 << 17)
26
27
static
inline
u32
tegra_pmc_readl(
u32
reg
)
28
{
29
return
readl
(
IO_ADDRESS
(
TEGRA_PMC_BASE
+ reg));
30
}
31
32
static
inline
void
tegra_pmc_writel(
u32
val
,
u32
reg
)
33
{
34
writel
(val,
IO_ADDRESS
(
TEGRA_PMC_BASE
+ reg));
35
}
36
37
#ifdef CONFIG_OF
38
static
const
struct
of_device_id
matches[]
__initconst
= {
39
{ .compatible =
"nvidia,tegra20-pmc"
},
40
{ }
41
};
42
#endif
43
44
void
__init
tegra_pmc_init
(
void
)
45
{
46
/*
47
* For now, Harmony is the only board that uses the PMC, and it wants
48
* the signal inverted. Seaboard would too if it used the PMC.
49
* Hopefully by the time other boards want to use the PMC, everything
50
* will be device-tree, or they also want it inverted.
51
*/
52
bool
invert_interrupt =
true
;
53
u32
val
;
54
55
#ifdef CONFIG_OF
56
if
(of_have_populated_dt()) {
57
struct
device_node
*np;
58
59
invert_interrupt =
false
;
60
61
np =
of_find_matching_node
(
NULL
, matches);
62
if
(np) {
63
if
(
of_find_property
(np,
"nvidia,invert-interrupt"
,
64
NULL
))
65
invert_interrupt =
true
;
66
}
67
}
68
#endif
69
70
val = tegra_pmc_readl(
PMC_CTRL
);
71
if
(invert_interrupt)
72
val |=
PMC_CTRL_INTR_LOW
;
73
else
74
val &= ~
PMC_CTRL_INTR_LOW
;
75
tegra_pmc_writel(val,
PMC_CTRL
);
76
}
Generated on Thu Jan 10 2013 13:02:08 for Linux Kernel by
1.8.2