aboutsummaryrefslogtreecommitdiff
path: root/clang-tools-extra/clang-tidy/android/CloexecPipeCheck.cpp
diff options
context:
space:
mode:
authorGeorge Burgess IV <george.burgess.iv@gmail.com>2019-06-06 05:21:45 +0000
committerGeorge Burgess IV <george.burgess.iv@gmail.com>2019-06-06 05:21:45 +0000
commit5b2a85d0ded21097885900889faa871fdb2e71b5 (patch)
tree040307052a8a0d7a911cf74d7c617a32cfea801c /clang-tools-extra/clang-tidy/android/CloexecPipeCheck.cpp
parent3da331b456214c51b1735d02d304df91930cd461 (diff)
downloadllvm-5b2a85d0ded21097885900889faa871fdb2e71b5.zip
llvm-5b2a85d0ded21097885900889faa871fdb2e71b5.tar.gz
llvm-5b2a85d0ded21097885900889faa871fdb2e71b5.tar.bz2
android: add a close-on-exec check on pipe()
On Android, pipe() is better to be replaced by pipe2() with O_CLOEXEC flag to avoid file descriptor leakage. Patch by Jian Cai! Differential Revision: https://reviews.llvm.org/D61967 llvm-svn: 362673
Diffstat (limited to 'clang-tools-extra/clang-tidy/android/CloexecPipeCheck.cpp')
-rw-r--r--clang-tools-extra/clang-tidy/android/CloexecPipeCheck.cpp37
1 files changed, 37 insertions, 0 deletions
diff --git a/clang-tools-extra/clang-tidy/android/CloexecPipeCheck.cpp b/clang-tools-extra/clang-tidy/android/CloexecPipeCheck.cpp
new file mode 100644
index 0000000..94b9450
--- /dev/null
+++ b/clang-tools-extra/clang-tidy/android/CloexecPipeCheck.cpp
@@ -0,0 +1,37 @@
+//===--- CloexecPipeCheck.cpp - clang-tidy---------------------------------===//
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+
+#include "CloexecPipeCheck.h"
+#include "clang/AST/ASTContext.h"
+#include "clang/ASTMatchers/ASTMatchFinder.h"
+
+using namespace clang::ast_matchers;
+
+namespace clang {
+namespace tidy {
+namespace android {
+
+void CloexecPipeCheck::registerMatchers(MatchFinder *Finder) {
+ registerMatchersImpl(Finder,
+ functionDecl(returns(isInteger()), hasName("pipe"),
+ hasParameter(0, hasType(pointsTo(isInteger())))));
+}
+
+void CloexecPipeCheck::check(const MatchFinder::MatchResult &Result) {
+ std::string ReplacementText =
+ (Twine("pipe2(") + getSpellingArg(Result, 0) + ", O_CLOEXEC)").str();
+
+ replaceFunc(
+ Result,
+ "prefer pipe2() with O_CLOEXEC to avoid leaking file descriptors to child processes",
+ ReplacementText);
+}
+
+} // namespace android
+} // namespace tidy
+} // namespace clang