| OLD | NEW |
| 1 | 1 |
| 2 /* | 2 /* |
| 3 * Copyright 2011 Google Inc. | 3 * Copyright 2011 Google Inc. |
| 4 * | 4 * |
| 5 * Use of this source code is governed by a BSD-style license that can be | 5 * Use of this source code is governed by a BSD-style license that can be |
| 6 * found in the LICENSE file. | 6 * found in the LICENSE file. |
| 7 */ | 7 */ |
| 8 #include "SkPixelRef.h" | 8 #include "SkPixelRef.h" |
| 9 #include "SkFlattenableBuffers.h" | 9 #include "SkFlattenableBuffers.h" |
| 10 #include "SkThread.h" | 10 #include "SkThread.h" |
| (...skipping 64 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 75 void SkPixelRef::setMutex(SkBaseMutex* mutex) { | 75 void SkPixelRef::setMutex(SkBaseMutex* mutex) { |
| 76 if (NULL == mutex) { | 76 if (NULL == mutex) { |
| 77 mutex = get_default_mutex(); | 77 mutex = get_default_mutex(); |
| 78 } | 78 } |
| 79 fMutex = mutex; | 79 fMutex = mutex; |
| 80 } | 80 } |
| 81 | 81 |
| 82 // just need a > 0 value, so pick a funny one to aid in debugging | 82 // just need a > 0 value, so pick a funny one to aid in debugging |
| 83 #define SKPIXELREF_PRELOCKED_LOCKCOUNT 123456789 | 83 #define SKPIXELREF_PRELOCKED_LOCKCOUNT 123456789 |
| 84 | 84 |
| 85 SkPixelRef::SkPixelRef(const SkImageInfo& info) { | 85 SkPixelRef::SkPixelRef(SkBaseMutex* mutex) { |
| 86 this->setMutex(NULL); | 86 this->setMutex(mutex); |
| 87 fInfo = info; | 87 fPixels = NULL; |
| 88 fRec.zero(); | 88 fColorTable = NULL; // we do not track ownership of this |
| 89 fLockCount = 0; | 89 fLockCount = 0; |
| 90 this->needsNewGenID(); | 90 this->needsNewGenID(); |
| 91 fIsImmutable = false; | 91 fIsImmutable = false; |
| 92 fPreLocked = false; | |
| 93 } | |
| 94 | |
| 95 SkPixelRef::SkPixelRef(const SkImageInfo& info, SkBaseMutex* mutex) { | |
| 96 this->setMutex(mutex); | |
| 97 fInfo = info; | |
| 98 fRec.zero(); | |
| 99 fLockCount = 0; | |
| 100 this->needsNewGenID(); | |
| 101 fIsImmutable = false; | |
| 102 fPreLocked = false; | 92 fPreLocked = false; |
| 103 } | 93 } |
| 104 | 94 |
| 105 SkPixelRef::SkPixelRef(SkFlattenableReadBuffer& buffer, SkBaseMutex* mutex) | 95 SkPixelRef::SkPixelRef(SkFlattenableReadBuffer& buffer, SkBaseMutex* mutex) |
| 106 : INHERITED(buffer) { | 96 : INHERITED(buffer) { |
| 107 this->setMutex(mutex); | 97 this->setMutex(mutex); |
| 108 | 98 fPixels = NULL; |
| 109 fInfo.unflatten(buffer); | 99 fColorTable = NULL; // we do not track ownership of this |
| 110 fRec.zero(); | |
| 111 fLockCount = 0; | 100 fLockCount = 0; |
| 112 fIsImmutable = buffer.readBool(); | 101 fIsImmutable = buffer.readBool(); |
| 113 fGenerationID = buffer.readUInt(); | 102 fGenerationID = buffer.readUInt(); |
| 114 fUniqueGenerationID = false; // Conservatively assuming the original still
exists. | 103 fUniqueGenerationID = false; // Conservatively assuming the original still
exists. |
| 115 fPreLocked = false; | 104 fPreLocked = false; |
| 116 } | 105 } |
| 117 | 106 |
| 118 SkPixelRef::~SkPixelRef() { | 107 SkPixelRef::~SkPixelRef() { |
| 119 this->callGenIDChangeListeners(); | 108 this->callGenIDChangeListeners(); |
| 120 } | 109 } |
| 121 | 110 |
| 122 void SkPixelRef::needsNewGenID() { | 111 void SkPixelRef::needsNewGenID() { |
| 123 fGenerationID = 0; | 112 fGenerationID = 0; |
| 124 fUniqueGenerationID = false; | 113 fUniqueGenerationID = false; |
| 125 } | 114 } |
| 126 | 115 |
| 127 void SkPixelRef::cloneGenID(const SkPixelRef& that) { | 116 void SkPixelRef::cloneGenID(const SkPixelRef& that) { |
| 128 // This is subtle. We must call that.getGenerationID() to make sure its gen
ID isn't 0. | 117 // This is subtle. We must call that.getGenerationID() to make sure its gen
ID isn't 0. |
| 129 this->fGenerationID = that.getGenerationID(); | 118 this->fGenerationID = that.getGenerationID(); |
| 130 this->fUniqueGenerationID = false; | 119 this->fUniqueGenerationID = false; |
| 131 that.fUniqueGenerationID = false; | 120 that.fUniqueGenerationID = false; |
| 132 } | 121 } |
| 133 | 122 |
| 134 void SkPixelRef::setPreLocked(void* pixels, size_t rowBytes, SkColorTable* ctabl
e) { | 123 void SkPixelRef::setPreLocked(void* pixels, SkColorTable* ctable) { |
| 135 #ifndef SK_IGNORE_PIXELREF_SETPRELOCKED | 124 #ifndef SK_IGNORE_PIXELREF_SETPRELOCKED |
| 136 // only call me in your constructor, otherwise fLockCount tracking can get | 125 // only call me in your constructor, otherwise fLockCount tracking can get |
| 137 // out of sync. | 126 // out of sync. |
| 138 fRec.fPixels = pixels; | 127 fPixels = pixels; |
| 139 fRec.fColorTable = ctable; | 128 fColorTable = ctable; |
| 140 fRec.fRowBytes = rowBytes; | |
| 141 fLockCount = SKPIXELREF_PRELOCKED_LOCKCOUNT; | 129 fLockCount = SKPIXELREF_PRELOCKED_LOCKCOUNT; |
| 142 fPreLocked = true; | 130 fPreLocked = true; |
| 143 #endif | 131 #endif |
| 144 } | 132 } |
| 145 | 133 |
| 146 void SkPixelRef::flatten(SkFlattenableWriteBuffer& buffer) const { | 134 void SkPixelRef::flatten(SkFlattenableWriteBuffer& buffer) const { |
| 147 this->INHERITED::flatten(buffer); | 135 this->INHERITED::flatten(buffer); |
| 148 | |
| 149 fInfo.flatten(buffer); | |
| 150 buffer.writeBool(fIsImmutable); | 136 buffer.writeBool(fIsImmutable); |
| 151 // We write the gen ID into the picture for within-process recording. This | 137 // We write the gen ID into the picture for within-process recording. This |
| 152 // is safe since the same genID will never refer to two different sets of | 138 // is safe since the same genID will never refer to two different sets of |
| 153 // pixels (barring overflow). However, each process has its own "namespace" | 139 // pixels (barring overflow). However, each process has its own "namespace" |
| 154 // of genIDs. So for cross-process recording we write a zero which will | 140 // of genIDs. So for cross-process recording we write a zero which will |
| 155 // trigger assignment of a new genID in playback. | 141 // trigger assignment of a new genID in playback. |
| 156 if (buffer.isCrossProcess()) { | 142 if (buffer.isCrossProcess()) { |
| 157 buffer.writeUInt(0); | 143 buffer.writeUInt(0); |
| 158 } else { | 144 } else { |
| 159 buffer.writeUInt(fGenerationID); | 145 buffer.writeUInt(fGenerationID); |
| 160 fUniqueGenerationID = false; // Conservative, a copy is probably about
to exist. | 146 fUniqueGenerationID = false; // Conservative, a copy is probably about
to exist. |
| 161 } | 147 } |
| 162 } | 148 } |
| 163 | 149 |
| 164 bool SkPixelRef::lockPixels(LockRec* rec) { | 150 void SkPixelRef::lockPixels() { |
| 165 SkASSERT(!fPreLocked || SKPIXELREF_PRELOCKED_LOCKCOUNT == fLockCount); | 151 SkASSERT(!fPreLocked || SKPIXELREF_PRELOCKED_LOCKCOUNT == fLockCount); |
| 166 | 152 |
| 167 if (!fPreLocked) { | 153 if (!fPreLocked) { |
| 168 SkAutoMutexAcquire ac(*fMutex); | 154 SkAutoMutexAcquire ac(*fMutex); |
| 169 | 155 |
| 170 if (1 == ++fLockCount) { | 156 if (1 == ++fLockCount) { |
| 171 LockRec rec; | 157 fPixels = this->onLockPixels(&fColorTable); |
| 172 if (!this->onNewLockPixels(&rec)) { | |
| 173 return false; | |
| 174 } | |
| 175 fRec = rec; | |
| 176 } | 158 } |
| 177 } | 159 } |
| 178 *rec = fRec; | |
| 179 return true; | |
| 180 } | |
| 181 | |
| 182 bool SkPixelRef::lockPixels() { | |
| 183 LockRec rec; | |
| 184 return this->lockPixels(&rec); | |
| 185 } | 160 } |
| 186 | 161 |
| 187 void SkPixelRef::unlockPixels() { | 162 void SkPixelRef::unlockPixels() { |
| 188 SkASSERT(!fPreLocked || SKPIXELREF_PRELOCKED_LOCKCOUNT == fLockCount); | 163 SkASSERT(!fPreLocked || SKPIXELREF_PRELOCKED_LOCKCOUNT == fLockCount); |
| 189 | 164 |
| 190 if (!fPreLocked) { | 165 if (!fPreLocked) { |
| 191 SkAutoMutexAcquire ac(*fMutex); | 166 SkAutoMutexAcquire ac(*fMutex); |
| 192 | 167 |
| 193 SkASSERT(fLockCount > 0); | 168 SkASSERT(fLockCount > 0); |
| 194 if (0 == --fLockCount) { | 169 if (0 == --fLockCount) { |
| 195 this->onUnlockPixels(); | 170 this->onUnlockPixels(); |
| 196 fRec.zero(); | 171 fPixels = NULL; |
| 172 fColorTable = NULL; |
| 197 } | 173 } |
| 198 } | 174 } |
| 199 } | 175 } |
| 200 | 176 |
| 201 bool SkPixelRef::lockPixelsAreWritable() const { | 177 bool SkPixelRef::lockPixelsAreWritable() const { |
| 202 return this->onLockPixelsAreWritable(); | 178 return this->onLockPixelsAreWritable(); |
| 203 } | 179 } |
| 204 | 180 |
| 205 bool SkPixelRef::onLockPixelsAreWritable() const { | 181 bool SkPixelRef::onLockPixelsAreWritable() const { |
| 206 return true; | 182 return true; |
| (...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 267 SkData* SkPixelRef::onRefEncodedData() { | 243 SkData* SkPixelRef::onRefEncodedData() { |
| 268 return NULL; | 244 return NULL; |
| 269 } | 245 } |
| 270 | 246 |
| 271 size_t SkPixelRef::getAllocatedSizeInBytes() const { | 247 size_t SkPixelRef::getAllocatedSizeInBytes() const { |
| 272 return 0; | 248 return 0; |
| 273 } | 249 } |
| 274 | 250 |
| 275 /////////////////////////////////////////////////////////////////////////////// | 251 /////////////////////////////////////////////////////////////////////////////// |
| 276 | 252 |
| 277 #ifdef SK_SUPPORT_LEGACY_ONLOCKPIXELS | |
| 278 | |
| 279 void* SkPixelRef::onLockPixels(SkColorTable** ctable) { | |
| 280 return NULL; | |
| 281 } | |
| 282 | |
| 283 bool SkPixelRef::onNewLockPixels(LockRec* rec) { | |
| 284 SkColorTable* ctable; | |
| 285 void* pixels = this->onLockPixels(&ctable); | |
| 286 if (!pixels) { | |
| 287 return false; | |
| 288 } | |
| 289 | |
| 290 rec->fPixels = pixels; | |
| 291 rec->fColorTable = ctable; | |
| 292 rec->fRowBytes = 0; // callers don't currently need this (thank goodness) | |
| 293 return true; | |
| 294 } | |
| 295 | |
| 296 #endif | |
| 297 | |
| 298 /////////////////////////////////////////////////////////////////////////////// | |
| 299 | |
| 300 #ifdef SK_BUILD_FOR_ANDROID | 253 #ifdef SK_BUILD_FOR_ANDROID |
| 301 void SkPixelRef::globalRef(void* data) { | 254 void SkPixelRef::globalRef(void* data) { |
| 302 this->ref(); | 255 this->ref(); |
| 303 } | 256 } |
| 304 | 257 |
| 305 void SkPixelRef::globalUnref() { | 258 void SkPixelRef::globalUnref() { |
| 306 this->unref(); | 259 this->unref(); |
| 307 } | 260 } |
| 308 #endif | 261 #endif |
| OLD | NEW |