blob: 9e1e7c28e3ba876086a6f0d47b18594338720519 [file] [log] [blame]
Joachim Protze82e94a52017-11-01 10:08:30 +00001// RUN: %libomp-compile-and-run | FileCheck %s
2// REQUIRES: ompt
3// GCC generates code that does not call the runtime for the master construct
4// XFAIL: gcc
5
6#include "callback.h"
7#include <omp.h>
8
9int main()
10{
11 int x = 0;
12 #pragma omp parallel num_threads(2)
13 {
14 #pragma omp master
15 {
16 print_fuzzy_address(1);
17 x++;
18 }
19 print_current_address(2);
20 }
21
22 printf("%" PRIu64 ": x=%d\n", ompt_get_thread_data()->value, x);
23
24 // Check if libomp supports the callbacks for this test.
25 // CHECK-NOT: {{^}}0: Could not register callback 'ompt_callback_master'
26
27 // CHECK: 0: NULL_POINTER=[[NULL:.*$]]
28
29 // CHECK: {{^}}[[MASTER_ID:[0-9]+]]: ompt_event_master_begin: parallel_id=[[PARALLEL_ID:[0-9]+]], task_id=[[TASK_ID:[0-9]+]], codeptr_ra=[[RETURN_ADDRESS:0x[0-f]+]]{{[0-f][0-f]}}
30 // CHECK: {{^}}[[MASTER_ID]]: fuzzy_address={{.*}}[[RETURN_ADDRESS]]
31 // CHECK: {{^}}[[MASTER_ID]]: ompt_event_master_end: parallel_id=[[PARALLEL_ID]], task_id=[[TASK_ID]], codeptr_ra=[[RETURN_ADDRESS_END:0x[0-f]+]]
32 // CHECK: {{^}}[[MASTER_ID]]: current_address=[[RETURN_ADDRESS_END]]
33
34
35 return 0;
36}