Diff for /wikisrc/users/maya/vax-gcc.mdwn between versions 1.2 and 1.4

version 1.2, 2019/08/29 12:46:29 version 1.4, 2019/08/29 20:39:43
Line 1 Line 1
 # Various GCC/vax issues and invesigation #  # Various GCC/vax issues and invesigation #
   
 # libgomp crash with -O2 #  ## libgomp crash with -O2 ##
 Repro:  Repro:
   
     #!/bin/sh      #!/bin/sh
Line 18  Repro: Line 18  Repro:
   
 Asserts at emit-rtl.c:2310 gcc_assert (memory_address_addr_space_p (mode, addr, as));  Asserts at emit-rtl.c:2310 gcc_assert (memory_address_addr_space_p (mode, addr, as));
   
 NetBSD avoids it with a local diff to reload.c/dse.c.  NetBSD avoids it with a [local diff](5f534f20bc66738c05c442a8f20088f55335b653/external/gpl3/gcc/dist/libgcc/gthr-posix.h#L418) to reload.c/dse.c.  
   It looks like a real bug in vax_legitimate_address_p not handling some addressing modes.  
   The code to handle offset(reg)[index] might be off: it doesn't like if neither xfoo0, xfoo1 are constant.
   
 It looks like a real bug in vax_legitimate_address_p not handling some addressing modes.  ## unrecognizable insn with any optimization ##
   
   Repro:
   
   #!/bin/sh
   
       cat << EOF > decl.ii
       struct a {
         long long *b() const;
       };
       template <typename> class d : a {
       public:
         template <typename e> d(e);
         long long f() const;
       };
       template <typename c> long long d<c>::f() const {
         int g;
         return b()[g];
       }
       int h;
       bool i() {
         d<int> j(h);
         return j.f();
       }
       EOF
       vax--netbsdelf-g++ -O2 -c decl.ii
   
 The code to handle offset(reg)[index] might be off: it doesn't like if neither xfoo0, xfoo1 are constant.  

Removed from v.1.2  
changed lines
  Added in v.1.4


CVSweb for NetBSD wikisrc <wikimaster@NetBSD.org> software: FreeBSD-CVSweb