-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1

On Mon, Feb 28, 2005 at 10:13:00AM +0100, Josef Angermeier wrote:
> Rehi
> > It's been done a couple of times already, first by me, and later my
> > code was extended by a couple of other people.  Don't know if you
> > want to start from scratch "on principle" though, otherwise search
> > the mail archives.
> 
> Just forget about the thesis. Tell me where to get that patch/code !

LOL.  I guess I'm one of those "other people", but alas, I've been
having difficulty since the whole tree-SSA move.

/mnt/disk2/src/gcc-i86/gcc/xgcc -B/mnt/disk2/src/gcc-i86/gcc/ 
-B/usr/cross/i86-none/bin/ -B/usr/cross/i86-none/lib/ -isystem 
/usr/cross/i86-none/include -isystem /usr/cross/i86-none/sys-include -O2  
-DIN_GCC -DCROSS_COMPILE   -W -Wall -Wwrite-strings -Wstrict-prototypes 
-Wmissing-prototypes -Wold-style-definition  -isystem ./include   -g 
-DHAVE_GTHR_DEFAULT -DIN_LIBGCC2 -D__GCC_FLOAT_NOT_NEEDED -Dinhibit_libc -I. 
-I. -I/mnt/disk2/src/gcc/gcc -I/mnt/disk2/src/gcc/gcc/. 
-I/mnt/disk2/src/gcc/gcc/../include -I/mnt/disk2/src/gcc/gcc/../libcpp/include  
-DL_ashrdi3 -c /mnt/disk2/src/gcc/gcc/libgcc2.c -o libgcc/./_ashrdi3.o
cc1: warning: target system does not support debug output
/mnt/disk2/src/gcc/gcc/libgcc2.c: In function '__ashrdi3':
/mnt/disk2/src/gcc/gcc/libgcc2.c:485: error: unable to find a register to spill 
in class 'BASE_REGS'
/mnt/disk2/src/gcc/gcc/libgcc2.c:485: error: this is the insn:
(insn 28 26 29 1 /mnt/disk2/src/gcc/gcc/libgcc2.c:464 (set (mem/i:HI (reg/f:HI 
8 si [orig:30 D.1371 ] [30]) [5 <result>+0 S2 A16])
        (subreg:HI (reg/v:DI 31 [ u ]) 0)) 1 {*movhi} (nil)
    (nil))
/mnt/disk2/src/gcc/gcc/libgcc2.c:485: internal compiler error: in 
spill_failure, at reload1.c:1872
Please submit a full bug report,
with preprocessed source if appropriate.

(Sorry, don't want to show too much code before paperwork is in order,
which may or may not take a while.  Any hints?  Or should I just go and
implement all the problem libgcc2 patterns in assembly?)

BTW DJ, I've changed the register model to treat al, ah, etc. as
first-class registers, with ax, dx:ax as simply groupings a la
HARD_REGNO_NREGS.

#define REG_CLASS_CONTENTS \
{ 0,            /* NO_REGS */                   \
  3, 0xc,       /* AXREGS, DXREGS */            \
  0x30, 0xc0,   /* CXREGS, BXREGS */            \
  0x400,        /* BPREGS */                    \
  0x100, 0x200, /* SIREGS, DIREGS */            \
  0xff,         /* Q_REGS */                    \
  0x300,        /* INDEX_REGS */                \
  0x440,        /* BASE_REGS */                 \
  0xfff,        /* GENERAL_REGS */              \
  0x01000,      /* FP_TOP_REGS */               \
  0x02000,      /* FP_SECOND_REGS */            \
  0xff000,      /* FLOAT_REGS */                \
  0x01fffff     /* ALL_REGS */ }

#define FIXED_REGISTERS \
  {   0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, \
  /* al,ah,dl,dh,cl,ch,bl,bh,si,di,bp,sp */ \
       0,  0,  0,  0,  0,  0,  0,  0,  1, 1 } \
  /* st0,st1,st2,st3,st4,st5,st6,st7,arg,flags */

#define CALL_USED_REGISTERS \
  {   1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 1, \
  /* al,ah,dl,dh,cl,ch,bl,bh,si,di,bp,sp */ \
       1,  1,  1,  1,  1,  1,  1,  1,  1, 1 } \
  /* st0,st1,st2,st3,st4,st5,st6,st7,arg,flags */

Not sure what else is pertinent without pasting it all.

- -- 
A: Because it messes up the order in which people normally read text.
Q: Why is top-posting such a bad thing?
A: Top-posting.
Q: What is the most annoying thing on usenet?
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.0.4 (GNU/Linux)
Comment: For info see http://www.gnupg.org

iD8DBQFCI19m/FmLrNfLpjMRAnB4AKCYpPrMnOJJKbn15WELjARGQiq+ogCfR65H
dc78Ra98g/HVJrJ9hwsy1a8=
=uVoT
-----END PGP SIGNATURE-----

Reply via email to