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
Kirill Smelkov
linux
Commits
2f046996
Commit
2f046996
authored
May 31, 2004
by
David Woodhouse
Committed by
David Woodhouse
May 31, 2004
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add PPC 8280 support, calculate core clock frequency.
Patch from Guy Streeter <streeter@redhat.com>
parent
dfc2505c
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
56 additions
and
6 deletions
+56
-6
arch/ppc/boot/simple/embed_config.c
arch/ppc/boot/simple/embed_config.c
+48
-6
arch/ppc/kernel/cputable.c
arch/ppc/kernel/cputable.c
+8
-0
No files found.
arch/ppc/boot/simple/embed_config.c
View file @
2f046996
...
@@ -402,14 +402,18 @@ embed_config(bd_t **bdp)
...
@@ -402,14 +402,18 @@ embed_config(bd_t **bdp)
#ifdef CONFIG_8260
#ifdef CONFIG_8260
/* Compute 8260 clock values if the rom doesn't provide them.
/* Compute 8260 clock values if the rom doesn't provide them.
* We can't compute the internal core frequency (I don't know how to
* do that).
*/
*/
static
unsigned
char
bus2core_8260
[]
=
{
/* 0 1 2 3 4 5 6 7 8 9 a b c d e f */
3
,
2
,
2
,
2
,
4
,
4
,
5
,
9
,
6
,
11
,
8
,
10
,
3
,
12
,
7
,
2
,
6
,
5
,
13
,
2
,
14
,
4
,
15
,
2
,
3
,
11
,
8
,
10
,
16
,
12
,
7
,
2
,
};
static
void
static
void
clk_8260
(
bd_t
*
bd
)
clk_8260
(
bd_t
*
bd
)
{
{
uint
scmr
,
vco_out
,
clkin
;
uint
scmr
,
vco_out
,
clkin
;
uint
plldf
,
pllmf
,
busdf
,
brgdf
,
cpmd
f
;
uint
plldf
,
pllmf
,
corecn
f
;
volatile
immap_t
*
ip
;
volatile
immap_t
*
ip
;
ip
=
(
immap_t
*
)
IMAP_ADDR
;
ip
=
(
immap_t
*
)
IMAP_ADDR
;
...
@@ -423,8 +427,7 @@ clk_8260(bd_t *bd)
...
@@ -423,8 +427,7 @@ clk_8260(bd_t *bd)
*/
*/
plldf
=
(
scmr
>>
12
)
&
1
;
plldf
=
(
scmr
>>
12
)
&
1
;
pllmf
=
scmr
&
0xfff
;
pllmf
=
scmr
&
0xfff
;
cpmdf
=
(
scmr
>>
16
)
&
0x0f
;
corecnf
=
(
scmr
>>
24
)
&
0x1f
;
busdf
=
(
scmr
>>
20
)
&
0x0f
;
/* This is arithmetic from the 8260 manual.
/* This is arithmetic from the 8260 manual.
*/
*/
...
@@ -433,6 +436,7 @@ clk_8260(bd_t *bd)
...
@@ -433,6 +436,7 @@ clk_8260(bd_t *bd)
bd
->
bi_vco
=
vco_out
;
/* Save for later */
bd
->
bi_vco
=
vco_out
;
/* Save for later */
bd
->
bi_cpmfreq
=
vco_out
/
2
;
/* CPM Freq, in MHz */
bd
->
bi_cpmfreq
=
vco_out
/
2
;
/* CPM Freq, in MHz */
bd
->
bi_intfreq
=
bd
->
bi_busfreq
*
bus2core_8260
[
corecnf
]
/
2
;
/* Set Baud rate divisor. The power up default is divide by 16,
/* Set Baud rate divisor. The power up default is divide by 16,
* but we set it again here in case it was changed.
* but we set it again here in case it was changed.
...
@@ -440,8 +444,46 @@ clk_8260(bd_t *bd)
...
@@ -440,8 +444,46 @@ clk_8260(bd_t *bd)
ip
->
im_clkrst
.
car_sccr
=
1
;
/* DIV 16 BRG */
ip
->
im_clkrst
.
car_sccr
=
1
;
/* DIV 16 BRG */
bd
->
bi_brgfreq
=
vco_out
/
16
;
bd
->
bi_brgfreq
=
vco_out
/
16
;
}
}
#endif
static
unsigned
char
bus2core_8280
[]
=
{
/* 0 1 2 3 4 5 6 7 8 9 a b c d e f */
3
,
2
,
2
,
2
,
4
,
4
,
5
,
9
,
6
,
11
,
8
,
10
,
3
,
12
,
7
,
2
,
6
,
5
,
13
,
2
,
14
,
2
,
15
,
2
,
3
,
2
,
2
,
2
,
16
,
2
,
2
,
2
,
};
static
void
clk_8280
(
bd_t
*
bd
)
{
uint
scmr
,
main_clk
,
clkin
;
uint
pllmf
,
corecnf
;
volatile
immap_t
*
ip
;
ip
=
(
immap_t
*
)
IMAP_ADDR
;
scmr
=
ip
->
im_clkrst
.
car_scmr
;
/* The clkin is always bus frequency.
*/
clkin
=
bd
->
bi_busfreq
;
/* Collect the bits from the scmr.
*/
pllmf
=
scmr
&
0xf
;
corecnf
=
(
scmr
>>
24
)
&
0x1f
;
/* This is arithmetic from the 8280 manual.
*/
main_clk
=
clkin
*
(
pllmf
+
1
);
bd
->
bi_cpmfreq
=
main_clk
/
2
;
/* CPM Freq, in MHz */
bd
->
bi_intfreq
=
bd
->
bi_busfreq
*
bus2core_8280
[
corecnf
]
/
2
;
/* Set Baud rate divisor. The power up default is divide by 16,
* but we set it again here in case it was changed.
*/
ip
->
im_clkrst
.
car_sccr
=
(
ip
->
im_clkrst
.
car_sccr
&
0x3
)
|
0x1
;
bd
->
bi_brgfreq
=
main_clk
/
16
;
}
#endif
#if defined(CONFIG_EST8260) || defined(CONFIG_TQM8260)
#if defined(CONFIG_EST8260) || defined(CONFIG_TQM8260)
void
void
embed_config
(
bd_t
**
bdp
)
embed_config
(
bd_t
**
bdp
)
...
...
arch/ppc/kernel/cputable.c
View file @
2f046996
...
@@ -350,6 +350,14 @@ struct cpu_spec cpu_specs[] = {
...
@@ -350,6 +350,14 @@ struct cpu_spec cpu_specs[] = {
32
,
32
,
32
,
32
,
__setup_cpu_603
__setup_cpu_603
},
},
{
/* 8280 is a G2_LE (603e core, plus some) */
0x7fff0000
,
0x00820000
,
"8280"
,
CPU_FTR_SPLIT_ID_CACHE
|
CPU_FTR_CAN_DOZE
|
CPU_FTR_USE_TB
|
CPU_FTR_CAN_NAP
|
CPU_FTR_HAS_HIGH_BATS
,
COMMON_PPC
,
32
,
32
,
__setup_cpu_603
},
{
/* default match, we assume split I/D cache & TB (non-601)... */
{
/* default match, we assume split I/D cache & TB (non-601)... */
0x00000000
,
0x00000000
,
"(generic PPC)"
,
0x00000000
,
0x00000000
,
"(generic PPC)"
,
CPU_FTR_COMMON
|
CPU_FTR_COMMON
|
...
...
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