PAPI 7.1.0.0
Loading...
Searching...
No Matches
forkexec4.c File Reference
Include dependency graph for forkexec4.c:

Go to the source code of this file.

Functions

int main (int argc, char **argv)
 

Function Documentation

◆ main()

int main ( int  argc,
char **  argv 
)

Definition at line 31 of file forkexec4.c.

32{
33 int retval;
34 int status;
35 int quiet;
36
37 /* Set TESTS_QUIET variable */
38 quiet = tests_quiet( argc, argv );
39
40 if ( ( argc > 1 ) && ( strcmp( argv[1], "xxx" ) == 0 ) ) {
41 /* In child */
43 if ( retval != PAPI_VER_CURRENT ) {
44 test_fail( __FILE__, __LINE__, "execed PAPI_library_init", retval );
45 }
46 return 0;
47 } else {
48 if (!quiet) printf("Testing Init/fork/exec/Init\n");
49
50 /* Init PAPI */
52 if ( retval != PAPI_VER_CURRENT ) {
53 test_fail( __FILE__, __LINE__, "main PAPI_library_init", retval );
54 }
55
56 if ( fork( ) == 0 ) {
57 /* In Child */
59 if ( retval != PAPI_VER_CURRENT ) {
60 test_fail( __FILE__, __LINE__, "forked PAPI_library_init",
61 retval );
62 }
63
64 if ( execlp( argv[0], argv[0], "xxx", NULL ) == -1 ) {
65 test_fail( __FILE__, __LINE__, "execlp", PAPI_ESYS );
66 }
67 } else {
68 /* Waiting in parent */
69 wait( &status );
70 if ( WEXITSTATUS( status ) != 0 ) {
71 test_fail( __FILE__, __LINE__, "fork", WEXITSTATUS( status ) );
72 } }
73 }
74
75 test_pass( __FILE__ );
76
77 return 0;
78}
initialize the PAPI library.
#define PAPI_VER_CURRENT
Definition: f90papi.h:54
#define PAPI_ESYS
Definition: f90papi.h:136
int tests_quiet(int argc, char **argv)
Definition: test_utils.c:376
void PAPI_NORETURN test_fail(const char *file, int line, const char *call, int retval)
Definition: test_utils.c:491
void PAPI_NORETURN test_pass(const char *filename)
Definition: test_utils.c:432
int quiet
Definition: rapl_overflow.c:19
int retval
Definition: zero_fork.c:53
Here is the call graph for this function: