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

Unified Diff: sandbox/linux/bpf_dsl/policy_compiler.cc

Issue 703533002: CodeGen: refactor API [1/3] (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: 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
Index: sandbox/linux/bpf_dsl/policy_compiler.cc
diff --git a/sandbox/linux/bpf_dsl/policy_compiler.cc b/sandbox/linux/bpf_dsl/policy_compiler.cc
index 5be32f4f65b2d8c740ac33bde22101abac7bb846..4e8429852509cb7d398ae0edb39e7bd6b2953f56 100644
--- a/sandbox/linux/bpf_dsl/policy_compiler.cc
+++ b/sandbox/linux/bpf_dsl/policy_compiler.cc
@@ -18,7 +18,6 @@
#include "sandbox/linux/seccomp-bpf/codegen.h"
#include "sandbox/linux/seccomp-bpf/die.h"
#include "sandbox/linux/seccomp-bpf/errorcode.h"
-#include "sandbox/linux/seccomp-bpf/instruction.h"
#include "sandbox/linux/seccomp-bpf/linux_seccomp.h"
#include "sandbox/linux/seccomp-bpf/syscall.h"
#include "sandbox/linux/seccomp-bpf/syscall_iterator.h"
@@ -146,7 +145,7 @@ scoped_ptr<CodeGen::Program> PolicyCompiler::Compile() {
return program.Pass();
}
-Instruction* PolicyCompiler::AssemblePolicy() {
+CodeGen::Addr PolicyCompiler::AssemblePolicy() {
// A compiled policy consists of three logical parts:
// 1. Check that the "arch" field matches the expected architecture.
// 2. If the policy involves unsafe traps, check if the syscall was
@@ -156,7 +155,7 @@ Instruction* PolicyCompiler::AssemblePolicy() {
return CheckArch(MaybeAddEscapeHatch(DispatchSyscall()));
}
-Instruction* PolicyCompiler::CheckArch(Instruction* passed) {
+CodeGen::Addr PolicyCompiler::CheckArch(CodeGen::Addr passed) {
// If the architecture doesn't match SECCOMP_ARCH, disallow the
// system call.
return gen_.MakeInstruction(
@@ -169,7 +168,7 @@ Instruction* PolicyCompiler::CheckArch(Instruction* passed) {
RetExpression(Kill("Invalid audit architecture in BPF filter"))));
}
-Instruction* PolicyCompiler::MaybeAddEscapeHatch(Instruction* rest) {
+CodeGen::Addr PolicyCompiler::MaybeAddEscapeHatch(CodeGen::Addr rest) {
// If no unsafe traps, then simply return |rest|.
if (!has_unsafe_traps_) {
return rest;
@@ -206,14 +205,14 @@ Instruction* PolicyCompiler::MaybeAddEscapeHatch(Instruction* rest) {
rest));
}
-Instruction* PolicyCompiler::DispatchSyscall() {
+CodeGen::Addr PolicyCompiler::DispatchSyscall() {
// Evaluate all possible system calls and group their ErrorCodes into
// ranges of identical codes.
Ranges ranges;
FindRanges(&ranges);
// Compile the system call ranges to an optimized BPF jumptable
- Instruction* jumptable = AssembleJumpTable(ranges.begin(), ranges.end());
+ CodeGen::Addr jumptable = AssembleJumpTable(ranges.begin(), ranges.end());
// Grab the system call number, so that we can check it and then
// execute the jump table.
@@ -221,11 +220,11 @@ Instruction* PolicyCompiler::DispatchSyscall() {
BPF_LD + BPF_W + BPF_ABS, SECCOMP_NR_IDX, CheckSyscallNumber(jumptable));
}
-Instruction* PolicyCompiler::CheckSyscallNumber(Instruction* passed) {
+CodeGen::Addr PolicyCompiler::CheckSyscallNumber(CodeGen::Addr passed) {
if (kIsIntel) {
// On Intel architectures, verify that system call numbers are in the
// expected number range.
- Instruction* invalidX32 =
+ CodeGen::Addr invalidX32 =
RetExpression(Kill("Illegal mixing of system call ABIs"));
if (kIsX32) {
// The newer x32 API always sets bit 30.
@@ -268,8 +267,8 @@ void PolicyCompiler::FindRanges(Ranges* ranges) {
ranges->push_back(Range(old_sysnum, old_err));
}
-Instruction* PolicyCompiler::AssembleJumpTable(Ranges::const_iterator start,
- Ranges::const_iterator stop) {
+CodeGen::Addr PolicyCompiler::AssembleJumpTable(Ranges::const_iterator start,
+ Ranges::const_iterator stop) {
// We convert the list of system call ranges into jump table that performs
// a binary search over the ranges.
// As a sanity check, we need to have at least one distinct ranges for us
@@ -289,12 +288,12 @@ Instruction* PolicyCompiler::AssembleJumpTable(Ranges::const_iterator start,
Ranges::const_iterator mid = start + (stop - start) / 2;
// Sub-divide the list of ranges and continue recursively.
- Instruction* jf = AssembleJumpTable(start, mid);
- Instruction* jt = AssembleJumpTable(mid, stop);
+ CodeGen::Addr jf = AssembleJumpTable(start, mid);
+ CodeGen::Addr jt = AssembleJumpTable(mid, stop);
return gen_.MakeInstruction(BPF_JMP + BPF_JGE + BPF_K, mid->from, jt, jf);
}
-Instruction* PolicyCompiler::RetExpression(const ErrorCode& err) {
+CodeGen::Addr PolicyCompiler::RetExpression(const ErrorCode& err) {
switch (err.error_type()) {
case ErrorCode::ET_COND:
return CondExpression(err);
@@ -306,7 +305,7 @@ Instruction* PolicyCompiler::RetExpression(const ErrorCode& err) {
}
}
-Instruction* PolicyCompiler::CondExpression(const ErrorCode& cond) {
+CodeGen::Addr PolicyCompiler::CondExpression(const ErrorCode& cond) {
// Sanity check that |cond| makes sense.
if (cond.argno_ < 0 || cond.argno_ >= 6) {
SANDBOX_DIE("sandbox_bpf: invalid argument number");
@@ -328,8 +327,8 @@ Instruction* PolicyCompiler::CondExpression(const ErrorCode& cond) {
// TODO(mdempsky): Reject TP_64BIT on 32-bit platforms. For now we allow it
// because some SandboxBPF unit tests exercise it.
- Instruction* passed = RetExpression(*cond.passed_);
- Instruction* failed = RetExpression(*cond.failed_);
+ CodeGen::Addr passed = RetExpression(*cond.passed_);
+ CodeGen::Addr failed = RetExpression(*cond.failed_);
// We want to emit code to check "(arg & mask) == value" where arg, mask, and
// value are 64-bit values, but the BPF machine is only 32-bit. We implement
@@ -341,16 +340,16 @@ Instruction* PolicyCompiler::CondExpression(const ErrorCode& cond) {
failed);
}
-Instruction* PolicyCompiler::CondExpressionHalf(const ErrorCode& cond,
- ArgHalf half,
- Instruction* passed,
- Instruction* failed) {
+CodeGen::Addr PolicyCompiler::CondExpressionHalf(const ErrorCode& cond,
+ ArgHalf half,
+ CodeGen::Addr passed,
+ CodeGen::Addr failed) {
if (cond.width_ == ErrorCode::TP_32BIT && half == UpperHalf) {
// Special logic for sanity checking the upper 32-bits of 32-bit system
// call arguments.
// TODO(mdempsky): Compile Unexpected64bitArgument() just per program.
- Instruction* invalid_64bit = RetExpression(Unexpected64bitArgument());
+ CodeGen::Addr invalid_64bit = RetExpression(Unexpected64bitArgument());
const uint32_t upper = SECCOMP_ARG_MSB_IDX(cond.argno_);
const uint32_t lower = SECCOMP_ARG_LSB_IDX(cond.argno_);

Powered by Google App Engine
This is Rietveld 408576698