From e68c380c8fd70d9c056b13175e0f380e50b31c07 Mon Sep 17 00:00:00 2001 From: Richard Henderson Date: Thu, 2 Mar 2000 22:20:53 -0800 Subject: [PATCH] * alpha.c (alpha_emit_set_const_1): Also try c + small constant. From-SVN: r32304 --- gcc/ChangeLog | 4 ++++ gcc/config/alpha/alpha.c | 8 ++++++++ 2 files changed, 12 insertions(+) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index d0eee382924..dc32f5e25d6 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,7 @@ +2000-03-02 Richard Henderson + + * alpha.c (alpha_emit_set_const_1): Also try c + small constant. + 2000-03-02 Mark Mitchell * tree.h (TYPE_ALIGN_UNIT): New macro. diff --git a/gcc/config/alpha/alpha.c b/gcc/config/alpha/alpha.c index 17a55a940e3..7b6eca3171d 100644 --- a/gcc/config/alpha/alpha.c +++ b/gcc/config/alpha/alpha.c @@ -1400,6 +1400,14 @@ alpha_emit_set_const_1 (target, mode, c, n) target, 0, OPTAB_WIDEN); } + /* Next, see if, minus some low bits, we've an easy load of high bits. */ + + new = ((c & 0xffff) ^ 0x8000) - 0x8000; + if (new != 0 + && (temp = alpha_emit_set_const (subtarget, mode, c - new, n - 1)) != 0) + return expand_binop (mode, add_optab, temp, GEN_INT (new), + target, 0, OPTAB_WIDEN); + return 0; } -- 2.30.2