Subject: re: EGCS on mips stable?
To: Jonathan Stone <jonathan@DSG.Stanford.EDU>
From: Castor Fu <castor@geocast.net>
List: port-mips
Date: 10/25/1998 23:34:37
On Sun, 25 Oct 1998, Jonathan Stone wrote:
> It looks like I get the same problem with gcc-2.7.2.2+myc1...

I'm confused.  You're not seeing same problem if you're getting
assembly output.  I die with internal compiler errors like the following:

GNU C version egcs-2.91.57 19980901 (egcs-1.1 release) (mips-geocast-elfbsd) compiled by GNU C version egcs-2.90.27 980315 (egcs-1.0.2 release).
	bug.c: In function `f':
	bug.c:10: internal error--unrecognizable insn:
	(insn 14 12 16 (set (reg:SI 81)
		(plus:SI (reg:SI 80)
		    (const_int 32800))) -1 (nil)
	    (nil))
	/geo/src/netbsd-1.3/src/usr/src/gnu/dist/gcc/toplev.c:1360: Internal compiler error in function fatal_insn

> > >	struct biggy {
> > >		char	buf[32800];	/* len further than 16 bit offset */
> > >		char    len  [10 ];
> > >	};
> > >
> > >	static
> > >	void f ( struct biggy * s, int v)
> > >	{
> > >		 s->len[v] = 13 ;
> > >	}

> so our intree egcs and gcc2.7.2.2. generate the same code: one outputs
> 13 in decimal and the other in hex. The problem is the immediate
> offset 32800 that doesnt fit in 16 bits.  Is that what you get?  is
> the assembler supposed to synthesize the instruction with the too-big
> offset, or what?  binutils 2.8.1 certainly doesnt seem to do so:

My binutils 2.8.1 cross environment has no problems synthesizing the
instruction sequence.  The sequence looks something like

	lui	$at, 0x1		# $at = <- 65536
	addu	$at, $at, v0
	sb	$v1, -32736($at)	# $v0[65536 - 32736] = $v1

So, while there's a negative offset, it's clearly the right thing to do.

> Compiling with -dp shows that the pattern used is mips.md:
> movqi_internal2/6, which is indeed dst class 'm'.
> 
> So I think the problem (if there is one) is that the C code in
> mips_move_1word is supposed to do the load via loading the offset into
> $at and adding, but it isnt handling this case properly.  (or is the
> assembler supposed to fake this up? that would rather make a mockery
> of the insn-size tradeoffs in egcs...)

As I said earlier, since you're getting assembly code, it looks like
there's some difference between the cross compilation and native
environments.  Darn.

	-castor