version 1.2, 2019/08/29 12:46:29
|
version 1.5, 2019/08/29 20:40:51
|
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. |
|