vect-reduc-pattern-2c.c

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

C
49
字号
/* { dg-require-effective-target vect_int } */#include <stdarg.h>#include "tree-vect.h"#define N 16signed char data_ch[N] =  { 0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28 };#define SUM 210__attribute__ ((noinline)) intfoo (){  int i;  signed short shortsum = 0;  /* widenning sum: sum chars into short.     The widening-summation pattern is currently not detected because of this     patch:     2005-12-26  Kazu Hirata  <kazu@codesourcery.com>                                                                                        PR tree-optimization/25125   */  for (i = 0; i < N; i++)    {      shortsum += data_ch[i];    }  /* check results:  */  if (shortsum != SUM)    abort ();  return 0;}intmain (void){  check_vect ();  return foo ();}/* { dg-final { scan-tree-dump-times "vect_recog_widen_sum_pattern: detected" 1 "vect" { xfail *-*-* } } } *//* { dg-final { scan-tree-dump-times "vectorized 1 loops" 1 "vect" { xfail *-*-* } } } *//* { dg-final { scan-tree-dump-times "vectorized 1 loops" 0 "vect" { target { ! vect_widen_sum_qi_to_hi } } } } *//* { dg-final { cleanup-tree-dump "vect" } } */

⌨️ 快捷键说明

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