aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/gpu/GrStencilBuffer.cpp
blob: 4b08e238efdb5ff53d74db565d3b861abe9a6f40 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55

/*
 * Copyright 2011 Google Inc.
 *
 * Use of this source code is governed by a BSD-style license that can be
 * found in the LICENSE file.
 */

#include "GrStencilBuffer.h"

#include "GrContext.h"
#include "GrGpu.h"

void GrStencilBuffer::wasDetachedFromRenderTarget(const GrRenderTarget* rt) {
    GrAssert(fRTAttachmentCnt > 0);
    if (0 == --fRTAttachmentCnt) {
        this->unlockInCache();
        // At this point we could be deleted!
    }
}

void GrStencilBuffer::transferToCacheAndLock() {
    GrAssert(NULL == fCacheEntry);
    fCacheEntry = 
        this->getGpu()->getContext()->addAndLockStencilBuffer(this);
}

void GrStencilBuffer::onRelease() {
    // When the GrGpu rips through its list of resources and releases
    // them it may release an SB before it releases its attached RTs.
    // In that case when GrStencilBuffer sees its last detach it no
    // long has a gpu ptr (gets nulled in GrResource::release()) and can't
    // access the cache to unlock itself. So if we're being released and still
    // have attachments go ahead and unlock now.
    if (fRTAttachmentCnt) {
        this->unlockInCache();
        // we shouldn't be deleted here because some RT still has a ref on us.
    }
    fCacheEntry = NULL;
}

void GrStencilBuffer::onAbandon() {
    // we can use the same behavior as release.
    this->onRelease();
}

void GrStencilBuffer::unlockInCache() {
    if (NULL != fCacheEntry) {
        GrGpu* gpu = this->getGpu();
        if (NULL != gpu) {
            GrAssert(NULL != gpu->getContext());
            gpu->getContext()->unlockStencilBuffer(fCacheEntry);
        }
    }
}