]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
[gdb/testsuite] Make inline-locals.c deterministic
authorTom de Vries <tdevries@suse.de>
Tue, 21 Jul 2020 08:25:42 +0000 (10:25 +0200)
committerTom de Vries <tdevries@suse.de>
Tue, 21 Jul 2020 08:25:42 +0000 (10:25 +0200)
When running testcase gdb.opt/inline-locals.exp on openSUSE Tumbleweed, I get:
...
(gdb) info locals^M
array = {0 <repeats 48 times>, 15775231, 0, 194, 0, -11497, 32767, 4199061, \
  0, 0, 0, 0, 0, 4198992, 0, 4198432, 0}^M
(gdb) FAIL: gdb.opt/inline-locals.exp: info locals above bar 2
...

Fix this by:
- completely initializing array before printing any value
- updating the pattern to match "array = {0 <repeats 64 times>}"

Tested on x86_64-linux.

gdb/testsuite/ChangeLog:

2020-07-21  Tom de Vries  <tdevries@suse.de>

* gdb.opt/inline-locals.c (init_array): New func.
(func1): Use init_array.
* gdb.opt/inline-locals.exp: Update pattern.

gdb/testsuite/ChangeLog
gdb/testsuite/gdb.opt/inline-locals.c
gdb/testsuite/gdb.opt/inline-locals.exp

index a68c272188c2b2d42afc4e4afe0c22e7b2358c64..f395665b13238920ccc6d8eb724b8a741a81234e 100644 (file)
@@ -1,3 +1,9 @@
+2020-07-21  Tom de Vries  <tdevries@suse.de>
+
+       * gdb.opt/inline-locals.c (init_array): New func.
+       (func1): Use init_array.
+       * gdb.opt/inline-locals.exp: Update pattern.
+
 2020-07-21  Tom de Vries  <tdevries@suse.de>
 
        * gdb.debuginfod/fetch_src_and_symbols.exp: Use save_vars for env
index 8fb91946fa1d7fe005f8591edec6e6a2a60de880..143a09ebc18a65ef0f93a3f04288b06070477acd 100644 (file)
@@ -29,9 +29,18 @@ volatile int *array_p;
 
 void bar(void);
 
+void
+init_array (int *array, int n)
+{
+  int i;
+  for (i = 0; i < n; ++i)
+    array[i] = 0;
+}
+
 inline ATTR int func1(int arg1)
 {
   int array[64];
+  init_array (array, 64);
   array_p = array;
   array[0] = result;
   array[1] = arg1;
index 8104b0f5b732e3d9fbc7dc8a21233d060c484fe0..841f1772096e7a5f243b250c10c747fa23201440 100644 (file)
@@ -43,7 +43,7 @@ if { ! $no_frames } {
        "backtrace from bar 2"
     gdb_test "up" "#1  .*func1 .* at .*" "up from bar 2"
     gdb_test "info frame" ".*inlined into frame.*" "func1 inlined 2"
-    set pass_re "array = {$decimal, \[^\r\n\]*}"
+    set pass_re "array = \\{0 <repeats 64 times>\\}"
     set kfail_re [multi_line $pass_re \
                      "array = {<optimized out> <repeats 64 times>}"]
     gdb_test_multiple "info locals" "info locals above bar 2" {