Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(864)

Unified Diff: sandbox/linux/seccomp-bpf/codegen.cc

Issue 703533002: CodeGen: refactor API [1/3] (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: s/Addr/Node/ and tweak comments Created 6 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « sandbox/linux/seccomp-bpf/codegen.h ('k') | sandbox/linux/seccomp-bpf/codegen_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: sandbox/linux/seccomp-bpf/codegen.cc
diff --git a/sandbox/linux/seccomp-bpf/codegen.cc b/sandbox/linux/seccomp-bpf/codegen.cc
index 1ee79b6ed0e9031e4b4104ba2ab8bbbea4fd433a..18d26daa0e9897daa3f5f6386b190dc0e94f790a 100644
--- a/sandbox/linux/seccomp-bpf/codegen.cc
+++ b/sandbox/linux/seccomp-bpf/codegen.cc
@@ -15,6 +15,11 @@
namespace sandbox {
+// Unfortunately this needs to be defined out-of-line because inline
+// initializing a static member to "nullptr" requires "constexpr",
+// which is currently banned by the Chromium style guide.
+const CodeGen::Node CodeGen::kNullNode = nullptr;
+
CodeGen::CodeGen() : compiled_(false) {}
CodeGen::~CodeGen() {
@@ -30,47 +35,28 @@ CodeGen::~CodeGen() {
}
}
-Instruction* CodeGen::MakeInstruction(uint16_t code,
- uint32_t k,
- Instruction* next) {
- // We can handle non-jumping instructions and "always" jumps. Both of
- // them are followed by exactly one "next" instruction.
- // We allow callers to defer specifying "next", but then they must call
- // "joinInstructions" later.
- if (BPF_CLASS(code) == BPF_JMP && BPF_OP(code) != BPF_JA) {
- SANDBOX_DIE(
- "Must provide both \"true\" and \"false\" branch "
- "for a BPF_JMP");
- }
- if (next && BPF_CLASS(code) == BPF_RET) {
- SANDBOX_DIE("Cannot append instructions after a return statement");
- }
+CodeGen::Node CodeGen::MakeInstruction(uint16_t code,
+ uint32_t k,
+ Node jt,
+ Node jf) {
+ Node insn;
if (BPF_CLASS(code) == BPF_JMP) {
- // "Always" jumps use the "true" branch target, only.
- Instruction* insn = new Instruction(code, 0, next, NULL);
- instructions_.push_back(insn);
- return insn;
+ CHECK_NE(kNullNode, jt);
+ if (BPF_OP(code) == BPF_JA) {
+ CHECK_EQ(kNullNode, jf);
+ } else {
+ CHECK_NE(kNullNode, jf);
+ }
+ insn = new Instruction(code, k, jt, jf);
} else {
- // Non-jumping instructions do not use any of the branch targets.
- Instruction* insn = new Instruction(code, k, next);
- instructions_.push_back(insn);
- return insn;
- }
-}
-
-Instruction* CodeGen::MakeInstruction(uint16_t code,
- uint32_t k,
- Instruction* jt,
- Instruction* jf) {
- // We can handle all conditional jumps. They are followed by both a
- // "true" and a "false" branch.
- if (BPF_CLASS(code) != BPF_JMP || BPF_OP(code) == BPF_JA) {
- SANDBOX_DIE("Expected a BPF_JMP instruction");
- }
- if (!jt || !jf) {
- SANDBOX_DIE("Branches must jump to a valid instruction");
+ if (BPF_CLASS(code) == BPF_RET) {
+ CHECK_EQ(kNullNode, jt);
+ } else {
+ CHECK_NE(kNullNode, jt);
+ }
+ CHECK_EQ(kNullNode, jf);
+ insn = new Instruction(code, k, jt);
}
- Instruction* insn = new Instruction(code, k, jt, jf);
instructions_.push_back(insn);
return insn;
}
« no previous file with comments | « sandbox/linux/seccomp-bpf/codegen.h ('k') | sandbox/linux/seccomp-bpf/codegen_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698