summaryrefslogtreecommitdiffstats
path: root/clang-tools-extra/clang-tidy/android/CloexecPipe2Check.cpp
diff options
context:
space:
mode:
authorGeorge Burgess IV <george.burgess.iv@gmail.com>2019-06-06 05:21:39 +0000
committerGeorge Burgess IV <george.burgess.iv@gmail.com>2019-06-06 05:21:39 +0000
commit3da331b456214c51b1735d02d304df91930cd461 (patch)
tree25f41650db39809fa3d7d360f96558b955d476b1 /clang-tools-extra/clang-tidy/android/CloexecPipe2Check.cpp
parent5e7ca755d8c75c92ff42874846885d37157e55eb (diff)
downloadbcm5719-llvm-3da331b456214c51b1735d02d304df91930cd461.tar.gz
bcm5719-llvm-3da331b456214c51b1735d02d304df91930cd461.zip
android: add a close-on-exec check on pipe2()
On Android, pipe2() is better to set O_CLOEXEC flag to avoid file descriptor leakage. Patch by Jian Cai! Differential Revision: https://reviews.llvm.org/D62049 llvm-svn: 362672
Diffstat (limited to 'clang-tools-extra/clang-tidy/android/CloexecPipe2Check.cpp')
-rw-r--r--clang-tools-extra/clang-tidy/android/CloexecPipe2Check.cpp33
1 files changed, 33 insertions, 0 deletions
diff --git a/clang-tools-extra/clang-tidy/android/CloexecPipe2Check.cpp b/clang-tools-extra/clang-tidy/android/CloexecPipe2Check.cpp
new file mode 100644
index 00000000000..7e3107da3b7
--- /dev/null
+++ b/clang-tools-extra/clang-tidy/android/CloexecPipe2Check.cpp
@@ -0,0 +1,33 @@
+//===--- CloexecPipe2Check.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 "CloexecPipe2Check.h"
+#include "../utils/ASTUtils.h"
+#include "clang/AST/ASTContext.h"
+#include "clang/ASTMatchers/ASTMatchFinder.h"
+
+using namespace clang::ast_matchers;
+
+namespace clang {
+namespace tidy {
+namespace android {
+
+void CloexecPipe2Check::registerMatchers(MatchFinder *Finder) {
+ registerMatchersImpl(Finder,
+ functionDecl(returns(isInteger()), hasName("pipe2"),
+ hasParameter(0, hasType(pointsTo(isInteger()))),
+ hasParameter(1, hasType(isInteger()))));
+}
+
+void CloexecPipe2Check::check(const MatchFinder::MatchResult &Result) {
+ insertMacroFlag(Result, /*MacroFlag=*/"O_CLOEXEC", /*ArgPos=*/1);
+}
+
+} // namespace android
+} // namespace tidy
+} // namespace clang
OpenPOWER on IntegriCloud