diff options
author | Alexander Droste <alexander.ra.droste@gmail.com> | 2016-08-12 19:30:31 +0000 |
---|---|---|
committer | Alexander Droste <alexander.ra.droste@gmail.com> | 2016-08-12 19:30:31 +0000 |
commit | 1512f9a0f96f2795ca497099d3d39ed30cdaea33 (patch) | |
tree | 2a882a91b985b237d94b92dcd61b488060170dcf /clang-tools-extra/test/clang-tidy/mpi-buffer-deref.cpp | |
parent | af32ccb195ece1a25511d1d35d8c14ce1b58ee9b (diff) | |
download | bcm5719-llvm-1512f9a0f96f2795ca497099d3d39ed30cdaea33.tar.gz bcm5719-llvm-1512f9a0f96f2795ca497099d3d39ed30cdaea33.zip |
[clang-tidy] MPIBufferDerefCheck
...
This check verifies if a buffer passed to an MPI (Message Passing Interface)
function is sufficiently dereferenced. Buffers should be passed as a single
pointer or array. As MPI function signatures specify void * for their buffer
types, insufficiently dereferenced buffers can be passed, like for example
as double pointers or multidimensional arrays, without a compiler warning
emitted.
Instructions on how to apply the check can be found at:
https://github.com/0ax1/MPI-Checker/tree/master/examples
Reviewers: Haojian Wu
Differential revision: https://reviews.llvm.org/D22729
llvm-svn: 278553
Diffstat (limited to 'clang-tools-extra/test/clang-tidy/mpi-buffer-deref.cpp')
-rw-r--r-- | clang-tools-extra/test/clang-tidy/mpi-buffer-deref.cpp | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/clang-tools-extra/test/clang-tidy/mpi-buffer-deref.cpp b/clang-tools-extra/test/clang-tidy/mpi-buffer-deref.cpp new file mode 100644 index 00000000000..67304d23010 --- /dev/null +++ b/clang-tools-extra/test/clang-tidy/mpi-buffer-deref.cpp @@ -0,0 +1,50 @@ +// RUN: %check_clang_tidy %s mpi-buffer-deref %t -- -- -I %S/Inputs/mpi-type-mismatch + +#include "mpimock.h" + +void negativeTests() { + char *buf; + MPI_Send(&buf, 1, MPI_CHAR, 0, 0, MPI_COMM_WORLD); + // CHECK-MESSAGES: :[[@LINE-1]]:12: warning: buffer is insufficiently dereferenced: pointer->pointer [mpi-buffer-deref] + + unsigned **buf2; + MPI_Send(buf2, 1, MPI_UNSIGNED, 0, 0, MPI_COMM_WORLD); + // CHECK-MESSAGES: :[[@LINE-1]]:12: warning: buffer is insufficiently dereferenced: pointer->pointer + + short buf3[1][1]; + MPI_Send(buf3, 1, MPI_SHORT, 0, 0, MPI_COMM_WORLD); + // CHECK-MESSAGES: :[[@LINE-1]]:12: warning: buffer is insufficiently dereferenced: array->array + + long double _Complex *buf4[1]; + MPI_Send(buf4, 1, MPI_C_LONG_DOUBLE_COMPLEX, 0, 0, MPI_COMM_WORLD); + // CHECK-MESSAGES: :[[@LINE-1]]:12: warning: buffer is insufficiently dereferenced: pointer->array + + std::complex<float> *buf5[1][1]; + MPI_Send(&buf5, 1, MPI_CXX_FLOAT_COMPLEX, 0, 0, MPI_COMM_WORLD); + // CHECK-MESSAGES: :[[@LINE-1]]:12: warning: buffer is insufficiently dereferenced: pointer->array->array->pointer +} + +void positiveTests() { + char buf; + MPI_Send(&buf, 1, MPI_CHAR, 0, 0, MPI_COMM_WORLD); + + unsigned *buf2; + MPI_Send(buf2, 1, MPI_UNSIGNED, 0, 0, MPI_COMM_WORLD); + + short buf3[1][1]; + MPI_Send(buf3[0], 1, MPI_SHORT, 0, 0, MPI_COMM_WORLD); + + long double _Complex *buf4[1]; + MPI_Send(*buf4, 1, MPI_C_LONG_DOUBLE_COMPLEX, 0, 0, MPI_COMM_WORLD); + + long double _Complex buf5[1]; + MPI_Send(buf5, 1, MPI_C_LONG_DOUBLE_COMPLEX, 0, 0, MPI_COMM_WORLD); + + std::complex<float> *buf6[1][1]; + MPI_Send(*buf6[0], 1, MPI_CXX_FLOAT_COMPLEX, 0, 0, MPI_COMM_WORLD); + + // Referencing an array with '&' is valid, as this also points to the + // beginning of the array. + long double _Complex buf7[1]; + MPI_Send(&buf7, 1, MPI_C_LONG_DOUBLE_COMPLEX, 0, 0, MPI_COMM_WORLD); +} |