Fix for MSAN unintialized value
authorjoshualitt <joshualitt@chromium.org>
Tue, 25 Aug 2015 19:10:54 +0000 (12:10 -0700)
committerCommit bot <commit-bot@chromium.org>
Tue, 25 Aug 2015 19:10:54 +0000 (12:10 -0700)
BUG=524094

Review URL: https://codereview.chromium.org/1320433002

src/gpu/effects/GrTextureDomain.cpp
src/gpu/effects/GrTextureDomain.h

index 3810c3482f5f2f2491b524d5c2f2e736cdad3a15..e5ae18c961247809617ef13f85d77a78ec90d8f3 100644 (file)
@@ -146,7 +146,7 @@ void GrTextureDomain::GLDomain::setData(const GrGLProgramDataManager& pdman,
                                         GrSurfaceOrigin textureOrigin) {
     SkASSERT(textureDomain.mode() == fMode);
     if (kIgnore_Mode != textureDomain.mode()) {
-        GrGLfloat values[4] = {
+        GrGLfloat values[kPrevDomainCount] = {
             SkScalarToFloat(textureDomain.domain().left()),
             SkScalarToFloat(textureDomain.domain().top()),
             SkScalarToFloat(textureDomain.domain().right()),
@@ -160,9 +160,9 @@ void GrTextureDomain::GLDomain::setData(const GrGLProgramDataManager& pdman,
             // of elements so that values = (l, t, r, b).
             SkTSwap(values[1], values[3]);
         }
-        if (0 != memcmp(values, fPrevDomain, 4 * sizeof(GrGLfloat))) {
+        if (0 != memcmp(values, fPrevDomain, kPrevDomainCount * sizeof(GrGLfloat))) {
             pdman.set4fv(fDomainUni, 1, values);
-            memcpy(fPrevDomain, values, 4 * sizeof(GrGLfloat));
+            memcpy(fPrevDomain, values, kPrevDomainCount * sizeof(GrGLfloat));
         }
     }
 }
index a2e6652e91cf91823cbe167104e4c9f62ab0bbad..11760fb62b5929433acf49226105f8f883e906a7 100644 (file)
@@ -95,7 +95,9 @@ public:
     class GLDomain {
     public:
         GLDomain() {
-            fPrevDomain[0] = SK_FloatNaN;
+            for (int i = 0; i < kPrevDomainCount; i++) {
+                fPrevDomain[i] = SK_FloatNaN;
+            }
             SkDEBUGCODE(fMode = (Mode) -1;)
         }
 
@@ -137,10 +139,11 @@ public:
         }
 
     private:
+        static const int kPrevDomainCount = 4;
         SkDEBUGCODE(Mode                      fMode;)
         GrGLProgramDataManager::UniformHandle fDomainUni;
         SkString                              fDomainName;
-        GrGLfloat                             fPrevDomain[4];
+        GrGLfloat                             fPrevDomain[kPrevDomainCount];
     };
 
 protected: