Updating trunk VERSION from 2139.0 to 2140.0
[chromium-blink-merge.git] / sandbox / linux / seccomp-bpf / basicblock.h
blobd15a372cfea083b7c8bf29398f0a901ff84880b7
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef SANDBOX_LINUX_SECCOMP_BPF_BASICBLOCK_H__
6 #define SANDBOX_LINUX_SECCOMP_BPF_BASICBLOCK_H__
8 #include <vector>
10 #include "sandbox/linux/seccomp-bpf/instruction.h"
12 namespace sandbox {
14 struct BasicBlock {
15 BasicBlock();
16 ~BasicBlock();
18 // Our implementation of the code generator uses a "Less" operator to
19 // identify common sequences of basic blocks. This would normally be
20 // really easy to do, but STL requires us to wrap the comparator into
21 // a class. We begrudgingly add some code here that provides this wrapping.
22 template <class T>
23 class Less {
24 public:
25 Less(const T& data,
26 int (*cmp)(const BasicBlock*, const BasicBlock*, const T& data))
27 : data_(data), cmp_(cmp) {}
29 bool operator()(const BasicBlock* a, const BasicBlock* b) const {
30 return cmp_(a, b, data_) < 0;
33 private:
34 const T& data_;
35 int (*cmp_)(const BasicBlock*, const BasicBlock*, const T&);
38 // Basic blocks are essentially nothing more than a set of instructions.
39 std::vector<Instruction*> instructions;
41 // In order to compute relative branch offsets we need to keep track of
42 // how far our block is away from the very last basic block. The "offset_"
43 // is measured in number of BPF instructions.
44 int offset;
47 } // namespace sandbox
49 #endif // SANDBOX_LINUX_SECCOMP_BPF_BASICBLOCK_H__