projects
/
libfirm
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Let the length of tarval be of type size_t.
[libfirm]
/
ir
/
be
/
bearch.c
diff --git
a/ir/be/bearch.c
b/ir/be/bearch.c
index
ec4aee0
..
06819e7
100644
(file)
--- a/
ir/be/bearch.c
+++ b/
ir/be/bearch.c
@@
-72,16
+72,16
@@
static inline const arch_irn_ops_t *get_irn_ops(const ir_node *irn)
const arch_register_req_t *arch_get_register_req(const ir_node *irn, int pos)
{
if (is_Proj(irn)) {
const arch_register_req_t *arch_get_register_req(const ir_node *irn, int pos)
{
if (is_Proj(irn)) {
+ ir_node *pred = get_Proj_pred(irn);
+ long pn = get_Proj_proj(irn);
assert(pos == -1);
assert(pos == -1);
- pos = -1-get_Proj_proj(irn);
- irn = get_Proj_pred(irn);
+ return arch_get_out_register_req(pred, pn);
}
if (pos < 0) {
return arch_get_out_register_req(irn, -pos-1);
} else {
}
if (pos < 0) {
return arch_get_out_register_req(irn, -pos-1);
} else {
- const arch_irn_ops_t *ops = get_irn_ops_simple(irn);
- return ops->get_irn_reg_req_in(irn, pos);
+ return arch_get_in_register_req(irn, pos);
}
}
}
}
@@
-97,12
+97,6
@@
ir_entity *arch_get_frame_entity(const ir_node *irn)
return ops->get_frame_entity(irn);
}
return ops->get_frame_entity(irn);
}
-void arch_set_frame_entity(ir_node *irn, ir_entity *ent)
-{
- const arch_irn_ops_t *ops = get_irn_ops(irn);
- ops->set_frame_entity(irn, ent);
-}
-
int arch_get_sp_bias(ir_node *irn)
{
const arch_irn_ops_t *ops = get_irn_ops(irn);
int arch_get_sp_bias(ir_node *irn)
{
const arch_irn_ops_t *ops = get_irn_ops(irn);
@@
-153,16
+147,6
@@
int arch_get_op_estimated_cost(const ir_node *irn)
}
}
}
}
-void arch_put_non_ignore_regs(const arch_register_class_t *cls, bitset_t *bs)
-{
- unsigned i;
-
- for (i = 0; i < cls->n_regs; ++i) {
- if (!arch_register_type_is(&cls->regs[i], ignore))
- bitset_set(bs, i);
- }
-}
-
int arch_reg_is_allocatable(const ir_node *irn, int pos,
const arch_register_t *reg)
{
int arch_reg_is_allocatable(const ir_node *irn, int pos,
const arch_register_t *reg)
{
@@
-310,6
+294,12
@@
void arch_dump_register_req(FILE *F, const arch_register_req_t *req,
}
}
}
}
+ if (req->width != 1) {
+ fprintf(F, " width:%u", req->width);
+ }
+ if (arch_register_req_is(req, aligned)) {
+ fprintf(F, " aligned");
+ }
if (arch_register_req_is(req, ignore)) {
fprintf(F, " ignore");
}
if (arch_register_req_is(req, ignore)) {
fprintf(F, " ignore");
}
@@
-367,6
+357,7
@@
static const arch_register_req_t no_requirement = {
NULL,
NULL,
0,
NULL,
NULL,
0,
+ 0,
0
};
const arch_register_req_t *arch_no_register_req = &no_requirement;
0
};
const arch_register_req_t *arch_no_register_req = &no_requirement;