Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
84965337
Commit
84965337
authored
Nov 16, 2010
by
Paul Mundt
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'common/clkfwk' into sh-fixes-for-linus
parents
6800e4c0
549015c3
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
11 additions
and
85 deletions
+11
-85
Documentation/DocBook/sh.tmpl
Documentation/DocBook/sh.tmpl
+0
-4
Documentation/sh/clk.txt
Documentation/sh/clk.txt
+0
-32
arch/arm/mach-shmobile/clock-sh7372.c
arch/arm/mach-shmobile/clock-sh7372.c
+2
-4
arch/sh/kernel/cpu/sh4/clock-sh4-202.c
arch/sh/kernel/cpu/sh4/clock-sh4-202.c
+1
-1
drivers/sh/clk/core.c
drivers/sh/clk/core.c
+3
-10
drivers/sh/clk/cpg.c
drivers/sh/clk/cpg.c
+2
-3
include/linux/sh_clk.h
include/linux/sh_clk.h
+3
-31
No files found.
Documentation/DocBook/sh.tmpl
View file @
84965337
...
...
@@ -79,10 +79,6 @@
</sect2>
</sect1>
</chapter>
<chapter
id=
"clk"
>
<title>
Clock Framework Extensions
</title>
!Iinclude/linux/sh_clk.h
</chapter>
<chapter
id=
"mach"
>
<title>
Machine Specific Interfaces
</title>
<sect1
id=
"dreamcast"
>
...
...
Documentation/sh/clk.txt
deleted
100644 → 0
View file @
6800e4c0
Clock framework on SuperH architecture
The framework on SH extends existing API by the function clk_set_rate_ex,
which prototype is as follows:
clk_set_rate_ex (struct clk *clk, unsigned long rate, int algo_id)
The algo_id parameter is used to specify algorithm used to recalculate clocks,
adjanced to clock, specified as first argument. It is assumed that algo_id==0
means no changes to adjanced clock
Internally, the clk_set_rate_ex forwards request to clk->ops->set_rate method,
if it is present in ops structure. The method should set the clock rate and adjust
all needed clocks according to the passed algo_id.
Exact values for algo_id are machine-dependent. For the sh7722, the following
values are defined:
NO_CHANGE = 0,
IUS_N1_N1, /* I:U = N:1, U:Sh = N:1 */
IUS_322, /* I:U:Sh = 3:2:2 */
IUS_522, /* I:U:Sh = 5:2:2 */
IUS_N11, /* I:U:Sh = N:1:1 */
SB_N1, /* Sh:B = N:1 */
SB3_N1, /* Sh:B3 = N:1 */
SB3_32, /* Sh:B3 = 3:2 */
SB3_43, /* Sh:B3 = 4:3 */
SB3_54, /* Sh:B3 = 5:4 */
BP_N1, /* B:P = N:1 */
IP_N1 /* I:P = N:1 */
Each of these constants means relation between clocks that can be set via the FRQCR
register
arch/arm/mach-shmobile/clock-sh7372.c
View file @
84965337
...
...
@@ -220,8 +220,7 @@ static void pllc2_disable(struct clk *clk)
__raw_writel
(
__raw_readl
(
PLLC2CR
)
&
~
0x80000000
,
PLLC2CR
);
}
static
int
pllc2_set_rate
(
struct
clk
*
clk
,
unsigned
long
rate
,
int
algo_id
)
static
int
pllc2_set_rate
(
struct
clk
*
clk
,
unsigned
long
rate
)
{
unsigned
long
value
;
int
idx
;
...
...
@@ -463,8 +462,7 @@ static int fsidiv_enable(struct clk *clk)
return
0
;
}
static
int
fsidiv_set_rate
(
struct
clk
*
clk
,
unsigned
long
rate
,
int
algo_id
)
static
int
fsidiv_set_rate
(
struct
clk
*
clk
,
unsigned
long
rate
)
{
int
idx
;
...
...
arch/sh/kernel/cpu/sh4/clock-sh4-202.c
View file @
84965337
...
...
@@ -110,7 +110,7 @@ static int shoc_clk_verify_rate(struct clk *clk, unsigned long rate)
return
0
;
}
static
int
shoc_clk_set_rate
(
struct
clk
*
clk
,
unsigned
long
rate
,
int
algo_id
)
static
int
shoc_clk_set_rate
(
struct
clk
*
clk
,
unsigned
long
rate
)
{
unsigned
long
frqcr3
;
unsigned
int
tmp
;
...
...
drivers/sh/clk/core.c
View file @
84965337
...
...
@@ -454,12 +454,6 @@ unsigned long clk_get_rate(struct clk *clk)
EXPORT_SYMBOL_GPL
(
clk_get_rate
);
int
clk_set_rate
(
struct
clk
*
clk
,
unsigned
long
rate
)
{
return
clk_set_rate_ex
(
clk
,
rate
,
0
);
}
EXPORT_SYMBOL_GPL
(
clk_set_rate
);
int
clk_set_rate_ex
(
struct
clk
*
clk
,
unsigned
long
rate
,
int
algo_id
)
{
int
ret
=
-
EOPNOTSUPP
;
unsigned
long
flags
;
...
...
@@ -467,7 +461,7 @@ int clk_set_rate_ex(struct clk *clk, unsigned long rate, int algo_id)
spin_lock_irqsave
(
&
clock_lock
,
flags
);
if
(
likely
(
clk
->
ops
&&
clk
->
ops
->
set_rate
))
{
ret
=
clk
->
ops
->
set_rate
(
clk
,
rate
,
algo_id
);
ret
=
clk
->
ops
->
set_rate
(
clk
,
rate
);
if
(
ret
!=
0
)
goto
out_unlock
;
}
else
{
...
...
@@ -485,7 +479,7 @@ int clk_set_rate_ex(struct clk *clk, unsigned long rate, int algo_id)
return
ret
;
}
EXPORT_SYMBOL_GPL
(
clk_set_rate
_ex
);
EXPORT_SYMBOL_GPL
(
clk_set_rate
);
int
clk_set_parent
(
struct
clk
*
clk
,
struct
clk
*
parent
)
{
...
...
@@ -653,8 +647,7 @@ static int clks_sysdev_suspend(struct sys_device *dev, pm_message_t state)
clkp
->
ops
->
set_parent
(
clkp
,
clkp
->
parent
);
if
(
likely
(
clkp
->
ops
->
set_rate
))
clkp
->
ops
->
set_rate
(
clkp
,
rate
,
NO_CHANGE
);
clkp
->
ops
->
set_rate
(
clkp
,
rate
);
else
if
(
likely
(
clkp
->
ops
->
recalc
))
clkp
->
rate
=
clkp
->
ops
->
recalc
(
clkp
);
}
...
...
drivers/sh/clk/cpg.c
View file @
84965337
...
...
@@ -110,8 +110,7 @@ static int sh_clk_div6_set_parent(struct clk *clk, struct clk *parent)
return
0
;
}
static
int
sh_clk_div6_set_rate
(
struct
clk
*
clk
,
unsigned
long
rate
,
int
algo_id
)
static
int
sh_clk_div6_set_rate
(
struct
clk
*
clk
,
unsigned
long
rate
)
{
unsigned
long
value
;
int
idx
;
...
...
@@ -253,7 +252,7 @@ static int sh_clk_div4_set_parent(struct clk *clk, struct clk *parent)
return
0
;
}
static
int
sh_clk_div4_set_rate
(
struct
clk
*
clk
,
unsigned
long
rate
,
int
algo_id
)
static
int
sh_clk_div4_set_rate
(
struct
clk
*
clk
,
unsigned
long
rate
)
{
struct
clk_div4_table
*
d4t
=
clk
->
priv
;
unsigned
long
value
;
...
...
include/linux/sh_clk.h
View file @
84965337
...
...
@@ -19,11 +19,13 @@ struct clk_mapping {
};
struct
clk_ops
{
#ifdef CONFIG_SH_CLK_CPG_LEGACY
void
(
*
init
)(
struct
clk
*
clk
);
#endif
int
(
*
enable
)(
struct
clk
*
clk
);
void
(
*
disable
)(
struct
clk
*
clk
);
unsigned
long
(
*
recalc
)(
struct
clk
*
clk
);
int
(
*
set_rate
)(
struct
clk
*
clk
,
unsigned
long
rate
,
int
algo_id
);
int
(
*
set_rate
)(
struct
clk
*
clk
,
unsigned
long
rate
);
int
(
*
set_parent
)(
struct
clk
*
clk
,
struct
clk
*
parent
);
long
(
*
round_rate
)(
struct
clk
*
clk
,
unsigned
long
rate
);
};
...
...
@@ -67,36 +69,6 @@ int clk_register(struct clk *);
void
clk_unregister
(
struct
clk
*
);
void
clk_enable_init_clocks
(
void
);
/**
* clk_set_rate_ex - set the clock rate for a clock source, with additional parameter
* @clk: clock source
* @rate: desired clock rate in Hz
* @algo_id: algorithm id to be passed down to ops->set_rate
*
* Returns success (0) or negative errno.
*/
int
clk_set_rate_ex
(
struct
clk
*
clk
,
unsigned
long
rate
,
int
algo_id
);
enum
clk_sh_algo_id
{
NO_CHANGE
=
0
,
IUS_N1_N1
,
IUS_322
,
IUS_522
,
IUS_N11
,
SB_N1
,
SB3_N1
,
SB3_32
,
SB3_43
,
SB3_54
,
BP_N1
,
IP_N1
,
};
struct
clk_div_mult_table
{
unsigned
int
*
divisors
;
unsigned
int
nr_divisors
;
...
...
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