Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
R
riscv-gcc-1
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lvzhengyang
riscv-gcc-1
Commits
7aa74e4c
Commit
7aa74e4c
authored
Mar 20, 1998
by
Stan Cox
Committed by
Stan Cox
Mar 20, 1998
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
(pop_stack): Define. Pops any register on stack and adjusts the stack.
From-SVN: r18723
parent
3cd730af
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
34 additions
and
4 deletions
+34
-4
gcc/ChangeLog
+6
-0
gcc/reg-stack.c
+28
-4
No files found.
gcc/ChangeLog
View file @
7aa74e4c
Fri Mar 20 11:19:40 1998 Stan Cox <scox@equinox.cygnus.com>
* reg-stack.c (pop_stack): Define. Pops any register on the
regstack and adjusts regstack.
(compare_for_stack_reg): Use pop_stack.
Thu Mar 19 23:51:01 1998 Jeffrey A Law (law@cygnus.com)
Thu Mar 19 23:51:01 1998 Jeffrey A Law (law@cygnus.com)
* configure.in (hppa1.0-hp-hpux10): Handle threads for this
* configure.in (hppa1.0-hp-hpux10): Handle threads for this
...
...
gcc/reg-stack.c
View file @
7aa74e4c
...
@@ -315,6 +315,32 @@ straighten_stack (insn, regstack)
...
@@ -315,6 +315,32 @@ straighten_stack (insn, regstack)
change_stack
(
insn
,
regstack
,
&
temp_stack
,
emit_insn_after
);
change_stack
(
insn
,
regstack
,
&
temp_stack
,
emit_insn_after
);
}
}
/* Pop a register from the stack */
static
void
pop_stack
(
regstack
,
regno
)
stack
regstack
;
int
regno
;
{
int
top
=
regstack
->
top
;
CLEAR_HARD_REG_BIT
(
regstack
->
reg_set
,
regno
);
regstack
->
top
--
;
/* If regno was not at the top of stack then adjust stack */
if
(
regstack
->
reg
[
top
]
!=
regno
)
{
int
i
;
for
(
i
=
regstack
->
top
;
i
>=
0
;
i
--
)
if
(
regstack
->
reg
[
i
]
==
regno
)
{
int
j
;
for
(
j
=
i
;
j
<
top
;
j
++
)
regstack
->
reg
[
j
]
=
regstack
->
reg
[
j
+
1
];
break
;
}
}
}
/* Return non-zero if any stack register is mentioned somewhere within PAT. */
/* Return non-zero if any stack register is mentioned somewhere within PAT. */
...
@@ -2067,9 +2093,8 @@ compare_for_stack_reg (insn, regstack, pat)
...
@@ -2067,9 +2093,8 @@ compare_for_stack_reg (insn, regstack, pat)
if
(
src1_note
)
if
(
src1_note
)
{
{
CLEAR_HARD_REG_BIT
(
regstack
->
reg_set
,
REGNO
(
XEXP
(
src1_note
,
0
)));
pop_stack
(
regstack
,
REGNO
(
XEXP
(
src1_note
,
0
)));
replace_reg
(
&
XEXP
(
src1_note
,
0
),
FIRST_STACK_REG
);
replace_reg
(
&
XEXP
(
src1_note
,
0
),
FIRST_STACK_REG
);
regstack
->
top
--
;
}
}
/* If the second operand dies, handle that. But if the operands are
/* If the second operand dies, handle that. But if the operands are
...
@@ -2088,9 +2113,8 @@ compare_for_stack_reg (insn, regstack, pat)
...
@@ -2088,9 +2113,8 @@ compare_for_stack_reg (insn, regstack, pat)
if
(
get_hard_regnum
(
regstack
,
XEXP
(
src2_note
,
0
))
==
FIRST_STACK_REG
if
(
get_hard_regnum
(
regstack
,
XEXP
(
src2_note
,
0
))
==
FIRST_STACK_REG
&&
src1_note
)
&&
src1_note
)
{
{
CLEAR_HARD_REG_BIT
(
regstack
->
reg_set
,
REGNO
(
XEXP
(
src2_note
,
0
)));
pop_stack
(
regstack
,
REGNO
(
XEXP
(
src2_note
,
0
)));
replace_reg
(
&
XEXP
(
src2_note
,
0
),
FIRST_STACK_REG
+
1
);
replace_reg
(
&
XEXP
(
src2_note
,
0
),
FIRST_STACK_REG
+
1
);
regstack
->
top
--
;
}
}
else
else
{
{
...
...
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