aboutsummaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorGravatar raftias <raftias@google.com>2016-10-20 10:38:58 -0700
committerGravatar Commit bot <commit-bot@chromium.org>2016-10-20 10:38:58 -0700
commit80739b842ad0681333d40feda578d04044c8157f (patch)
tree041a04e121df2885e22972eeb80d51a8b6bc083a /src
parent313c4635e3f1005e6807f5b0ad52805f30902d66 (diff)
Fixed potential read-out-of-bounds issue in ICC profile loading
For 8-bit precision color LUT in A2B0 ICC color space profiles it was skipping every 2nd CLUT value and then reading past the end of the CLUT data table. Now it properly increments through 8-bit precision color LUT tables in profiles. BUG=skia: GOLD_TRYBOT_URL= https://gold.skia.org/search?issue=2434563007 Review-Url: https://chromiumcodereview.appspot.com/2434563007
Diffstat (limited to 'src')
-rw-r--r--src/core/SkColorSpace_ICC.cpp2
1 files changed, 1 insertions, 1 deletions
diff --git a/src/core/SkColorSpace_ICC.cpp b/src/core/SkColorSpace_ICC.cpp
index df665ecd69..6fc3090caf 100644
--- a/src/core/SkColorSpace_ICC.cpp
+++ b/src/core/SkColorSpace_ICC.cpp
@@ -656,7 +656,7 @@ static bool load_color_lut(sk_sp<SkColorLookUpTable>* colorLUT, uint32_t inputCh
const uint8_t* ptr = src + kColorLUTHeaderSize;
for (uint32_t i = 0; i < numEntries; i++, ptr += precision) {
if (1 == precision) {
- table[i] = ((float) ptr[i]) / 255.0f;
+ table[i] = ((float) *ptr) / 255.0f;
} else {
table[i] = ((float) read_big_endian_u16(ptr)) / 65535.0f;
}