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
3ded9b7a
Commit
3ded9b7a
authored
May 03, 2003
by
Anton Blanchard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ppc64: rework fast SLB miss handler castout code
parent
de7924cb
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
25 additions
and
22 deletions
+25
-22
arch/ppc64/kernel/entry.S
arch/ppc64/kernel/entry.S
+0
-5
arch/ppc64/kernel/head.S
arch/ppc64/kernel/head.S
+25
-17
No files found.
arch/ppc64/kernel/entry.S
View file @
3ded9b7a
...
@@ -408,11 +408,6 @@ restore:
...
@@ -408,11 +408,6 @@ restore:
ld
r4
,
GPR4
(
r1
)
ld
r4
,
GPR4
(
r1
)
ld
r1
,
GPR1
(
r1
)
ld
r1
,
GPR1
(
r1
)
/
*
*
What
if
we
took
an
exception
and
stole
this
segment
,
we
may
*
fault
on
the
above
addresses
and
globber
SRR0
/
1
.
Should
check
RI
*
bit
and
repeat
-
Anton
*/
rfid
rfid
/*
Note
:
this
must
change
if
we
start
using
the
TIF_NOTIFY_RESUME
bit
*/
/*
Note
:
this
must
change
if
we
start
using
the
TIF_NOTIFY_RESUME
bit
*/
...
...
arch/ppc64/kernel/head.S
View file @
3ded9b7a
...
@@ -1051,7 +1051,7 @@ _GLOBAL(do_slb_bolted)
...
@@ -1051,7 +1051,7 @@ _GLOBAL(do_slb_bolted)
slbmfee
r23
,
r22
slbmfee
r23
,
r22
rldicl
r23
,
r23
,
37
,
63
rldicl
r23
,
r23
,
37
,
63
cmpwi
r23
,
0
cmpwi
r23
,
0
beq
3
f
/*
Found
an
invalid
entry
*/
beq
4
f
/*
Found
an
invalid
entry
*/
addi
r22
,
r22
,
1
addi
r22
,
r22
,
1
cmpldi
r22
,
64
cmpldi
r22
,
64
...
@@ -1060,18 +1060,37 @@ _GLOBAL(do_slb_bolted)
...
@@ -1060,18 +1060,37 @@ _GLOBAL(do_slb_bolted)
/
*
No
free
entry
-
just
take
the
next
entry
,
round
-
robin
*/
/
*
No
free
entry
-
just
take
the
next
entry
,
round
-
robin
*/
/
*
XXX
we
should
get
the
number
of
SLB
entries
from
the
naca
*/
/
*
XXX
we
should
get
the
number
of
SLB
entries
from
the
naca
*/
SLB_NUM_ENTRIES
=
64
SLB_NUM_ENTRIES
=
64
mfspr
r21
,
SPRG3
2
:
mfspr
r21
,
SPRG3
ld
r22
,
PACASTABRR
(
r21
)
ld
r22
,
PACASTABRR
(
r21
)
addi
r23
,
r22
,
1
addi
r23
,
r22
,
1
cmpdi
r23
,
SLB_NUM_ENTRIES
cmpdi
r23
,
SLB_NUM_ENTRIES
blt
2
f
blt
3
f
li
r23
,
1
li
r23
,
1
2
:
std
r23
,
PACASTABRR
(
r21
)
3
:
std
r23
,
PACASTABRR
(
r21
)
/
*
r20
=
vsid
,
r22
=
entry
*/
/
*
r20
=
vsid
,
r22
=
entry
*/
3
:
/
*
*
Never
cast
out
the
segment
for
our
kernel
stack
.
Since
we
*
dont
invalidate
the
ERAT
we
could
have
a
valid
translation
*
for
the
kernel
stack
during
the
first
part
of
exception
exit
*
which
gets
invalidated
due
to
a
tlbie
from
another
cpu
at
a
*
non
recoverable
point
(
after
setting
srr0
/
1
)
-
Anton
*/
slbmfee
r23
,
r22
srdi
r23
,
r23
,
28
/
*
*
This
is
incorrect
(
r1
is
not
the
kernel
stack
)
if
we
entered
*
from
userspace
but
there
is
no
critical
window
from
userspace
*
so
this
should
be
OK
.
Also
if
we
cast
out
the
userspace
stack
*
segment
while
in
userspace
we
will
fault
it
straight
back
in
.
*/
srdi
r21
,
r1
,
28
cmpd
r21
,
r23
beq
-
2
b
/
*
Put
together
the
vsid
portion
of
the
entry
.
*/
/
*
Put
together
the
vsid
portion
of
the
entry
.
*/
li
r21
,
0
4
:
li
r21
,
0
rldimi
r21
,
r20
,
12
,
0
rldimi
r21
,
r20
,
12
,
0
ori
r20
,
r21
,
1024
ori
r20
,
r21
,
1024
ori
r20
,
r20
,
128
/*
set
class
bit
for
kernel
region
*/
ori
r20
,
r20
,
128
/*
set
class
bit
for
kernel
region
*/
...
@@ -1079,17 +1098,6 @@ SLB_NUM_ENTRIES = 64
...
@@ -1079,17 +1098,6 @@ SLB_NUM_ENTRIES = 64
ori
r20
,
r20
,
256
/*
map
kernel
region
with
large
ptes
*/
ori
r20
,
r20
,
256
/*
map
kernel
region
with
large
ptes
*/
#endif
#endif
/
*
*
XXX
we
should
handle
this
in
the
exception
exit
path
in
2
.5
,
*
we
need
to
make
this
path
quick
-
Anton
*/
/
*
Invalidate
the
old
entry
*/
slbmfee
r21
,
r22
lis
r23
,-
2049
ori
r23
,
r23
,
65535
and
r21
,
r21
,
r23
slbie
r21
/
*
Put
together
the
esid
portion
of
the
entry
.
*/
/
*
Put
together
the
esid
portion
of
the
entry
.
*/
mfspr
r21
,
DAR
/*
Get
the
new
esid
*/
mfspr
r21
,
DAR
/*
Get
the
new
esid
*/
rldicl
r21
,
r21
,
36
,
28
/*
Permits
a
full
36
b
of
ESID
*/
rldicl
r21
,
r21
,
36
,
28
/*
Permits
a
full
36
b
of
ESID
*/
...
...
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