Mercurial > hg > CbC > CbC_gcc
view gcc/testsuite/gcc.dg/vshift-7.c @ 145:1830386684a0
gcc-9.2.0
author | anatofuz |
---|---|
date | Thu, 13 Feb 2020 11:34:05 +0900 |
parents | 04ced10e8804 |
children |
line wrap: on
line source
/* { dg-do compile } */ /* { dg-options "-O1 -Wshift-count-negative -Wshift-count-overflow" } */ typedef unsigned int v1qi_t __attribute__((mode(QI), vector_size(1))); typedef unsigned int v1hi_t __attribute__((mode(HI), vector_size(2))); typedef unsigned int v1si_t __attribute__((mode(SI), vector_size(4))); static const signed shift_neg = -1; static const unsigned shift_qi = 8; static const unsigned shift_hi = 16; static const unsigned shift_si = 32; v1qi_t test1qi(v1qi_t x, int c) { switch(c) { case 0: return x << shift_neg; /* { dg-warning "shift count is negative" } */ case 1: return x << (shift_qi - 1); case 2: return x << shift_qi; /* { dg-warning "shift count >= width" } */ case ~0: return x >> shift_neg; /* { dg-warning "shift count is negative" } */ case ~1: return x >> (shift_qi - 1); case ~2: return x >> shift_qi; /* { dg-warning "shift count >= width" } */ } return c < 0 ? x >> -c : x << c; } v1hi_t test1hi(v1hi_t x, int c) { switch(c) { case 0: return x << shift_neg; /* { dg-warning "shift count is negative" } */ case 1: return x << (shift_hi - 1); case 2: return x << shift_hi; /* { dg-warning "shift count >= width" } */ case ~0: return x >> shift_neg; /* { dg-warning "shift count is negative" } */ case ~1: return x >> (shift_hi - 1); case ~2: return x >> shift_hi; /* { dg-warning "shift count >= width" } */ } return c < 0 ? x >> -c : x << c; } v1si_t test1si(v1si_t x, int c) { switch(c) { case 0: return x << shift_neg; /* { dg-warning "shift count is negative" } */ case 1: return x << (shift_si - 1); case 2: return x << shift_si; /* { dg-warning "shift count >= width" } */ case ~0: return x >> shift_neg; /* { dg-warning "shift count is negative" } */ case ~1: return x >> (shift_si - 1); case ~2: return x >> shift_si; /* { dg-warning "shift count >= width" } */ } return c < 0 ? x >> -c : x << c; }