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
c84f2c3f
Commit
c84f2c3f
authored
Jan 09, 2005
by
Russell King
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[ARM] Move common CPU initialisation into head.S
parent
a359e554
Changes
15
Show whitespace changes
Inline
Side-by-side
Showing
15 changed files
with
285 additions
and
340 deletions
+285
-340
arch/arm/kernel/head.S
arch/arm/kernel/head.S
+19
-1
arch/arm/mm/proc-arm1020.S
arch/arm/mm/proc-arm1020.S
+17
-28
arch/arm/mm/proc-arm1020e.S
arch/arm/mm/proc-arm1020e.S
+17
-29
arch/arm/mm/proc-arm1022.S
arch/arm/mm/proc-arm1022.S
+17
-27
arch/arm/mm/proc-arm1026.S
arch/arm/mm/proc-arm1026.S
+18
-27
arch/arm/mm/proc-arm6_7.S
arch/arm/mm/proc-arm6_7.S
+0
-12
arch/arm/mm/proc-arm720.S
arch/arm/mm/proc-arm720.S
+53
-38
arch/arm/mm/proc-arm920.S
arch/arm/mm/proc-arm920.S
+17
-27
arch/arm/mm/proc-arm922.S
arch/arm/mm/proc-arm922.S
+17
-27
arch/arm/mm/proc-arm925.S
arch/arm/mm/proc-arm925.S
+17
-30
arch/arm/mm/proc-arm926.S
arch/arm/mm/proc-arm926.S
+17
-27
arch/arm/mm/proc-sa110.S
arch/arm/mm/proc-sa110.S
+18
-12
arch/arm/mm/proc-sa1100.S
arch/arm/mm/proc-sa1100.S
+21
-15
arch/arm/mm/proc-v6.S
arch/arm/mm/proc-v6.S
+20
-27
arch/arm/mm/proc-xscale.S
arch/arm/mm/proc-xscale.S
+17
-13
No files found.
arch/arm/kernel/head.S
View file @
c84f2c3f
...
...
@@ -14,6 +14,7 @@
#include <linux/init.h>
#include <asm/assembler.h>
#include <asm/domain.h>
#include <asm/mach-types.h>
#include <asm/procinfo.h>
#include <asm/ptrace.h>
...
...
@@ -166,7 +167,9 @@ __mmap_switched:
/*
*
Setup
common
bits
before
finally
enabling
the
MMU
.
*
Setup
common
bits
before
finally
enabling
the
MMU
.
Essentially
*
this
is
just
loading
the
page
table
pointer
and
domain
access
*
registers
.
*/
.
type
__enable_mmu
,
%
function
__enable_mmu
:
...
...
@@ -175,6 +178,21 @@ __enable_mmu:
#else
bic
r0
,
r0
,
#
CR_A
#endif
#ifdef CONFIG_CPU_DCACHE_DISABLE
bic
r0
,
r0
,
#
CR_C
#endif
#ifdef CONFIG_CPU_BPREDICT_DISABLE
bic
r0
,
r0
,
#
CR_Z
#endif
#ifdef CONFIG_CPU_ICACHE_DISABLE
bic
r0
,
r0
,
#
CR_I
#endif
mov
r5
,
#(
domain_val
(
DOMAIN_USER
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_KERNEL
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_TABLE
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_IO
,
DOMAIN_CLIENT
))
mcr
p15
,
0
,
r5
,
c3
,
c0
,
0
@
load
domain
access
register
mcr
p15
,
0
,
r4
,
c2
,
c0
,
0
@
load
page
table
pointer
b
__turn_mmu_on
/*
...
...
arch/arm/mm/proc-arm1020.S
View file @
c84f2c3f
...
...
@@ -30,7 +30,6 @@
#include <asm/assembler.h>
#include <asm/constants.h>
#include <asm/pgtable.h>
#include <asm/domain.h>
#include <asm/procinfo.h>
#include <asm/ptrace.h>
#include <asm/hardware.h>
...
...
@@ -432,39 +431,29 @@ __arm1020_setup:
mcr
p15
,
0
,
r0
,
c7
,
c7
@
invalidate
I
,
D
caches
on
v4
mcr
p15
,
0
,
r0
,
c7
,
c10
,
4
@
drain
write
buffer
on
v4
mcr
p15
,
0
,
r0
,
c8
,
c7
@
invalidate
I
,
D
TLBs
on
v4
mcr
p15
,
0
,
r4
,
c2
,
c0
@
load
page
table
pointer
mov
r0
,
#(
domain_val
(
DOMAIN_USER
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_KERNEL
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_TABLE
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_IO
,
DOMAIN_CLIENT
))
mcr
p15
,
0
,
r0
,
c3
,
c0
@
load
domain
access
register
mrc
p15
,
0
,
r0
,
c1
,
c0
@
get
control
register
v4
/*
*
Clear
out
'unwanted'
bits
(
then
put
them
in
if
we
need
them
)
*/
bic
r0
,
r0
,
#
0x1e00
@
i
...
??
r
.........
bic
r0
,
r0
,
#
0x000e
@
............
wca
.
/*
*
Turn
on
what
we
want
*/
orr
r0
,
r0
,
#
0x0031
@
..........
DP
...
M
orr
r0
,
r0
,
#
0x0100
@
.......
S
........
ldr
r5
,
arm1020_cr1_clear
bic
r0
,
r0
,
r5
ldr
r5
,
arm1020_cr1_set
orr
r0
,
r0
,
r5
#ifdef CONFIG_CPU_CACHE_ROUND_ROBIN
orr
r0
,
r0
,
#
0x4000
@
.
R
..............
#endif
#ifndef CONFIG_CPU_BPREDICT_DISABLE
orr
r0
,
r0
,
#
0x0800
@
....
Z
...........
#endif
#ifndef CONFIG_CPU_DCACHE_DISABLE
orr
r0
,
r0
,
#
0x0004
@
Enable
D
cache
#endif
#ifndef CONFIG_CPU_ICACHE_DISABLE
orr
r0
,
r0
,
#
0x1000
@
I
Cache
on
orr
r0
,
r0
,
#
0x4000
@
.
R
..
....
....
....
#endif
mov
pc
,
lr
.
size
__arm1020_setup
,
.
-
__arm1020_setup
/
*
*
R
*
.
RVI
ZFRS
BLDP
WCAM
*
.0.1
1001
..11
0101
/*
FIXME
:
why
no
V
bit
?
*/
*/
.
type
arm1020_cr1_clear
,
#
object
.
type
arm1020_cr1_set
,
#
object
arm1020_cr1_clear
:
.
word
0x593f
arm1020_cr1_set
:
.
word
0x1935
__INITDATA
/*
...
...
arch/arm/mm/proc-arm1020e.S
View file @
c84f2c3f
...
...
@@ -30,7 +30,6 @@
#include <asm/assembler.h>
#include <asm/constants.h>
#include <asm/pgtable.h>
#include <asm/domain.h>
#include <asm/procinfo.h>
#include <asm/ptrace.h>
#include <asm/hardware.h>
...
...
@@ -414,40 +413,29 @@ __arm1020e_setup:
mcr
p15
,
0
,
r0
,
c7
,
c7
@
invalidate
I
,
D
caches
on
v4
mcr
p15
,
0
,
r0
,
c7
,
c10
,
4
@
drain
write
buffer
on
v4
mcr
p15
,
0
,
r0
,
c8
,
c7
@
invalidate
I
,
D
TLBs
on
v4
mcr
p15
,
0
,
r4
,
c2
,
c0
@
load
page
table
pointer
mov
r0
,
#(
domain_val
(
DOMAIN_USER
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_KERNEL
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_TABLE
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_IO
,
DOMAIN_CLIENT
))
mcr
p15
,
0
,
r0
,
c3
,
c0
@
load
domain
access
register
mrc
p15
,
0
,
r0
,
c1
,
c0
@
get
control
register
v4
/*
*
Clear
out
'unwanted'
bits
(
then
put
them
in
if
we
need
them
)
*/
bic
r0
,
r0
,
#
0x1e00
@
i
...
??
r
.........
bic
r0
,
r0
,
#
0x000e
@
............
wca
.
/*
*
Turn
on
what
we
want
*/
orr
r0
,
r0
,
#
0x0031
@
..........
DP
...
M
orr
r0
,
r0
,
#
0x0100
@
.......
S
........
ldr
r5
,
arm1020e_cr1_clear
bic
r0
,
r0
,
r5
ldr
r5
,
arm1020e_cr1_set
orr
r0
,
r0
,
r5
#ifdef CONFIG_CPU_CACHE_ROUND_ROBIN
orr
r0
,
r0
,
#
0x4000
@
.
R
..............
#endif
#ifndef CONFIG_CPU_BPREDICT_DISABLE
orr
r0
,
r0
,
#
0x0800
@
....
Z
...........
#endif
#ifndef CONFIG_CPU_DCACHE_DISABLE
orr
r0
,
r0
,
#
0x0004
@
Enable
D
cache
#endif
#ifndef CONFIG_CPU_ICACHE_DISABLE
orr
r0
,
r0
,
#
0x1000
@
I
Cache
on
orr
r0
,
r0
,
#
0x4000
@
.
R
..
....
....
....
#endif
mov
pc
,
lr
.
size
__arm1020e_setup
,
.
-
__arm1020e_setup
/
*
*
R
*
.
RVI
ZFRS
BLDP
WCAM
*
.0.1
1001
..11
0101
/*
FIXME
:
why
no
V
bit
?
*/
*/
.
type
arm1020e_cr1_clear
,
#
object
.
type
arm1020e_cr1_set
,
#
object
arm1020e_cr1_clear
:
.
word
0x5f3f
arm1020e_cr1_set
:
.
word
0x1935
__INITDATA
/*
...
...
arch/arm/mm/proc-arm1022.S
View file @
c84f2c3f
...
...
@@ -19,7 +19,6 @@
#include <asm/assembler.h>
#include <asm/constants.h>
#include <asm/pgtable.h>
#include <asm/domain.h>
#include <asm/procinfo.h>
#include <asm/ptrace.h>
...
...
@@ -395,39 +394,30 @@ __arm1022_setup:
mcr
p15
,
0
,
r0
,
c7
,
c7
@
invalidate
I
,
D
caches
on
v4
mcr
p15
,
0
,
r0
,
c7
,
c10
,
4
@
drain
write
buffer
on
v4
mcr
p15
,
0
,
r0
,
c8
,
c7
@
invalidate
I
,
D
TLBs
on
v4
mcr
p15
,
0
,
r4
,
c2
,
c0
@
load
page
table
pointer
mov
r0
,
#(
domain_val
(
DOMAIN_USER
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_KERNEL
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_TABLE
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_IO
,
DOMAIN_CLIENT
))
mcr
p15
,
0
,
r0
,
c3
,
c0
@
load
domain
access
register
mrc
p15
,
0
,
r0
,
c1
,
c0
@
get
control
register
v4
/*
*
Clear
out
'unwanted'
bits
(
then
put
them
in
if
we
need
them
)
*/
bic
r0
,
r0
,
#
0x1e00
@
...
i
??
r
.........
bic
r0
,
r0
,
#
0x000e
@
............
wca
.
/*
*
Turn
on
what
we
want
*/
orr
r0
,
r0
,
#
0x0031
@
..........
DP
...
M
orr
r0
,
r0
,
#
0x2100
@
..
V
....
S
........
ldr
r5
,
arm1022_cr1_clear
bic
r0
,
r0
,
r5
ldr
r5
,
arm1022_cr1_set
orr
r0
,
r0
,
r5
#ifdef CONFIG_CPU_CACHE_ROUND_ROBIN
orr
r0
,
r0
,
#
0x4000
@
.
R
..............
#endif
#ifndef CONFIG_CPU_BPREDICT_DISABLE
orr
r0
,
r0
,
#
0x0800
@
....
Z
...........
#endif
#ifndef CONFIG_CPU_DCACHE_DISABLE
orr
r0
,
r0
,
#
0x0004
@
.............
C
..
#endif
#ifndef CONFIG_CPU_ICACHE_DISABLE
orr
r0
,
r0
,
#
0x1000
@
...
I
............
#endif
mov
pc
,
lr
.
size
__arm1022_setup
,
.
-
__arm1022_setup
/
*
*
R
*
.
RVI
ZFRS
BLDP
WCAM
*
.011
1001
..11
0101
*
*/
.
type
arm1022_cr1_clear
,
#
object
.
type
arm1022_cr1_set
,
#
object
arm1022_cr1_clear
:
.
word
0x7f3f
arm1022_cr1_set
:
.
word
0x3935
__INITDATA
/*
...
...
arch/arm/mm/proc-arm1026.S
View file @
c84f2c3f
...
...
@@ -19,7 +19,6 @@
#include <asm/assembler.h>
#include <asm/constants.h>
#include <asm/pgtable.h>
#include <asm/domain.h>
#include <asm/procinfo.h>
#include <asm/ptrace.h>
...
...
@@ -390,38 +389,30 @@ __arm1026_setup:
mov
r0
,
#
4
@
explicitly
disable
writeback
mcr
p15
,
7
,
r0
,
c15
,
c0
,
0
#endif
mov
r0
,
#(
domain_val
(
DOMAIN_USER
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_KERNEL
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_TABLE
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_IO
,
DOMAIN_CLIENT
))
mcr
p15
,
0
,
r0
,
c3
,
c0
@
load
domain
access
register
mrc
p15
,
0
,
r0
,
c1
,
c0
@
get
control
register
v4
/*
*
Clear
out
'unwanted'
bits
(
then
put
them
in
if
we
need
them
)
*/
bic
r0
,
r0
,
#
0x1e00
@
...
i
??
r
.........
bic
r0
,
r0
,
#
0x000e
@
............
wca
.
/*
*
Turn
on
what
we
want
*/
orr
r0
,
r0
,
#
0x0031
@
..........
DP
...
M
orr
r0
,
r0
,
#
0x2100
@
..
V
....
S
........
ldr
r5
,
arm1026_cr1_clear
bic
r0
,
r0
,
r5
ldr
r5
,
arm1026_cr1_set
orr
r0
,
r0
,
r5
#ifdef CONFIG_CPU_CACHE_ROUND_ROBIN
orr
r0
,
r0
,
#
0x4000
@
.
R
..............
#endif
#ifndef CONFIG_CPU_BPREDICT_DISABLE
orr
r0
,
r0
,
#
0x0800
@
....
Z
...........
#endif
#ifndef CONFIG_CPU_DCACHE_DISABLE
orr
r0
,
r0
,
#
0x0004
@
.............
C
..
#endif
#ifndef CONFIG_CPU_ICACHE_DISABLE
orr
r0
,
r0
,
#
0x1000
@
...
I
............
orr
r0
,
r0
,
#
0x4000
@
.
R
..
....
....
....
#endif
mov
pc
,
lr
.
size
__arm1026_setup
,
.
-
__arm1026_setup
/
*
*
R
*
.
RVI
ZFRS
BLDP
WCAM
*
.011
1001
..11
0101
*
*/
.
type
arm1026_cr1_clear
,
#
object
.
type
arm1026_cr1_set
,
#
object
arm1026_cr1_clear
:
.
word
0x7f3f
arm1026_cr1_set
:
.
word
0x3935
__INITDATA
/*
...
...
arch/arm/mm/proc-arm6_7.S
View file @
c84f2c3f
...
...
@@ -15,7 +15,6 @@
#include <asm/assembler.h>
#include <asm/constants.h>
#include <asm/pgtable.h>
#include <asm/domain.h>
#include <asm/procinfo.h>
#include <asm/ptrace.h>
...
...
@@ -254,12 +253,6 @@ ENTRY(cpu_arm7_reset)
__arm6_setup
:
mov
r0
,
#
0
mcr
p15
,
0
,
r0
,
c7
,
c0
@
flush
caches
on
v3
mcr
p15
,
0
,
r0
,
c5
,
c0
@
flush
TLBs
on
v3
mcr
p15
,
0
,
r4
,
c2
,
c0
@
load
page
table
pointer
mov
r0
,
#(
domain_val
(
DOMAIN_USER
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_KERNEL
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_TABLE
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_IO
,
DOMAIN_CLIENT
))
mcr
p15
,
0
,
r0
,
c3
,
c0
@
load
domain
access
register
mov
r0
,
#
0x3d
@
.
..
RS
BLDP
WCAM
orr
r0
,
r0
,
#
0x100
@
.
..01
0011
1101
mov
pc
,
lr
...
...
@@ -269,11 +262,6 @@ __arm6_setup: mov r0, #0
__arm7_setup
:
mov
r0
,
#
0
mcr
p15
,
0
,
r0
,
c7
,
c0
@
flush
caches
on
v3
mcr
p15
,
0
,
r0
,
c5
,
c0
@
flush
TLBs
on
v3
mcr
p15
,
0
,
r4
,
c2
,
c0
@
load
page
table
pointer
mov
r0
,
#(
domain_val
(
DOMAIN_IO
,
DOMAIN_CLIENT
)
|
\
domain_val
(
DOMAIN_KERNEL
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_TABLE
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_USER
,
DOMAIN_MANAGER
))
mcr
p15
,
0
,
r0
,
c3
,
c0
@
load
domain
access
register
mov
r0
,
#
0x7d
@
.
..
RS
BLDP
WCAM
orr
r0
,
r0
,
#
0x100
@
.
..01
0111
1101
...
...
arch/arm/mm/proc-arm720.S
View file @
c84f2c3f
...
...
@@ -35,7 +35,6 @@
#include <asm/assembler.h>
#include <asm/constants.h>
#include <asm/pgtable.h>
#include <asm/domain.h>
#include <asm/procinfo.h>
#include <asm/ptrace.h>
#include <asm/hardware.h>
...
...
@@ -128,41 +127,57 @@ ENTRY(cpu_arm720_reset)
__INIT
.
type
__arm710_setup
,
#
function
__arm710_setup
:
mov
r0
,
#
0
__arm710_setup
:
mov
r0
,
#
0
mcr
p15
,
0
,
r0
,
c7
,
c7
,
0
@
invalidate
caches
mcr
p15
,
0
,
r0
,
c8
,
c7
,
0
@
flush
TLB
(
v4
)
mcr
p15
,
0
,
r4
,
c2
,
c0
@
load
page
table
pointer
mov
r0
,
#(
domain_val
(
DOMAIN_USER
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_KERNEL
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_TABLE
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_IO
,
DOMAIN_CLIENT
))
mcr
p15
,
0
,
r0
,
c3
,
c0
@
load
domain
access
register
mrc
p15
,
0
,
r0
,
c1
,
c0
@
get
control
register
bic
r0
,
r0
,
#
0x0e00
@
..
V
.
..
RS
BLDP
WCAM
orr
r0
,
r0
,
#
0x0100
@
....
....
.111
....
(
old
)
orr
r0
,
r0
,
#
0x003d
@
....
..01
..11
1101
(
new
)
ldr
r5
,
arm710_cr1_clear
bic
r0
,
r0
,
r5
ldr
r5
,
arm710_cr1_set
orr
r0
,
r0
,
r5
mov
pc
,
lr
@
__ret
(
head
.
S
)
.
size
__arm710_setup
,
.
-
__arm710_setup
/
*
*
R
*
.
RVI
ZFRS
BLDP
WCAM
*
....
0001
..11
1101
*
*/
.
type
arm710_cr1_clear
,
#
object
.
type
arm710_cr1_set
,
#
object
arm710_cr1_clear
:
.
word
0x0f3f
arm710_cr1_set
:
.
word
0x013d
.
type
__arm720_setup
,
#
function
__arm720_setup
:
mov
r0
,
#
0
__arm720_setup
:
mov
r0
,
#
0
mcr
p15
,
0
,
r0
,
c7
,
c7
,
0
@
invalidate
caches
mcr
p15
,
0
,
r0
,
c8
,
c7
,
0
@
flush
TLB
(
v4
)
mcr
p15
,
0
,
r4
,
c2
,
c0
@
load
page
table
pointer
mov
r0
,
#(
domain_val
(
DOMAIN_USER
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_KERNEL
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_TABLE
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_IO
,
DOMAIN_CLIENT
))
mcr
p15
,
0
,
r0
,
c3
,
c0
@
load
domain
access
register
mrc
p15
,
0
,
r0
,
c1
,
c0
@
get
control
register
bic
r0
,
r0
,
#
0x0e00
@
..
V
.
..
RS
BLDP
WCAM
orr
r0
,
r0
,
#
0x2100
@
....
....
.111
....
(
old
)
orr
r0
,
r0
,
#
0x003d
@
..1.
..01
..11
1101
(
new
)
ldr
r5
,
arm720_cr1_clear
bic
r0
,
r0
,
r5
ldr
r5
,
arm720_cr1_set
orr
r0
,
r0
,
r5
mov
pc
,
lr
@
__ret
(
head
.
S
)
.
size
__arm720_setup
,
.
-
__arm720_setup
/
*
*
R
*
.
RVI
ZFRS
BLDP
WCAM
*
..1.
1001
..11
1101
*
*/
.
type
arm720_cr1_clear
,
#
object
.
type
arm720_cr1_set
,
#
object
arm720_cr1_clear
:
.
word
0x2f3f
arm720_cr1_set
:
.
word
0x213d
__INITDATA
/*
...
...
arch/arm/mm/proc-arm920.S
View file @
c84f2c3f
...
...
@@ -29,7 +29,6 @@
#include <linux/init.h>
#include <asm/assembler.h>
#include <asm/pgtable.h>
#include <asm/domain.h>
#include <asm/procinfo.h>
#include <asm/hardware.h>
#include <asm/page.h>
...
...
@@ -383,36 +382,27 @@ __arm920_setup:
mcr
p15
,
0
,
r0
,
c7
,
c7
@
invalidate
I
,
D
caches
on
v4
mcr
p15
,
0
,
r0
,
c7
,
c10
,
4
@
drain
write
buffer
on
v4
mcr
p15
,
0
,
r0
,
c8
,
c7
@
invalidate
I
,
D
TLBs
on
v4
mcr
p15
,
0
,
r4
,
c2
,
c0
@
load
page
table
pointer
mov
r0
,
#(
domain_val
(
DOMAIN_USER
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_KERNEL
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_TABLE
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_IO
,
DOMAIN_CLIENT
))
mcr
p15
,
0
,
r0
,
c3
,
c0
@
load
domain
access
register
mrc
p15
,
0
,
r0
,
c1
,
c0
@
get
control
register
v4
/*
*
Clear
out
'unwanted'
bits
(
then
put
them
in
if
we
need
them
)
*/
@
VI
ZFRS
BLDP
WCAM
bic
r0
,
r0
,
#
0x0e00
bic
r0
,
r0
,
#
0x0002
bic
r0
,
r0
,
#
0x000c
bic
r0
,
r0
,
#
0x1000
@
...0
000
.
....
000
.
/*
*
Turn
on
what
we
want
*/
orr
r0
,
r0
,
#
0x0031
orr
r0
,
r0
,
#
0x2100
@
..1.
...1
..11
...1
#ifndef CONFIG_CPU_DCACHE_DISABLE
orr
r0
,
r0
,
#
0x0004
@
....
....
....
.1..
#endif
#ifndef CONFIG_CPU_ICACHE_DISABLE
orr
r0
,
r0
,
#
0x1000
@
...1
....
....
....
#endif
ldr
r5
,
arm920_cr1_clear
bic
r0
,
r0
,
r5
ldr
r5
,
arm920_cr1_set
orr
r0
,
r0
,
r5
mov
pc
,
lr
.
size
__arm920_setup
,
.
-
__arm920_setup
/
*
*
R
*
.
RVI
ZFRS
BLDP
WCAM
*
..11
0001
..11
0101
*
*/
.
type
arm920_cr1_clear
,
#
object
.
type
arm920_cr1_set
,
#
object
arm920_cr1_clear
:
.
word
0x3f3f
arm920_cr1_set
:
.
word
0x3135
__INITDATA
/*
...
...
arch/arm/mm/proc-arm922.S
View file @
c84f2c3f
...
...
@@ -30,7 +30,6 @@
#include <linux/init.h>
#include <asm/assembler.h>
#include <asm/pgtable.h>
#include <asm/domain.h>
#include <asm/procinfo.h>
#include <asm/hardware.h>
#include <asm/page.h>
...
...
@@ -387,36 +386,27 @@ __arm922_setup:
mcr
p15
,
0
,
r0
,
c7
,
c7
@
invalidate
I
,
D
caches
on
v4
mcr
p15
,
0
,
r0
,
c7
,
c10
,
4
@
drain
write
buffer
on
v4
mcr
p15
,
0
,
r0
,
c8
,
c7
@
invalidate
I
,
D
TLBs
on
v4
mcr
p15
,
0
,
r4
,
c2
,
c0
@
load
page
table
pointer
mov
r0
,
#(
domain_val
(
DOMAIN_USER
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_KERNEL
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_TABLE
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_IO
,
DOMAIN_CLIENT
))
mcr
p15
,
0
,
r0
,
c3
,
c0
@
load
domain
access
register
mrc
p15
,
0
,
r0
,
c1
,
c0
@
get
control
register
v4
/*
*
Clear
out
'unwanted'
bits
(
then
put
them
in
if
we
need
them
)
*/
@
VI
ZFRS
BLDP
WCAM
bic
r0
,
r0
,
#
0x0e00
bic
r0
,
r0
,
#
0x0002
bic
r0
,
r0
,
#
0x000c
bic
r0
,
r0
,
#
0x1000
@
...0
000
.
....
000
.
/*
*
Turn
on
what
we
want
*/
orr
r0
,
r0
,
#
0x0031
orr
r0
,
r0
,
#
0x2100
@
..1.
...1
..11
...1
#ifndef CONFIG_CPU_DCACHE_DISABLE
orr
r0
,
r0
,
#
0x0004
@
....
....
....
.1..
#endif
#ifndef CONFIG_CPU_ICACHE_DISABLE
orr
r0
,
r0
,
#
0x1000
@
...1
....
....
....
#endif
ldr
r5
,
arm922_cr1_clear
bic
r0
,
r0
,
r5
ldr
r5
,
arm922_cr1_set
orr
r0
,
r0
,
r5
mov
pc
,
lr
.
size
__arm922_setup
,
.
-
__arm922_setup
/
*
*
R
*
.
RVI
ZFRS
BLDP
WCAM
*
..11
0001
..11
0101
*
*/
.
type
arm922_cr1_clear
,
#
object
.
type
arm922_cr1_set
,
#
object
arm922_cr1_clear
:
.
word
0x3f3f
arm922_cr1_set
:
.
word
0x3135
__INITDATA
/*
...
...
arch/arm/mm/proc-arm925.S
View file @
c84f2c3f
...
...
@@ -52,7 +52,6 @@
#include <linux/init.h>
#include <asm/assembler.h>
#include <asm/pgtable.h>
#include <asm/domain.h>
#include <asm/procinfo.h>
#include <asm/hardware.h>
#include <asm/page.h>
...
...
@@ -440,48 +439,36 @@ __arm925_setup:
mcr
p15
,
0
,
r0
,
c7
,
c7
@
invalidate
I
,
D
caches
on
v4
mcr
p15
,
0
,
r0
,
c7
,
c10
,
4
@
drain
write
buffer
on
v4
mcr
p15
,
0
,
r0
,
c8
,
c7
@
invalidate
I
,
D
TLBs
on
v4
mcr
p15
,
0
,
r4
,
c2
,
c0
@
load
page
table
pointer
#ifdef CONFIG_CPU_DCACHE_WRITETHROUGH
mov
r0
,
#
4
@
disable
write
-
back
on
caches
explicitly
mcr
p15
,
7
,
r0
,
c15
,
c0
,
0
#endif
mov
r0
,
#(
domain_val
(
DOMAIN_USER
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_KERNEL
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_TABLE
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_IO
,
DOMAIN_CLIENT
))
mcr
p15
,
0
,
r0
,
c3
,
c0
@
load
domain
access
register
mrc
p15
,
0
,
r0
,
c1
,
c0
@
get
control
register
v4
/*
*
Clear
out
'unwanted'
bits
(
then
put
them
in
if
we
need
them
)
*/
@
VI
ZFRS
BLDP
WCAM
bic
r0
,
r0
,
#
0x0e00
bic
r0
,
r0
,
#
0x0002
bic
r0
,
r0
,
#
0x000c
bic
r0
,
r0
,
#
0x1000
@
...0
000
.
....
000
.
/*
*
Turn
on
what
we
want
*/
orr
r0
,
r0
,
#
0x0031
orr
r0
,
r0
,
#
0x2100
@
..1.
...1
..11
...1
/
*
Writebuffer
on
*/
orr
r0
,
r0
,
#
0x0008
@
....
....
....
1
...
ldr
r5
,
arm925_cr1_clear
bic
r0
,
r0
,
r5
ldr
r5
,
arm925_cr1_set
orr
r0
,
r0
,
r5
#ifdef CONFIG_CPU_CACHE_ROUND_ROBIN
orr
r0
,
r0
,
#
0x4000
@
.1..
....
....
....
#endif
#ifndef CONFIG_CPU_DCACHE_DISABLE
orr
r0
,
r0
,
#
0x0004
@
....
....
....
.1..
#endif
#ifndef CONFIG_CPU_ICACHE_DISABLE
orr
r0
,
r0
,
#
0x1000
@
...1
....
....
....
#endif
mov
pc
,
lr
.
size
__arm925_setup
,
.
-
__arm925_setup
/
*
*
R
*
.
RVI
ZFRS
BLDP
WCAM
*
.011
0001
..11
1101
*
*/
.
type
arm925_cr1_clear
,
#
object
.
type
arm925_cr1_set
,
#
object
arm925_cr1_clear
:
.
word
0x7f3f
arm925_cr1_set
:
.
word
0x313d
__INITDATA
/*
...
...
arch/arm/mm/proc-arm926.S
View file @
c84f2c3f
...
...
@@ -29,7 +29,6 @@
#include <linux/init.h>
#include <asm/assembler.h>
#include <asm/pgtable.h>
#include <asm/domain.h>
#include <asm/procinfo.h>
#include <asm/hardware.h>
#include <asm/page.h>
...
...
@@ -389,7 +388,6 @@ __arm926_setup:
mcr
p15
,
0
,
r0
,
c7
,
c7
@
invalidate
I
,
D
caches
on
v4
mcr
p15
,
0
,
r0
,
c7
,
c10
,
4
@
drain
write
buffer
on
v4
mcr
p15
,
0
,
r0
,
c8
,
c7
@
invalidate
I
,
D
TLBs
on
v4
mcr
p15
,
0
,
r4
,
c2
,
c0
@
load
page
table
pointer
#ifdef CONFIG_CPU_DCACHE_WRITETHROUGH
...
...
@@ -397,38 +395,30 @@ __arm926_setup:
mcr
p15
,
7
,
r0
,
c15
,
c0
,
0
#endif
mov
r0
,
#(
domain_val
(
DOMAIN_USER
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_KERNEL
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_TABLE
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_IO
,
DOMAIN_CLIENT
))
mcr
p15
,
0
,
r0
,
c3
,
c0
@
load
domain
access
register
mrc
p15
,
0
,
r0
,
c1
,
c0
@
get
control
register
v4
/*
*
Clear
out
'unwanted'
bits
(
then
put
them
in
if
we
need
them
)
*/
@
VI
ZFRS
BLDP
WCAM
bic
r0
,
r0
,
#
0x0e00
bic
r0
,
r0
,
#
0x0002
bic
r0
,
r0
,
#
0x000c
bic
r0
,
r0
,
#
0x1000
@
...0
000
.
....
000
.
/*
*
Turn
on
what
we
want
*/
orr
r0
,
r0
,
#
0x0031
orr
r0
,
r0
,
#
0x2100
@
..1.
...1
..11
...1
ldr
r5
,
arm926_cr1_clear
bic
r0
,
r0
,
r5
ldr
r5
,
arm926_cr1_set
orr
r0
,
r0
,
r5
#ifdef CONFIG_CPU_CACHE_ROUND_ROBIN
orr
r0
,
r0
,
#
0x4000
@
.1..
....
....
....
#endif
#ifndef CONFIG_CPU_DCACHE_DISABLE
orr
r0
,
r0
,
#
0x0004
@
....
....
....
.1..
#endif
#ifndef CONFIG_CPU_ICACHE_DISABLE
orr
r0
,
r0
,
#
0x1000
@
...1
....
....
....
#endif
mov
pc
,
lr
.
size
__arm926_setup
,
.
-
__arm926_setup
/
*
*
R
*
.
RVI
ZFRS
BLDP
WCAM
*
.011
0001
..11
0101
*
*/
.
type
arm926_cr1_clear
,
#
object
.
type
arm926_cr1_set
,
#
object
arm926_cr1_clear
:
.
word
0x7f3f
arm926_cr1_set
:
.
word
0x3135
__INITDATA
/*
...
...
arch/arm/mm/proc-sa110.S
View file @
c84f2c3f
...
...
@@ -19,7 +19,6 @@
#include <asm/procinfo.h>
#include <asm/hardware.h>
#include <asm/pgtable.h>
#include <asm/domain.h>
#include <asm/ptrace.h>
/*
...
...
@@ -187,24 +186,31 @@ ENTRY(cpu_sa110_set_pte)
.
type
__sa110_setup
,
#
function
__sa110_setup
:
mrc
p15
,
0
,
r0
,
c1
,
c0
@
get
control
register
v4
bic
r0
,
r0
,
#
0x2e00
@
..
VI
ZFRS
BLDP
WCAM
bic
r0
,
r0
,
#
0x0002
@
..0.
000
.
....
..0.
orr
r0
,
r0
,
#
0x003d
orr
r0
,
r0
,
#
0x1100
@
...1
...1
..11
11
.1
mov
r10
,
#
0
mcr
p15
,
0
,
r10
,
c7
,
c7
@
invalidate
I
,
D
caches
on
v4
mcr
p15
,
0
,
r10
,
c7
,
c10
,
4
@
drain
write
buffer
on
v4
mcr
p15
,
0
,
r10
,
c8
,
c7
@
invalidate
I
,
D
TLBs
on
v4
mcr
p15
,
0
,
r4
,
c2
,
c0
@
load
page
table
pointer
mov
r10
,
#(
domain_val
(
DOMAIN_USER
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_KERNEL
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_TABLE
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_IO
,
DOMAIN_CLIENT
))
mcr
p15
,
0
,
r10
,
c3
,
c0
@
load
domain
access
register
mrc
p15
,
0
,
r0
,
c1
,
c0
@
get
control
register
v4
ldr
r5
,
sa110_cr1_clear
bic
r0
,
r0
,
r5
ldr
r5
,
sa110_cr1_set
orr
r0
,
r0
,
r5
mov
pc
,
lr
.
size
__sa110_setup
,
.
-
__sa110_setup
/
*
*
R
*
.
RVI
ZFRS
BLDP
WCAM
*
..01
0001
..11
1101
*
*/
.
type
sa110_cr1_clear
,
#
object
.
type
sa110_cr1_set
,
#
object
sa110_cr1_clear
:
.
word
0x3f3f
sa110_cr1_set
:
.
word
0x113d
__INITDATA
/*
...
...
arch/arm/mm/proc-sa1100.S
View file @
c84f2c3f
...
...
@@ -20,7 +20,6 @@
#include <linux/linkage.h>
#include <linux/init.h>
#include <asm/assembler.h>
#include <asm/domain.h>
#include <asm/constants.h>
#include <asm/procinfo.h>
#include <asm/hardware.h>
...
...
@@ -210,24 +209,31 @@ ENTRY(cpu_sa1100_set_pte)
.
type
__sa1100_setup
,
#
function
__sa1100_setup
:
mov
r10
,
#
0
mcr
p15
,
0
,
r10
,
c7
,
c7
@
invalidate
I
,
D
caches
on
v4
mcr
p15
,
0
,
r10
,
c7
,
c10
,
4
@
drain
write
buffer
on
v4
mcr
p15
,
0
,
r10
,
c8
,
c7
@
invalidate
I
,
D
TLBs
on
v4
mov
r0
,
#(
domain_val
(
DOMAIN_USER
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_KERNEL
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_TABLE
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_IO
,
DOMAIN_CLIENT
))
mcr
p15
,
0
,
r0
,
c3
,
c0
@
load
domain
access
register
mcr
p15
,
0
,
r4
,
c2
,
c0
@
load
page
table
pointer
mov
r0
,
#
0
mcr
p15
,
0
,
r0
,
c7
,
c7
@
invalidate
I
,
D
caches
on
v4
mcr
p15
,
0
,
r0
,
c7
,
c10
,
4
@
drain
write
buffer
on
v4
mcr
p15
,
0
,
r0
,
c8
,
c7
@
invalidate
I
,
D
TLBs
on
v4
mrc
p15
,
0
,
r0
,
c1
,
c0
@
get
control
register
v4
bic
r0
,
r0
,
#
0x0e00
@
..
VI
ZFRS
BLDP
WCAM
bic
r0
,
r0
,
#
0x0002
@
....
000
.
....
..0.
orr
r0
,
r0
,
#
0x003d
orr
r0
,
r0
,
#
0x3100
@
..11
...1
..11
11
.1
ldr
r5
,
sa1100_cr1_clear
bic
r0
,
r0
,
r5
ldr
r5
,
sa1100_cr1_set
orr
r0
,
r0
,
r5
mov
pc
,
lr
.
size
__sa1100_setup
,
.
-
__sa1100_setup
/
*
*
R
*
.
RVI
ZFRS
BLDP
WCAM
*
..11
0001
..11
1101
*
*/
.
type
sa1100_cr1_clear
,
#
object
.
type
sa1100_cr1_set
,
#
object
sa1100_cr1_clear
:
.
word
0x3f3f
sa1100_cr1_set
:
.
word
0x313d
__INITDATA
/*
...
...
arch/arm/mm/proc-v6.S
View file @
c84f2c3f
...
...
@@ -14,7 +14,6 @@
#include <asm/constants.h>
#include <asm/procinfo.h>
#include <asm/pgtable.h>
#include <asm/domain.h>
#include "proc-macros.S"
...
...
@@ -190,30 +189,24 @@ cpu_v6_name:
*
-
cache
type
register
is
implemented
*/
__v6_setup
:
mov
r10
,
#
0
mcr
p15
,
0
,
r10
,
c7
,
c14
,
0
@
clean
+
invalidate
D
cache
mcr
p15
,
0
,
r10
,
c7
,
c5
,
0
@
invalidate
I
cache
mcr
p15
,
0
,
r10
,
c7
,
c15
,
0
@
clean
+
invalidate
cache
mcr
p15
,
0
,
r10
,
c7
,
c10
,
4
@
drain
write
buffer
mcr
p15
,
0
,
r10
,
c8
,
c7
,
0
@
invalidate
I
+
D
TLBs
mcr
p15
,
0
,
r10
,
c2
,
c0
,
2
@
TTB
control
register
mcr
p15
,
0
,
r4
,
c2
,
c0
,
0
@
load
TTB0
mov
r0
,
#
0
mcr
p15
,
0
,
r0
,
c7
,
c14
,
0
@
clean
+
invalidate
D
cache
mcr
p15
,
0
,
r0
,
c7
,
c5
,
0
@
invalidate
I
cache
mcr
p15
,
0
,
r0
,
c7
,
c15
,
0
@
clean
+
invalidate
cache
mcr
p15
,
0
,
r0
,
c7
,
c10
,
4
@
drain
write
buffer
mcr
p15
,
0
,
r0
,
c8
,
c7
,
0
@
invalidate
I
+
D
TLBs
mcr
p15
,
0
,
r0
,
c2
,
c0
,
2
@
TTB
control
register
mcr
p15
,
0
,
r4
,
c2
,
c0
,
1
@
load
TTB1
mov
r10
,
#(
domain_val
(
DOMAIN_USER
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_KERNEL
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_TABLE
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_IO
,
DOMAIN_CLIENT
))
mcr
p15
,
0
,
r10
,
c3
,
c0
,
0
@
load
domain
access
register
mrc
p15
,
0
,
r0
,
c1
,
c0
,
0
@
read
control
register
#ifdef CONFIG_VFP
mrc
p15
,
0
,
r
1
0
,
c1
,
c0
,
2
orr
r
10
,
r1
0
,
#(
3
<<
20
)
mcr
p15
,
0
,
r
1
0
,
c1
,
c0
,
2
@
Enable
full
access
to
VFP
mrc
p15
,
0
,
r0
,
c1
,
c0
,
2
orr
r
0
,
r
0
,
#(
3
<<
20
)
mcr
p15
,
0
,
r0
,
c1
,
c0
,
2
@
Enable
full
access
to
VFP
#endif
ldr
r10
,
cr1_clear
@
get
mask
for
bits
to
clear
bic
r0
,
r0
,
r10
@
clear
bits
them
ldr
r10
,
cr1_set
@
get
mask
for
bits
to
set
orr
r0
,
r0
,
r10
@
set
them
mrc
p15
,
0
,
r0
,
c1
,
c0
,
0
@
read
control
register
ldr
r5
,
v6_cr1_clear
@
get
mask
for
bits
to
clear
bic
r0
,
r0
,
r5
@
clear
bits
them
ldr
r5
,
v6_cr1_set
@
get
mask
for
bits
to
set
orr
r0
,
r0
,
r5
@
set
them
mov
pc
,
lr
@
return
to
head
.
S
:
__ret
/
*
...
...
@@ -222,11 +215,11 @@ __v6_setup:
*
rrrr
rrrx
xxx0
0101
xxxx
xxxx
x111
xxxx
<
forced
*
0
110
0011
1
.00
.111
1101
<
we
want
*/
.
type
cr1_clear
,
#
object
.
type
cr1_set
,
#
object
cr1_clear
:
.
word
0x01
20c302
cr1_set
:
.
type
v6_
cr1_clear
,
#
object
.
type
v6_
cr1_set
,
#
object
v6_
cr1_clear
:
.
word
0x01
e0fb7f
v6_
cr1_set
:
.
word
0x00c0387d
.
type
v6_processor_functions
,
#
object
...
...
arch/arm/mm/proc-xscale.S
View file @
c84f2c3f
...
...
@@ -26,7 +26,6 @@
#include <asm/procinfo.h>
#include <asm/hardware.h>
#include <asm/pgtable.h>
#include <asm/domain.h>
#include <asm/page.h>
#include <asm/ptrace.h>
#include "proc-macros.S"
...
...
@@ -595,17 +594,9 @@ ENTRY(cpu_xscale_set_pte)
.
type
__xscale_setup
,
#
function
__xscale_setup
:
mov
r0
,
#
PSR_F_BIT|PSR_I_BIT|SVC_MODE
msr
cpsr_c
,
r0
mcr
p15
,
0
,
ip
,
c7
,
c7
,
0
@
invalidate
I
,
D
caches
&
BTB
mcr
p15
,
0
,
ip
,
c7
,
c10
,
4
@
Drain
Write
(&
Fill
)
Buffer
mcr
p15
,
0
,
ip
,
c8
,
c7
,
0
@
invalidate
I
,
D
TLBs
mcr
p15
,
0
,
r4
,
c2
,
c0
,
0
@
load
page
table
pointer
mov
r0
,
#(
domain_val
(
DOMAIN_USER
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_KERNEL
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_TABLE
,
DOMAIN_MANAGER
)
|
\
domain_val
(
DOMAIN_IO
,
DOMAIN_CLIENT
))
mcr
p15
,
0
,
r0
,
c3
,
c0
,
0
@
load
domain
access
register
#ifdef CONFIG_IWMMXT
mov
r0
,
#
0
@
initially
disallow
access
to
CP0
/
CP1
#else
...
...
@@ -615,13 +606,26 @@ __xscale_setup:
orr
r0
,
r0
,
#
1
<<
13
@
Its
undefined
whether
this
mcr
p15
,
0
,
r0
,
c15
,
c1
,
0
@
affects
USR
or
SVC
modes
mrc
p15
,
0
,
r0
,
c1
,
c0
,
0
@
get
control
register
bic
r0
,
r0
,
#
0x0200
@
....
..
R
.
....
....
bic
r0
,
r0
,
#
0x0002
@
....
....
....
..
A
.
orr
r0
,
r0
,
#
0x0005
@
....
....
....
.
C
.
M
orr
r0
,
r0
,
#
0x3900
@
..
VI
Z
..
S
....
....
ldr
r5
,
xscale_cr1_clear
bic
r0
,
r0
,
r5
ldr
r5
,
xscale_cr1_set
orr
r0
,
r0
,
r5
mov
pc
,
lr
.
size
__xscale_setup
,
.
-
__xscale_setup
/
*
*
R
*
.
RVI
ZFRS
BLDP
WCAM
*
..11
1
.01
....
.101
*
*/
.
type
xscale_cr1_clear
,
#
object
.
type
xscale_cr1_set
,
#
object
xscale_cr1_clear
:
.
word
0x3b07
xscale_cr1_set
:
.
word
0x3905
__INITDATA
/*
...
...
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