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

Side by Side Diff: ppapi/proxy/file_mapping_resource.h

Issue 69663002: PPAPI: Implement PPB_FileMapping on POSIX (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: bbudge review comment, fix windows build (probably) Created 6 years, 10 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
OLDNEW
(Empty)
1 // Copyright (c) 2014 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 PPAPI_PROXY_FILE_MAPPING_RESOURCE_H_
6 #define PPAPI_PROXY_FILE_MAPPING_RESOURCE_H_
7
8 #include "ppapi/proxy/file_io_resource.h"
9 #include "ppapi/proxy/plugin_resource.h"
10 #include "ppapi/proxy/ppapi_proxy_export.h"
11 #include "ppapi/thunk/ppb_file_mapping_api.h"
12
13 namespace ppapi {
14 namespace proxy {
15
16 // The proxy-side resource for PPB_FileMapping.
17 class PPAPI_PROXY_EXPORT FileMappingResource
18 : public PluginResource,
19 public thunk::PPB_FileMapping_API {
20 public:
21 FileMappingResource(Connection connection, PP_Instance instance);
22
23 private:
24 virtual ~FileMappingResource();
25
26 // Resource implementation.
27 virtual thunk::PPB_FileMapping_API* AsPPB_FileMapping_API() OVERRIDE;
28
29 // PPB_FileMapping_API implementation.
30 virtual int32_t Map(PP_Instance instance,
31 PP_Resource file_io,
32 int64_t length,
33 uint32_t map_protection,
34 uint32_t map_flags,
35 int64_t offset,
36 void** address,
37 scoped_refptr<TrackedCallback> callback) OVERRIDE;
38 virtual int32_t Unmap(PP_Instance instance,
39 const void* address,
40 int64_t length,
41 scoped_refptr<TrackedCallback> callback) OVERRIDE;
42 virtual int64_t GetMapPageSize(PP_Instance instance) OVERRIDE;
43
44 struct MapResult {
45 MapResult() : result(PP_ERROR_FAILED), address(NULL) {
46 }
47 int32_t result;
48 void* address;
49 };
50 void OnMapCompleted(void** mapped_address_out_param,
51 int64_t length,
52 scoped_refptr<TrackedCallback> callback,
53 const MapResult& map_result);
54
55 // These perform the actual operations in platform-dependent ways,
56 // synchronously on the thread on which their invoked, and do not require the
57 // the proxy lock to be acquired. Map, Unmap, and GetMapPageSize forward
58 // calls to these. See file_mapping_resource_posix.cc and
59 // file_mapping_resource_win.cc for the implementations of the Do* functions.
bbudge 2014/01/25 01:04:55 Rework. How about this? // These functions perf
dmichael (off chromium) 2014/01/27 18:29:53 Thanks, that's much better. Only downside is I don
60 static MapResult DoMap(scoped_refptr<FileIOResource::FileHandleHolder> handle,
61 void* address_hint,
62 int64_t length,
63 uint32_t map_protection,
64 uint32_t map_flags,
65 int64_t offset);
66 static int32_t DoUnmap(const void* address,
67 int64_t length);
68 static int64_t DoGetMapPageSize();
69
70 DISALLOW_COPY_AND_ASSIGN(FileMappingResource);
71 };
72
73 } // namespace proxy
74 } // namespace ppapi
75
76 #endif // PPAPI_PROXY_FILE_MAPPING_RESOURCE_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698