问题描述
我有一个使用 OpenMP 并行化的代码。我想确保部署的线程遵循我想到的相同序列图。为了做到这一点,我寻找了一个高效的工具(库、软件等)并找到了 lib OMPTrace,这是一个用于跟踪和可视化 OpenMP 程序的简单工具执行。它显示了 here 如何安装和使用它。我要编译的文件名为 hecese_OpenMP.f90
(Fortran)。
我执行了以下命令块以可视化线程的行为。
flang -g -mp hecese_OpenMP.f90 -L/home/hakim/llvm-openmp-install/lib -o heceseflang
14 h 40
objdump -d heceseflang >heceseflang.objdump
14 h 40
LD_PRELOAD=/home/hakim/llvm-openmp-install/lib/libomp.so:/home/hakim/llvm-openmp/BUILD/omptrace/build/libomptrace.so ./heceseflang
它显示:
140557273808912: ompt_event_release_nest_lock_last: wait_id=140558880879816,codeptr_ra=0x411abe
140557273808912: ompt_event_wait_nest_lock: wait_id=140558880879816,hint=0,impl=2,codeptr_ra=0x41199f
140557273808912: ompt_event_acquired_nest_lock_first: wait_id=140558880879816,codeptr_ra=0x41199f
140557273808912: ompt_event_release_nest_lock_last: wait_id=140558880879816,codeptr_ra=0x411abe
Erreur de segmentation (core dumped)
我在 hello_world 程序上测试了该库,它运行良好。 我试图重现我想到的序列图,它给了我:
问题是,如果我用 gfortran
编译我的代码并执行它,我不会遇到分段错误(一切正常)但是当我尝试使用 OMPTrace 我遇到分段错误。
我的问题很简单。问题是来自库本身(知道它适用于 hello_world 代码)还是来自我的代码(知道它可以在没有 lib 的情况下工作)?我怀疑这个库不支持大代码。我的代码包含 1200 行。
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)