Commit 5e1a2fc7 by Jakub Jelinek Committed by Jakub Jelinek

i386.md (andsi_1+1): Allow HImode.

	* config/i386/i386.md (andsi_1+1): Allow HImode.
	(andsi_1+2): Require q_regs_operand.
	* gcc.dg/20000720-1.c: New test.

From-SVN: r35249
parent 9e81685a
2000-07-25 Jakub Jelinek <jakub@redhat.com>
* config/i386/i386.md (andsi_1+1): Allow HImode.
(andsi_1+2): Require q_regs_operand.
2000-07-25 Jakub Jelinek <jakub@redhat.com>
* config/i386/i386.md (call_pop): Check operands[0],
not operands[1]. Only check SYMBOL_REF_FLAG for a SYMBOL_REF.
(call): Likewise.
......
......@@ -5000,8 +5000,8 @@
"operands[1] = gen_lowpart (HImode, operands[0]);")
(define_split
[(set (match_operand:SI 0 "q_regs_operand" "")
(and:SI (match_dup 0)
[(set (match_operand 0 "q_regs_operand" "")
(and (match_dup 0)
(const_int -256)))
(clobber (reg:CC 17))]
"(optimize_size || !TARGET_PARTIAL_REG_STALL)
......@@ -5010,7 +5010,7 @@
"operands[1] = gen_lowpart (QImode, operands[0]);")
(define_split
[(set (match_operand 0 "register_operand" "")
[(set (match_operand 0 "q_regs_operand" "")
(and (match_dup 0)
(const_int -65281)))
(clobber (reg:CC 17))]
......
2000-07-25 Jakub Jelinek <jakub@redhat.com>
* gcc.dg/20000720-1.c: New test.
2000-07-25 Toon Moene <toon@moene.indiv.nluug.nl>
* g77.f-torture/compile/20000630-2.x: Removed. Case fixed.
......
/* { dg-do compile { target i?86-*-* } } */
/* { dg-options "-mpreferred-stack-boundary=2 -march=i586 -O2 -fomit-frame-pointer" } */
extern void *foo(void *a, const void *b, unsigned c);
extern inline void *
bar(void *a, const void *b, unsigned c)
{
int d0, d1, d2;
__asm__ __volatile__(
"" :
"=&c" (d0), "=&D" (d1), "=&S" (d2) :
"0" (c/4), "q" (c), "1" (a), "2" (b) :
"memory");
return a;
}
typedef struct {
unsigned char a;
unsigned b : 2;
unsigned c : 4;
unsigned d : 2;
} *baz;
static int
dead(unsigned short *v, char *w, unsigned char *x, int y, int z)
{
int i = 0;
unsigned short j = *v;
while (y > 0) {
((baz)x)->a = j;
((baz)x)->b = 0;
((baz)x)->c = 0;
((baz)x)->d = 0;
__builtin_constant_p(i) ? foo(x, w, i) : bar(x, w, i);
}
return z - y;
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment