diff options
Diffstat (limited to 'ppapi')
-rw-r--r-- | ppapi/proxy/file_io_resource.cc | 4 | ||||
-rw-r--r-- | ppapi/proxy/file_system_resource.cc | 17 | ||||
-rw-r--r-- | ppapi/proxy/file_system_resource_unittest.cc | 18 | ||||
-rw-r--r-- | ppapi/proxy/nacl_message_scanner.cc | 35 | ||||
-rw-r--r-- | ppapi/proxy/nacl_message_scanner_unittest.cc | 32 | ||||
-rw-r--r-- | ppapi/proxy/ppapi_messages.h | 17 | ||||
-rw-r--r-- | ppapi/shared_impl/file_growth.cc | 18 | ||||
-rw-r--r-- | ppapi/shared_impl/file_growth.h | 5 |
8 files changed, 87 insertions, 59 deletions
diff --git a/ppapi/proxy/file_io_resource.cc b/ppapi/proxy/file_io_resource.cc index a35c9ec..7157574 100644 --- a/ppapi/proxy/file_io_resource.cc +++ b/ppapi/proxy/file_io_resource.cc @@ -404,10 +404,8 @@ void FileIOResource::Close() { if (file_handle_) file_handle_ = NULL; - // TODO(tzik): Post |max_written_offset_| and |append_mode_write_amount_| - // separately by using FileGrowth after the IPC signature changed. Post(BROWSER, PpapiHostMsg_FileIO_Close( - max_written_offset_ + append_mode_write_amount_)); + FileGrowth(max_written_offset_, append_mode_write_amount_))); } int32_t FileIOResource::RequestOSFileHandle( diff --git a/ppapi/proxy/file_system_resource.cc b/ppapi/proxy/file_system_resource.cc index 5d6161e..0be0ea5 100644 --- a/ppapi/proxy/file_system_resource.cc +++ b/ppapi/proxy/file_system_resource.cc @@ -175,8 +175,7 @@ void FileSystemResource::ReserveQuota(int64_t amount) { DCHECK(!reserving_quota_); reserving_quota_ = true; - // TODO(tzik): Use FileGrowthMap here after the IPC signature changed. - FileSizeMap file_sizes; + FileGrowthMap file_growths; for (std::set<PP_Resource>::iterator it = files_.begin(); it != files_.end(); ++it) { EnterResourceNoLock<PPB_FileIO_API> enter(*it, true); @@ -185,12 +184,12 @@ void FileSystemResource::ReserveQuota(int64_t amount) { continue; } PPB_FileIO_API* file_io_api = enter.object(); - file_sizes[*it] = - file_io_api->GetMaxWrittenOffset() + - file_io_api->GetAppendModeWriteAmount(); + file_growths[*it] = FileGrowth( + file_io_api->GetMaxWrittenOffset(), + file_io_api->GetAppendModeWriteAmount()); } Call<PpapiPluginMsg_FileSystem_ReserveQuotaReply>(BROWSER, - PpapiHostMsg_FileSystem_ReserveQuota(amount, file_sizes), + PpapiHostMsg_FileSystem_ReserveQuota(amount, file_growths), base::Bind(&FileSystemResource::ReserveQuotaComplete, this)); } @@ -198,13 +197,13 @@ void FileSystemResource::ReserveQuota(int64_t amount) { void FileSystemResource::ReserveQuotaComplete( const ResourceMessageReplyParams& params, int64_t amount, - const FileSizeMap& max_written_offsets) { + const FileSizeMap& file_sizes) { DCHECK(reserving_quota_); reserving_quota_ = false; reserved_quota_ = amount; - for (FileSizeMap::const_iterator it = max_written_offsets.begin(); - it != max_written_offsets.end(); ++it) { + for (FileSizeMap::const_iterator it = file_sizes.begin(); + it != file_sizes.end(); ++it) { EnterResourceNoLock<PPB_FileIO_API> enter(it->first, true); // It is possible that the host has sent an offset for a file that has been diff --git a/ppapi/proxy/file_system_resource_unittest.cc b/ppapi/proxy/file_system_resource_unittest.cc index e60a808..f936954 100644 --- a/ppapi/proxy/file_system_resource_unittest.cc +++ b/ppapi/proxy/file_system_resource_unittest.cc @@ -238,13 +238,13 @@ TEST_F(FileSystemResourceTest, RequestQuota) { sink().ClearMessages(); int64_t amount = 0; - FileOffsetMap max_written_offsets; + FileGrowthMap file_growths; ASSERT_TRUE(UnpackMessage<PpapiHostMsg_FileSystem_ReserveQuota>( - msg, &amount, &max_written_offsets)); + msg, &amount, &file_growths)); ASSERT_EQ(kQuotaRequestAmount1, amount); - ASSERT_EQ(2U, max_written_offsets.size()); - ASSERT_EQ(0, max_written_offsets[file_io1.get()]); - ASSERT_EQ(0, max_written_offsets[file_io2.get()]); + ASSERT_EQ(2U, file_growths.size()); + ASSERT_EQ(0, file_growths[file_io1.get()].max_written_offset); + ASSERT_EQ(0, file_growths[file_io2.get()].max_written_offset); // Make another request while the "reserve quota" message is pending. MockRequestQuotaCallback cb2; @@ -263,7 +263,7 @@ TEST_F(FileSystemResourceTest, RequestQuota) { PP_OK, PpapiPluginMsg_FileSystem_ReserveQuotaReply( kQuotaRequestAmount1 + kQuotaRequestAmount2, - max_written_offsets)); + FileGrowthMapToFileSizeMapForTesting(file_growths))); } ASSERT_TRUE(cb1.called()); ASSERT_EQ(kQuotaRequestAmount1, cb1.result()); @@ -294,7 +294,7 @@ TEST_F(FileSystemResourceTest, RequestQuota) { PP_OK, PpapiPluginMsg_FileSystem_ReserveQuotaReply( kQuotaRequestAmount1 - 1, - max_written_offsets)); + FileGrowthMapToFileSizeMapForTesting(file_growths))); } ASSERT_TRUE(cb1.called()); ASSERT_EQ(0, cb1.result()); @@ -325,7 +325,7 @@ TEST_F(FileSystemResourceTest, RequestQuota) { PP_OK, PpapiPluginMsg_FileSystem_ReserveQuotaReply( kQuotaRequestAmount1, - max_written_offsets)); + FileGrowthMapToFileSizeMapForTesting(file_growths))); } ASSERT_TRUE(cb1.called()); ASSERT_EQ(kQuotaRequestAmount1, cb1.result()); @@ -343,7 +343,7 @@ TEST_F(FileSystemResourceTest, RequestQuota) { PP_OK, PpapiPluginMsg_FileSystem_ReserveQuotaReply( kQuotaRequestAmount1 + kQuotaRequestAmount2, - max_written_offsets)); + FileGrowthMapToFileSizeMapForTesting(file_growths))); } ASSERT_TRUE(cb2.called()); diff --git a/ppapi/proxy/nacl_message_scanner.cc b/ppapi/proxy/nacl_message_scanner.cc index 3c2b45f8..44324c3 100644 --- a/ppapi/proxy/nacl_message_scanner.cc +++ b/ppapi/proxy/nacl_message_scanner.cc @@ -381,9 +381,9 @@ void NaClMessageScanner::ScanUntrustedMessage( return; // Audit FileIO Close messages to make sure the plugin reports an // accurate file size. - int64_t max_written_offset = 0; + FileGrowth file_growth; if (!UnpackMessage<PpapiHostMsg_FileIO_Close>( - nested_msg, &max_written_offset)) + nested_msg, &file_growth)) return; int64_t trusted_max_written_offset = it->second->max_written_offset(); @@ -391,11 +391,12 @@ void NaClMessageScanner::ScanUntrustedMessage( files_.erase(it); // If the plugin is under-reporting, rewrite the message with the // trusted value. - if (trusted_max_written_offset > max_written_offset) { + if (trusted_max_written_offset > file_growth.max_written_offset) { new_msg_ptr->reset( new PpapiHostMsg_ResourceCall( params, - PpapiHostMsg_FileIO_Close(trusted_max_written_offset))); + PpapiHostMsg_FileIO_Close( + FileGrowth(trusted_max_written_offset, 0)))); } } case PpapiHostMsg_FileIO_SetLength::ID: { @@ -429,22 +430,26 @@ void NaClMessageScanner::ScanUntrustedMessage( // Audit FileSystem ReserveQuota messages to make sure the plugin // reports accurate file sizes. int64_t amount = 0; - FileOffsetMap max_written_offsets; + FileGrowthMap file_growths; if (!UnpackMessage<PpapiHostMsg_FileSystem_ReserveQuota>( - nested_msg, &amount, &max_written_offsets)) + nested_msg, &amount, &file_growths)) return; bool audit_failed = false; - for (FileOffsetMap::iterator it = max_written_offsets.begin(); - it != max_written_offsets.end(); ++it) { + for (FileGrowthMap::iterator it = file_growths.begin(); + it != file_growths.end(); ++it) { FileIOMap::iterator file_it = files_.find(it->first); if (file_it == files_.end()) continue; int64_t trusted_max_written_offset = file_it->second->max_written_offset(); - if (trusted_max_written_offset > it->second) { + if (trusted_max_written_offset > it->second.max_written_offset) { audit_failed = true; - it->second = trusted_max_written_offset; + it->second.max_written_offset = trusted_max_written_offset; + } + if (it->second.append_mode_write_amount < 0) { + audit_failed = true; + it->second.append_mode_write_amount = 0; } } if (audit_failed) { @@ -452,7 +457,7 @@ void NaClMessageScanner::ScanUntrustedMessage( new PpapiHostMsg_ResourceCall( params, PpapiHostMsg_FileSystem_ReserveQuota( - amount, max_written_offsets))); + amount, file_growths))); } break; } @@ -518,15 +523,15 @@ void NaClMessageScanner::AuditNestedMessage(PP_Resource resource, case PpapiPluginMsg_FileSystem_ReserveQuotaReply::ID: { // The amount of reserved quota for a FileSystem was refreshed. int64_t amount = 0; - FileOffsetMap max_written_offsets; + FileSizeMap file_sizes; if (ppapi::UnpackMessage<PpapiPluginMsg_FileSystem_ReserveQuotaReply>( - msg, &amount, &max_written_offsets)) { + msg, &amount, &file_sizes)) { FileSystemMap::iterator it = file_systems_.find(resource); DCHECK(it != file_systems_.end()); it->second->UpdateReservedQuota(amount); - FileOffsetMap::const_iterator offset_it = max_written_offsets.begin(); - for (; offset_it != max_written_offsets.end(); ++offset_it) { + FileSizeMap::const_iterator offset_it = file_sizes.begin(); + for (; offset_it != file_sizes.end(); ++offset_it) { FileIOMap::iterator fio_it = files_.find(offset_it->first); DCHECK(fio_it != files_.end()); if (fio_it != files_.end()) diff --git a/ppapi/proxy/nacl_message_scanner_unittest.cc b/ppapi/proxy/nacl_message_scanner_unittest.cc index e0516ff..8e81e24 100644 --- a/ppapi/proxy/nacl_message_scanner_unittest.cc +++ b/ppapi/proxy/nacl_message_scanner_unittest.cc @@ -124,18 +124,18 @@ TEST_F(NaClMessageScannerTest, FileOpenClose) { test.ScanUntrustedMessage( PpapiHostMsg_ResourceCall( fio_call_params, - PpapiHostMsg_FileIO_Close(0)), + PpapiHostMsg_FileIO_Close(FileGrowth(0, 0))), &new_msg_ptr); EXPECT_TRUE(new_msg_ptr); ResourceMessageCallParams call_params; IPC::Message nested_msg; - int64_t max_written_offset = 0; + FileGrowth file_growth; EXPECT_TRUE(UnpackMessage<PpapiHostMsg_ResourceCall>( *new_msg_ptr, &call_params, &nested_msg) && UnpackMessage<PpapiHostMsg_FileIO_Close>( - nested_msg, &max_written_offset)); + nested_msg, &file_growth)); new_msg_ptr.reset(); - EXPECT_EQ(kNewFileSize, max_written_offset); + EXPECT_EQ(kNewFileSize, file_growth.max_written_offset); EXPECT_FALSE(FindFileIO(test, kFileIO)); // Reopen the file. @@ -147,7 +147,7 @@ TEST_F(NaClMessageScannerTest, FileOpenClose) { test.ScanUntrustedMessage( PpapiHostMsg_ResourceCall( fio_call_params, - PpapiHostMsg_FileIO_Close(kNewFileSize)), + PpapiHostMsg_FileIO_Close(FileGrowth(kNewFileSize, 0))), &new_msg_ptr); EXPECT_FALSE(new_msg_ptr); EXPECT_FALSE(FindFileIO(test, kFileIO)); @@ -185,14 +185,14 @@ TEST_F(NaClMessageScannerTest, QuotaAuditing) { // Receive reserved quota, and updated file sizes. const int64_t kNewFileSize = 10; - FileOffsetMap offset_map; - offset_map.insert(std::make_pair(kFileIO, kNewFileSize)); + FileSizeMap file_sizes; + file_sizes[kFileIO] = kNewFileSize; test.ScanMessage( PpapiPluginMsg_ResourceReply( fs_reply_params, PpapiPluginMsg_FileSystem_ReserveQuotaReply( kQuotaReservationAmount, - offset_map)), + file_sizes)), &unused_handles, &new_msg_ptr); EXPECT_FALSE(new_msg_ptr); @@ -210,26 +210,26 @@ TEST_F(NaClMessageScannerTest, QuotaAuditing) { EXPECT_EQ(kNewFileSize + 1, fio->max_written_offset()); // Plugin should not under-report max written offsets when reserving quota. - offset_map[kFileIO] = 0; // should be kNewFileSize + 1. + file_sizes[kFileIO] = 0; // should be kNewFileSize + 1. test.ScanUntrustedMessage( PpapiHostMsg_ResourceCall( fio_call_params, PpapiHostMsg_FileSystem_ReserveQuota( kQuotaReservationAmount, - offset_map)), + FileSizeMapToFileGrowthMapForTesting(file_sizes))), &new_msg_ptr); EXPECT_TRUE(new_msg_ptr); ResourceMessageCallParams call_params; IPC::Message nested_msg; int64_t amount = 0; - FileOffsetMap new_offset_map; + FileGrowthMap new_file_growths; EXPECT_TRUE(UnpackMessage<PpapiHostMsg_ResourceCall>( *new_msg_ptr, &call_params, &nested_msg) && UnpackMessage<PpapiHostMsg_FileSystem_ReserveQuota>( - nested_msg, &amount, &new_offset_map)); + nested_msg, &amount, &new_file_growths)); new_msg_ptr.reset(); EXPECT_EQ(kQuotaReservationAmount, amount); - EXPECT_EQ(kNewFileSize + 1, new_offset_map[kFileIO]); + EXPECT_EQ(kNewFileSize + 1, new_file_growths[kFileIO].max_written_offset); } TEST_F(NaClMessageScannerTest, SetLength) { @@ -247,14 +247,14 @@ TEST_F(NaClMessageScannerTest, SetLength) { // Receive reserved quota, and updated file sizes. const int64_t kNewFileSize = 10; - FileOffsetMap offset_map; - offset_map.insert(std::make_pair(kFileIO, 0)); + FileSizeMap file_sizes; + file_sizes[kFileIO] = 0; test.ScanMessage( PpapiPluginMsg_ResourceReply( fs_reply_params, PpapiPluginMsg_FileSystem_ReserveQuotaReply( kQuotaReservationAmount, - offset_map)), + file_sizes)), &unused_handles, &new_msg_ptr); diff --git a/ppapi/proxy/ppapi_messages.h b/ppapi/proxy/ppapi_messages.h index ab28cf8..9a2ad06 100644 --- a/ppapi/proxy/ppapi_messages.h +++ b/ppapi/proxy/ppapi_messages.h @@ -59,6 +59,7 @@ #include "ppapi/proxy/serialized_structs.h" #include "ppapi/proxy/serialized_var.h" #include "ppapi/shared_impl/dir_contents.h" +#include "ppapi/shared_impl/file_growth.h" #include "ppapi/shared_impl/file_path.h" #include "ppapi/shared_impl/file_ref_create_info.h" #include "ppapi/shared_impl/ppapi_nacl_channel_args.h" @@ -210,6 +211,11 @@ IPC_STRUCT_TRAITS_BEGIN(PP_FileInfo) IPC_STRUCT_TRAITS_MEMBER(last_modified_time) IPC_STRUCT_TRAITS_END() +IPC_STRUCT_TRAITS_BEGIN(ppapi::FileGrowth) + IPC_STRUCT_TRAITS_MEMBER(max_written_offset) + IPC_STRUCT_TRAITS_MEMBER(append_mode_write_amount) +IPC_STRUCT_TRAITS_END() + IPC_STRUCT_TRAITS_BEGIN(ppapi::DeviceRefData) IPC_STRUCT_TRAITS_MEMBER(type) IPC_STRUCT_TRAITS_MEMBER(name) @@ -1246,9 +1252,9 @@ IPC_MESSAGE_CONTROL2(PpapiHostMsg_FileIO_Open, int32_t /* open_flags */) IPC_MESSAGE_CONTROL2(PpapiPluginMsg_FileIO_OpenReply, PP_Resource /* quota_file_system */, - int64_t /* max_written_offset */) + int64_t /* file_size */) IPC_MESSAGE_CONTROL1(PpapiHostMsg_FileIO_Close, - int64_t /* max_written_offset */) + ppapi::FileGrowth /* file_growth */) IPC_MESSAGE_CONTROL2(PpapiHostMsg_FileIO_Touch, PP_Time /* last_access_time */, PP_Time /* last_modified_time */) @@ -1337,15 +1343,12 @@ IPC_MESSAGE_CONTROL2(PpapiHostMsg_FileSystem_CreateFromRenderer, // linked to the existing resource host given in the ResourceVar. IPC_MESSAGE_CONTROL1(PpapiPluginMsg_FileSystem_CreateFromPendingHost, PP_FileSystemType /* file_system_type */) -// IPC_MESSAGE macros choke on extra , in the std::map, when expanding. We need -// to typedef it to avoid that. -typedef std::map<int32_t, int64_t> FileOffsetMap; IPC_MESSAGE_CONTROL2(PpapiHostMsg_FileSystem_ReserveQuota, int64_t /* amount */, - FileOffsetMap /* max_written_offsets */) + ppapi::FileGrowthMap /* file_growths */) IPC_MESSAGE_CONTROL2(PpapiPluginMsg_FileSystem_ReserveQuotaReply, int64_t /* amount */, - FileOffsetMap /* max_written_offsets */) + ppapi::FileSizeMap /* file_sizes */) // Flash DRM ------------------------------------------------------------------ IPC_MESSAGE_CONTROL0(PpapiHostMsg_FlashDRM_Create) diff --git a/ppapi/shared_impl/file_growth.cc b/ppapi/shared_impl/file_growth.cc index 002bd0f..ac97506 100644 --- a/ppapi/shared_impl/file_growth.cc +++ b/ppapi/shared_impl/file_growth.cc @@ -21,4 +21,22 @@ FileGrowth::FileGrowth(int64_t max_written_offset, DCHECK_LE(0, append_mode_write_amount); } +FileGrowthMap FileSizeMapToFileGrowthMapForTesting( + const FileSizeMap& file_sizes) { + FileGrowthMap file_growths; + for (FileSizeMap::const_iterator it = file_sizes.begin(); + it != file_sizes.end(); ++it) + file_growths[it->first] = FileGrowth(it->second, 0); + return file_growths; +} + +FileSizeMap FileGrowthMapToFileSizeMapForTesting( + const FileGrowthMap& file_growths) { + FileSizeMap file_sizes; + for (FileGrowthMap::const_iterator it = file_growths.begin(); + it != file_growths.end(); ++it) + file_sizes[it->first] = it->second.max_written_offset; + return file_sizes; +} + } // namespace ppapi diff --git a/ppapi/shared_impl/file_growth.h b/ppapi/shared_impl/file_growth.h index b9e83ec..23f12e0 100644 --- a/ppapi/shared_impl/file_growth.h +++ b/ppapi/shared_impl/file_growth.h @@ -23,6 +23,11 @@ struct PPAPI_SHARED_EXPORT FileGrowth { typedef std::map<int32_t, FileGrowth> FileGrowthMap; typedef std::map<int32_t, int64_t> FileSizeMap; +PPAPI_SHARED_EXPORT FileGrowthMap FileSizeMapToFileGrowthMapForTesting( + const FileSizeMap& file_sizes); +PPAPI_SHARED_EXPORT FileSizeMap FileGrowthMapToFileSizeMapForTesting( + const FileGrowthMap& file_growths); + } // namespace ppapi #endif // PPAPI_SHARED_IMPL_FILE_GROWTH_H_ |