projects
/
libfirm
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
|
inline
| side by side (parent:
3e49de2
)
Implement binary emitter for ia32 ffreep.
author
Christoph Mallon
<christoph.mallon@gmx.de>
Sun, 11 Nov 2012 21:45:14 +0000
(22:45 +0100)
committer
Christoph Mallon
<christoph.mallon@gmx.de>
Sun, 11 Nov 2012 22:19:06 +0000
(23:19 +0100)
ir/be/ia32/ia32_emitter.c
patch
|
blob
|
history
diff --git
a/ir/be/ia32/ia32_emitter.c
b/ir/be/ia32/ia32_emitter.c
index
385611b
..
0bc2936
100644
(file)
--- a/
ir/be/ia32/ia32_emitter.c
+++ b/
ir/be/ia32/ia32_emitter.c
@@
-3290,6
+3290,11
@@
static void bemit_fdivrp(const ir_node *node)
bemit_fbinopp(node, 0xF0);
}
bemit_fbinopp(node, 0xF0);
}
+static void bemit_ffreep(ir_node const *const node)
+{
+ bemit_fop_reg(node, 0xDF, 0xC0);
+}
+
static void bemit_fild(const ir_node *node)
{
switch (get_mode_size_bits(get_ia32_ls_mode(node))) {
static void bemit_fild(const ir_node *node)
{
switch (get_mode_size_bits(get_ia32_ls_mode(node))) {
@@
-3667,6
+3672,7
@@
static void ia32_register_binary_emitters(void)
register_emitter(op_ia32_fdivp, bemit_fdivp);
register_emitter(op_ia32_fdivr, bemit_fdivr);
register_emitter(op_ia32_fdivrp, bemit_fdivrp);
register_emitter(op_ia32_fdivp, bemit_fdivp);
register_emitter(op_ia32_fdivr, bemit_fdivr);
register_emitter(op_ia32_fdivrp, bemit_fdivrp);
+ register_emitter(op_ia32_ffreep, bemit_ffreep);
register_emitter(op_ia32_fild, bemit_fild);
register_emitter(op_ia32_fist, bemit_fist);
register_emitter(op_ia32_fistp, bemit_fistp);
register_emitter(op_ia32_fild, bemit_fild);
register_emitter(op_ia32_fist, bemit_fist);
register_emitter(op_ia32_fistp, bemit_fistp);