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 NET_DISK_CACHE_FLASH_ENTRY_IMPL_H_ 6 #define NET_DISK_CACHE_FLASH_ENTRY_IMPL_H_ 7 8 #include <string> 9 10 #include "base/memory/ref_counted.h" 11 #include "base/memory/scoped_ptr.h" 12 #include "net/base/net_export.h" 13 #include "net/disk_cache/disk_cache.h" 14 #include "net/disk_cache/flash/internal_entry.h" 15 16 namespace base { 17 18 class MessageLoopProxy; 19 20 } // namespace base 21 22 namespace disk_cache { 23 24 class InternalEntry; 25 class IOBuffer; 26 class LogStore; 27 28 // We use split objects to minimize the context switches between the main thread 29 // and the cache thread in the most common case of creating a new entry. 30 // 31 // All calls on a new entry are served synchronously. When an object is 32 // destructed (via final Close() call), a message is posted to the cache thread 33 // to save the object to storage. 34 // 35 // When an entry is not new, every asynchronous call is posted to the cache 36 // thread, just as before; synchronous calls like GetKey() and GetDataSize() are 37 // served from the main thread. 38 class NET_EXPORT_PRIVATE FlashEntryImpl 39 : public Entry, 40 public base::RefCountedThreadSafe<FlashEntryImpl> { 41 friend class base::RefCountedThreadSafe<FlashEntryImpl>; 42 public: 43 FlashEntryImpl(const std::string& key, 44 LogStore* store, 45 base::MessageLoopProxy* cache_thread); 46 FlashEntryImpl(int32 id, 47 LogStore* store, 48 base::MessageLoopProxy* cache_thread); 49 50 int Init(const CompletionCallback& callback); 51 52 // disk_cache::Entry interface. 53 virtual void Doom() OVERRIDE; 54 virtual void Close() OVERRIDE; 55 virtual std::string GetKey() const OVERRIDE; 56 virtual base::Time GetLastUsed() const OVERRIDE; 57 virtual base::Time GetLastModified() const OVERRIDE; 58 virtual int32 GetDataSize(int index) const OVERRIDE; 59 virtual int ReadData(int index, int offset, IOBuffer* buf, int buf_len, 60 const CompletionCallback& callback) OVERRIDE; 61 virtual int WriteData(int index, int offset, IOBuffer* buf, int buf_len, 62 const CompletionCallback& callback, 63 bool truncate) OVERRIDE; 64 virtual int ReadSparseData(int64 offset, IOBuffer* buf, int buf_len, 65 const CompletionCallback& callback) OVERRIDE; 66 virtual int WriteSparseData(int64 offset, IOBuffer* buf, int buf_len, 67 const CompletionCallback& callback) OVERRIDE; 68 virtual int GetAvailableRange(int64 offset, int len, int64* start, 69 const CompletionCallback& callback) OVERRIDE; 70 virtual bool CouldBeSparse() const OVERRIDE; 71 virtual void CancelSparseIO() OVERRIDE; 72 virtual int ReadyForSparseIO(const CompletionCallback& callback) OVERRIDE; 73 74 private: 75 void OnInitComplete(scoped_ptr<KeyAndStreamSizes> key_and_stream_sizes); 76 virtual ~FlashEntryImpl(); 77 78 bool init_; 79 std::string key_; 80 int stream_sizes_[kFlashLogStoreEntryNumStreams]; 81 82 // Used if |this| is an newly created entry. 83 scoped_refptr<InternalEntry> new_internal_entry_; 84 85 // Used if |this| is an existing entry. 86 scoped_refptr<InternalEntry> old_internal_entry_; 87 88 // Copy of the callback for asynchronous calls on |old_internal_entry_|. 89 CompletionCallback callback_; 90 91 scoped_refptr<base::MessageLoopProxy> cache_thread_; 92 93 DISALLOW_COPY_AND_ASSIGN(FlashEntryImpl); 94 }; 95 96 } // namespace disk_cache 97 98 #endif // NET_DISK_CACHE_FLASH_ENTRY_IMPL_H_ 99