Jamie Gennis | aca51c0 | 2011-11-03 17:42:43 -0700 | [diff] [blame] | 1 | /* |
| 2 | ** Copyright 2011, The Android Open Source Project |
| 3 | ** |
| 4 | ** Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | ** you may not use this file except in compliance with the License. |
| 6 | ** You may obtain a copy of the License at |
| 7 | ** |
| 8 | ** http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | ** |
| 10 | ** Unless required by applicable law or agreed to in writing, software |
| 11 | ** distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | ** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | ** See the License for the specific language governing permissions and |
| 14 | ** limitations under the License. |
| 15 | */ |
| 16 | |
Jamie Gennis | 7660108 | 2011-11-06 14:14:33 -0800 | [diff] [blame] | 17 | #ifndef ANDROID_EGL_CACHE_H |
| 18 | #define ANDROID_EGL_CACHE_H |
| 19 | |
| 20 | #include <EGL/egl.h> |
| 21 | #include <EGL/eglext.h> |
| 22 | |
| 23 | #include <utils/BlobCache.h> |
Jamie Gennis | 98c6383 | 2011-11-07 17:03:54 -0800 | [diff] [blame] | 24 | #include <utils/String8.h> |
Jamie Gennis | 7660108 | 2011-11-06 14:14:33 -0800 | [diff] [blame] | 25 | #include <utils/StrongPointer.h> |
| 26 | |
Jamie Gennis | aca51c0 | 2011-11-03 17:42:43 -0700 | [diff] [blame] | 27 | // ---------------------------------------------------------------------------- |
| 28 | namespace android { |
| 29 | // ---------------------------------------------------------------------------- |
| 30 | |
| 31 | class egl_display_t; |
| 32 | |
Jamie Gennis | 98c6383 | 2011-11-07 17:03:54 -0800 | [diff] [blame] | 33 | class EGLAPI egl_cache_t { |
Jamie Gennis | aca51c0 | 2011-11-03 17:42:43 -0700 | [diff] [blame] | 34 | public: |
| 35 | |
Jamie Gennis | 7660108 | 2011-11-06 14:14:33 -0800 | [diff] [blame] | 36 | // get returns a pointer to the singleton egl_cache_t object. This |
| 37 | // singleton object will never be destroyed. |
Jamie Gennis | aca51c0 | 2011-11-03 17:42:43 -0700 | [diff] [blame] | 38 | static egl_cache_t* get(); |
| 39 | |
Jamie Gennis | 7660108 | 2011-11-06 14:14:33 -0800 | [diff] [blame] | 40 | // initialize puts the egl_cache_t into an initialized state, such that it |
| 41 | // is able to insert and retrieve entries from the cache. This should be |
| 42 | // called when EGL is initialized. When not in the initialized state the |
| 43 | // getBlob and setBlob methods will return without performing any cache |
| 44 | // operations. |
Jamie Gennis | aca51c0 | 2011-11-03 17:42:43 -0700 | [diff] [blame] | 45 | void initialize(egl_display_t* display); |
Jamie Gennis | 7660108 | 2011-11-06 14:14:33 -0800 | [diff] [blame] | 46 | |
| 47 | // terminate puts the egl_cache_t back into the uninitialized state. When |
| 48 | // in this state the getBlob and setBlob methods will return without |
| 49 | // performing any cache operations. |
| 50 | void terminate(); |
| 51 | |
| 52 | // setBlob attempts to insert a new key/value blob pair into the cache. |
| 53 | // This will be called by the hardware vendor's EGL implementation via the |
| 54 | // EGL_ANDROID_blob_cache extension. |
Jamie Gennis | c42fcf0 | 2011-11-09 15:35:34 -0800 | [diff] [blame] | 55 | void setBlob(const void* key, EGLsizeiANDROID keySize, const void* value, |
| 56 | EGLsizeiANDROID valueSize); |
Jamie Gennis | 7660108 | 2011-11-06 14:14:33 -0800 | [diff] [blame] | 57 | |
| 58 | // getBlob attempts to retrieve the value blob associated with a given key |
| 59 | // blob from cache. This will be called by the hardware vendor's EGL |
| 60 | // implementation via the EGL_ANDROID_blob_cache extension. |
Jamie Gennis | c42fcf0 | 2011-11-09 15:35:34 -0800 | [diff] [blame] | 61 | EGLsizeiANDROID getBlob(const void* key, EGLsizeiANDROID keySize, |
| 62 | void* value, EGLsizeiANDROID valueSize); |
Jamie Gennis | 7660108 | 2011-11-06 14:14:33 -0800 | [diff] [blame] | 63 | |
Jamie Gennis | 98c6383 | 2011-11-07 17:03:54 -0800 | [diff] [blame] | 64 | // setCacheFilename sets the name of the file that should be used to store |
| 65 | // cache contents from one program invocation to another. |
| 66 | void setCacheFilename(const char* filename); |
| 67 | |
Jamie Gennis | 7660108 | 2011-11-06 14:14:33 -0800 | [diff] [blame] | 68 | private: |
| 69 | // Creation and (the lack of) destruction is handled internally. |
| 70 | egl_cache_t(); |
| 71 | ~egl_cache_t(); |
| 72 | |
| 73 | // Copying is disallowed. |
| 74 | egl_cache_t(const egl_cache_t&); // not implemented |
| 75 | void operator=(const egl_cache_t&); // not implemented |
| 76 | |
| 77 | // getBlobCacheLocked returns the BlobCache object being used to store the |
| 78 | // key/value blob pairs. If the BlobCache object has not yet been created, |
| 79 | // this will do so, loading the serialized cache contents from disk if |
| 80 | // possible. |
| 81 | sp<BlobCache> getBlobCacheLocked(); |
| 82 | |
| 83 | // saveBlobCache attempts to save the current contents of mBlobCache to |
| 84 | // disk. |
| 85 | void saveBlobCacheLocked(); |
| 86 | |
| 87 | // loadBlobCache attempts to load the saved cache contents from disk into |
| 88 | // mBlobCache. |
| 89 | void loadBlobCacheLocked(); |
| 90 | |
| 91 | // mInitialized indicates whether the egl_cache_t is in the initialized |
| 92 | // state. It is initialized to false at construction time, and gets set to |
| 93 | // true when initialize is called. It is set back to false when terminate |
| 94 | // is called. When in this state, the cache behaves as normal. When not, |
| 95 | // the getBlob and setBlob methods will return without performing any cache |
| 96 | // operations. |
| 97 | bool mInitialized; |
| 98 | |
| 99 | // mBlobCache is the cache in which the key/value blob pairs are stored. It |
| 100 | // is initially NULL, and will be initialized by getBlobCacheLocked the |
| 101 | // first time it's needed. |
| 102 | sp<BlobCache> mBlobCache; |
| 103 | |
Jamie Gennis | 98c6383 | 2011-11-07 17:03:54 -0800 | [diff] [blame] | 104 | // mFilename is the name of the file for storing cache contents in between |
| 105 | // program invocations. It is initialized to an empty string at |
| 106 | // construction time, and can be set with the setCacheFilename method. An |
| 107 | // empty string indicates that the cache should not be saved to or restored |
| 108 | // from disk. |
| 109 | String8 mFilename; |
| 110 | |
Jamie Gennis | 99c3d70 | 2011-11-08 17:59:36 -0800 | [diff] [blame] | 111 | // mSavePending indicates whether or not a deferred save operation is |
| 112 | // pending. Each time a key/value pair is inserted into the cache via |
| 113 | // setBlob, a deferred save is initiated if one is not already pending. |
| 114 | // This will wait some amount of time and then trigger a save of the cache |
| 115 | // contents to disk. |
| 116 | bool mSavePending; |
| 117 | |
Jamie Gennis | 7660108 | 2011-11-06 14:14:33 -0800 | [diff] [blame] | 118 | // mMutex is the mutex used to prevent concurrent access to the member |
| 119 | // variables. It must be locked whenever the member variables are accessed. |
| 120 | mutable Mutex mMutex; |
Jamie Gennis | 98c6383 | 2011-11-07 17:03:54 -0800 | [diff] [blame] | 121 | |
| 122 | // sCache is the singleton egl_cache_t object. |
| 123 | static egl_cache_t sCache; |
Jamie Gennis | aca51c0 | 2011-11-03 17:42:43 -0700 | [diff] [blame] | 124 | }; |
| 125 | |
| 126 | // ---------------------------------------------------------------------------- |
| 127 | }; // namespace android |
| 128 | // ---------------------------------------------------------------------------- |
Jamie Gennis | 7660108 | 2011-11-06 14:14:33 -0800 | [diff] [blame] | 129 | |
| 130 | #endif // ANDROID_EGL_CACHE_H |