Update copyright to LGPL on all files
[dyninst.git] / testsuite / src / dyninst / test1_6F_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
32 /* Test application (Mutatee) */
33
34 /* $Id: test1_6F_mutatee.c,v 1.1 2008/10/30 19:19:51 legendre Exp $ */
35
36 #include <stdlib.h>
37 #include "mutatee_util.h"
38
39 // **********************************************************************
40 // The following structure (struct block_) is made to correspond with the
41 // Fortran common block (globals) defined in test1_common.h.  Be sure all
42 // changes to this structure are reflected in the other.
43 // **********************************************************************
44 struct block_ {
45   int test1_6_globalVariable1_, test1_6_globalVariable2_, test1_6_globalVariable3_, test1_6_globalVariable4_, test1_6_globalVariable5_,
46     test1_6_globalVariable6_, test1_6_globalVariable1a_, test1_6_globalVariable2a_, test1_6_globalVariable3a_, test1_6_globalVariable4a_,
47     test1_6_globalVariable5a_, test1_6_globalVariable6a_;
48
49   int test1_6_constVar0_, test1_6_constVar1_, test1_6_constVar2_, test1_6_constVar3_, test1_6_constVar4_, test1_6_constVar5_, test1_6_constVar6_, test1_6_constVar7_,
50     test1_6_constVar9_, test1_6_constVar10_, test1_6_constVar60_, test1_6_constVar64_, test1_6_constVar66_, test1_6_constVar67_;
51   int passedTest_;
52 };
53
54 #if !defined(XLF)
55 #define test1_6_func1 test1_6_func1_
56 #define test1_6f_init_globals test1_6f_init_globals_
57 #define test1_6f_globals test1_6f_globals_
58 #endif
59
60 extern struct block_ test1_6f_globals;
61
62 extern void test1_6f_init_globals ();
63 extern void test1_6_func1 ();
64
65 int mutateeFortran = 1;
66
67 #ifdef F77
68 int mutateeF77 = 1;
69 #else
70 int mutateeF77 = 0;
71 #endif
72
73 int test1_6F_mutatee() {
74     int i, j;
75
76     int *pp1, *pp2, *pp3, *pp4, *pp5, *pp6, *pp7, *pp8, *pp9, *pp10;
77
78     test1_6f_globals.passedTest_ = FALSE;
79
80     pp1 = (int*) malloc (sizeof (int));
81     pp2 = (int*) malloc (sizeof (int));
82     pp3 = (int*) malloc (sizeof (int));
83     pp4 = (int*) malloc (sizeof (int));
84     pp5 = (int*) malloc (sizeof (int));
85     pp6 = (int*) malloc (sizeof (int));
86     pp7 = (int*) malloc (sizeof (int));
87     pp8 = (int*) malloc (sizeof (int));
88     pp9 = (int*) malloc (sizeof (int));
89     pp10 = (int*) malloc (sizeof (int));
90
91     *pp1 = 1; *pp2 = 2; *pp3 = 3; *pp4 = 4; *pp5 = 5;
92     *pp6 = 6; *pp7 = 7; *pp8 = 8; *pp9 = 9; *pp10 = 10;
93
94     if (setupFortranOutput()) {
95       logerror("Error redirecting Fortran component output to log file\n");
96     }
97
98     test1_6f_init_globals();
99
100     test1_6_func1();
101
102     if (cleanupFortranOutput()) {
103       logerror("Error restoring output to stdout\n");
104     }
105
106     /* Combine fortran passedTest with C passedTest */
107     if (test1_6f_globals.passedTest_) {
108       test_passes(testname);
109       return 0;
110     } else {
111       return -1;
112     }
113 }