From c996ec162f5e73d316884ab4d8feb35ac2e48896 Mon Sep 17 00:00:00 2001 From: Matthias Braun Date: Wed, 30 Apr 2008 12:16:02 +0000 Subject: [PATCH] correct fix for benode comparison [r19469] --- ir/be/benode.c | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/ir/be/benode.c b/ir/be/benode.c index bdd3349b9..7c55b6a64 100644 --- a/ir/be/benode.c +++ b/ir/be/benode.c @@ -152,6 +152,15 @@ static const ir_op_ops be_node_op_ops; #define K irop_flag_keep #define M irop_flag_uses_memory +static int be_reqs_equal(const be_req_t *req1, const be_req_t *req2) +{ + if(!reg_reqs_equal(&req1->req, &req2->req)) + return 0; + if(req1->flags != req2->flags) + return 0; + + return 1; +} /** * Compare two be node attributes. @@ -167,8 +176,8 @@ static int _node_cmp_attr(const be_node_attr_t *a, const be_node_attr_t *b) { len = ARR_LEN(a->reg_data); for (i = 0; i < len; ++i) { if (a->reg_data[i].reg != b->reg_data[i].reg || - !reg_reqs_equal(&a->reg_data[i].in_req, &b->reg_data[i].in_req) || - !reg_reqs_equal(&a->reg_data[i].req, &b->reg_data[i].req)) + !be_reqs_equal(&a->reg_data[i].in_req, &b->reg_data[i].in_req) || + !be_reqs_equal(&a->reg_data[i].req, &b->reg_data[i].req)) return 1; } -- 2.20.1