RISC-V: Fix for combine bug with shift and AND operations.
[official-gcc.git] / gcc / testsuite / gcc.target / riscv / shift-and-2.c
blob2c98e50101bcb7bd7285b8eab88bc106ad0dbaf8
1 /* { dg-do compile { target { riscv64*-*-* } } } */
2 /* { dg-options "-march=rv64gc -mabi=lp64 -O" } */
4 /* Test for <optab>si3_mask_1. */
5 extern int k;
6 void
7 sub2 (int i, long j)
9 k = i << (j & 0x1f);
12 /* Test for <optab>si3_extend_mask. */
13 unsigned long
14 sub3 (int mask)
16 return 1 << (mask & 0xff);
19 /* Test for <optab>si3_extend_mask_1. */
20 int
21 sub4 (int i, int j)
23 return i << (j & 0x1f);
26 /* Test for <optab>di3_mask. */
27 long
28 sub5 (long i, int j)
30 char k = j & 0x3f;
31 return i << k;
34 /* Test for <optab>di3_mask_1. */
35 long
36 sub6 (long i, long j)
38 return i << (j & 0x3f);
40 /* { dg-final { scan-assembler-not "andi" } } */
41 /* { dg-final { scan-assembler-not "sext.w" } } */