OLD | NEW |
---|---|
(Empty) | |
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_SYSCALL_ITERATOR_H__ | |
6 #define SANDBOX_LINUX_SECCOMP_BPF_SYSCALL_ITERATOR_H__ | |
7 | |
8 #include <stdint.h> | |
9 | |
10 #include <base/logging.h> | |
11 | |
12 namespace playground2 { | |
13 | |
14 // Iterates over the entire system call range from 0..0xFFFFFFFFu. This | |
15 // iterator is aware of how system calls look like and will skip quickly | |
16 // over ranges that can't contain system calls. It iterates more slowly | |
17 // whenever it reaches a range that is potentially problematic, returning | |
18 // the last invalid value before a valid range of system calls, and the | |
19 // first invalid value after a valid range of syscalls. It iterates over | |
20 // individual values whenever it is in the normal range for system calls | |
21 // (typically MIN_SYSCALL..MAX_SYSCALL). | |
22 // If |invalid_only| is true, this iterator will only return invalid | |
23 // syscall numbers, but will still skip quickly over invalid ranges, | |
24 // returning the first invalid value in the range and then skipping | |
25 // to the last invalid value in the range. | |
26 // | |
27 // Example usage: | |
28 // for (SyscallIterator iter(false); !iter.Done(); ) { | |
29 // uint32_t sysnum = iter.Next(); | |
30 // // Do something with sysnum. | |
31 // } | |
32 // | |
33 // TODO(markus): Make this a classic C++ iterator. | |
34 class SyscallIterator { | |
35 public: | |
36 explicit SyscallIterator(bool invalid_only) | |
37 : invalid_only_(invalid_only), | |
jln (very slow on Chromium)
2012/10/13 17:44:55
Yeah the indent is right, for some reason the revi
Jorge Lucangeli Obes
2012/10/15 17:25:36
Done.
| |
38 done_(false), | |
39 num_(MIN_SYSCALL) {} | |
jln (very slow on Chromium)
2012/10/13 17:44:55
I'm sorry I'm being picky about the details, but t
Jorge Lucangeli Obes
2012/10/15 17:25:36
Done. It's clear now what you meant.
| |
40 | |
41 bool Done() const { return done_; } | |
42 uint32_t Next(); | |
43 static bool IsValid(uint32_t num); | |
44 | |
45 private: | |
46 static bool IsArmPrivate(uint32_t num); | |
47 | |
48 bool invalid_only_; | |
49 bool done_; | |
50 uint32_t num_; | |
51 | |
52 DISALLOW_COPY_AND_ASSIGN(SyscallIterator); | |
53 }; | |
54 | |
55 } // namespace playground2 | |
56 | |
57 #endif // SANDBOX_LINUX_SECCOMP_BPF_SYSCALL_ITERATOR_H__ | |
58 | |
OLD | NEW |