diff options
author | sugoi@google.com <sugoi@google.com@2bbb7eff-a529-9590-31e7-b0007b416f81> | 2013-11-04 16:18:15 +0000 |
---|---|---|
committer | sugoi@google.com <sugoi@google.com@2bbb7eff-a529-9590-31e7-b0007b416f81> | 2013-11-04 16:18:15 +0000 |
commit | 305f78e8c18a26b7ead11758d6a4fa0519932cca (patch) | |
tree | 84ce0e834d8c52393c0b52190fa0583168304ffd /tests/MatrixTest.cpp | |
parent | fe2faa8b16e2a607543c5b30637e7da54012e169 (diff) |
Checking structure sizes before reading them from memory to avoid overflowing the buffer's stream.
BUG=
R=reed@google.com
Review URL: https://codereview.chromium.org/41253002
git-svn-id: http://skia.googlecode.com/svn/trunk@12114 2bbb7eff-a529-9590-31e7-b0007b416f81
Diffstat (limited to 'tests/MatrixTest.cpp')
-rw-r--r-- | tests/MatrixTest.cpp | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/tests/MatrixTest.cpp b/tests/MatrixTest.cpp index 07eacb6f44..e9886941eb 100644 --- a/tests/MatrixTest.cpp +++ b/tests/MatrixTest.cpp @@ -112,18 +112,19 @@ static void test_matrix_recttorect(skiatest::Reporter* reporter) { static void test_flatten(skiatest::Reporter* reporter, const SkMatrix& m) { // add 100 in case we have a bug, I don't want to kill my stack in the test - char buffer[SkMatrix::kMaxFlattenSize + 100]; - uint32_t size1 = m.writeToMemory(NULL); - uint32_t size2 = m.writeToMemory(buffer); + static const size_t kBufferSize = SkMatrix::kMaxFlattenSize + 100; + char buffer[kBufferSize]; + size_t size1 = m.writeToMemory(NULL); + size_t size2 = m.writeToMemory(buffer); REPORTER_ASSERT(reporter, size1 == size2); REPORTER_ASSERT(reporter, size1 <= SkMatrix::kMaxFlattenSize); SkMatrix m2; - uint32_t size3 = m2.readFromMemory(buffer); + size_t size3 = m2.readFromMemory(buffer, kBufferSize); REPORTER_ASSERT(reporter, size1 == size3); REPORTER_ASSERT(reporter, are_equal(reporter, m, m2)); - char buffer2[SkMatrix::kMaxFlattenSize + 100]; + char buffer2[kBufferSize]; size3 = m2.writeToMemory(buffer2); REPORTER_ASSERT(reporter, size1 == size3); REPORTER_ASSERT(reporter, memcmp(buffer, buffer2, size1) == 0); |