aboutsummaryrefslogtreecommitdiffhomepage
path: root/tests/OverAlignedTest.cpp
diff options
context:
space:
mode:
authorGravatar Mike Klein <mtklein@chromium.org>2016-09-27 07:41:45 -0400
committerGravatar Skia Commit-Bot <skia-commit-bot@chromium.org>2016-09-27 12:16:39 +0000
commit7bfc08b9fb4289381609cee1deb0dc6325f878e1 (patch)
treef52431c3b81c9d5510a1a7be5646de0866fdb783 /tests/OverAlignedTest.cpp
parent75d6ffbc74b6afd851387a24d9dc8c0689d19197 (diff)
Focus -Wno-over-aligned to just 32-bit x86 Android. (2)
I've even found the code that's making this happen, just don't know why. I've added a test to assert that it's safe to assume malloc() is 8-byte aligned. Test should compile this time. CQ_INCLUDE_TRYBOTS=master.client.skia.android:Test-Android-Clang-NexusPlayer-CPU-Moorefield-x86-Release-GN_Android-Trybot Change-Id: I48714b99670c20704adf4f7f216da0d60d7d9bcd Reviewed-on: https://skia-review.googlesource.com/2662 Reviewed-on: https://skia-review.googlesource.com/2703 Reviewed-by: Mike Klein <mtklein@chromium.org> Commit-Queue: Mike Klein <mtklein@chromium.org>
Diffstat (limited to 'tests/OverAlignedTest.cpp')
-rw-r--r--tests/OverAlignedTest.cpp22
1 files changed, 22 insertions, 0 deletions
diff --git a/tests/OverAlignedTest.cpp b/tests/OverAlignedTest.cpp
new file mode 100644
index 0000000000..aea74c7daa
--- /dev/null
+++ b/tests/OverAlignedTest.cpp
@@ -0,0 +1,22 @@
+/*
+ * Copyright 2016 Google Inc.
+ *
+ * Use of this source code is governed by a BSD-style license that can be
+ * found in the LICENSE file.
+ */
+
+#include "Test.h"
+#include "SkRandom.h"
+
+// Clang seems to think only 32-bit alignment is guaranteed on 32-bit x86 Android.
+// See https://reviews.llvm.org/D8357
+// This is why we have disabled -Wover-aligned there (we allocate 8-byte aligned structs in Ganesh).
+DEF_TEST(OverAligned, r) {
+ SkRandom rand;
+ // Let's test that assertion. We think it really should be providing 8-byte alignment.
+ for (int i = 0; i < 1000; i++) {
+ void* p = malloc(rand.nextRangeU(0,100));
+ REPORTER_ASSERT(r, SkIsAlign8((uintptr_t)p));
+ free(p);
+ }
+}