api2.c
2.6 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
// RUN: %libomp-compile-and-run
// RUN: %libomp-run | %python %S/check.py -c 'CHECK' %s
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <omp.h>
#define XSTR(x) #x
#define STR(x) XSTR(x)
#define streqls(s1, s2) (!strcmp(s1, s2))
#define check(condition) \
if (!(condition)) { \
fprintf(stderr, "error: %s: %d: " STR(condition) "\n", __FILE__, \
__LINE__); \
exit(1); \
}
#if defined(_WIN32)
#define snprintf _snprintf
#endif
#define BUFFER_SIZE 1024
int main(int argc, char** argv) {
char buf[BUFFER_SIZE];
size_t needed, length;
const char* format = "tl:%L tn:%n nt:%N an:%a";
const char* second_format = "nesting_level:%{nesting_level} thread_num:%{thread_num} num_threads:%{num_threads} ancestor_tnum:%{ancestor_tnum}";
length = strlen(format);
omp_set_affinity_format(format);
needed = omp_get_affinity_format(buf, BUFFER_SIZE);
check(streqls(buf, format));
check(needed == length)
// Check that it is truncated properly
omp_get_affinity_format(buf, 5);
check(streqls(buf, "tl:%"));
#pragma omp parallel
{
char my_buf[512];
char supposed[512];
int tl, tn, nt, an;
size_t needed, needed2;
tl = omp_get_level();
tn = omp_get_thread_num();
nt = omp_get_num_threads();
an = omp_get_ancestor_thread_num(omp_get_level()-1);
needed = omp_capture_affinity(my_buf, 512, NULL);
needed2 = (size_t)snprintf(supposed, 512, "tl:%d tn:%d nt:%d an:%d", tl, tn, nt, an);
check(streqls(my_buf, supposed));
check(needed == needed2);
// Check that it is truncated properly
supposed[4] = '\0';
omp_capture_affinity(my_buf, 5, NULL);
check(streqls(my_buf, supposed));
needed = omp_capture_affinity(my_buf, 512, second_format);
needed2 = (size_t)snprintf(supposed, 512, "nesting_level:%d thread_num:%d num_threads:%d ancestor_tnum:%d", tl, tn, nt, an);
check(streqls(my_buf, supposed));
check(needed == needed2);
// Check that it is truncated properly
supposed[25] = '\0';
omp_capture_affinity(my_buf, 26, second_format);
check(streqls(my_buf, supposed));
}
#pragma omp parallel num_threads(4)
{
omp_display_affinity(NULL);
omp_display_affinity(second_format);
}
return 0;
}
// CHECK: num_threads=4 tl:[0-9]+ tn:[0-9]+ nt:[0-9]+ an:[0-9]+
// CHECK: num_threads=4 nesting_level:[0-9]+ thread_num:[0-9]+ num_threads:[0-9]+ ancestor_tnum:[0-9]+