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
8b4b9b7a
Commit
8b4b9b7a
authored
25 years ago
by
Jeffrey A Law
Committed by
Jeff Law
25 years ago
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* pa.md (reload shift-add patterns): Remove.
From-SVN: r30688
parent
2e02044a
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
4 additions
and
41 deletions
+4
-41
gcc/ChangeLog
+4
-0
gcc/config/pa/pa.md
+0
-41
No files found.
gcc/ChangeLog
View file @
8b4b9b7a
Sun
Nov
28
13
:
21
:
00
1999
Jeffrey
A
Law
(
law
@cygnus
.
com
)
*
pa
.
md
(
reload
shift
-
add
patterns
)
:
Remove
.
1999
-
11
-
28
Herman
A
.
J
.
ten
Brugge
<
Haj
.
Ten
.
Brugge
@net
.
HCC
.
nl
>
*
reorg
.
c
(
dbr_schedule
)
Print
more
statistics
.
Corrected
...
...
This diff is collapsed.
Click to expand it.
gcc/config/pa/pa.md
View file @
8b4b9b7a
...
...
@@ -3118,25 +3118,6 @@
(set_attr "pa_combine_type" "addmove")
(set_attr "length" "4,4")])
;; Disgusting kludge to work around reload bugs with frame pointer
;; elimination. Similar to other magic reload patterns in the
;; indexed memory operations.
(define_insn ""
[
(set (match_operand:SI 0 "register_operand" "=&r")
(plus:SI (plus:SI (match_operand:SI 1 "register_operand" "%r")
(match_operand:SI 2 "register_operand" "r"))
(match_operand:SI 3 "const_int_operand" "rL")))]
"reload_in_progress"
"
*
{
if (GET_CODE (operands
[
3
]
) == CONST_INT)
return
\"
ldo %3(%2),%0
\;
{addl|add,l} %1,%0,%0
\"
;
else
return
\"
{addl|add,l} %3,%2,%0
\;
{addl|add,l} %1,%0,%0
\"
;
}"
[
(set_attr "type" "binary")
(set_attr "length" "8")])
(define_expand "subdi3"
[
(set (match_operand:DI 0 "register_operand" "")
(minus:DI (match_operand:DI 1 "register_operand" "")
...
...
@@ -4223,28 +4204,6 @@
[
(set_attr "type" "binary")
(set_attr "length" "4")])
;; This variant of the above insn can occur if the first operand
;; is the frame pointer. This is a kludge, but there doesn't
;; seem to be a way around it. Only recognize it while reloading.
;; Note how operand 3 uses a predicate of "const_int_operand", but
;; has constraints allowing a register. I don't know how this works,
;; but it somehow makes sure that out-of-range constants are placed
;; in a register which somehow magically is a "const_int_operand".
;; (this was stolen from alpha.md, I'm not going to try and change it.
(define_insn ""
[
(set (match_operand:SI 0 "register_operand" "=&r,r")
(plus:SI (plus:SI (mult:SI (match_operand:SI 2 "register_operand" "r,r")
(match_operand:SI 4 "shadd_operand" ""))
(match_operand:SI 1 "register_operand" "r,r"))
(match_operand:SI 3 "const_int_operand" "r,J")))]
"reload_in_progress"
"@
{sh%O4addl %2,%1,%0|shladd,l %2,%O4,%1,%0}
\;
{addl|add,l} %3,%0,%0
{sh%O4addl %2,%1,%0|shladd,l %2,%O4,%1,%0}
\;
ldo %3(%0),%0"
[
(set_attr "type" "multi")
(set_attr "length" "8")])
;; This anonymous pattern and splitter wins because it reduces the latency
;; of the shadd sequence without increasing the latency of the shift.
;;
...
...
This diff is collapsed.
Click to expand it.
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