• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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.
4 
5 #ifndef SANDBOX_LINUX_SECCOMP_BPF_BASICBLOCK_H__
6 #define SANDBOX_LINUX_SECCOMP_BPF_BASICBLOCK_H__
7 
8 #include <vector>
9 
10 #include "sandbox/linux/seccomp-bpf/instruction.h"
11 
12 namespace sandbox {
13 
14 struct BasicBlock {
15   BasicBlock();
16   ~BasicBlock();
17 
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:
LessBasicBlock25     Less(const T& data,
26          int (*cmp)(const BasicBlock*, const BasicBlock*, const T& data))
27         : data_(data), cmp_(cmp) {}
28 
operatorBasicBlock29     bool operator()(const BasicBlock* a, const BasicBlock* b) const {
30       return cmp_(a, b, data_) < 0;
31     }
32 
33    private:
34     const T& data_;
35     int (*cmp_)(const BasicBlock*, const BasicBlock*, const T&);
36   };
37 
38   // Basic blocks are essentially nothing more than a set of instructions.
39   std::vector<Instruction*> instructions;
40 
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;
45 };
46 
47 }  // namespace sandbox
48 
49 #endif  // SANDBOX_LINUX_SECCOMP_BPF_BASICBLOCK_H__
50