如何解决根据valgrind客户端检查请求,MPI异步调用使内存无法处理是什么原因造成的?
我正在用valgrind测试一些MPI代码,该代码以对未初始化读取的误报而闻名,但是下面的代码显示了我从未见过的错误。使用openmpi会发生这种情况,在mpich下,代码是valgrind-clean。
[... some errors that I believe to be false positives]
==8229== Unaddressable byte(s) found during client check request
==8229== at 0x4016F2: main (unaddressable.c:45)
==8229== Address 0x7909ce0 is 0 bytes inside a block of size 400 alloc'd
==8229== at 0x483980B: malloc (vg_replace_malloc.c:307)
==8229== by 0x401460: main (unaddressable.c:20)
我的理解是,当您超出范围访问堆数组时,将发生无法解决的内存错误,但是valgrind在此承认该地址位于尚未释放的未分配块中。 释放以外的其他事件甚至会使内存变得无法弥补?
我认为我的代码是正确的,它是使用mpicc -Wall -Wextra -Wpedantic -g unaddressable.c && mpiexec -n 4 valgrind --quiet --track-origins=yes ./a.out
编译并运行的。
#include <mpi.h>
#include <valgrind/memcheck.h>
#include <assert.h>
#include <stdlib.h>
int main()
{
MPI_Init(NULL,NULL);
int world_rank; MPI_Comm_rank(MPI_COMM_WORLD,& world_rank);
int world_size; MPI_Comm_size(MPI_COMM_WORLD,&world_size);
int left = (world_rank-1+world_size)%world_size;
int right = (world_rank+1+world_size)%world_size;
int size = 100;
int * recv_from_right = malloc(sizeof(int)*size);
int * recv_from_left = malloc(sizeof(int)*size);
int * send_to_left = malloc(sizeof(int)*size);
int * send_to_right = malloc(sizeof(int)*size);
assert(recv_from_right && recv_from_left && send_to_left && send_to_right);
for (int i=0; i<size; i++)
{
send_to_left[i] = i;
send_to_right[i] = size-i;
}
MPI_Request reqs[4]; MPI_Request * req = &reqs[0];
MPI_Isend(send_to_left,size,MPI_INT,left,MPI_COMM_WORLD,req++);
MPI_Irecv(recv_from_right,right,req++);
MPI_Isend(send_to_right,1,req++);
MPI_Irecv(recv_from_left,req++);
MPI_Waitall(4,reqs,MPI_STATUS_IGnorE);
// these client check requests produce error "Unaddressable byte(s) found [...] 0 bytes inside a block"
VALGRIND_CHECK_MEM_IS_DEFINED(recv_from_left,size*sizeof(int));
VALGRIND_CHECK_MEM_IS_DEFINED(recv_from_right,size*sizeof(int));
free(send_to_left); free(send_to_right); free(recv_from_left); free(recv_from_right);
MPI_Finalize();
}
我正在使用
- gcc 9.3.1
- valgrind-3.16.0
对于mpi:
- mpich 3.3.2(valgrind-clean)
- 打开MPI 4.0.2(针对错误)
我通过dnf安装了Openmpi,以下是ompi_info的输出
Package: Open MPI
mockbuild@buildhw-02.phx2.fedoraproject.org
distribution
Open MPI: 4.0.2
Open MPI repo revision: v4.0.2
Open MPI release date: Oct 07,2019
Open RTE: 4.0.2
Open RTE repo revision: v4.0.2
Open RTE release date: Oct 07,2019
OPAL: 4.0.2
OPAL repo revision: v4.0.2
OPAL release date: Oct 07,2019
MPI API: 3.1.0
Ident string: 4.0.2
Prefix: /usr/lib64/openmpi
Configured architecture: x86_64-unkNown-linux-gnu
Configure host: buildhw-02.phx2.fedoraproject.org
Configured by: mockbuild
Configured on: Mon Oct 7 23:28:49 UTC 2019
Configure host: buildhw-02.phx2.fedoraproject.org
Configure command line: '--prefix=/usr/lib64/openmpi'
'--mandir=/usr/share/man/openmpi-x86_64'
'--includedir=/usr/include/openmpi-x86_64'
'--sysconfdir=/etc/openmpi-x86_64'
'--disable-silent-rules' '--enable-builtin-atomics'
'--enable-mpi-cxx' '--enable-mpi-java'
'--enable-mpi1-compatibility' '--with-sge'
'--with-valgrind' '--enable-memchecker'
'--with-hwloc=/usr' '--with-libevent=external'
'--with-pmix=external' 'CC=gcc' 'CXX=g++'
'LDFLAGS=-Wl,-z,relro -Wl,--as-needed -Wl,Now
-specs=/usr/lib/rpm/redhat/redhat-hardened-ld'
'CFLAGS= -O2 -g -pipe -Wall -Werror=format-security
-Wp,-D_FORTIFY_SOURCE=2 -Wp,-D_GLIBCXX_ASSERTIONS
-fexceptions -fstack-protector-strong
-grecord-gcc-switches
-specs=/usr/lib/rpm/redhat/redhat-hardened-cc1
-specs=/usr/lib/rpm/redhat/redhat-annobin-cc1 -m64
-mtune=generic -fasynchronous-unwind-tables
-fstack-clash-protection -fcf-protection'
'CXXFLAGS= -O2 -g -pipe -Wall
-Werror=format-security -Wp,-D_FORTIFY_SOURCE=2
-Wp,-D_GLIBCXX_ASSERTIONS -fexceptions
-fstack-protector-strong -grecord-gcc-switches
-specs=/usr/lib/rpm/redhat/redhat-hardened-cc1
-specs=/usr/lib/rpm/redhat/redhat-annobin-cc1 -m64
-mtune=generic -fasynchronous-unwind-tables
-fstack-clash-protection -fcf-protection'
'FC=gfortran' 'FCFLAGS= -O2 -g -pipe -Wall
-Werror=format-security -Wp,-D_GLIBCXX_ASSERTIONS -fexceptions
-fstack-protector-strong -grecord-gcc-switches
-specs=/usr/lib/rpm/redhat/redhat-hardened-cc1
-specs=/usr/lib/rpm/redhat/redhat-annobin-cc1 -m64
-mtune=generic -fasynchronous-unwind-tables
-fstack-clash-protection -fcf-protection'
Built by: mockbuild
Built on: Mon Oct 7 23:34:02 UTC 2019
Built host: buildhw-02.phx2.fedoraproject.org
C bindings: yes
C++ bindings: yes
Fort mpif.h: yes (all)
Fort use mpi: yes (full: ignore TKR)
Fort use mpi size: deprecated-ompi-info-value
Fort use mpi_f08: yes
Fort mpi_f08 compliance: The mpi_f08 module is available,but due to
limitations in the gfortran compiler and/or Open
MPI,does not support the following: array
subsections,direct passthru (where possible) to
underlying Open MPI's C functionality
Fort mpi_f08 subarrays: no
Java bindings: yes
Wrapper compiler rpath: runpath
C compiler: gcc
C compiler absolute: /usr/bin/gcc
C compiler family name: GNU
C compiler version: 9.2.1
C++ compiler: g++
C++ compiler absolute: /usr/bin/g++
Fort compiler: gfortran
Fort compiler abs: /usr/bin/gfortran
Fort ignore TKR: yes (!GCC$ ATTRIBUTES NO_ARG_CHECK ::)
Fort 08 assumed shape: yes
Fort optional args: yes
Fort INTERFACE: yes
Fort ISO_FORTRAN_ENV: yes
Fort STORAGE_SIZE: yes
Fort BIND(C) (all): yes
Fort ISO_C_BINDING: yes
Fort SUbroUTINE BIND(C): yes
Fort TYPE,BIND(C): yes
Fort T,BIND(C,name="a"): yes
Fort PRIVATE: yes
Fort PROTECTED: yes
Fort ABSTRACT: yes
Fort ASYNCHRONOUS: yes
Fort PROCEDURE: yes
Fort USE...ONLY: yes
Fort C_FUNLOC: yes
Fort f08 using wrappers: yes
Fort MPI_SIZEOF: yes
C profiling: yes
C++ profiling: yes
Fort mpif.h profiling: yes
Fort use mpi profiling: yes
Fort use mpi_f08 prof: yes
C++ exceptions: no
Thread support: posix (MPI_THREAD_MULTIPLE: yes,OPAL support: yes,OMPI progress: no,ORTE progress: yes,Event lib:
yes)
Sparse Groups: no
Internal debug support: no
MPI interface warnings: yes
MPI parameter check: runtime
Memory profiling support: no
Memory debugging support: no
dl support: yes
Heterogeneous support: no
mpirun default --prefix: no
MPI_WTIME support: native
Symbol vis. support: yes
Host topology support: yes
IPv6 support: no
MPI1 compatibility: yes
MPI extensions: affinity,cuda,pcollreq
FT Checkpoint support: no (checkpoint thread: no)
C/R Enabled Debugging: no
MPI_MAX_PROCESSOR_NAME: 256
MPI_MAX_ERROR_STRING: 256
MPI_MAX_OBJECT_NAME: 64
MPI_MAX_INFO_KEY: 36
MPI_MAX_INFO_VAL: 256
MPI_MAX_PORT_NAME: 1024
MPI_MAX_DATAREP_STRING: 128
MCA allocator: bucket (MCA v2.1.0,API v2.0.0,Component v4.0.2)
MCA allocator: basic (MCA v2.1.0,Component v4.0.2)
MCA backtrace: execinfo (MCA v2.1.0,Component v4.0.2)
MCA btl: tcp (MCA v2.1.0,API v3.1.0,Component v4.0.2)
MCA btl: openib (MCA v2.1.0,Component v4.0.2)
MCA btl: vader (MCA v2.1.0,Component v4.0.2)
MCA btl: uct (MCA v2.1.0,Component v4.0.2)
MCA btl: usnic (MCA v2.1.0,Component v4.0.2)
MCA btl: self (MCA v2.1.0,Component v4.0.2)
MCA compress: gzip (MCA v2.1.0,Component v4.0.2)
MCA compress: bzip (MCA v2.1.0,Component v4.0.2)
MCA crs: none (MCA v2.1.0,Component v4.0.2)
MCA dl: dlopen (MCA v2.1.0,API v1.0.0,Component v4.0.2)
MCA event: external (MCA v2.1.0,Component v4.0.2)
MCA hwloc: external (MCA v2.1.0,Component v4.0.2)
MCA if: linux_ipv6 (MCA v2.1.0,Component
v4.0.2)
MCA if: posix_ipv4 (MCA v2.1.0,Component
v4.0.2)
MCA installdirs: env (MCA v2.1.0,Component v4.0.2)
MCA installdirs: config (MCA v2.1.0,Component v4.0.2)
MCA memchecker: valgrind (MCA v2.1.0,Component v4.0.2)
MCA memory: patcher (MCA v2.1.0,Component v4.0.2)
MCA mpool: hugepage (MCA v2.1.0,API v3.0.0,Component v4.0.2)
MCA patcher: overwrite (MCA v2.1.0,Component
v4.0.2)
MCA pmix: isolated (MCA v2.1.0,Component v4.0.2)
MCA pmix: ext3x (MCA v2.1.0,Component v4.0.2)
MCA pmix: flux (MCA v2.1.0,Component v4.0.2)
MCA pstat: linux (MCA v2.1.0,Component v4.0.2)
MCA rcache: Grdma (MCA v2.1.0,API v3.3.0,Component v4.0.2)
MCA reachable: weighted (MCA v2.1.0,Component v4.0.2)
MCA shmem: mmap (MCA v2.1.0,Component v4.0.2)
MCA shmem: sysv (MCA v2.1.0,Component v4.0.2)
MCA shmem: posix (MCA v2.1.0,Component v4.0.2)
MCA timer: linux (MCA v2.1.0,Component v4.0.2)
MCA errmgr: default_hnp (MCA v2.1.0,Component
v4.0.2)
MCA errmgr: default_tool (MCA v2.1.0,Component
v4.0.2)
MCA errmgr: default_app (MCA v2.1.0,Component
v4.0.2)
MCA errmgr: default_orted (MCA v2.1.0,Component
v4.0.2)
MCA ess: pmi (MCA v2.1.0,Component v4.0.2)
MCA ess: singleton (MCA v2.1.0,Component
v4.0.2)
MCA ess: env (MCA v2.1.0,Component v4.0.2)
MCA ess: hnp (MCA v2.1.0,Component v4.0.2)
MCA ess: tool (MCA v2.1.0,Component v4.0.2)
MCA ess: slurm (MCA v2.1.0,Component v4.0.2)
MCA filem: raw (MCA v2.1.0,Component v4.0.2)
MCA grpcomm: direct (MCA v2.1.0,Component v4.0.2)
MCA iof: tool (MCA v2.1.0,Component v4.0.2)
MCA iof: orted (MCA v2.1.0,Component v4.0.2)
MCA iof: hnp (MCA v2.1.0,Component v4.0.2)
MCA odls: default (MCA v2.1.0,Component v4.0.2)
MCA odls: pspawn (MCA v2.1.0,Component v4.0.2)
MCA oob: tcp (MCA v2.1.0,Component v4.0.2)
MCA plm: rsh (MCA v2.1.0,Component v4.0.2)
MCA plm: isolated (MCA v2.1.0,Component v4.0.2)
MCA plm: slurm (MCA v2.1.0,Component v4.0.2)
MCA ras: simulator (MCA v2.1.0,Component
v4.0.2)
MCA ras: slurm (MCA v2.1.0,Component v4.0.2)
MCA ras: gridengine (MCA v2.1.0,Component
v4.0.2)
MCA regx: naive (MCA v2.1.0,Component v4.0.2)
MCA regx: reverse (MCA v2.1.0,Component v4.0.2)
MCA regx: fwd (MCA v2.1.0,Component v4.0.2)
MCA rmaps: rank_file (MCA v2.1.0,Component
v4.0.2)
MCA rmaps: seq (MCA v2.1.0,Component v4.0.2)
MCA rmaps: ppr (MCA v2.1.0,Component v4.0.2)
MCA rmaps: round_robin (MCA v2.1.0,Component
v4.0.2)
MCA rmaps: resilient (MCA v2.1.0,Component
v4.0.2)
MCA rmaps: mindist (MCA v2.1.0,Component v4.0.2)
MCA rml: oob (MCA v2.1.0,Component v4.0.2)
MCA routed: direct (MCA v2.1.0,Component v4.0.2)
MCA routed: radix (MCA v2.1.0,Component v4.0.2)
MCA routed: binomial (MCA v2.1.0,Component v4.0.2)
MCA rtc: hwloc (MCA v2.1.0,Component v4.0.2)
MCA schizo: slurm (MCA v2.1.0,Component v4.0.2)
MCA schizo: orte (MCA v2.1.0,Component v4.0.2)
MCA schizo: flux (MCA v2.1.0,Component v4.0.2)
MCA schizo: ompi (MCA v2.1.0,Component v4.0.2)
MCA state: orted (MCA v2.1.0,Component v4.0.2)
MCA state: hnp (MCA v2.1.0,Component v4.0.2)
MCA state: app (MCA v2.1.0,Component v4.0.2)
MCA state: tool (MCA v2.1.0,Component v4.0.2)
MCA state: novm (MCA v2.1.0,Component v4.0.2)
MCA bml: r2 (MCA v2.1.0,Component v4.0.2)
MCA coll: basic (MCA v2.1.0,Component v4.0.2)
MCA coll: libnbc (MCA v2.1.0,Component v4.0.2)
MCA coll: monitoring (MCA v2.1.0,Component
v4.0.2)
MCA coll: inter (MCA v2.1.0,Component v4.0.2)
MCA coll: tuned (MCA v2.1.0,Component v4.0.2)
MCA coll: self (MCA v2.1.0,Component v4.0.2)
MCA coll: sm (MCA v2.1.0,Component v4.0.2)
MCA coll: sync (MCA v2.1.0,Component v4.0.2)
MCA fbtl: posix (MCA v2.1.0,Component v4.0.2)
MCA fbtl: pvfs2 (MCA v2.1.0,Component v4.0.2)
MCA fcoll: dynamic_gen2 (MCA v2.1.0,Component
v4.0.2)
MCA fcoll: two_phase (MCA v2.1.0,Component
v4.0.2)
MCA fcoll: dynamic (MCA v2.1.0,Component v4.0.2)
MCA fcoll: individual (MCA v2.1.0,Component
v4.0.2)
MCA fcoll: vulcan (MCA v2.1.0,Component v4.0.2)
MCA fs: pvfs2 (MCA v2.1.0,Component v4.0.2)
MCA fs: ufs (MCA v2.1.0,Component v4.0.2)
MCA io: romio321 (MCA v2.1.0,Component v4.0.2)
MCA io: ompio (MCA v2.1.0,Component v4.0.2)
MCA mtl: psm2 (MCA v2.1.0,Component v4.0.2)
MCA mtl: ofi (MCA v2.1.0,Component v4.0.2)
MCA mtl: psm (MCA v2.1.0,Component v4.0.2)
MCA osc: sm (MCA v2.1.0,Component v4.0.2)
MCA osc: monitoring (MCA v2.1.0,Component
v4.0.2)
MCA osc: rdma (MCA v2.1.0,Component v4.0.2)
MCA osc: pt2pt (MCA v2.1.0,Component v4.0.2)
MCA osc: ucx (MCA v2.1.0,Component v4.0.2)
MCA pml: v (MCA v2.1.0,Component v4.0.2)
MCA pml: ucx (MCA v2.1.0,Component v4.0.2)
MCA pml: ob1 (MCA v2.1.0,Component v4.0.2)
MCA pml: cm (MCA v2.1.0,Component v4.0.2)
MCA pml: monitoring (MCA v2.1.0,Component
v4.0.2)
MCA rte: orte (MCA v2.1.0,Component v4.0.2)
MCA sharedfp: lockedfile (MCA v2.1.0,Component
v4.0.2)
MCA sharedfp: sm (MCA v2.1.0,Component v4.0.2)
MCA sharedfp: individual (MCA v2.1.0,Component
v4.0.2)
MCA topo: treematch (MCA v2.1.0,API v2.2.0,Component
v4.0.2)
MCA topo: basic (MCA v2.1.0,Component v4.0.2)
MCA vprotocol: pessimist (MCA v2.1.0,Component
v4.0.2)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。