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
d895fd24
Commit
d895fd24
authored
Feb 11, 2009
by
Kevin Hilman
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
davinci: clkdev: convert to new clkdev infrastructure
Signed-off-by:
Kevin Hilman
<
khilman@deeprootsystems.com
>
parent
61fa7027
Changes
16
Hide whitespace changes
Inline
Side-by-side
Showing
16 changed files
with
189 additions
and
266 deletions
+189
-266
arch/arm/Kconfig
arch/arm/Kconfig
+1
-0
arch/arm/mach-davinci/clock.c
arch/arm/mach-davinci/clock.c
+17
-126
arch/arm/mach-davinci/clock.h
arch/arm/mach-davinci/clock.h
+15
-0
arch/arm/mach-davinci/devices.c
arch/arm/mach-davinci/devices.c
+0
-4
arch/arm/mach-davinci/dm355.c
arch/arm/mach-davinci/dm355.c
+46
-46
arch/arm/mach-davinci/dm644x.c
arch/arm/mach-davinci/dm644x.c
+44
-42
arch/arm/mach-davinci/dm646x.c
arch/arm/mach-davinci/dm646x.c
+37
-30
arch/arm/mach-davinci/include/mach/clkdev.h
arch/arm/mach-davinci/include/mach/clkdev.h
+13
-0
arch/arm/mach-davinci/include/mach/clock.h
arch/arm/mach-davinci/include/mach/clock.h
+0
-1
arch/arm/mach-davinci/time.c
arch/arm/mach-davinci/time.c
+10
-7
drivers/i2c/busses/i2c-davinci.c
drivers/i2c/busses/i2c-davinci.c
+1
-1
drivers/ide/palm_bk3710.c
drivers/ide/palm_bk3710.c
+1
-1
drivers/mmc/host/davinci_mmc.c
drivers/mmc/host/davinci_mmc.c
+1
-1
drivers/net/davinci_emac.c
drivers/net/davinci_emac.c
+1
-1
drivers/watchdog/davinci_wdt.c
drivers/watchdog/davinci_wdt.c
+1
-1
sound/soc/davinci/davinci-i2s.c
sound/soc/davinci/davinci-i2s.c
+1
-5
No files found.
arch/arm/Kconfig
View file @
d895fd24
...
@@ -560,6 +560,7 @@ config ARCH_DAVINCI
...
@@ -560,6 +560,7 @@ config ARCH_DAVINCI
select HAVE_CLK
select HAVE_CLK
select ZONE_DMA
select ZONE_DMA
select HAVE_IDE
select HAVE_IDE
select COMMON_CLKDEV
help
help
Support for TI's DaVinci platform.
Support for TI's DaVinci platform.
...
...
arch/arm/mach-davinci/clock.c
View file @
d895fd24
...
@@ -30,114 +30,6 @@ static LIST_HEAD(clocks);
...
@@ -30,114 +30,6 @@ static LIST_HEAD(clocks);
static
DEFINE_MUTEX
(
clocks_mutex
);
static
DEFINE_MUTEX
(
clocks_mutex
);
static
DEFINE_SPINLOCK
(
clockfw_lock
);
static
DEFINE_SPINLOCK
(
clockfw_lock
);
extern
void
davinci_psc_config
(
unsigned
int
domain
,
unsigned
int
id
,
char
enable
);
/*
* Register a mapping { dev, logical_clockname } --> clock
*
* Device drivers should always use logical clocknames, so they
* don't need to change the physical name when new silicon grows
* another instance of that module or changes the clock tree.
*/
struct
clk_mapping
{
struct
device
*
dev
;
const
char
*
name
;
struct
clk
*
clock
;
struct
clk_mapping
*
next
;
};
static
struct
clk_mapping
*
maplist
;
int
__init
davinci_clk_associate
(
struct
device
*
dev
,
const
char
*
logical_clockname
,
const
char
*
physical_clockname
)
{
int
status
=
-
EINVAL
;
struct
clk
*
clock
;
struct
clk_mapping
*
mapping
;
if
(
!
dev
)
goto
done
;
clock
=
clk_get
(
dev
,
physical_clockname
);
if
(
IS_ERR
(
clock
)
||
!
try_module_get
(
clock
->
owner
))
goto
done
;
mutex_lock
(
&
clocks_mutex
);
for
(
mapping
=
maplist
;
mapping
;
mapping
=
mapping
->
next
)
{
if
(
dev
!=
mapping
->
dev
)
continue
;
if
(
strcmp
(
logical_clockname
,
mapping
->
name
)
!=
0
)
continue
;
goto
fail
;
}
mapping
=
kzalloc
(
sizeof
*
mapping
,
GFP_KERNEL
);
mapping
->
dev
=
dev
;
mapping
->
name
=
logical_clockname
;
mapping
->
clock
=
clock
;
mapping
->
next
=
maplist
;
maplist
=
mapping
;
status
=
0
;
fail:
mutex_unlock
(
&
clocks_mutex
);
done:
WARN_ON
(
status
<
0
);
return
status
;
}
/*
* Returns a clock. Note that we first try to use device id on the bus
* and clock name. If this fails, we try to use clock name only.
*/
struct
clk
*
clk_get
(
struct
device
*
dev
,
const
char
*
id
)
{
struct
clk
*
p
,
*
clk
=
ERR_PTR
(
-
ENOENT
);
struct
clk_mapping
*
mapping
;
if
(
!
id
)
return
ERR_PTR
(
-
EINVAL
);
mutex_lock
(
&
clocks_mutex
);
/* always prefer logical clock names */
if
(
dev
)
{
for
(
mapping
=
maplist
;
mapping
;
mapping
=
mapping
->
next
)
{
if
(
dev
!=
mapping
->
dev
)
continue
;
if
(
strcmp
(
id
,
mapping
->
name
)
!=
0
)
continue
;
clk
=
mapping
->
clock
;
goto
found
;
}
}
list_for_each_entry
(
p
,
&
clocks
,
node
)
{
if
(
strcmp
(
id
,
p
->
name
)
==
0
&&
try_module_get
(
p
->
owner
))
{
clk
=
p
;
break
;
}
}
found:
mutex_unlock
(
&
clocks_mutex
);
WARN
(
IS_ERR
(
clk
),
"CLK: can't find %s/%s
\n
"
,
dev
?
dev_name
(
dev
)
:
"nodev"
,
id
);
return
clk
;
}
EXPORT_SYMBOL
(
clk_get
);
void
clk_put
(
struct
clk
*
clk
)
{
if
(
clk
&&
!
IS_ERR
(
clk
))
module_put
(
clk
->
owner
);
}
EXPORT_SYMBOL
(
clk_put
);
static
unsigned
psc_domain
(
struct
clk
*
clk
)
static
unsigned
psc_domain
(
struct
clk
*
clk
)
{
{
return
(
clk
->
flags
&
PSC_DSP
)
return
(
clk
->
flags
&
PSC_DSP
)
...
@@ -372,31 +264,30 @@ static void __init clk_pll_init(struct clk *clk)
...
@@ -372,31 +264,30 @@ static void __init clk_pll_init(struct clk *clk)
pr_debug
(
"] --> %lu MHz output.
\n
"
,
clk
->
rate
/
1000000
);
pr_debug
(
"] --> %lu MHz output.
\n
"
,
clk
->
rate
/
1000000
);
}
}
int
__init
davinci_clk_init
(
struct
clk
*
clocks
[]
)
int
__init
davinci_clk_init
(
struct
davinci_clk
*
clocks
)
{
{
struct
clk
*
clkp
;
struct
davinci_clk
*
c
;
int
i
=
0
;
struct
clk
*
clk
;
while
((
clkp
=
clocks
[
i
++
]))
{
for
(
c
=
clocks
;
c
->
lk
.
clk
;
c
++
)
{
if
(
clkp
->
pll_data
)
clk
=
c
->
lk
.
clk
;
clk_pll_init
(
clkp
);
/* Calculate rates for PLL-derived clocks */
if
(
clk
->
pll_data
)
else
if
(
clkp
->
flags
&
CLK_PLL
)
clk_pll_init
(
clk
);
clk_sysclk_recalc
(
clkp
);
if
(
clkp
->
lpsc
)
/* Calculate rates for PLL-derived clocks */
clkp
->
flags
|=
CLK_PSC
;
else
if
(
clk
->
flags
&
CLK_PLL
)
clk_sysclk_recalc
(
clk
);
clk_register
(
clkp
);
if
(
clk
->
lpsc
)
clk
->
flags
|=
CLK_PSC
;
/* FIXME: remove equivalent special-cased code from
clkdev_add
(
&
c
->
lk
);
* davinci_psc_init() once cpus list *all* clocks.
clk_register
(
clk
);
*/
/* Turn on clocks that Linux doesn't otherwise manage */
/* Turn on clocks that Linux doesn't otherwise manage */
if
(
clk
p
->
flags
&
ALWAYS_ENABLED
)
if
(
clk
->
flags
&
ALWAYS_ENABLED
)
clk_enable
(
clk
p
);
clk_enable
(
clk
);
}
}
return
0
;
return
0
;
...
...
arch/arm/mach-davinci/clock.h
View file @
d895fd24
...
@@ -12,6 +12,7 @@
...
@@ -12,6 +12,7 @@
#define __ARCH_ARM_DAVINCI_CLOCK_H
#define __ARCH_ARM_DAVINCI_CLOCK_H
#include <linux/list.h>
#include <linux/list.h>
#include <asm/clkdev.h>
#define DAVINCI_PLL1_BASE 0x01c40800
#define DAVINCI_PLL1_BASE 0x01c40800
#define DAVINCI_PLL2_BASE 0x01c40c00
#define DAVINCI_PLL2_BASE 0x01c40c00
...
@@ -76,7 +77,21 @@ struct clk {
...
@@ -76,7 +77,21 @@ struct clk {
#define CLK_PLL BIT(4)
/* PLL-derived clock */
#define CLK_PLL BIT(4)
/* PLL-derived clock */
#define PRE_PLL BIT(5)
/* source is before PLL mult/div */
#define PRE_PLL BIT(5)
/* source is before PLL mult/div */
struct
davinci_clk
{
struct
clk_lookup
lk
;
};
#define CLK(dev, con, ck) \
{ \
.lk = { \
.dev_id = dev, \
.con_id = con, \
.clk = ck, \
}, \
}
int
davinci_clk_associate
(
struct
device
*
dev
,
const
char
*
logical_clockname
,
int
davinci_clk_associate
(
struct
device
*
dev
,
const
char
*
logical_clockname
,
const
char
*
physical_clockname
);
const
char
*
physical_clockname
);
int
davinci_clk_init
(
struct
davinci_clk
*
clocks
);
#endif
#endif
arch/arm/mach-davinci/devices.c
View file @
d895fd24
...
@@ -152,7 +152,6 @@ static struct platform_device davinci_mmcsd1_device = {
...
@@ -152,7 +152,6 @@ static struct platform_device davinci_mmcsd1_device = {
void
__init
davinci_setup_mmc
(
int
module
,
struct
davinci_mmc_config
*
config
)
void
__init
davinci_setup_mmc
(
int
module
,
struct
davinci_mmc_config
*
config
)
{
{
struct
platform_device
*
pdev
=
NULL
;
struct
platform_device
*
pdev
=
NULL
;
const
char
*
clockname
;
if
(
WARN_ON
(
cpu_is_davinci_dm646x
()))
if
(
WARN_ON
(
cpu_is_davinci_dm646x
()))
return
;
return
;
...
@@ -179,7 +178,6 @@ void __init davinci_setup_mmc(int module, struct davinci_mmc_config *config)
...
@@ -179,7 +178,6 @@ void __init davinci_setup_mmc(int module, struct davinci_mmc_config *config)
davinci_cfg_reg
(
DM355_SD1_DATA3
);
davinci_cfg_reg
(
DM355_SD1_DATA3
);
pdev
=
&
davinci_mmcsd1_device
;
pdev
=
&
davinci_mmcsd1_device
;
clockname
=
"mmcsd1"
;
break
;
break
;
case
0
:
case
0
:
if
(
cpu_is_davinci_dm355
())
{
if
(
cpu_is_davinci_dm355
())
{
...
@@ -206,7 +204,6 @@ void __init davinci_setup_mmc(int module, struct davinci_mmc_config *config)
...
@@ -206,7 +204,6 @@ void __init davinci_setup_mmc(int module, struct davinci_mmc_config *config)
}
}
pdev
=
&
davinci_mmcsd0_device
;
pdev
=
&
davinci_mmcsd0_device
;
clockname
=
cpu_is_davinci_dm355
()
?
"mmcsd0"
:
"mmcsd"
;
break
;
break
;
}
}
...
@@ -214,7 +211,6 @@ void __init davinci_setup_mmc(int module, struct davinci_mmc_config *config)
...
@@ -214,7 +211,6 @@ void __init davinci_setup_mmc(int module, struct davinci_mmc_config *config)
return
;
return
;
pdev
->
dev
.
platform_data
=
config
;
pdev
->
dev
.
platform_data
=
config
;
davinci_clk_associate
(
&
pdev
->
dev
,
"mmc"
,
clockname
);
platform_device_register
(
pdev
);
platform_device_register
(
pdev
);
}
}
...
...
arch/arm/mach-davinci/dm355.c
View file @
d895fd24
...
@@ -205,7 +205,7 @@ static struct clk uart2_clk = {
...
@@ -205,7 +205,7 @@ static struct clk uart2_clk = {
};
};
static
struct
clk
i2c_clk
=
{
static
struct
clk
i2c_clk
=
{
.
name
=
"
I2CCLK
"
,
.
name
=
"
i2c
"
,
.
parent
=
&
pll1_aux_clk
,
.
parent
=
&
pll1_aux_clk
,
.
lpsc
=
DAVINCI_LPSC_I2C
,
.
lpsc
=
DAVINCI_LPSC_I2C
,
};
};
...
@@ -304,6 +304,7 @@ static struct clk timer2_clk = {
...
@@ -304,6 +304,7 @@ static struct clk timer2_clk = {
.
name
=
"timer2"
,
.
name
=
"timer2"
,
.
parent
=
&
pll1_aux_clk
,
.
parent
=
&
pll1_aux_clk
,
.
lpsc
=
DAVINCI_LPSC_TIMER2
,
.
lpsc
=
DAVINCI_LPSC_TIMER2
,
.
usecount
=
1
,
/* REVISIT: why cant' this be disabled? */
};
};
static
struct
clk
timer3_clk
=
{
static
struct
clk
timer3_clk
=
{
...
@@ -324,50 +325,50 @@ static struct clk usb_clk = {
...
@@ -324,50 +325,50 @@ static struct clk usb_clk = {
.
lpsc
=
DAVINCI_LPSC_USB
,
.
lpsc
=
DAVINCI_LPSC_USB
,
};
};
static
struct
clk
*
dm355_clks
[]
__initdata
=
{
static
struct
davinci_clk
dm355_clks
[]
=
{
&
ref_clk
,
CLK
(
NULL
,
"ref"
,
&
ref_clk
)
,
&
pll1_clk
,
CLK
(
NULL
,
"pll1"
,
&
pll1_clk
)
,
&
pll1_sysclk1
,
CLK
(
NULL
,
"pll1_sysclk1"
,
&
pll1_sysclk1
)
,
&
pll1_sysclk2
,
CLK
(
NULL
,
"pll1_sysclk2"
,
&
pll1_sysclk2
)
,
&
pll1_sysclk3
,
CLK
(
NULL
,
"pll1_sysclk3"
,
&
pll1_sysclk3
)
,
&
pll1_sysclk4
,
CLK
(
NULL
,
"pll1_sysclk4"
,
&
pll1_sysclk4
)
,
&
pll1_aux_clk
,
CLK
(
NULL
,
"pll1_aux"
,
&
pll1_aux_clk
)
,
&
pll1_sysclkbp
,
CLK
(
NULL
,
"pll1_sysclkbp"
,
&
pll1_sysclkbp
)
,
&
vpss_dac_clk
,
CLK
(
NULL
,
"vpss_dac"
,
&
vpss_dac_clk
)
,
&
vpss_master_clk
,
CLK
(
NULL
,
"vpss_master"
,
&
vpss_master_clk
)
,
&
vpss_slave_clk
,
CLK
(
NULL
,
"vpss_slave"
,
&
vpss_slave_clk
)
,
&
clkout1_clk
,
CLK
(
NULL
,
"clkout1"
,
&
clkout1_clk
)
,
&
clkout2_clk
,
CLK
(
NULL
,
"clkout2"
,
&
clkout2_clk
)
,
&
pll2_clk
,
CLK
(
NULL
,
"pll2"
,
&
pll2_clk
)
,
&
pll2_sysclk1
,
CLK
(
NULL
,
"pll2_sysclk1"
,
&
pll2_sysclk1
)
,
&
pll2_sysclkbp
,
CLK
(
NULL
,
"pll2_sysclkbp"
,
&
pll2_sysclkbp
)
,
&
clkout3_clk
,
CLK
(
NULL
,
"clkout3"
,
&
clkout3_clk
)
,
&
arm_clk
,
CLK
(
NULL
,
"arm"
,
&
arm_clk
)
,
&
mjcp_clk
,
CLK
(
NULL
,
"mjcp"
,
&
mjcp_clk
)
,
&
uart0_clk
,
CLK
(
NULL
,
"uart0"
,
&
uart0_clk
)
,
&
uart1_clk
,
CLK
(
NULL
,
"uart1"
,
&
uart1_clk
)
,
&
uart2_clk
,
CLK
(
NULL
,
"uart2"
,
&
uart2_clk
)
,
&
i2c_clk
,
CLK
(
"i2c_davinci.1"
,
NULL
,
&
i2c_clk
)
,
&
asp0_clk
,
CLK
(
"soc-audio.0"
,
NULL
,
&
asp0_clk
)
,
&
asp1_clk
,
CLK
(
"soc-audio.1"
,
NULL
,
&
asp1_clk
)
,
&
mmcsd0_clk
,
CLK
(
"davinci_mmc.0"
,
NULL
,
&
mmcsd0_clk
)
,
&
mmcsd1_clk
,
CLK
(
"davinci_mmc.1"
,
NULL
,
&
mmcsd1_clk
)
,
&
spi0_clk
,
CLK
(
NULL
,
"spi0"
,
&
spi0_clk
)
,
&
spi1_clk
,
CLK
(
NULL
,
"spi1"
,
&
spi1_clk
)
,
&
spi2_clk
,
CLK
(
NULL
,
"spi2"
,
&
spi2_clk
)
,
&
gpio_clk
,
CLK
(
NULL
,
"gpio"
,
&
gpio_clk
)
,
&
aemif_clk
,
CLK
(
NULL
,
"aemif"
,
&
aemif_clk
)
,
&
pwm0_clk
,
CLK
(
NULL
,
"pwm0"
,
&
pwm0_clk
)
,
&
pwm1_clk
,
CLK
(
NULL
,
"pwm1"
,
&
pwm1_clk
)
,
&
pwm2_clk
,
CLK
(
NULL
,
"pwm2"
,
&
pwm2_clk
)
,
&
pwm3_clk
,
CLK
(
NULL
,
"pwm3"
,
&
pwm3_clk
)
,
&
timer0_clk
,
CLK
(
NULL
,
"timer0"
,
&
timer0_clk
)
,
&
timer1_clk
,
CLK
(
NULL
,
"timer1"
,
&
timer1_clk
)
,
&
timer2_clk
,
CLK
(
"watchdog"
,
NULL
,
&
timer2_clk
)
,
&
timer3_clk
,
CLK
(
NULL
,
"timer3"
,
&
timer3_clk
)
,
&
rto_clk
,
CLK
(
NULL
,
"rto"
,
&
rto_clk
)
,
&
usb_clk
,
CLK
(
NULL
,
"usb"
,
&
usb_clk
)
,
NULL
,
CLK
(
NULL
,
NULL
,
NULL
)
,
};
};
/*----------------------------------------------------------------------*/
/*----------------------------------------------------------------------*/
...
@@ -418,7 +419,6 @@ void __init dm355_init_spi0(unsigned chipselect_mask,
...
@@ -418,7 +419,6 @@ void __init dm355_init_spi0(unsigned chipselect_mask,
spi_register_board_info
(
info
,
len
);
spi_register_board_info
(
info
,
len
);
davinci_clk_associate
(
&
dm355_spi0_device
.
dev
,
"spi"
,
"spi0"
);
platform_device_register
(
&
dm355_spi0_device
);
platform_device_register
(
&
dm355_spi0_device
);
}
}
...
...
arch/arm/mach-davinci/dm644x.c
View file @
d895fd24
...
@@ -177,13 +177,13 @@ static struct clk emac_clk = {
...
@@ -177,13 +177,13 @@ static struct clk emac_clk = {
};
};
static
struct
clk
i2c_clk
=
{
static
struct
clk
i2c_clk
=
{
.
name
=
"
I2CCLK
"
,
.
name
=
"
i2c
"
,
.
parent
=
&
pll1_aux_clk
,
.
parent
=
&
pll1_aux_clk
,
.
lpsc
=
DAVINCI_LPSC_I2C
,
.
lpsc
=
DAVINCI_LPSC_I2C
,
};
};
static
struct
clk
ide_clk
=
{
static
struct
clk
ide_clk
=
{
.
name
=
"
IDECLK
"
,
.
name
=
"
ide
"
,
.
parent
=
&
pll1_sysclk5
,
.
parent
=
&
pll1_sysclk5
,
.
lpsc
=
DAVINCI_LPSC_ATA
,
.
lpsc
=
DAVINCI_LPSC_ATA
,
};
};
...
@@ -264,46 +264,48 @@ static struct clk timer2_clk = {
...
@@ -264,46 +264,48 @@ static struct clk timer2_clk = {
.
name
=
"timer2"
,
.
name
=
"timer2"
,
.
parent
=
&
pll1_aux_clk
,
.
parent
=
&
pll1_aux_clk
,
.
lpsc
=
DAVINCI_LPSC_TIMER2
,
.
lpsc
=
DAVINCI_LPSC_TIMER2
,
};
.
usecount
=
1
,
/* REVISIT: why cant' this be disabled? */
};
static
struct
clk
*
dm644x_clks
[]
__initdata
=
{
&
ref_clk
,
struct
davinci_clk
dm644x_clks
[]
=
{
&
pll1_clk
,
CLK
(
NULL
,
"ref"
,
&
ref_clk
),
&
pll1_sysclk1
,
CLK
(
NULL
,
"pll1"
,
&
pll1_clk
),
&
pll1_sysclk2
,
CLK
(
NULL
,
"pll1_sysclk1"
,
&
pll1_sysclk1
),
&
pll1_sysclk3
,
CLK
(
NULL
,
"pll1_sysclk2"
,
&
pll1_sysclk2
),
&
pll1_sysclk5
,
CLK
(
NULL
,
"pll1_sysclk3"
,
&
pll1_sysclk3
),
&
pll1_aux_clk
,
CLK
(
NULL
,
"pll1_sysclk5"
,
&
pll1_sysclk5
),
&
pll1_sysclkbp
,
CLK
(
NULL
,
"pll1_aux"
,
&
pll1_aux_clk
),
&
pll2_clk
,
CLK
(
NULL
,
"pll1_sysclkbp"
,
&
pll1_sysclkbp
),
&
pll2_sysclk1
,
CLK
(
NULL
,
"pll2"
,
&
pll2_clk
),
&
pll2_sysclk2
,
CLK
(
NULL
,
"pll2_sysclk1"
,
&
pll2_sysclk1
),
&
pll2_sysclkbp
,
CLK
(
NULL
,
"pll2_sysclk2"
,
&
pll2_sysclk2
),
&
dsp_clk
,
CLK
(
NULL
,
"pll2_sysclkbp"
,
&
pll2_sysclkbp
),
&
arm_clk
,
CLK
(
NULL
,
"dsp"
,
&
dsp_clk
),
&
vicp_clk
,
CLK
(
NULL
,
"arm"
,
&
arm_clk
),
&
vpss_master_clk
,
CLK
(
NULL
,
"vicp"
,
&
vicp_clk
),
&
vpss_slave_clk
,
CLK
(
NULL
,
"vpss_master"
,
&
vpss_master_clk
),
&
uart0_clk
,
CLK
(
NULL
,
"vpss_slave"
,
&
vpss_slave_clk
),
&
uart1_clk
,
CLK
(
NULL
,
"arm"
,
&
arm_clk
),
&
uart2_clk
,
CLK
(
NULL
,
"uart0"
,
&
uart0_clk
),
&
emac_clk
,
CLK
(
NULL
,
"uart1"
,
&
uart1_clk
),
&
i2c_clk
,
CLK
(
NULL
,
"uart2"
,
&
uart2_clk
),
&
ide_clk
,
CLK
(
"davinci_emac.1"
,
NULL
,
&
emac_clk
),
&
asp_clk
,
CLK
(
"i2c_davinci.1"
,
NULL
,
&
i2c_clk
),
&
mmcsd_clk
,
CLK
(
"palm_bk3710"
,
NULL
,
&
ide_clk
),
&
spi_clk
,
CLK
(
"soc-audio.0"
,
NULL
,
&
asp_clk
),
&
gpio_clk
,
CLK
(
"davinci_mmc.0"
,
NULL
,
&
mmcsd_clk
),
&
usb_clk
,
CLK
(
NULL
,
"spi"
,
&
spi_clk
),
&
vlynq_clk
,
CLK
(
NULL
,
"gpio"
,
&
gpio_clk
),
&
aemif_clk
,
CLK
(
NULL
,
"usb"
,
&
usb_clk
),
&
pwm0_clk
,
CLK
(
NULL
,
"vlynq"
,
&
vlynq_clk
),
&
pwm1_clk
,
CLK
(
NULL
,
"aemif"
,
&
aemif_clk
),
&
pwm2_clk
,
CLK
(
NULL
,
"pwm0"
,
&
pwm0_clk
),
&
timer0_clk
,
CLK
(
NULL
,
"pwm1"
,
&
pwm1_clk
),
&
timer1_clk
,
CLK
(
NULL
,
"pwm2"
,
&
pwm2_clk
),
&
timer2_clk
,
CLK
(
NULL
,
"timer0"
,
&
timer0_clk
),
NULL
,
CLK
(
NULL
,
"timer1"
,
&
timer1_clk
),
CLK
(
"watchdog"
,
NULL
,
&
timer2_clk
),
CLK
(
NULL
,
NULL
,
NULL
),
};
};
/*
/*
...
...
arch/arm/mach-davinci/dm646x.c
View file @
d895fd24
...
@@ -220,36 +220,43 @@ static struct clk timer1_clk = {
...
@@ -220,36 +220,43 @@ static struct clk timer1_clk = {
.
lpsc
=
DM646X_LPSC_TIMER1
,
.
lpsc
=
DM646X_LPSC_TIMER1
,
};
};
static
struct
clk
*
dm646x_clks
[]
__initdata
=
{
static
struct
clk
timer2_clk
=
{
&
ref_clk
,
.
name
=
"timer2"
,
&
aux_clkin
,
.
parent
=
&
pll1_sysclk3
,
&
pll1_clk
,
.
flags
=
ALWAYS_ENABLED
,
/* no LPSC, always enabled; c.f. spruep9a */
&
pll1_sysclk1
,
};
&
pll1_sysclk2
,
&
pll1_sysclk3
,
struct
davinci_clk
dm646x_clks
[]
=
{
&
pll1_sysclk4
,
CLK
(
NULL
,
"ref"
,
&
ref_clk
),
&
pll1_sysclk5
,
CLK
(
NULL
,
"aux"
,
&
aux_clkin
),
&
pll1_sysclk6
,
CLK
(
NULL
,
"pll1"
,
&
pll1_clk
),
&
pll1_sysclk8
,
CLK
(
NULL
,
"pll1_sysclk"
,
&
pll1_sysclk1
),
&
pll1_sysclk9
,
CLK
(
NULL
,
"pll1_sysclk"
,
&
pll1_sysclk2
),
&
pll1_sysclkbp
,
CLK
(
NULL
,
"pll1_sysclk"
,
&
pll1_sysclk3
),
&
pll1_aux_clk
,
CLK
(
NULL
,
"pll1_sysclk"
,
&
pll1_sysclk4
),
&
pll2_clk
,
CLK
(
NULL
,
"pll1_sysclk"
,
&
pll1_sysclk5
),
&
pll2_sysclk1
,
CLK
(
NULL
,
"pll1_sysclk"
,
&
pll1_sysclk6
),
&
dsp_clk
,
CLK
(
NULL
,
"pll1_sysclk"
,
&
pll1_sysclk8
),
&
arm_clk
,
CLK
(
NULL
,
"pll1_sysclk"
,
&
pll1_sysclk9
),
&
uart0_clk
,
CLK
(
NULL
,
"pll1_sysclk"
,
&
pll1_sysclkbp
),
&
uart1_clk
,
CLK
(
NULL
,
"pll1_aux"
,
&
pll1_aux_clk
),
&
uart2_clk
,
CLK
(
NULL
,
"pll2"
,
&
pll2_clk
),
&
i2c_clk
,
CLK
(
NULL
,
"pll2_sysclk1"
,
&
pll2_sysclk1
),
&
gpio_clk
,
CLK
(
NULL
,
"dsp"
,
&
dsp_clk
),
&
aemif_clk
,
CLK
(
NULL
,
"arm"
,
&
arm_clk
),
&
emac_clk
,
CLK
(
NULL
,
"uart0"
,
&
uart0_clk
),
&
pwm0_clk
,
CLK
(
NULL
,
"uart1"
,
&
uart1_clk
),
&
pwm1_clk
,
CLK
(
NULL
,
"uart2"
,
&
uart2_clk
),
&
timer0_clk
,
CLK
(
"i2c_davinci.1"
,
NULL
,
&
i2c_clk
),
&
timer1_clk
,
CLK
(
NULL
,
"gpio"
,
&
gpio_clk
),
NULL
,
CLK
(
NULL
,
"aemif"
,
&
aemif_clk
),
CLK
(
"davinci_emac.1"
,
NULL
,
&
emac_clk
),
CLK
(
NULL
,
"pwm0"
,
&
pwm0_clk
),
CLK
(
NULL
,
"pwm1"
,
&
pwm1_clk
),
CLK
(
NULL
,
"timer0"
,
&
timer0_clk
),
CLK
(
NULL
,
"timer1"
,
&
timer1_clk
),
CLK
(
"watchdog"
,
NULL
,
&
timer2_clk
),
CLK
(
NULL
,
NULL
,
NULL
),
};
};
/*
/*
...
...
arch/arm/mach-davinci/include/mach/clkdev.h
0 → 100644
View file @
d895fd24
#ifndef __MACH_CLKDEV_H
#define __MACH_CLKDEV_H
static
inline
int
__clk_get
(
struct
clk
*
clk
)
{
return
1
;
}
static
inline
void
__clk_put
(
struct
clk
*
clk
)
{
}
#endif
arch/arm/mach-davinci/include/mach/clock.h
View file @
d895fd24
...
@@ -17,6 +17,5 @@ struct clk;
...
@@ -17,6 +17,5 @@ struct clk;
extern
int
clk_register
(
struct
clk
*
clk
);
extern
int
clk_register
(
struct
clk
*
clk
);
extern
void
clk_unregister
(
struct
clk
*
clk
);
extern
void
clk_unregister
(
struct
clk
*
clk
);
extern
int
davinci_clk_init
(
struct
clk
*
clocks
[]);
#endif
#endif
arch/arm/mach-davinci/time.c
View file @
d895fd24
...
@@ -18,6 +18,7 @@
...
@@ -18,6 +18,7 @@
#include <linux/io.h>
#include <linux/io.h>
#include <linux/clk.h>
#include <linux/clk.h>
#include <linux/err.h>
#include <linux/err.h>
#include <linux/device.h>
#include <mach/hardware.h>
#include <mach/hardware.h>
#include <asm/system.h>
#include <asm/system.h>
...
@@ -309,7 +310,7 @@ static struct clock_event_device clockevent_davinci = {
...
@@ -309,7 +310,7 @@ static struct clock_event_device clockevent_davinci = {
static
void
__init
davinci_timer_init
(
void
)
static
void
__init
davinci_timer_init
(
void
)
{
{
struct
clk
*
timer_clk
,
*
wd_clk
;
struct
clk
*
timer_clk
;
static
char
err
[]
__initdata
=
KERN_ERR
static
char
err
[]
__initdata
=
KERN_ERR
"%s: can't register clocksource!
\n
"
;
"%s: can't register clocksource!
\n
"
;
...
@@ -321,12 +322,6 @@ static void __init davinci_timer_init(void)
...
@@ -321,12 +322,6 @@ static void __init davinci_timer_init(void)
BUG_ON
(
IS_ERR
(
timer_clk
));
BUG_ON
(
IS_ERR
(
timer_clk
));
clk_enable
(
timer_clk
);
clk_enable
(
timer_clk
);
if
(
cpu_is_davinci_dm644x
()
||
cpu_is_davinci_dm355
())
{
wd_clk
=
clk_get
(
NULL
,
"timer2"
);
BUG_ON
(
IS_ERR
(
wd_clk
));
clk_enable
(
wd_clk
);
}
davinci_clock_tick_rate
=
clk_get_rate
(
timer_clk
);
davinci_clock_tick_rate
=
clk_get_rate
(
timer_clk
);
clk_put
(
timer_clk
);
clk_put
(
timer_clk
);
...
@@ -358,6 +353,14 @@ struct sys_timer davinci_timer = {
...
@@ -358,6 +353,14 @@ struct sys_timer davinci_timer = {
void
davinci_watchdog_reset
(
void
)
{
void
davinci_watchdog_reset
(
void
)
{
u32
tgcr
,
wdtcr
;
u32
tgcr
,
wdtcr
;
void
__iomem
*
base
=
IO_ADDRESS
(
DAVINCI_WDOG_BASE
);
void
__iomem
*
base
=
IO_ADDRESS
(
DAVINCI_WDOG_BASE
);
struct
device
dev
;
struct
clk
*
wd_clk
;
dev_set_name
(
&
dev
,
"watchdog"
);
wd_clk
=
clk_get
(
&
dev
,
NULL
);
if
(
WARN_ON
(
IS_ERR
(
wd_clk
)))
return
;
clk_enable
(
wd_clk
);
/* disable, internal clock source */
/* disable, internal clock source */
__raw_writel
(
0
,
base
+
TCR
);
__raw_writel
(
0
,
base
+
TCR
);
...
...
drivers/i2c/busses/i2c-davinci.c
View file @
d895fd24
...
@@ -554,7 +554,7 @@ static int davinci_i2c_probe(struct platform_device *pdev)
...
@@ -554,7 +554,7 @@ static int davinci_i2c_probe(struct platform_device *pdev)
dev
->
irq
=
irq
->
start
;
dev
->
irq
=
irq
->
start
;
platform_set_drvdata
(
pdev
,
dev
);
platform_set_drvdata
(
pdev
,
dev
);
dev
->
clk
=
clk_get
(
&
pdev
->
dev
,
"I2CCLK"
);
dev
->
clk
=
clk_get
(
&
pdev
->
dev
,
NULL
);
if
(
IS_ERR
(
dev
->
clk
))
{
if
(
IS_ERR
(
dev
->
clk
))
{
r
=
-
ENODEV
;
r
=
-
ENODEV
;
goto
err_free_mem
;
goto
err_free_mem
;
...
...
drivers/ide/palm_bk3710.c
View file @
d895fd24
...
@@ -351,7 +351,7 @@ static int __init palm_bk3710_probe(struct platform_device *pdev)
...
@@ -351,7 +351,7 @@ static int __init palm_bk3710_probe(struct platform_device *pdev)
int
i
,
rc
;
int
i
,
rc
;
hw_regs_t
hw
,
*
hws
[]
=
{
&
hw
,
NULL
,
NULL
,
NULL
};
hw_regs_t
hw
,
*
hws
[]
=
{
&
hw
,
NULL
,
NULL
,
NULL
};
clk
=
clk_get
(
&
pdev
->
dev
,
"IDECLK"
);
clk
=
clk_get
(
&
pdev
->
dev
,
NULL
);
if
(
IS_ERR
(
clk
))
if
(
IS_ERR
(
clk
))
return
-
ENODEV
;
return
-
ENODEV
;
...
...
drivers/mmc/host/davinci_mmc.c
View file @
d895fd24
...
@@ -1133,7 +1133,7 @@ static int __init davinci_mmcsd_probe(struct platform_device *pdev)
...
@@ -1133,7 +1133,7 @@ static int __init davinci_mmcsd_probe(struct platform_device *pdev)
goto
out
;
goto
out
;
ret
=
-
ENXIO
;
ret
=
-
ENXIO
;
host
->
clk
=
clk_get
(
&
pdev
->
dev
,
"mmc"
);
host
->
clk
=
clk_get
(
&
pdev
->
dev
,
NULL
);
if
(
IS_ERR
(
host
->
clk
))
{
if
(
IS_ERR
(
host
->
clk
))
{
ret
=
PTR_ERR
(
host
->
clk
);
ret
=
PTR_ERR
(
host
->
clk
);
goto
out
;
goto
out
;
...
...
drivers/net/davinci_emac.c
View file @
d895fd24
...
@@ -2605,7 +2605,7 @@ static int __devinit davinci_emac_probe(struct platform_device *pdev)
...
@@ -2605,7 +2605,7 @@ static int __devinit davinci_emac_probe(struct platform_device *pdev)
unsigned
long
size
;
unsigned
long
size
;
/* obtain emac clock from kernel */
/* obtain emac clock from kernel */
emac_clk
=
clk_get
(
&
pdev
->
dev
,
"emac"
);
emac_clk
=
clk_get
(
&
pdev
->
dev
,
NULL
);
if
(
IS_ERR
(
emac_clk
))
{
if
(
IS_ERR
(
emac_clk
))
{
printk
(
KERN_ERR
"DaVinci EMAC: Failed to get EMAC clock
\n
"
);
printk
(
KERN_ERR
"DaVinci EMAC: Failed to get EMAC clock
\n
"
);
return
-
EBUSY
;
return
-
EBUSY
;
...
...
drivers/watchdog/davinci_wdt.c
View file @
d895fd24
...
@@ -205,7 +205,7 @@ static int davinci_wdt_probe(struct platform_device *pdev)
...
@@ -205,7 +205,7 @@ static int davinci_wdt_probe(struct platform_device *pdev)
struct
resource
*
res
;
struct
resource
*
res
;
struct
device
*
dev
=
&
pdev
->
dev
;
struct
device
*
dev
=
&
pdev
->
dev
;
wdt_clk
=
clk_get
(
dev
,
"timer2"
);
wdt_clk
=
clk_get
(
dev
,
NULL
);
if
(
WARN_ON
(
!
wdt_clk
))
if
(
WARN_ON
(
!
wdt_clk
))
return
-
ENODEV
;
return
-
ENODEV
;
clk_enable
(
wdt_clk
);
clk_enable
(
wdt_clk
);
...
...
sound/soc/davinci/davinci-i2s.c
View file @
d895fd24
...
@@ -446,10 +446,6 @@ static int davinci_i2s_probe(struct platform_device *pdev,
...
@@ -446,10 +446,6 @@ static int davinci_i2s_probe(struct platform_device *pdev,
struct
resource
*
mem
,
*
ioarea
;
struct
resource
*
mem
,
*
ioarea
;
struct
evm_snd_platform_data
*
pdata
;
struct
evm_snd_platform_data
*
pdata
;
int
ret
;
int
ret
;
static
const
char
*
clocks
[]
=
{
"asp0"
,
"asp1"
,
};
if
(
pdev
->
id
<
0
||
pdev
->
id
>
ARRAY_SIZE
(
clocks
))
return
-
EINVAL
;
mem
=
platform_get_resource
(
pdev
,
IORESOURCE_MEM
,
0
);
mem
=
platform_get_resource
(
pdev
,
IORESOURCE_MEM
,
0
);
if
(
!
mem
)
{
if
(
!
mem
)
{
...
@@ -472,7 +468,7 @@ static int davinci_i2s_probe(struct platform_device *pdev,
...
@@ -472,7 +468,7 @@ static int davinci_i2s_probe(struct platform_device *pdev,
cpu_dai
->
private_data
=
dev
;
cpu_dai
->
private_data
=
dev
;
dev
->
clk
=
clk_get
(
&
pdev
->
dev
,
clocks
[
pdev
->
id
]
);
dev
->
clk
=
clk_get
(
&
pdev
->
dev
,
NULL
);
if
(
IS_ERR
(
dev
->
clk
))
{
if
(
IS_ERR
(
dev
->
clk
))
{
ret
=
-
ENODEV
;
ret
=
-
ENODEV
;
goto
err_free_mem
;
goto
err_free_mem
;
...
...
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