Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 9753b9d6 authored by Linux Build Service Account's avatar Linux Build Service Account Committed by Gerrit - the friendly Code Review server
Browse files

Merge "Fix the texture ID reuse issue in HWUI."

parents 407909fb 9069a90c
Loading
Loading
Loading
Loading
+14 −5
Original line number Diff line number Diff line
@@ -554,11 +554,8 @@ void Caches::deleteTexture(GLuint texture) {
    // call, any texture operation will be performed on the default
    // texture (name=0)

    for (int i = 0; i < REQUIRED_TEXTURE_UNITS_COUNT; i++) {
        if (mBoundTextures[i] == texture) {
            mBoundTextures[i] = 0;
        }
    }
    unbindTexture(texture);

    glDeleteTextures(1, &texture);
}

@@ -566,6 +563,18 @@ void Caches::resetBoundTextures() {
    memset(mBoundTextures, 0, REQUIRED_TEXTURE_UNITS_COUNT * sizeof(GLuint));
}

uint32_t Caches::getBoundTexture() {
    return mBoundTextures[mTextureUnit];
}

void Caches::unbindTexture(GLuint texture) {
    for (int i = 0; i < REQUIRED_TEXTURE_UNITS_COUNT; i++) {
        if (mBoundTextures[i] == texture) {
            mBoundTextures[i] = 0;
        }
    }
}

///////////////////////////////////////////////////////////////////////////////
// Scissor
///////////////////////////////////////////////////////////////////////////////
+10 −0
Original line number Diff line number Diff line
@@ -263,6 +263,16 @@ public:
     */
    void resetBoundTextures();

    /**
     * Get the mBoundTextures[mTextureUnit].
     */
    uint32_t getBoundTexture();

    /**
     * Clear the cache of bound textures.
     */
    void unbindTexture(GLuint texture);

    /**
     * Sets the scissor for the current surface.
     */
+3 −0
Original line number Diff line number Diff line
@@ -171,6 +171,9 @@ void Layer::deleteTexture() {
}

void Layer::clearTexture() {
    if (texture.id == caches.getBoundTexture()) {
        caches.unbindTexture(texture.id);
    }
    texture.id = 0;
}