blob: e431d2cb361d8bbac7f423129b93fdacc41f0e0e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
|
// Copyright (c) 2006-2008 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "sandbox/src/shared_handles.h"
namespace sandbox {
// Note once again the the assumption here is that the shared memory is
// initialized with zeros in the process that calls SetHandle and that
// the process that calls GetHandle 'sees' this memory.
SharedHandles::SharedHandles() {
shared_.items = NULL;
shared_.max_items = 0;
}
bool SharedHandles::Init(void* raw_mem, size_t size_bytes) {
if (size_bytes < sizeof(shared_.items[0])) {
// The shared memory is too small!
return false;
}
shared_.items = static_cast<SharedItem*>(raw_mem);
shared_.max_items = size_bytes / sizeof(shared_.items[0]);
return true;
}
// Note that an empty slot is marked with a tag == 0 that is why is
// not a valid imput tag
bool SharedHandles::SetHandle(uint32 tag, HANDLE handle) {
if (0 == tag) {
// Invalid tag
return false;
}
// Find empty slot and put the tag and the handle there
SharedItem* empty_slot = FindByTag(0);
if (NULL == empty_slot) {
return false;
}
empty_slot->tag = tag;
empty_slot->item = handle;
return true;
}
bool SharedHandles::GetHandle(uint32 tag, HANDLE* handle) {
if (0 == tag) {
// Invalid tag
return false;
}
SharedItem* found = FindByTag(tag);
if (NULL == found) {
return false;
}
*handle = found->item;
return true;
}
SharedHandles::SharedItem* SharedHandles::FindByTag(uint32 tag) {
for (size_t ix = 0; ix != shared_.max_items; ++ix) {
if (tag == shared_.items[ix].tag) {
return &shared_.items[ix];
}
}
return NULL;
}
} // namespace sandbox
|