⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 loop-4.c

📁 linux下编程用 编译软件
💻 C
字号:
/* A test for strength reduction and induction variable elimination.  *//* { dg-do compile } *//* { dg-options "-O1 -fdump-tree-vars" } *//* Size of this structure should be sufficiently weird so that no memory   addressing mode applies.  */struct bla{  char x[187];  int y;  char z[253];} arr_base[100];int foo(void);void xxx(void){  int iter;  for (iter = 0; iter < 100; iter++)    arr_base[iter].y = foo ();}/* Access to arr_base[iter].y should be strength reduced.  Depending on   whether we have an addressing mode of type [base + offset], one of the   following forms might get chosen:   -- induction variable with base &arr_base[0].y, the memory access of      form *iv = ...   -- induction variable with base 0, the memory access of form      *(iv + &arr_base[0].y) = ...   In any case, we should not have any multiplication.  *//* { dg-final { scan-tree-dump-times " \\* \[^\\n\\r\]*=" 0 "vars" } } *//* { dg-final { scan-tree-dump-times "\[^\\n\\r\]*= \\* " 0 "vars" } } *//* { dg-final { scan-tree-dump-times "MEM" 1 "vars" } } *//* And the original induction variable should be eliminated.  *//* { dg-final { scan-tree-dump-times "iter" 0 "vars" } } *//* { dg-final { cleanup-tree-dump "vars" } } */

⌨️ 快捷键说明

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