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
a14003ee
Commit
a14003ee
authored
Apr 16, 1999
by
Jan Hubicka
Committed by
Jeff Law
Apr 15, 1999
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
* i386.c (x86_adjust_cost): Move break statement to correct place.
From-SVN: r26485
parent
6419e5b0
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
110 additions
and
61 deletions
+110
-61
gcc/ChangeLog
+4
-0
gcc/config/i386/i386.c
+106
-61
No files found.
gcc/ChangeLog
View file @
a14003ee
Fri
Apr
16
00
:
19
:
31
1999
Jan
Hubicka
<
hubicka
@freesoft
.
cz
>
*
i386
.
c
(
x86_adjust_cost
)
:
Move
break
statement
to
correct
place
.
Thu
Apr
15
23
:
17
:
33
1999
Jerry
Quinn
<
jquinn
@nortelnetworks
.
com
>
*
pa
.
h
(
HAVE_PRE_INCREMENT
,
HAVE_POST_INCREMENT
,
...
...
gcc/config/i386/i386.c
View file @
a14003ee
...
...
@@ -3139,7 +3139,8 @@ put_jump_code (code, reverse, file)
FILE
*
file
;
{
int
flags
=
cc_prev_status
.
flags
;
int
ieee
=
(
TARGET_IEEE_FP
&&
(
flags
&
CC_IN_80387
));
int
ieee
=
(
TARGET_IEEE_FP
&&
(
flags
&
CC_IN_80387
)
&&
!
(
cc_prev_status
.
flags
&
CC_FCOMI
));
const
char
*
suffix
;
if
(
flags
&
CC_Z_IN_NOT_C
)
...
...
@@ -3896,7 +3897,7 @@ notice_update_cc (exp)
if
(
stack_regs_mentioned_p
(
SET_SRC
(
XVECEXP
(
exp
,
0
,
0
))))
{
cc_status
.
flags
|=
CC_IN_80387
;
if
(
0
&&
TARGET_CMOVE
&&
stack_regs_mentioned_p
if
(
TARGET_CMOVE
&&
stack_regs_mentioned_p
(
XEXP
(
SET_SRC
(
XVECEXP
(
exp
,
0
,
0
)),
1
)))
cc_status
.
flags
|=
CC_FCOMI
;
}
...
...
@@ -4254,7 +4255,7 @@ output_float_compare (insn, operands)
int
unordered_compare
=
GET_MODE
(
SET_SRC
(
body
))
==
CCFPEQmode
;
rtx
tmp
;
if
(
0
&&
TARGET_CMOVE
&&
STACK_REG_P
(
operands
[
1
]))
if
(
TARGET_CMOVE
&&
STACK_REG_P
(
operands
[
1
]))
{
cc_status
.
flags
|=
CC_FCOMI
;
cc_prev_status
.
flags
&=
~
CC_TEST_AX
;
...
...
@@ -4288,7 +4289,8 @@ output_float_compare (insn, operands)
{
output_asm_insn
(
AS2
(
fucomip
,
%
y1
,
%
0
),
operands
);
output_asm_insn
(
AS1
(
fstp
,
%
y0
),
operands
);
return
""
;
if
(
!
TARGET_IEEE_FP
)
return
""
;
}
else
output_asm_insn
(
"fucompp"
,
operands
);
...
...
@@ -4324,7 +4326,8 @@ output_float_compare (insn, operands)
if
(
cc_status
.
flags
&
CC_FCOMI
)
{
output_asm_insn
(
strcat
(
buf
,
AS2
(
%
z1
,
%
y1
,
%
0
)),
operands
);
return
""
;
if
(
!
TARGET_IEEE_FP
)
return
""
;
}
else
output_asm_insn
(
strcat
(
buf
,
AS1
(
%
z1
,
%
y1
)),
operands
);
...
...
@@ -4348,17 +4351,19 @@ output_fp_cc0_set (insn)
rtx
next
;
enum
rtx_code
code
;
xops
[
0
]
=
gen_rtx_REG
(
HImode
,
0
);
output_asm_insn
(
AS1
(
fnsts
%
W0
,
%
0
),
xops
);
if
(
!
(
cc_status
.
flags
&
CC_FCOMI
))
{
xops
[
0
]
=
gen_rtx_REG
(
HImode
,
0
);
output_asm_insn
(
AS1
(
fnsts
%
W0
,
%
0
),
xops
);
}
if
(
!
TARGET_IEEE_FP
)
{
if
(
!
(
cc_status
.
flags
&
CC_REVERSED
))
{
next
=
next_cc0_user
(
insn
);
if
(
GET_CODE
(
next
)
==
JUMP_INSN
&&
GET_CODE
(
PATTERN
(
next
))
==
SET
if
(
GET_CODE
(
PATTERN
(
next
))
==
SET
&&
SET_DEST
(
PATTERN
(
next
))
==
pc_rtx
&&
GET_CODE
(
SET_SRC
(
PATTERN
(
next
)))
==
IF_THEN_ELSE
)
code
=
GET_CODE
(
XEXP
(
SET_SRC
(
PATTERN
(
next
)),
0
));
...
...
@@ -4383,8 +4388,7 @@ output_fp_cc0_set (insn)
if
(
next
==
NULL_RTX
)
abort
();
if
(
GET_CODE
(
next
)
==
JUMP_INSN
&&
GET_CODE
(
PATTERN
(
next
))
==
SET
if
(
GET_CODE
(
PATTERN
(
next
))
==
SET
&&
SET_DEST
(
PATTERN
(
next
))
==
pc_rtx
&&
GET_CODE
(
SET_SRC
(
PATTERN
(
next
)))
==
IF_THEN_ELSE
)
code
=
GET_CODE
(
XEXP
(
SET_SRC
(
PATTERN
(
next
)),
0
));
...
...
@@ -4407,61 +4411,103 @@ output_fp_cc0_set (insn)
else
abort
();
xops
[
0
]
=
gen_rtx_REG
(
QImode
,
0
);
if
(
cc_status
.
flags
&
CC_FCOMI
)
{
/* It is very tricky. We have to do it right. */
xops
[
0
]
=
gen_rtx_REG
(
QImode
,
0
);
switch
(
code
)
switch
(
code
)
{
case
GT
:
case
GE
:
break
;
case
LT
:
output_asm_insn
(
AS1
(
setb
,
%
b0
),
xops
);
output_asm_insn
(
AS1
(
setp
,
%
h0
),
xops
);
output_asm_insn
(
AS2
(
cmp
%
B0
,
%
b0
,
%
h0
),
xops
);
break
;
case
LE
:
output_asm_insn
(
AS1
(
setbe
,
%
b0
),
xops
);
output_asm_insn
(
AS1
(
setnp
,
%
h0
),
xops
);
output_asm_insn
(
AS2
(
xor
%
B0
,
%
b0
,
%
h0
),
xops
);
break
;
case
EQ
:
case
NE
:
output_asm_insn
(
AS1
(
setne
,
%
b0
),
xops
);
output_asm_insn
(
AS1
(
setp
,
%
h0
),
xops
);
output_asm_insn
(
AS2
(
or
%
B0
,
%
b0
,
%
h0
),
xops
);
break
;
case
GTU
:
case
LTU
:
case
GEU
:
case
LEU
:
default
:
abort
();
}
}
else
{
case
GT
:
xops
[
1
]
=
GEN_INT
(
0x45
);
output_asm_insn
(
AS2
(
and
%
B0
,
%
1
,
%
h0
),
xops
);
/* je label */
break
;
xops
[
0
]
=
gen_rtx_REG
(
QImode
,
0
);
case
LT
:
xops
[
1
]
=
GEN_INT
(
0x45
);
xops
[
2
]
=
GEN_INT
(
0x01
);
output_asm_insn
(
AS2
(
and
%
B0
,
%
1
,
%
h0
),
xops
);
output_asm_insn
(
AS2
(
cmp
%
B0
,
%
2
,
%
h0
),
xops
);
/* je label */
break
;
switch
(
code
)
{
case
GT
:
xops
[
1
]
=
GEN_INT
(
0x45
);
output_asm_insn
(
AS2
(
and
%
B0
,
%
1
,
%
h0
),
xops
);
/* je label */
break
;
case
GE
:
xops
[
1
]
=
GEN_INT
(
0x05
);
output_asm_insn
(
AS2
(
and
%
B0
,
%
1
,
%
h0
),
xops
);
/* je label */
break
;
case
LT
:
xops
[
1
]
=
GEN_INT
(
0x45
);
xops
[
2
]
=
GEN_INT
(
0x01
);
output_asm_insn
(
AS2
(
and
%
B0
,
%
1
,
%
h0
),
xops
);
output_asm_insn
(
AS2
(
cmp
%
B0
,
%
2
,
%
h0
),
xops
);
/* je label */
break
;
case
LE
:
xops
[
1
]
=
GEN_INT
(
0x45
);
xops
[
2
]
=
GEN_INT
(
0x40
);
output_asm_insn
(
AS2
(
and
%
B0
,
%
1
,
%
h0
),
xops
);
output_asm_insn
(
AS1
(
dec
%
B0
,
%
h0
),
xops
);
output_asm_insn
(
AS2
(
cmp
%
B0
,
%
2
,
%
h0
),
xops
);
/* jb label */
break
;
case
GE
:
xops
[
1
]
=
GEN_INT
(
0x05
);
output_asm_insn
(
AS2
(
and
%
B0
,
%
1
,
%
h0
),
xops
);
/* je label */
break
;
case
EQ
:
xops
[
1
]
=
GEN_INT
(
0x45
);
xops
[
2
]
=
GEN_INT
(
0x40
);
output_asm_insn
(
AS2
(
and
%
B0
,
%
1
,
%
h0
),
xops
);
output_asm_insn
(
AS2
(
cmp
%
B0
,
%
2
,
%
h0
),
xops
);
/* je label */
break
;
case
LE
:
xops
[
1
]
=
GEN_INT
(
0x45
);
xops
[
2
]
=
GEN_INT
(
0x40
);
output_asm_insn
(
AS2
(
and
%
B0
,
%
1
,
%
h0
),
xops
);
output_asm_insn
(
AS1
(
dec
%
B0
,
%
h0
),
xops
);
output_asm_insn
(
AS2
(
cmp
%
B0
,
%
2
,
%
h0
),
xops
);
/* jb label */
break
;
case
NE
:
xops
[
1
]
=
GEN_INT
(
0x44
);
xops
[
2
]
=
GEN_INT
(
0x40
);
output_asm_insn
(
AS2
(
and
%
B0
,
%
1
,
%
h0
),
xops
);
output_asm_insn
(
AS2
(
xor
%
B0
,
%
2
,
%
h0
),
xops
);
/* jn
e label */
break
;
case
EQ
:
xops
[
1
]
=
GEN_INT
(
0x45
);
xops
[
2
]
=
GEN_INT
(
0x40
);
output_asm_insn
(
AS2
(
and
%
B0
,
%
1
,
%
h0
),
xops
);
output_asm_insn
(
AS2
(
cmp
%
B0
,
%
2
,
%
h0
),
xops
);
/* j
e label */
break
;
case
GTU
:
case
LTU
:
case
GEU
:
case
LEU
:
default
:
abort
();
case
NE
:
xops
[
1
]
=
GEN_INT
(
0x44
);
xops
[
2
]
=
GEN_INT
(
0x40
);
output_asm_insn
(
AS2
(
and
%
B0
,
%
1
,
%
h0
),
xops
);
output_asm_insn
(
AS2
(
xor
%
B0
,
%
2
,
%
h0
),
xops
);
/* jne label */
break
;
case
GTU
:
case
LTU
:
case
GEU
:
case
LEU
:
default
:
abort
();
}
}
return
""
;
...
...
@@ -5493,12 +5539,11 @@ x86_adjust_cost (insn, link, dep_insn, cost)
&&
GET_CODE
(
next_inst
)
==
JUMP_INSN
)
/* compare probably paired with jump */
return
0
;
break
;
/* Stores stalls one cycle longer than other insns. */
if
(
is_fp_insn
(
insn
)
&&
cost
&&
is_fp_store
(
dep_insn
))
cost
++
;
break
;
case
PROCESSOR_K6
:
default
:
if
(
!
is_fp_dest
(
dep_insn
))
...
...
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