Lines Matching refs:row
101 // We already have the data in a row, so we can just return that row
102 AtlasRow* row = fKeyTable[index];
103 if (0 == row->fLocks) {
104 this->removeFromLRU(row);
106 ++row->fLocks;
110 // required for storing row numbers and just compute it with some pointer arithmetic
111 rowNumber = static_cast<int>(row - fRows);
116 // We don't have this data cached, so pick the least recently used row to copy into
117 AtlasRow* row = this->getLRU();
121 if (NULL == row) {
124 row = this->getLRU();
125 if (NULL == row) {
131 this->removeFromLRU(row);
133 uint32_t oldKey = row->fKey;
135 // If we are writing into a row that already held bitmap data, we need to remove the
149 row->fKey = key;
150 row->fLocks = 1;
151 fKeyTable.insert(index, 1, &row);
152 rowNumber = static_cast<int>(row - fRows);
172 void GrTextureStripAtlas::unlockRow(int row) {
174 --fRows[row].fLocks;
176 GrAssert(fRows[row].fLocks >= 0 && fLockedRows >= 0);
177 if (0 == fRows[row].fLocks) {
178 this->appendLRU(fRows + row);
188 AtlasRow* row = fLRUFront;
189 return row;
235 void GrTextureStripAtlas::appendLRU(AtlasRow* row) {
236 GrAssert(NULL == row->fPrev && NULL == row->fNext);
238 fLRUFront = row;
239 fLRUBack = row;
241 row->fPrev = fLRUBack;
242 fLRUBack->fNext = row;
243 fLRUBack = row;
247 void GrTextureStripAtlas::removeFromLRU(AtlasRow* row) {
248 GrAssert(NULL != row);
249 if (NULL != row->fNext && NULL != row->fPrev) {
250 row->fPrev->fNext = row->fNext;
251 row->fNext->fPrev = row->fPrev;
253 if (NULL == row->fNext) {
254 GrAssert(row == fLRUBack);
255 fLRUBack = row->fPrev;
260 if (NULL == row->fPrev) {
261 GrAssert(row == fLRUFront);
262 fLRUFront = row->fNext;
268 row->fNext = NULL;
269 row->fPrev = NULL;
330 // Our count of locks should equal the sum of row locks, unless we ran out of rows and flushed,
332 // lock of a row; which ensures we don't unlock the texture prematurely).
335 // We should have one lru entry for each free row