mirror of
https://gcc.gnu.org/git/gcc.git
synced 2024-11-28 14:24:43 +08:00
5fae049dc2
libgomp/ * acc_prof.h: New file. * oacc-profiling.c: Likewise. * Makefile.am (nodist_libsubinclude_HEADERS, libgomp_la_SOURCES): Add these, respectively. * Makefile.in: Regenerate. * env.c (initialize_env): Call goacc_profiling_initialize. * oacc-plugin.c (GOMP_PLUGIN_goacc_thread) (GOMP_PLUGIN_goacc_profiling_dispatch): New functions. * oacc-plugin.h (GOMP_PLUGIN_goacc_thread) (GOMP_PLUGIN_goacc_profiling_dispatch): Declare. * libgomp.map (OACC_2.5.1): Add acc_prof_lookup, acc_prof_register, acc_prof_unregister, and acc_register_library. (GOMP_PLUGIN_1.3): Add GOMP_PLUGIN_goacc_profiling_dispatch, and GOMP_PLUGIN_goacc_thread. * oacc-int.h (struct goacc_thread): Add prof_info, api_info, prof_callbacks_enabled members. (goacc_prof_enabled, goacc_profiling_initialize) (_goacc_profiling_dispatch_p, _goacc_profiling_setup_p) (goacc_profiling_dispatch): Declare. (GOACC_PROF_ENABLED, GOACC_PROFILING_DISPATCH_P) (GOACC_PROFILING_SETUP_P): Define. * oacc-async.c (acc_async_test, acc_async_test_all, acc_wait) (acc_wait_async, acc_wait_all, acc_wait_all_async): Update for OpenACC Profiling Interface. * oacc-cuda.c (acc_get_current_cuda_device) (acc_get_current_cuda_context, acc_get_cuda_stream) (acc_set_cuda_stream): Likewise. * oacc-init.c (acc_init_1, goacc_attach_host_thread_to_device) (acc_init, acc_set_device_type, acc_get_device_type) (acc_get_device_num, goacc_lazy_initialize): Likewise. * oacc-mem.c (acc_malloc, acc_free, memcpy_tofrom_device) (acc_deviceptr, acc_hostptr, acc_is_present, acc_map_data) (acc_unmap_data, present_create_copy, delete_copyout) (update_dev_host): Likewise. * oacc-parallel.c (GOACC_parallel_keyed, GOACC_data_start) (GOACC_data_end, GOACC_enter_exit_data, GOACC_update, GOACC_wait): Likewise. * plugin/plugin-nvptx.c (nvptx_exec, nvptx_alloc, nvptx_free) (GOMP_OFFLOAD_openacc_exec, GOMP_OFFLOAD_openacc_async_exec): Likewise. * libgomp.texi: Update. * testsuite/libgomp.oacc-c-c++-common/acc_prof-dispatch-1.c: New file. * testsuite/libgomp.oacc-c-c++-common/acc_prof-init-1.c: Likewise. * testsuite/libgomp.oacc-c-c++-common/acc_prof-kernels-1.c: Likewise. * testsuite/libgomp.oacc-c-c++-common/acc_prof-parallel-1.c: Likewise. * testsuite/libgomp.oacc-c-c++-common/acc_prof-valid_bytes-1.c: Likewise. * testsuite/libgomp.oacc-c-c++-common/acc_prof-version-1.c: Likewise. From-SVN: r271346
532 lines
11 KiB
Plaintext
532 lines
11 KiB
Plaintext
OMP_1.0 {
|
|
global:
|
|
omp_set_num_threads;
|
|
omp_get_num_threads;
|
|
omp_get_max_threads;
|
|
omp_get_thread_num;
|
|
omp_get_num_procs;
|
|
omp_in_parallel;
|
|
omp_set_dynamic;
|
|
omp_get_dynamic;
|
|
omp_set_nested;
|
|
omp_get_nested;
|
|
#ifdef HAVE_SYMVER_SYMBOL_RENAMING_RUNTIME_SUPPORT
|
|
# If the assembler used lacks the .symver directive or the linker
|
|
# doesn't support GNU symbol versioning, we have the same symbol in
|
|
# two versions, which Sun ld chokes on.
|
|
omp_init_lock;
|
|
omp_init_nest_lock;
|
|
omp_destroy_lock;
|
|
omp_destroy_nest_lock;
|
|
omp_set_lock;
|
|
omp_set_nest_lock;
|
|
omp_unset_lock;
|
|
omp_unset_nest_lock;
|
|
omp_test_lock;
|
|
omp_test_nest_lock;
|
|
omp_destroy_lock_;
|
|
omp_destroy_nest_lock_;
|
|
omp_init_lock_;
|
|
omp_init_nest_lock_;
|
|
omp_set_lock_;
|
|
omp_set_nest_lock_;
|
|
omp_test_lock_;
|
|
omp_test_nest_lock_;
|
|
omp_unset_lock_;
|
|
omp_unset_nest_lock_;
|
|
#endif
|
|
omp_get_dynamic_;
|
|
omp_get_max_threads_;
|
|
omp_get_nested_;
|
|
omp_get_num_procs_;
|
|
omp_get_num_threads_;
|
|
omp_get_thread_num_;
|
|
omp_in_parallel_;
|
|
omp_set_dynamic_;
|
|
omp_set_dynamic_8_;
|
|
omp_set_nested_;
|
|
omp_set_nested_8_;
|
|
omp_set_num_threads_;
|
|
omp_set_num_threads_8_;
|
|
local:
|
|
*;
|
|
};
|
|
|
|
OMP_2.0 {
|
|
global:
|
|
omp_get_wtick;
|
|
omp_get_wtime;
|
|
omp_get_wtick_;
|
|
omp_get_wtime_;
|
|
} OMP_1.0;
|
|
|
|
OMP_3.0 {
|
|
global:
|
|
omp_set_schedule;
|
|
omp_set_schedule_;
|
|
omp_set_schedule_8_;
|
|
omp_get_schedule;
|
|
omp_get_schedule_;
|
|
omp_get_schedule_8_;
|
|
omp_get_thread_limit;
|
|
omp_get_thread_limit_;
|
|
omp_set_max_active_levels;
|
|
omp_set_max_active_levels_;
|
|
omp_set_max_active_levels_8_;
|
|
omp_get_max_active_levels;
|
|
omp_get_max_active_levels_;
|
|
omp_get_level;
|
|
omp_get_level_;
|
|
omp_get_ancestor_thread_num;
|
|
omp_get_ancestor_thread_num_;
|
|
omp_get_ancestor_thread_num_8_;
|
|
omp_get_team_size;
|
|
omp_get_team_size_;
|
|
omp_get_team_size_8_;
|
|
omp_get_active_level;
|
|
omp_get_active_level_;
|
|
omp_init_lock;
|
|
omp_init_nest_lock;
|
|
omp_destroy_lock;
|
|
omp_destroy_nest_lock;
|
|
omp_set_lock;
|
|
omp_set_nest_lock;
|
|
omp_unset_lock;
|
|
omp_unset_nest_lock;
|
|
omp_test_lock;
|
|
omp_test_nest_lock;
|
|
omp_destroy_lock_;
|
|
omp_destroy_nest_lock_;
|
|
omp_init_lock_;
|
|
omp_init_nest_lock_;
|
|
omp_set_lock_;
|
|
omp_set_nest_lock_;
|
|
omp_test_lock_;
|
|
omp_test_nest_lock_;
|
|
omp_unset_lock_;
|
|
omp_unset_nest_lock_;
|
|
} OMP_2.0;
|
|
|
|
OMP_3.1 {
|
|
global:
|
|
omp_in_final;
|
|
omp_in_final_;
|
|
} OMP_3.0;
|
|
|
|
OMP_4.0 {
|
|
global:
|
|
omp_get_cancellation;
|
|
omp_get_cancellation_;
|
|
omp_get_proc_bind;
|
|
omp_get_proc_bind_;
|
|
omp_set_default_device;
|
|
omp_set_default_device_;
|
|
omp_set_default_device_8_;
|
|
omp_get_default_device;
|
|
omp_get_default_device_;
|
|
omp_get_num_devices;
|
|
omp_get_num_devices_;
|
|
omp_get_num_teams;
|
|
omp_get_num_teams_;
|
|
omp_get_team_num;
|
|
omp_get_team_num_;
|
|
omp_is_initial_device;
|
|
omp_is_initial_device_;
|
|
} OMP_3.1;
|
|
|
|
OMP_4.5 {
|
|
global:
|
|
omp_get_max_task_priority;
|
|
omp_get_max_task_priority_;
|
|
omp_get_num_places;
|
|
omp_get_num_places_;
|
|
omp_get_place_num_procs;
|
|
omp_get_place_num_procs_;
|
|
omp_get_place_num_procs_8_;
|
|
omp_get_place_proc_ids;
|
|
omp_get_place_proc_ids_;
|
|
omp_get_place_proc_ids_8_;
|
|
omp_get_place_num;
|
|
omp_get_place_num_;
|
|
omp_get_partition_num_places;
|
|
omp_get_partition_num_places_;
|
|
omp_get_partition_place_nums;
|
|
omp_get_partition_place_nums_;
|
|
omp_get_partition_place_nums_8_;
|
|
omp_get_initial_device;
|
|
omp_get_initial_device_;
|
|
omp_target_alloc;
|
|
omp_target_free;
|
|
omp_target_is_present;
|
|
omp_target_memcpy;
|
|
omp_target_memcpy_rect;
|
|
omp_target_associate_ptr;
|
|
omp_target_disassociate_ptr;
|
|
} OMP_4.0;
|
|
|
|
OMP_5.0 {
|
|
global:
|
|
omp_capture_affinity;
|
|
omp_capture_affinity_;
|
|
omp_display_affinity;
|
|
omp_display_affinity_;
|
|
omp_get_affinity_format;
|
|
omp_get_affinity_format_;
|
|
omp_set_affinity_format;
|
|
omp_set_affinity_format_;
|
|
omp_pause_resource;
|
|
omp_pause_resource_;
|
|
omp_pause_resource_all;
|
|
omp_pause_resource_all_;
|
|
} OMP_4.5;
|
|
|
|
GOMP_1.0 {
|
|
global:
|
|
GOMP_atomic_end;
|
|
GOMP_atomic_start;
|
|
GOMP_barrier;
|
|
GOMP_critical_end;
|
|
GOMP_critical_name_end;
|
|
GOMP_critical_name_start;
|
|
GOMP_critical_start;
|
|
GOMP_loop_dynamic_next;
|
|
GOMP_loop_dynamic_start;
|
|
GOMP_loop_end;
|
|
GOMP_loop_end_nowait;
|
|
GOMP_loop_guided_next;
|
|
GOMP_loop_guided_start;
|
|
GOMP_loop_ordered_dynamic_next;
|
|
GOMP_loop_ordered_dynamic_start;
|
|
GOMP_loop_ordered_guided_next;
|
|
GOMP_loop_ordered_guided_start;
|
|
GOMP_loop_ordered_runtime_next;
|
|
GOMP_loop_ordered_runtime_start;
|
|
GOMP_loop_ordered_static_next;
|
|
GOMP_loop_ordered_static_start;
|
|
GOMP_loop_runtime_next;
|
|
GOMP_loop_runtime_start;
|
|
GOMP_loop_static_next;
|
|
GOMP_loop_static_start;
|
|
GOMP_ordered_end;
|
|
GOMP_ordered_start;
|
|
GOMP_parallel_end;
|
|
GOMP_parallel_loop_dynamic_start;
|
|
GOMP_parallel_loop_guided_start;
|
|
GOMP_parallel_loop_runtime_start;
|
|
GOMP_parallel_loop_static_start;
|
|
GOMP_parallel_sections_start;
|
|
GOMP_parallel_start;
|
|
GOMP_sections_end;
|
|
GOMP_sections_end_nowait;
|
|
GOMP_sections_next;
|
|
GOMP_sections_start;
|
|
GOMP_single_copy_end;
|
|
GOMP_single_copy_start;
|
|
GOMP_single_start;
|
|
};
|
|
|
|
GOMP_2.0 {
|
|
global:
|
|
GOMP_task;
|
|
GOMP_taskwait;
|
|
GOMP_loop_ull_dynamic_next;
|
|
GOMP_loop_ull_dynamic_start;
|
|
GOMP_loop_ull_guided_next;
|
|
GOMP_loop_ull_guided_start;
|
|
GOMP_loop_ull_ordered_dynamic_next;
|
|
GOMP_loop_ull_ordered_dynamic_start;
|
|
GOMP_loop_ull_ordered_guided_next;
|
|
GOMP_loop_ull_ordered_guided_start;
|
|
GOMP_loop_ull_ordered_runtime_next;
|
|
GOMP_loop_ull_ordered_runtime_start;
|
|
GOMP_loop_ull_ordered_static_next;
|
|
GOMP_loop_ull_ordered_static_start;
|
|
GOMP_loop_ull_runtime_next;
|
|
GOMP_loop_ull_runtime_start;
|
|
GOMP_loop_ull_static_next;
|
|
GOMP_loop_ull_static_start;
|
|
} GOMP_1.0;
|
|
|
|
GOMP_3.0 {
|
|
global:
|
|
GOMP_taskyield;
|
|
} GOMP_2.0;
|
|
|
|
GOMP_4.0 {
|
|
global:
|
|
GOMP_barrier_cancel;
|
|
GOMP_cancel;
|
|
GOMP_cancellation_point;
|
|
GOMP_loop_end_cancel;
|
|
GOMP_parallel_loop_dynamic;
|
|
GOMP_parallel_loop_guided;
|
|
GOMP_parallel_loop_runtime;
|
|
GOMP_parallel_loop_static;
|
|
GOMP_parallel_sections;
|
|
GOMP_parallel;
|
|
GOMP_sections_end_cancel;
|
|
GOMP_taskgroup_start;
|
|
GOMP_taskgroup_end;
|
|
GOMP_target;
|
|
GOMP_target_data;
|
|
GOMP_target_end_data;
|
|
GOMP_target_update;
|
|
GOMP_teams;
|
|
} GOMP_3.0;
|
|
|
|
GOMP_4.0.1 {
|
|
global:
|
|
GOMP_offload_register;
|
|
GOMP_offload_unregister;
|
|
} GOMP_4.0;
|
|
|
|
GOMP_4.5 {
|
|
global:
|
|
GOMP_target_ext;
|
|
GOMP_target_data_ext;
|
|
GOMP_target_update_ext;
|
|
GOMP_target_enter_exit_data;
|
|
GOMP_taskloop;
|
|
GOMP_taskloop_ull;
|
|
GOMP_offload_register_ver;
|
|
GOMP_offload_unregister_ver;
|
|
GOMP_loop_doacross_dynamic_start;
|
|
GOMP_loop_doacross_guided_start;
|
|
GOMP_loop_doacross_runtime_start;
|
|
GOMP_loop_doacross_static_start;
|
|
GOMP_doacross_post;
|
|
GOMP_doacross_wait;
|
|
GOMP_loop_ull_doacross_dynamic_start;
|
|
GOMP_loop_ull_doacross_guided_start;
|
|
GOMP_loop_ull_doacross_runtime_start;
|
|
GOMP_loop_ull_doacross_static_start;
|
|
GOMP_doacross_ull_post;
|
|
GOMP_doacross_ull_wait;
|
|
GOMP_loop_nonmonotonic_dynamic_next;
|
|
GOMP_loop_nonmonotonic_dynamic_start;
|
|
GOMP_loop_nonmonotonic_guided_next;
|
|
GOMP_loop_nonmonotonic_guided_start;
|
|
GOMP_loop_ull_nonmonotonic_dynamic_next;
|
|
GOMP_loop_ull_nonmonotonic_dynamic_start;
|
|
GOMP_loop_ull_nonmonotonic_guided_next;
|
|
GOMP_loop_ull_nonmonotonic_guided_start;
|
|
GOMP_parallel_loop_nonmonotonic_dynamic;
|
|
GOMP_parallel_loop_nonmonotonic_guided;
|
|
} GOMP_4.0.1;
|
|
|
|
GOMP_5.0 {
|
|
global:
|
|
GOMP_loop_doacross_start;
|
|
GOMP_loop_maybe_nonmonotonic_runtime_next;
|
|
GOMP_loop_maybe_nonmonotonic_runtime_start;
|
|
GOMP_loop_nonmonotonic_runtime_next;
|
|
GOMP_loop_nonmonotonic_runtime_start;
|
|
GOMP_loop_ordered_start;
|
|
GOMP_loop_start;
|
|
GOMP_loop_ull_doacross_start;
|
|
GOMP_loop_ull_maybe_nonmonotonic_runtime_next;
|
|
GOMP_loop_ull_maybe_nonmonotonic_runtime_start;
|
|
GOMP_loop_ull_nonmonotonic_runtime_next;
|
|
GOMP_loop_ull_nonmonotonic_runtime_start;
|
|
GOMP_loop_ull_ordered_start;
|
|
GOMP_loop_ull_start;
|
|
GOMP_parallel_loop_maybe_nonmonotonic_runtime;
|
|
GOMP_parallel_loop_nonmonotonic_runtime;
|
|
GOMP_parallel_reductions;
|
|
GOMP_sections2_start;
|
|
GOMP_taskgroup_reduction_register;
|
|
GOMP_taskgroup_reduction_unregister;
|
|
GOMP_task_reduction_remap;
|
|
GOMP_taskwait_depend;
|
|
GOMP_teams_reg;
|
|
GOMP_workshare_task_reduction_unregister;
|
|
} GOMP_4.5;
|
|
|
|
OACC_2.0 {
|
|
global:
|
|
acc_get_num_devices;
|
|
acc_get_num_devices_h_;
|
|
acc_set_device_type;
|
|
acc_set_device_type_h_;
|
|
acc_get_device_type;
|
|
acc_get_device_type_h_;
|
|
acc_set_device_num;
|
|
acc_set_device_num_h_;
|
|
acc_get_device_num;
|
|
acc_get_device_num_h_;
|
|
acc_async_test;
|
|
acc_async_test_h_;
|
|
acc_async_test_all;
|
|
acc_async_test_all_h_;
|
|
acc_wait;
|
|
acc_wait_h_;
|
|
acc_wait_async;
|
|
acc_wait_async_h_;
|
|
acc_wait_all;
|
|
acc_wait_all_h_;
|
|
acc_wait_all_async;
|
|
acc_wait_all_async_h_;
|
|
acc_init;
|
|
acc_init_h_;
|
|
acc_shutdown;
|
|
acc_shutdown_h_;
|
|
acc_on_device;
|
|
acc_on_device_h_;
|
|
acc_malloc;
|
|
acc_free;
|
|
acc_copyin;
|
|
acc_copyin_32_h_;
|
|
acc_copyin_64_h_;
|
|
acc_copyin_array_h_;
|
|
acc_present_or_copyin;
|
|
acc_present_or_copyin_32_h_;
|
|
acc_present_or_copyin_64_h_;
|
|
acc_present_or_copyin_array_h_;
|
|
acc_create;
|
|
acc_create_32_h_;
|
|
acc_create_64_h_;
|
|
acc_create_array_h_;
|
|
acc_present_or_create;
|
|
acc_present_or_create_32_h_;
|
|
acc_present_or_create_64_h_;
|
|
acc_present_or_create_array_h_;
|
|
acc_copyout;
|
|
acc_copyout_32_h_;
|
|
acc_copyout_64_h_;
|
|
acc_copyout_array_h_;
|
|
acc_delete;
|
|
acc_delete_32_h_;
|
|
acc_delete_64_h_;
|
|
acc_delete_array_h_;
|
|
acc_update_device;
|
|
acc_update_device_32_h_;
|
|
acc_update_device_64_h_;
|
|
acc_update_device_array_h_;
|
|
acc_update_self;
|
|
acc_update_self_32_h_;
|
|
acc_update_self_64_h_;
|
|
acc_update_self_array_h_;
|
|
acc_map_data;
|
|
acc_unmap_data;
|
|
acc_deviceptr;
|
|
acc_hostptr;
|
|
acc_is_present;
|
|
acc_is_present_32_h_;
|
|
acc_is_present_64_h_;
|
|
acc_is_present_array_h_;
|
|
acc_memcpy_to_device;
|
|
acc_memcpy_from_device;
|
|
acc_get_current_cuda_device;
|
|
acc_get_current_cuda_context;
|
|
acc_get_cuda_stream;
|
|
acc_set_cuda_stream;
|
|
};
|
|
|
|
OACC_2.0.1 {
|
|
global:
|
|
acc_async_wait;
|
|
acc_async_wait_all;
|
|
acc_pcopyin;
|
|
acc_pcreate;
|
|
} OACC_2.0;
|
|
|
|
OACC_2.5 {
|
|
global:
|
|
acc_copyin_async;
|
|
acc_copyin_async_32_h_;
|
|
acc_copyin_async_64_h_;
|
|
acc_copyin_async_array_h_;
|
|
acc_copyout_async;
|
|
acc_copyout_async_32_h_;
|
|
acc_copyout_async_64_h_;
|
|
acc_copyout_async_array_h_;
|
|
acc_copyout_finalize;
|
|
acc_copyout_finalize_32_h_;
|
|
acc_copyout_finalize_64_h_;
|
|
acc_copyout_finalize_array_h_;
|
|
acc_copyout_finalize_async;
|
|
acc_copyout_finalize_async_32_h_;
|
|
acc_copyout_finalize_async_64_h_;
|
|
acc_copyout_finalize_async_array_h_;
|
|
acc_create_async;
|
|
acc_create_async_32_h_;
|
|
acc_create_async_64_h_;
|
|
acc_create_async_array_h_;
|
|
acc_delete_async;
|
|
acc_delete_async_32_h_;
|
|
acc_delete_async_64_h_;
|
|
acc_delete_async_array_h_;
|
|
acc_delete_finalize;
|
|
acc_delete_finalize_32_h_;
|
|
acc_delete_finalize_64_h_;
|
|
acc_delete_finalize_array_h_;
|
|
acc_delete_finalize_async;
|
|
acc_delete_finalize_async_32_h_;
|
|
acc_delete_finalize_async_64_h_;
|
|
acc_delete_finalize_async_array_h_;
|
|
acc_memcpy_from_device_async;
|
|
acc_memcpy_to_device_async;
|
|
acc_update_device_async;
|
|
acc_update_device_async_32_h_;
|
|
acc_update_device_async_64_h_;
|
|
acc_update_device_async_array_h_;
|
|
acc_update_self_async;
|
|
acc_update_self_async_32_h_;
|
|
acc_update_self_async_64_h_;
|
|
acc_update_self_async_array_h_;
|
|
} OACC_2.0.1;
|
|
|
|
OACC_2.5.1 {
|
|
global:
|
|
acc_prof_lookup;
|
|
acc_prof_register;
|
|
acc_prof_unregister;
|
|
acc_register_library;
|
|
} OACC_2.5;
|
|
|
|
GOACC_2.0 {
|
|
global:
|
|
GOACC_data_end;
|
|
GOACC_data_start;
|
|
GOACC_enter_exit_data;
|
|
GOACC_parallel;
|
|
GOACC_update;
|
|
GOACC_wait;
|
|
GOACC_get_thread_num;
|
|
GOACC_get_num_threads;
|
|
};
|
|
|
|
GOACC_2.0.1 {
|
|
global:
|
|
GOACC_declare;
|
|
GOACC_parallel_keyed;
|
|
} GOACC_2.0;
|
|
|
|
GOMP_PLUGIN_1.0 {
|
|
global:
|
|
GOMP_PLUGIN_malloc;
|
|
GOMP_PLUGIN_malloc_cleared;
|
|
GOMP_PLUGIN_realloc;
|
|
GOMP_PLUGIN_debug;
|
|
GOMP_PLUGIN_error;
|
|
GOMP_PLUGIN_fatal;
|
|
GOMP_PLUGIN_async_unmap_vars;
|
|
GOMP_PLUGIN_acc_thread;
|
|
};
|
|
|
|
GOMP_PLUGIN_1.1 {
|
|
global:
|
|
GOMP_PLUGIN_target_task_completion;
|
|
} GOMP_PLUGIN_1.0;
|
|
|
|
GOMP_PLUGIN_1.2 {
|
|
global:
|
|
GOMP_PLUGIN_acc_default_dim;
|
|
} GOMP_PLUGIN_1.1;
|
|
|
|
GOMP_PLUGIN_1.3 {
|
|
global:
|
|
GOMP_PLUGIN_goacc_profiling_dispatch;
|
|
GOMP_PLUGIN_goacc_thread;
|
|
} GOMP_PLUGIN_1.2;
|