blob: 8dea302f6302a225e281a0b0f647d984915323a3 [file] [log] [blame]
Jamie Gennisaca51c02011-11-03 17:42:43 -07001/*
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 Gennis76601082011-11-06 14:14:33 -080017#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>
24#include <utils/StrongPointer.h>
25
Mathias Agopian65421432017-03-08 11:49:05 -080026#include <mutex>
27#include <string>
28
Jamie Gennisaca51c02011-11-03 17:42:43 -070029// ----------------------------------------------------------------------------
30namespace android {
31// ----------------------------------------------------------------------------
32
33class egl_display_t;
34
Jamie Gennis98c63832011-11-07 17:03:54 -080035class EGLAPI egl_cache_t {
Jamie Gennisaca51c02011-11-03 17:42:43 -070036public:
37
Jamie Gennis76601082011-11-06 14:14:33 -080038 // get returns a pointer to the singleton egl_cache_t object. This
39 // singleton object will never be destroyed.
Jamie Gennisaca51c02011-11-03 17:42:43 -070040 static egl_cache_t* get();
41
Jamie Gennis76601082011-11-06 14:14:33 -080042 // initialize puts the egl_cache_t into an initialized state, such that it
43 // is able to insert and retrieve entries from the cache. This should be
44 // called when EGL is initialized. When not in the initialized state the
45 // getBlob and setBlob methods will return without performing any cache
46 // operations.
Jamie Gennisaca51c02011-11-03 17:42:43 -070047 void initialize(egl_display_t* display);
Jamie Gennis76601082011-11-06 14:14:33 -080048
49 // terminate puts the egl_cache_t back into the uninitialized state. When
50 // in this state the getBlob and setBlob methods will return without
51 // performing any cache operations.
52 void terminate();
53
54 // setBlob attempts to insert a new key/value blob pair into the cache.
55 // This will be called by the hardware vendor's EGL implementation via the
56 // EGL_ANDROID_blob_cache extension.
Jamie Gennisc42fcf02011-11-09 15:35:34 -080057 void setBlob(const void* key, EGLsizeiANDROID keySize, const void* value,
58 EGLsizeiANDROID valueSize);
Jamie Gennis76601082011-11-06 14:14:33 -080059
60 // getBlob attempts to retrieve the value blob associated with a given key
61 // blob from cache. This will be called by the hardware vendor's EGL
62 // implementation via the EGL_ANDROID_blob_cache extension.
Jamie Gennisc42fcf02011-11-09 15:35:34 -080063 EGLsizeiANDROID getBlob(const void* key, EGLsizeiANDROID keySize,
64 void* value, EGLsizeiANDROID valueSize);
Jamie Gennis76601082011-11-06 14:14:33 -080065
Jamie Gennis98c63832011-11-07 17:03:54 -080066 // setCacheFilename sets the name of the file that should be used to store
67 // cache contents from one program invocation to another.
68 void setCacheFilename(const char* filename);
69
Jamie Gennis76601082011-11-06 14:14:33 -080070private:
71 // Creation and (the lack of) destruction is handled internally.
72 egl_cache_t();
73 ~egl_cache_t();
74
75 // Copying is disallowed.
76 egl_cache_t(const egl_cache_t&); // not implemented
77 void operator=(const egl_cache_t&); // not implemented
78
79 // getBlobCacheLocked returns the BlobCache object being used to store the
80 // key/value blob pairs. If the BlobCache object has not yet been created,
81 // this will do so, loading the serialized cache contents from disk if
82 // possible.
83 sp<BlobCache> getBlobCacheLocked();
84
85 // saveBlobCache attempts to save the current contents of mBlobCache to
86 // disk.
87 void saveBlobCacheLocked();
88
89 // loadBlobCache attempts to load the saved cache contents from disk into
90 // mBlobCache.
91 void loadBlobCacheLocked();
92
93 // mInitialized indicates whether the egl_cache_t is in the initialized
94 // state. It is initialized to false at construction time, and gets set to
95 // true when initialize is called. It is set back to false when terminate
96 // is called. When in this state, the cache behaves as normal. When not,
97 // the getBlob and setBlob methods will return without performing any cache
98 // operations.
99 bool mInitialized;
100
101 // mBlobCache is the cache in which the key/value blob pairs are stored. It
102 // is initially NULL, and will be initialized by getBlobCacheLocked the
103 // first time it's needed.
104 sp<BlobCache> mBlobCache;
105
Jamie Gennis98c63832011-11-07 17:03:54 -0800106 // mFilename is the name of the file for storing cache contents in between
107 // program invocations. It is initialized to an empty string at
108 // construction time, and can be set with the setCacheFilename method. An
109 // empty string indicates that the cache should not be saved to or restored
110 // from disk.
Mathias Agopian65421432017-03-08 11:49:05 -0800111 std::string mFilename;
Jamie Gennis98c63832011-11-07 17:03:54 -0800112
Jamie Gennis99c3d702011-11-08 17:59:36 -0800113 // mSavePending indicates whether or not a deferred save operation is
114 // pending. Each time a key/value pair is inserted into the cache via
115 // setBlob, a deferred save is initiated if one is not already pending.
116 // This will wait some amount of time and then trigger a save of the cache
117 // contents to disk.
118 bool mSavePending;
119
Jamie Gennis76601082011-11-06 14:14:33 -0800120 // mMutex is the mutex used to prevent concurrent access to the member
121 // variables. It must be locked whenever the member variables are accessed.
Mathias Agopian65421432017-03-08 11:49:05 -0800122 mutable std::mutex mMutex;
Jamie Gennis98c63832011-11-07 17:03:54 -0800123
124 // sCache is the singleton egl_cache_t object.
125 static egl_cache_t sCache;
Jamie Gennisaca51c02011-11-03 17:42:43 -0700126};
127
128// ----------------------------------------------------------------------------
129}; // namespace android
130// ----------------------------------------------------------------------------
Jamie Gennis76601082011-11-06 14:14:33 -0800131
132#endif // ANDROID_EGL_CACHE_H