vect-strided-store-u32-i2.c

来自「用于进行gcc测试」· C语言 代码 · 共 46 行

C
46
字号
/* { dg-require-effective-target vect_int } */#include <stdarg.h>#include <stdio.h>#include "tree-vect.h"#define N 16__attribute__ ((noinline)) intmain1 (void){  int i;  int a[N*2];  int b[N] = {0,2,4,6,8,10,12,14,16,18,20,22,24,26,28,30};  int c[N] = {1,3,5,7,9,11,13,15,17,19,21,23,25,27,29,31};  /* Strided access pattern.  */  for (i = 0; i < N/2; i++)    {      a[i*2] = b[i] + c[i];      a[i*2+1] = b[i] * c[i];    }  /* Check results.  */  for (i = 0; i < N/2; i++)    {      if (a[i*2] != b[i] + c[i]          || a[i*2+1] != b[i] * c[i])        abort();    }  return 0;}int main (void){  check_vect ();  return main1 ();}/* Needs interleaving support.  *//* { dg-final { scan-tree-dump-times "vectorized 1 loops" 1 "vect" { target { vect_interleave } } } } *//* { dg-final { scan-tree-dump-times "vectorized 0 loops" 1 "vect" { xfail { vect_interleave } } } } *//* { dg-final { cleanup-tree-dump "vect" } } */

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?