This patch adds the affinity format functionality introduced in OpenMP 5.0.
This patch adds: Two new environment variables:
- OMP_DISPLAY_AFFINITY=TRUE|FALSE
- OMP_AFFINITY_FORMAT=<string>
and Four new API:
- omp_set_affinity_format()
- omp_get_affinity_format()
- omp_display_affinity()
- omp_capture_affinity()
The affinity format functionality has two ICV's associated with it:
affinity-display-var (bool) and affinity-format-var (string).
The affinity-display-var enables/disables the functionality through the
envirable OMP_DISPLAY_AFFINITY. The affinity-format-var is a formatted
string with the special field types beginning with a '%' character
similar to printf
For example, the affinity-format-var could be:
"OMP: host:%H pid:%P OStid:%i num_threads:%N thread_num:%n affinity:{%A}"
The affinity-format-var is displayed by every thread implicitly at the beginning
of a parallel region when any thread's affinity has changed (including a brand
new thread being spawned), or explicitly using the omp_display_affinity() API.
The omp_capture_affinity() function can capture the affinity-format-var in a
char buffer. And omp_set|get_affinity_format() allow the user to set|get the
affinity-format-var explicitly at runtime. omp_capture_affinity() and
omp_get_affinity_format() both return the number of characters needed to hold
the entire string it tried to make (not including NULL character). If not enough buffer space is available,
both these functions truncate their output.
@jlpeyton @AndreyChurbanov Is there any particular reason that these functions are not bind(c)?