Update copyright to LGPL on all files
[dyninst.git] / testsuite / src / dyninst / test1_17_mutatee.c
1 /*
2  * Copyright (c) 1996-2009 Barton P. Miller
3  * 
4  * We provide the Paradyn Parallel Performance Tools (below
5  * described as "Paradyn") on an AS IS basis, and do not warrant its
6  * validity or performance.  We reserve the right to update, modify,
7  * or discontinue this software at any time.  We shall have no
8  * obligation to supply such updates or modifications or any other
9  * form of support to you.
10  * 
11  * By your use of Paradyn, you understand and agree that we (or any
12  * other person or entity with proprietary rights in Paradyn) are
13  * under no obligation to provide either maintenance services,
14  * update services, notices of latent defects, or correction of
15  * defects for Paradyn.
16  * 
17  * This library is free software; you can redistribute it and/or
18  * modify it under the terms of the GNU Lesser General Public
19  * License as published by the Free Software Foundation; either
20  * version 2.1 of the License, or (at your option) any later version.
21  * 
22  * This library is distributed in the hope that it will be useful,
23  * but WITHOUT ANY WARRANTY; without even the implied warranty of
24  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
25  * Lesser General Public License for more details.
26  * 
27  * You should have received a copy of the GNU Lesser General Public
28  * License along with this library; if not, write to the Free Software
29  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
30  */
31 #include <assert.h>
32
33 #include "mutatee_util.h"
34
35 /* Externally accessed function prototypes.  These must have globally unique
36  * names.  I suggest following the pattern <testname>_<function>
37  */
38
39 int test1_17_func1();
40 int test1_17_func2();
41 int test1_17_call1(int p1);
42 int test1_17_call2(int p1);
43
44 /* Global variables accessed by the mutator.  These must have globally unique
45  * names.
46  */
47
48 /* Internally used function prototypes.  These should be declared with the
49  * keyword static so they don't interfere with other mutatees in the group.
50  */
51
52 static void func17_3();
53 static int func17_4();
54
55 /* Global variables used internally by the mutatee.  These should be declared
56  * with the keyword static so they don't interfere with other mutatees in the
57  * group.
58  */
59
60 static int globalVariable17_1 = 0;
61 static int globalVariable17_2 = 0;
62
63 #define RAN17_1 1701000
64
65 #define RET17_1 1700100
66 #define RET17_2 1700200
67
68 /* Function definitions follow */
69
70 /*
71  * Test #17 - return values from func calls
72  *      See test1.C for a detailed comment
73  */
74 int test1_17_func1() {
75     int retval;
76     int ret17_1;
77
78     /* kludge = 1; /* Here so that the following function call isn't the first
79                       instruction */
80
81     ret17_1 = test1_17_func2();
82     func17_3();
83
84     if ((ret17_1 != RET17_1) ||
85         (globalVariable17_1 != RET17_2) ||
86         (globalVariable17_2 != RAN17_1)) {
87         logerror("**Failed** test case #17 (return values from func calls)\n");
88         if (ret17_1 != RET17_1) {
89             logerror("  return value was %d, not %d\n", ret17_1, RET17_1);
90         }
91         if (globalVariable17_1 != RET17_2) {
92             logerror("  return value was %d, not %d\n",
93                 globalVariable17_1, RET17_2);
94         }
95         if (globalVariable17_2 != RAN17_1) {
96             logerror("  function test1_17_call2 was not inserted\n");
97         }
98         retval = -1; /* Test failed */
99     } else {
100         logerror("Passed test #17 (return values from func calls)\n");
101         retval = 0; /* Test passed */
102     }
103     return retval;
104 }
105
106 int test1_17_func2() {
107     return RET17_1;
108 }
109
110 void func17_3() {
111     globalVariable17_1 = func17_4();
112     return;
113 }
114
115 int func17_4() {
116     return RET17_2;
117 }
118
119 int test1_17_call1(int p1) {
120      /* make sure the function uses lots of registers */
121
122      int a1, a2, a3, a4, a5, a6, a7;
123
124      dprintf("test1_17_call1 (p1=%d)\n", p1);
125      assert(p1!=0); /* shouldn't try to divide by zero! */
126      assert(p1==1); /* actually only expect calls with p1==1 */
127
128      a1 = p1;
129      a2 = a1 + p1;
130      a3 = a1 * a2;
131      a4 = a3 / p1;
132      a5 = a4 + p1;
133      a6 = a5 + a1;
134      a7 = a6 + p1;
135
136      dprintf("test1_17_call1 (ret=%d)\n", a7);
137
138      return a7;
139 }
140
141 int test1_17_call2(int p1) {
142      /* make sure the function uses lots of registers */
143
144      int a1, a2, a3, a4, a5, a6, a7;
145
146      dprintf("test1_17_call2 (p1=%d)\n", p1);
147      assert(p1!=0); /* shouldn't try to divide by zero! */
148      assert(p1==1); /* actually only expect calls with p1==1 */
149
150      a1 = p1;
151      a2 = a1 + p1;
152      a3 = a1 * a2;
153      a4 = a3 / p1;
154      a5 = a4 + p1;
155      a6 = a5 + a1;
156      a7 = a6 + p1;
157      globalVariable17_2 = RAN17_1;
158
159      dprintf("test1_17_call2 (ret=%d)\n", a7);
160
161      return a7;
162 }
163
164 int test1_17_mutatee() {
165   if (test1_17_func1() == 0) {
166     test_passes(testname);
167     return 0;
168   } else {
169     return -1;
170   }
171 }