Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
L
linux-davinci
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Redmine
Redmine
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
linux
linux-davinci
Commits
5ccc1c3c
Commit
5ccc1c3c
authored
Aug 19, 2008
by
Kevin Hilman
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ARM: DaVinci: merge changes after include move
Signed-off-by:
Kevin Hilman
<
khilman@deeprootsystems.com
>
parent
6fd1e0f9
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
35 additions
and
40 deletions
+35
-40
arch/arm/mach-davinci/include/mach/entry-macro.S
arch/arm/mach-davinci/include/mach/entry-macro.S
+1
-2
arch/arm/mach-davinci/include/mach/gpio.h
arch/arm/mach-davinci/include/mach/gpio.h
+33
-38
arch/arm/mach-davinci/include/mach/serial.h
arch/arm/mach-davinci/include/mach/serial.h
+1
-0
No files found.
arch/arm/mach-davinci/include/mach/entry-macro.S
View file @
5ccc1c3c
...
...
@@ -23,9 +23,8 @@
.
macro
get_irqnr_and_base
,
irqnr
,
irqstat
,
base
,
tmp
ldr
\
tmp
,
[
\
base
,
#
0x14
]
mov
\
tmp
,
\
tmp
,
lsr
#
2
mov
s
\
tmp
,
\
tmp
,
lsr
#
2
sub
\
irqnr
,
\
tmp
,
#
1
cmp
\
tmp
,
#
0
.
endm
.
macro
irq_prio_table
...
...
arch/arm/mach-davinci/include/mach/gpio.h
View file @
5ccc1c3c
...
...
@@ -14,6 +14,7 @@
#define __DAVINCI_GPIO_H
#include <linux/io.h>
#include <asm-generic/gpio.h>
#include <mach/hardware.h>
/*
...
...
@@ -27,13 +28,16 @@
* need to pay attention to PINMUX0 and PINMUX1 to be sure those pins are
* used as gpios, not with other peripherals.
*
*
GPIOs are numbered 0..(DAVINCI_N_GPIO-1). For documentation, and maybe
* for later updates, code should write GPIO(N) or:
*
On-chip GPIOs are numbered 0..(DAVINCI_N_GPIO-1). For documentation,
*
and maybe
for later updates, code should write GPIO(N) or:
* - GPIOV18(N) for 1.8V pins, N in 0..53; same as GPIO(0)..GPIO(53)
* - GPIOV33(N) for 3.3V pins, N in 0..17; same as GPIO(54)..GPIO(70)
*
* For GPIO IRQs use gpio_to_irq(GPIO(N)) or gpio_to_irq(GPIOV33(N)) etc
* for now, that's != GPIO(N)
*
* GPIOs can also be on external chips, numbered after the ones built-in
* to the DaVinci chip. For now, they won't be usable as IRQ sources.
*/
#define GPIO(X) (X)
/* 0 <= X <= 70 */
#define GPIOV18(X) (X)
/* 1.8V i/o; 0 <= X <= 53 */
...
...
@@ -67,11 +71,11 @@ __gpio_to_controller(unsigned gpio)
void
*
__iomem
ptr
;
if
(
gpio
<
32
)
ptr
=
(
void
*
__iomem
)
IO_ADDRESS
(
DAVINCI_GPIO_BASE
+
0x10
);
ptr
=
(
void
*
__iomem
)
IO_ADDRESS
(
DAVINCI_GPIO_BASE
+
0x10
);
else
if
(
gpio
<
64
)
ptr
=
(
void
*
__iomem
)
IO_ADDRESS
(
DAVINCI_GPIO_BASE
+
0x38
);
ptr
=
(
void
*
__iomem
)
IO_ADDRESS
(
DAVINCI_GPIO_BASE
+
0x38
);
else
if
(
gpio
<
DAVINCI_N_GPIO
)
ptr
=
(
void
*
__iomem
)
IO_ADDRESS
(
DAVINCI_GPIO_BASE
+
0x60
);
ptr
=
(
void
*
__iomem
)
IO_ADDRESS
(
DAVINCI_GPIO_BASE
+
0x60
);
else
ptr
=
NULL
;
return
ptr
;
...
...
@@ -83,25 +87,17 @@ static inline u32 __gpio_mask(unsigned gpio)
}
/* The get/set/clear functions will inline when called with constant
* parameters, for low-overhead bitbanging. Illegal constant parameters
* cause link-time errors.
* parameters referencing built-in GPIOs, for low-overhead bitbanging.
*
* Otherwise, calls with variable parameters use outlined functions.
* Otherwise, calls with variable parameters or referencing external
* GPIOs (e.g. on GPIO expander chips) use outlined functions.
*/
extern
int
__error_inval_gpio
(
void
);
extern
void
__gpio_set
(
unsigned
gpio
,
int
value
);
extern
int
__gpio_get
(
unsigned
gpio
);
static
inline
void
gpio_set_value
(
unsigned
gpio
,
int
value
)
{
if
(
__builtin_constant_p
(
value
))
{
if
(
__builtin_constant_p
(
value
)
&&
gpio
<
DAVINCI_N_GPIO
)
{
struct
gpio_controller
*
__iomem
g
;
u32
mask
;
if
(
gpio
>=
DAVINCI_N_GPIO
)
__error_inval_gpio
();
g
=
__gpio_to_controller
(
gpio
);
mask
=
__gpio_mask
(
gpio
);
if
(
value
)
...
...
@@ -111,48 +107,47 @@ static inline void gpio_set_value(unsigned gpio, int value)
return
;
}
__gpio_set
(
gpio
,
value
);
__gpio_set
_value
(
gpio
,
value
);
}
/* Returns zero or nonzero; works for gpios configured as inputs OR
* as outputs.
* as outputs
, at least for built-in GPIOs
.
*
* NOTE: changes in reported values are synchronized to the GPIO clock.
* This is most easily seen after calling gpio_set_value() and then immediatly
* gpio_get_value(), where the gpio_get_value() would return the old value
* until the GPIO clock ticks and the new value gets latched.
* NOTE: for built-in GPIOs, changes in reported values are synchronized
* to the GPIO clock. This is easily seen after calling gpio_set_value()
* and then immediately gpio_get_value(), where the gpio_get_value() will
* return the old value until the GPIO clock ticks and the new value gets
* latched.
*/
static
inline
int
gpio_get_value
(
unsigned
gpio
)
{
struct
gpio_controller
*
__iomem
g
;
if
(
!
__builtin_constant_p
(
gpio
))
return
__gpio_get
(
gpio
);
struct
gpio_controller
*
__iomem
g
;
if
(
gpio
>=
DAVINCI_N_GPIO
)
return
__
error_inval_gpio
(
);
if
(
!
__builtin_constant_p
(
gpio
)
||
gpio
>=
DAVINCI_N_GPIO
)
return
__
gpio_get_value
(
gpio
);
g
=
__gpio_to_controller
(
gpio
);
return
!!
(
__gpio_mask
(
gpio
)
&
__raw_readl
(
&
g
->
in_data
));
}
/* powerup default direction is IN */
extern
int
gpio_direction_input
(
unsigned
gpio
);
extern
int
gpio_direction_output
(
unsigned
gpio
,
int
value
);
#include <asm-generic/gpio.h>
/* cansleep wrappers */
extern
int
gpio_request
(
unsigned
gpio
,
const
char
*
tag
);
extern
void
gpio_free
(
unsigned
gpio
);
static
inline
int
gpio_cansleep
(
unsigned
gpio
)
{
if
(
__builtin_constant_p
(
gpio
)
&&
gpio
<
DAVINCI_N_GPIO
)
return
0
;
else
return
__gpio_cansleep
(
gpio
);
}
static
inline
int
gpio_to_irq
(
unsigned
gpio
)
{
if
(
gpio
>=
DAVINCI_N_GPIO
)
return
-
EINVAL
;
return
DAVINCI_N_AINTC_IRQ
+
gpio
;
}
static
inline
int
irq_to_gpio
(
unsigned
irq
)
{
/* caller guarantees gpio_to_irq() succeeded */
return
irq
-
DAVINCI_N_AINTC_IRQ
;
}
...
...
arch/arm/mach-davinci/include/mach/serial.h
View file @
5ccc1c3c
...
...
@@ -13,6 +13,7 @@
#include <mach/io.h>
#define DAVINCI_MAX_NR_UARTS 3
#define DAVINCI_UART0_BASE (IO_PHYS + 0x20000)
#define DAVINCI_UART1_BASE (IO_PHYS + 0x20400)
#define DAVINCI_UART2_BASE (IO_PHYS + 0x20800)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment