]> git.ipfire.org Git - thirdparty/gcc.git/commit
backport: re PR target/87532 (bad results from vec_extract(unsigned char, foo) depend...
authorKelvin Nilsen <kelvin@gcc.gnu.org>
Mon, 22 Apr 2019 16:09:13 +0000 (16:09 +0000)
committerKelvin Nilsen <kelvin@gcc.gnu.org>
Mon, 22 Apr 2019 16:09:13 +0000 (16:09 +0000)
commit23011067badd32bb09d7c3f62d7d1f9ab5d764e3
tree9c2a4bc9d863f72eadfd32940085a4b049861159
parent0e38199ed2fd1854ed3822dbdb134c50a263f0da
backport: re PR target/87532 (bad results from vec_extract(unsigned char, foo) dependent upon function inline)

gcc/ChangeLog:

2019-04-22  Kelvin Nilsen  <kelvin@gcc.gnu.org>

Backport from mainline
2019-03-15  Kelvin Nilsen  <kelvin@gcc.gnu.org>

PR target/87532
* config/rs6000/rs6000-c.c (altivec_resolve_overloaded_builtin):
When handling vec_extract, use modular arithmetic to allow
constant selectors greater than vector length.
* config/rs6000/rs6000.c (rs6000_expand_vector_extract): Allow
V1TImode vectors to have constant selector values greater than 0.
Use modular arithmetic to compute vector index.
(rs6000_split_vec_extract_var): Use modular arithmetic to compute
index for in-memory vectors.  Correct code generation for
in-register vectors.  Use inner mode of vector rather than mode of
destination for move instruction.
(altivec_expand_vec_ext_builtin): Use modular arithmetic to
compute index.

2019-04-12  Kelvin Nilsen  <kelvin@gcc.gnu.org>

PR target/87532
* config/rs6000/vsx.md (*vsx_extract_<mode>_<VS_scalar>mode_var):
Use QI inner mode with V16QI vector mode.

gcc/testsuite/ChangeLog:

2019-04-22  Kelvin Nilsen  <kelvin@gcc.gnu.org>

Backport from mainline
2019-03-15  Kelvin Nilsen  <kelvin@gcc.gnu.org>

PR target/87532
* gcc.target/powerpc/pr87532-mc.c: New test.
* gcc.target/powerpc/pr87532.c: New test.
* gcc.target/powerpc/vec-extract-v16qiu-v2.h: New test.
* gcc.target/powerpc/vec-extract-v16qiu-v2a.c: New test.
* gcc.target/powerpc/vec-extract-v16qiu-v2b.c: New test.
* gcc.target/powerpc/vsx-builtin-10a.c: New test.
* gcc.target/powerpc/vsx-builtin-10b.c: New test.
* gcc.target/powerpc/vsx-builtin-11a.c: New test.
* gcc.target/powerpc/vsx-builtin-11b.c: New test.
* gcc.target/powerpc/vsx-builtin-12a.c: New test.
* gcc.target/powerpc/vsx-builtin-12b.c: New test.
* gcc.target/powerpc/vsx-builtin-13a.c: New test.
* gcc.target/powerpc/vsx-builtin-13b.c: New test.
* gcc.target/powerpc/vsx-builtin-14a.c: New test.
* gcc.target/powerpc/vsx-builtin-14b.c: New test.
* gcc.target/powerpc/vsx-builtin-15a.c: New test.
* gcc.target/powerpc/vsx-builtin-15b.c: New test.
* gcc.target/powerpc/vsx-builtin-16a.c: New test.
* gcc.target/powerpc/vsx-builtin-16b.c: New test.
* gcc.target/powerpc/vsx-builtin-17a.c: New test.
* gcc.target/powerpc/vsx-builtin-17b.c: New test.
* gcc.target/powerpc/vsx-builtin-18a.c: New test.
* gcc.target/powerpc/vsx-builtin-18b.c: New test.
* gcc.target/powerpc/vsx-builtin-19a.c: New test.
* gcc.target/powerpc/vsx-builtin-19b.c: New test.
* gcc.target/powerpc/vsx-builtin-20a.c: New test.
* gcc.target/powerpc/vsx-builtin-20b.c: New test.
* gcc.target/powerpc/vsx-builtin-9a.c: New test.
* gcc.target/powerpc/vsx-builtin-9b.c: New test.

2019-03-19  Kelvin Nilsen  <kelvin@gcc.gnu.org>

PR target/89736
* gcc.target/powerpc/pr87532-mc.c: Modify dejagnu directives to
restrict this test to vsx targets.

From-SVN: r270493
34 files changed:
gcc/ChangeLog
gcc/config/rs6000/rs6000-c.c
gcc/config/rs6000/rs6000.c
gcc/config/rs6000/vsx.md
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/powerpc/pr87532-mc.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/pr87532.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vec-extract-v16qiu-v2.h [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vec-extract-v16qiu-v2a.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vec-extract-v16qiu-v2b.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-10a.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-10b.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-11a.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-11b.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-12a.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-12b.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-13a.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-13b.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-14a.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-14b.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-15a.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-15b.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-16a.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-16b.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-17a.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-17b.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-18a.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-18b.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-19a.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-19b.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-20a.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-20b.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-9a.c [new file with mode: 0644]
gcc/testsuite/gcc.target/powerpc/vsx-builtin-9b.c [new file with mode: 0644]