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

Side by Side Diff: sandbox/linux/bpf_dsl/bpf_dsl.h

Issue 511993005: sandbox: style cleanup (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 3 months 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 unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « no previous file | sandbox/linux/bpf_dsl/bpf_dsl.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef SANDBOX_LINUX_BPF_DSL_BPF_DSL_H_ 5 #ifndef SANDBOX_LINUX_BPF_DSL_BPF_DSL_H_
6 #define SANDBOX_LINUX_BPF_DSL_BPF_DSL_H_ 6 #define SANDBOX_LINUX_BPF_DSL_BPF_DSL_H_
7 7
8 #include <stdint.h> 8 #include <stdint.h>
9 9
10 #include <limits>
10 #include <utility> 11 #include <utility>
11 12
12 #include "base/macros.h" 13 #include "base/macros.h"
13 #include "base/memory/ref_counted.h" 14 #include "base/memory/ref_counted.h"
14 #include "sandbox/linux/bpf_dsl/cons.h" 15 #include "sandbox/linux/bpf_dsl/cons.h"
15 #include "sandbox/linux/seccomp-bpf/sandbox_bpf_policy.h" 16 #include "sandbox/linux/seccomp-bpf/sandbox_bpf_policy.h"
16 #include "sandbox/linux/seccomp-bpf/trap.h" 17 #include "sandbox/linux/seccomp-bpf/trap.h"
17 #include "sandbox/sandbox_export.h" 18 #include "sandbox/sandbox_export.h"
18 19
19 namespace sandbox { 20 namespace sandbox {
(...skipping 81 matching lines...) Expand 10 before | Expand all | Expand 10 after
101 virtual ResultExpr InvalidSyscall() const; 102 virtual ResultExpr InvalidSyscall() const;
102 103
103 // Override implementations from SandboxBPFPolicy. Marked as FINAL 104 // Override implementations from SandboxBPFPolicy. Marked as FINAL
104 // to prevent mixups with child classes accidentally overloading 105 // to prevent mixups with child classes accidentally overloading
105 // these instead of the above methods. 106 // these instead of the above methods.
106 virtual ErrorCode EvaluateSyscall(SandboxBPF* sb, 107 virtual ErrorCode EvaluateSyscall(SandboxBPF* sb,
107 int sysno) const OVERRIDE FINAL; 108 int sysno) const OVERRIDE FINAL;
108 virtual ErrorCode InvalidSyscall(SandboxBPF* sb) const OVERRIDE FINAL; 109 virtual ErrorCode InvalidSyscall(SandboxBPF* sb) const OVERRIDE FINAL;
109 110
110 // Helper method so policies can just write Trap(func, aux). 111 // Helper method so policies can just write Trap(func, aux).
111 static ResultExpr Trap(::sandbox::Trap::TrapFnc trap_func, void* aux); 112 static ResultExpr Trap(Trap::TrapFnc trap_func, void* aux);
112 113
113 private: 114 private:
114 DISALLOW_COPY_AND_ASSIGN(SandboxBPFDSLPolicy); 115 DISALLOW_COPY_AND_ASSIGN(SandboxBPFDSLPolicy);
115 }; 116 };
116 117
117 // Allow specifies a result that the system call should be allowed to 118 // Allow specifies a result that the system call should be allowed to
118 // execute normally. 119 // execute normally.
119 SANDBOX_EXPORT ResultExpr Allow(); 120 SANDBOX_EXPORT ResultExpr Allow();
120 121
121 // Error specifies a result that the system call should fail with 122 // Error specifies a result that the system call should fail with
122 // error number |err|. As a special case, Error(0) will result in the 123 // error number |err|. As a special case, Error(0) will result in the
123 // system call appearing to have succeeded, but without having any 124 // system call appearing to have succeeded, but without having any
124 // side effects. 125 // side effects.
125 SANDBOX_EXPORT ResultExpr Error(int err); 126 SANDBOX_EXPORT ResultExpr Error(int err);
126 127
127 // Trap specifies a result that the system call should be handled by 128 // Trap specifies a result that the system call should be handled by
128 // trapping back into userspace and invoking |trap_func|, passing 129 // trapping back into userspace and invoking |trap_func|, passing
129 // |aux| as the second parameter. 130 // |aux| as the second parameter.
130 SANDBOX_EXPORT ResultExpr Trap(::sandbox::Trap::TrapFnc trap_func, void* aux); 131 SANDBOX_EXPORT ResultExpr Trap(Trap::TrapFnc trap_func, void* aux);
131 132
132 template <typename T> 133 template <typename T>
133 class SANDBOX_EXPORT Arg { 134 class SANDBOX_EXPORT Arg {
134 public: 135 public:
135 // Initializes the Arg to represent the |num|th system call 136 // Initializes the Arg to represent the |num|th system call
136 // argument (indexed from 0), which is of type |T|. 137 // argument (indexed from 0), which is of type |T|.
137 explicit Arg(int num) : num_(num), mask_(-1) {} 138 explicit Arg(int num)
139 : num_(num), mask_(std::numeric_limits<uint64_t>::max()) {}
138 140
139 Arg(const Arg& arg) : num_(arg.num_), mask_(arg.mask_) {} 141 Arg(const Arg& arg) : num_(arg.num_), mask_(arg.mask_) {}
140 142
141 // Returns an Arg representing the current argument, but after 143 // Returns an Arg representing the current argument, but after
142 // bitwise-and'ing it with |rhs|. 144 // bitwise-and'ing it with |rhs|.
143 Arg operator&(uint64_t rhs) const { return Arg(num_, mask_ & rhs); } 145 friend Arg operator&(const Arg& lhs, uint64_t rhs) {
146 return Arg(lhs.num_, lhs.mask_ & rhs);
147 }
144 148
145 // Returns a boolean expression comparing whether the system call 149 // Returns a boolean expression comparing whether the system call
146 // argument (after applying any bitmasks, if appropriate) equals |rhs|. 150 // argument (after applying any bitmasks, if appropriate) equals |rhs|.
147 BoolExpr operator==(T rhs) const; 151 friend BoolExpr operator==(const Arg& lhs, T rhs) { return lhs.EqualTo(rhs); }
148 152
149 private: 153 private:
150 Arg(int num, uint64_t mask) : num_(num), mask_(mask) {} 154 Arg(int num, uint64_t mask) : num_(num), mask_(mask) {}
155
156 BoolExpr EqualTo(T val) const;
157
151 int num_; 158 int num_;
152 uint64_t mask_; 159 uint64_t mask_;
160
153 DISALLOW_ASSIGN(Arg); 161 DISALLOW_ASSIGN(Arg);
154 }; 162 };
155 163
156 // Various ways to combine boolean expressions into more complex expressions. 164 // Various ways to combine boolean expressions into more complex expressions.
157 // They follow standard boolean algebra laws. 165 // They follow standard boolean algebra laws.
158 SANDBOX_EXPORT BoolExpr operator!(BoolExpr cond); 166 SANDBOX_EXPORT BoolExpr operator!(const BoolExpr& cond);
159 SANDBOX_EXPORT BoolExpr operator&&(BoolExpr lhs, BoolExpr rhs); 167 SANDBOX_EXPORT BoolExpr operator&&(const BoolExpr& lhs, const BoolExpr& rhs);
160 SANDBOX_EXPORT BoolExpr operator||(BoolExpr lhs, BoolExpr rhs); 168 SANDBOX_EXPORT BoolExpr operator||(const BoolExpr& lhs, const BoolExpr& rhs);
161 169
162 // If begins a conditional result expression predicated on the 170 // If begins a conditional result expression predicated on the
163 // specified boolean expression. 171 // specified boolean expression.
164 SANDBOX_EXPORT Elser If(BoolExpr cond, ResultExpr then_result); 172 SANDBOX_EXPORT Elser If(const BoolExpr& cond, const ResultExpr& then_result);
165 173
166 class SANDBOX_EXPORT Elser { 174 class SANDBOX_EXPORT Elser {
167 public: 175 public:
168 Elser(const Elser& elser); 176 Elser(const Elser& elser);
169 ~Elser(); 177 ~Elser();
170 178
171 // ElseIf extends the conditional result expression with another 179 // ElseIf extends the conditional result expression with another
172 // "if then" clause, predicated on the specified boolean expression. 180 // "if then" clause, predicated on the specified boolean expression.
173 Elser ElseIf(BoolExpr cond, ResultExpr then_result) const; 181 Elser ElseIf(const BoolExpr& cond, const ResultExpr& then_result) const;
174 182
175 // Else terminates a conditional result expression using |else_result| as 183 // Else terminates a conditional result expression using |else_result| as
176 // the default fallback result expression. 184 // the default fallback result expression.
177 ResultExpr Else(ResultExpr else_result) const; 185 ResultExpr Else(const ResultExpr& else_result) const;
178 186
179 private: 187 private:
180 typedef std::pair<BoolExpr, ResultExpr> Clause; 188 typedef std::pair<BoolExpr, ResultExpr> Clause;
189
181 explicit Elser(Cons<Clause>::List clause_list); 190 explicit Elser(Cons<Clause>::List clause_list);
191
182 Cons<Clause>::List clause_list_; 192 Cons<Clause>::List clause_list_;
183 friend Elser If(BoolExpr, ResultExpr); 193
194 friend Elser If(const BoolExpr&, const ResultExpr&);
184 DISALLOW_ASSIGN(Elser); 195 DISALLOW_ASSIGN(Elser);
185 }; 196 };
186 197
187 // ===================================================================== 198 // =====================================================================
188 // Official API ends here. 199 // Official API ends here.
189 // ===================================================================== 200 // =====================================================================
190 201
191 // Definitions below are necessary here only for C++03 compatibility. 202 // Definitions below are necessary here only for C++03 compatibility.
192 // Once C++11 is available, they should be moved into bpf_dsl.cc via extern 203 // Once C++11 is available, they should be moved into bpf_dsl.cc via extern
193 // templates. 204 // templates.
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after
228 private: 239 private:
229 friend class base::RefCounted<ResultExprImpl>; 240 friend class base::RefCounted<ResultExprImpl>;
230 DISALLOW_COPY_AND_ASSIGN(ResultExprImpl); 241 DISALLOW_COPY_AND_ASSIGN(ResultExprImpl);
231 }; 242 };
232 243
233 } // namespace internal 244 } // namespace internal
234 245
235 // Definition requires ArgEq to have been declared. Moved out-of-line 246 // Definition requires ArgEq to have been declared. Moved out-of-line
236 // to minimize how much internal clutter users have to ignore while 247 // to minimize how much internal clutter users have to ignore while
237 // reading the header documentation. 248 // reading the header documentation.
249 //
250 // Additionally, we use this helper member function to avoid linker errors
251 // caused by defining operator== out-of-line. For a more detailed explanation,
252 // see http://www.parashift.com/c++-faq-lite/template-friends.html.
238 template <typename T> 253 template <typename T>
239 BoolExpr Arg<T>::operator==(T rhs) const { 254 BoolExpr Arg<T>::EqualTo(T val) const {
240 return internal::ArgEq(num_, sizeof(T), mask_, static_cast<uint64_t>(rhs)); 255 return internal::ArgEq(num_, sizeof(T), mask_, static_cast<uint64_t>(val));
241 } 256 }
242 257
243 } // namespace bpf_dsl 258 } // namespace bpf_dsl
244 } // namespace sandbox 259 } // namespace sandbox
245 260
246 #endif // SANDBOX_LINUX_BPF_DSL_BPF_DSL_H_ 261 #endif // SANDBOX_LINUX_BPF_DSL_BPF_DSL_H_
OLDNEW
« no previous file with comments | « no previous file | sandbox/linux/bpf_dsl/bpf_dsl.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698