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

Side by Side Diff: mojo/system/entrypoints.cc

Issue 418033005: Mojo: Change how we handle invalid pointer arguments (at the system layer). (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: review changes Created 6 years, 4 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 | « mojo/system/core_unittest.cc ('k') | mojo/system/mapping_table.h » ('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 #include "mojo/system/entrypoints.h" 5 #include "mojo/system/entrypoints.h"
6 6
7 #include "mojo/public/c/system/buffer.h" 7 #include "mojo/public/c/system/buffer.h"
8 #include "mojo/public/c/system/data_pipe.h" 8 #include "mojo/public/c/system/data_pipe.h"
9 #include "mojo/public/c/system/functions.h" 9 #include "mojo/public/c/system/functions.h"
10 #include "mojo/public/c/system/message_pipe.h" 10 #include "mojo/public/c/system/message_pipe.h"
11 #include "mojo/system/core.h" 11 #include "mojo/system/core.h"
12 12
13 static mojo::system::Core* g_core = NULL; 13 static mojo::system::Core* g_core = NULL;
14 14
15 using mojo::system::MakeUserPointer;
16 using mojo::system::MakeUserPointerValue;
17
15 namespace mojo { 18 namespace mojo {
16 namespace system { 19 namespace system {
17 namespace entrypoints { 20 namespace entrypoints {
18 21
19 void SetCore(Core* core) { 22 void SetCore(Core* core) {
20 g_core = core; 23 g_core = core;
21 } 24 }
22 25
23 Core* GetCore() { 26 Core* GetCore() {
24 return g_core; 27 return g_core;
(...skipping 17 matching lines...) Expand all
42 MojoResult MojoWait(MojoHandle handle, 45 MojoResult MojoWait(MojoHandle handle,
43 MojoHandleSignals signals, 46 MojoHandleSignals signals,
44 MojoDeadline deadline) { 47 MojoDeadline deadline) {
45 return g_core->Wait(handle, signals, deadline); 48 return g_core->Wait(handle, signals, deadline);
46 } 49 }
47 50
48 MojoResult MojoWaitMany(const MojoHandle* handles, 51 MojoResult MojoWaitMany(const MojoHandle* handles,
49 const MojoHandleSignals* signals, 52 const MojoHandleSignals* signals,
50 uint32_t num_handles, 53 uint32_t num_handles,
51 MojoDeadline deadline) { 54 MojoDeadline deadline) {
52 return g_core->WaitMany(handles, signals, num_handles, deadline); 55 return g_core->WaitMany(MakeUserPointer(handles),
56 MakeUserPointer(signals),
57 num_handles,
58 deadline);
53 } 59 }
54 60
55 MojoResult MojoCreateMessagePipe(const MojoCreateMessagePipeOptions* options, 61 MojoResult MojoCreateMessagePipe(const MojoCreateMessagePipeOptions* options,
56 MojoHandle* message_pipe_handle0, 62 MojoHandle* message_pipe_handle0,
57 MojoHandle* message_pipe_handle1) { 63 MojoHandle* message_pipe_handle1) {
58 return g_core->CreateMessagePipe( 64 return g_core->CreateMessagePipe(MakeUserPointer(options),
59 options, message_pipe_handle0, message_pipe_handle1); 65 MakeUserPointer(message_pipe_handle0),
66 MakeUserPointer(message_pipe_handle1));
60 } 67 }
61 68
62 MojoResult MojoWriteMessage(MojoHandle message_pipe_handle, 69 MojoResult MojoWriteMessage(MojoHandle message_pipe_handle,
63 const void* bytes, 70 const void* bytes,
64 uint32_t num_bytes, 71 uint32_t num_bytes,
65 const MojoHandle* handles, 72 const MojoHandle* handles,
66 uint32_t num_handles, 73 uint32_t num_handles,
67 MojoWriteMessageFlags flags) { 74 MojoWriteMessageFlags flags) {
68 return g_core->WriteMessage( 75 return g_core->WriteMessage(message_pipe_handle,
69 message_pipe_handle, bytes, num_bytes, handles, num_handles, flags); 76 MakeUserPointer(bytes),
77 num_bytes,
78 MakeUserPointer(handles),
79 num_handles,
80 flags);
70 } 81 }
71 82
72 MojoResult MojoReadMessage(MojoHandle message_pipe_handle, 83 MojoResult MojoReadMessage(MojoHandle message_pipe_handle,
73 void* bytes, 84 void* bytes,
74 uint32_t* num_bytes, 85 uint32_t* num_bytes,
75 MojoHandle* handles, 86 MojoHandle* handles,
76 uint32_t* num_handles, 87 uint32_t* num_handles,
77 MojoReadMessageFlags flags) { 88 MojoReadMessageFlags flags) {
78 return g_core->ReadMessage( 89 return g_core->ReadMessage(message_pipe_handle,
79 message_pipe_handle, bytes, num_bytes, handles, num_handles, flags); 90 MakeUserPointer(bytes),
91 MakeUserPointer(num_bytes),
92 MakeUserPointer(handles),
93 MakeUserPointer(num_handles),
94 flags);
80 } 95 }
81 96
82 MojoResult MojoCreateDataPipe(const MojoCreateDataPipeOptions* options, 97 MojoResult MojoCreateDataPipe(const MojoCreateDataPipeOptions* options,
83 MojoHandle* data_pipe_producer_handle, 98 MojoHandle* data_pipe_producer_handle,
84 MojoHandle* data_pipe_consumer_handle) { 99 MojoHandle* data_pipe_consumer_handle) {
85 return g_core->CreateDataPipe( 100 return g_core->CreateDataPipe(MakeUserPointer(options),
86 options, data_pipe_producer_handle, data_pipe_consumer_handle); 101 MakeUserPointer(data_pipe_producer_handle),
102 MakeUserPointer(data_pipe_consumer_handle));
87 } 103 }
88 104
89 MojoResult MojoWriteData(MojoHandle data_pipe_producer_handle, 105 MojoResult MojoWriteData(MojoHandle data_pipe_producer_handle,
90 const void* elements, 106 const void* elements,
91 uint32_t* num_elements, 107 uint32_t* num_elements,
92 MojoWriteDataFlags flags) { 108 MojoWriteDataFlags flags) {
93 return g_core->WriteData( 109 return g_core->WriteData(data_pipe_producer_handle,
94 data_pipe_producer_handle, elements, num_elements, flags); 110 MakeUserPointer(elements),
111 MakeUserPointer(num_elements),
112 flags);
95 } 113 }
96 114
97 MojoResult MojoBeginWriteData(MojoHandle data_pipe_producer_handle, 115 MojoResult MojoBeginWriteData(MojoHandle data_pipe_producer_handle,
98 void** buffer, 116 void** buffer,
99 uint32_t* buffer_num_elements, 117 uint32_t* buffer_num_elements,
100 MojoWriteDataFlags flags) { 118 MojoWriteDataFlags flags) {
101 return g_core->BeginWriteData( 119 return g_core->BeginWriteData(data_pipe_producer_handle,
102 data_pipe_producer_handle, buffer, buffer_num_elements, flags); 120 MakeUserPointer(buffer),
121 MakeUserPointer(buffer_num_elements),
122 flags);
103 } 123 }
104 124
105 MojoResult MojoEndWriteData(MojoHandle data_pipe_producer_handle, 125 MojoResult MojoEndWriteData(MojoHandle data_pipe_producer_handle,
106 uint32_t num_elements_written) { 126 uint32_t num_elements_written) {
107 return g_core->EndWriteData(data_pipe_producer_handle, num_elements_written); 127 return g_core->EndWriteData(data_pipe_producer_handle, num_elements_written);
108 } 128 }
109 129
110 MojoResult MojoReadData(MojoHandle data_pipe_consumer_handle, 130 MojoResult MojoReadData(MojoHandle data_pipe_consumer_handle,
111 void* elements, 131 void* elements,
112 uint32_t* num_elements, 132 uint32_t* num_elements,
113 MojoReadDataFlags flags) { 133 MojoReadDataFlags flags) {
114 return g_core->ReadData( 134 return g_core->ReadData(data_pipe_consumer_handle,
115 data_pipe_consumer_handle, elements, num_elements, flags); 135 MakeUserPointer(elements),
136 MakeUserPointer(num_elements),
137 flags);
116 } 138 }
117 139
118 MojoResult MojoBeginReadData(MojoHandle data_pipe_consumer_handle, 140 MojoResult MojoBeginReadData(MojoHandle data_pipe_consumer_handle,
119 const void** buffer, 141 const void** buffer,
120 uint32_t* buffer_num_elements, 142 uint32_t* buffer_num_elements,
121 MojoReadDataFlags flags) { 143 MojoReadDataFlags flags) {
122 return g_core->BeginReadData( 144 return g_core->BeginReadData(data_pipe_consumer_handle,
123 data_pipe_consumer_handle, buffer, buffer_num_elements, flags); 145 MakeUserPointer(buffer),
146 MakeUserPointer(buffer_num_elements),
147 flags);
124 } 148 }
125 149
126 MojoResult MojoEndReadData(MojoHandle data_pipe_consumer_handle, 150 MojoResult MojoEndReadData(MojoHandle data_pipe_consumer_handle,
127 uint32_t num_elements_read) { 151 uint32_t num_elements_read) {
128 return g_core->EndReadData(data_pipe_consumer_handle, num_elements_read); 152 return g_core->EndReadData(data_pipe_consumer_handle, num_elements_read);
129 } 153 }
130 154
131 MojoResult MojoCreateSharedBuffer( 155 MojoResult MojoCreateSharedBuffer(
132 const struct MojoCreateSharedBufferOptions* options, 156 const struct MojoCreateSharedBufferOptions* options,
133 uint64_t num_bytes, 157 uint64_t num_bytes,
134 MojoHandle* shared_buffer_handle) { 158 MojoHandle* shared_buffer_handle) {
135 return g_core->CreateSharedBuffer(options, num_bytes, shared_buffer_handle); 159 return g_core->CreateSharedBuffer(MakeUserPointer(options),
160 num_bytes,
161 MakeUserPointer(shared_buffer_handle));
136 } 162 }
137 163
138 MojoResult MojoDuplicateBufferHandle( 164 MojoResult MojoDuplicateBufferHandle(
139 MojoHandle buffer_handle, 165 MojoHandle buffer_handle,
140 const struct MojoDuplicateBufferHandleOptions* options, 166 const struct MojoDuplicateBufferHandleOptions* options,
141 MojoHandle* new_buffer_handle) { 167 MojoHandle* new_buffer_handle) {
142 return g_core->DuplicateBufferHandle( 168 return g_core->DuplicateBufferHandle(buffer_handle,
143 buffer_handle, options, new_buffer_handle); 169 MakeUserPointer(options),
170 MakeUserPointer(new_buffer_handle));
144 } 171 }
145 172
146 MojoResult MojoMapBuffer(MojoHandle buffer_handle, 173 MojoResult MojoMapBuffer(MojoHandle buffer_handle,
147 uint64_t offset, 174 uint64_t offset,
148 uint64_t num_bytes, 175 uint64_t num_bytes,
149 void** buffer, 176 void** buffer,
150 MojoMapBufferFlags flags) { 177 MojoMapBufferFlags flags) {
151 return g_core->MapBuffer(buffer_handle, offset, num_bytes, buffer, flags); 178 return g_core->MapBuffer(buffer_handle,
179 offset,
180 num_bytes,
181 MakeUserPointer(buffer),
182 flags);
152 } 183 }
153 184
154 MojoResult MojoUnmapBuffer(void* buffer) { 185 MojoResult MojoUnmapBuffer(void* buffer) {
155 return g_core->UnmapBuffer(buffer); 186 return g_core->UnmapBuffer(MakeUserPointerValue(buffer));
156 } 187 }
157 188
158 } // extern "C" 189 } // extern "C"
OLDNEW
« no previous file with comments | « mojo/system/core_unittest.cc ('k') | mojo/system/mapping_table.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698