Kostya Serebryany | 4fb7801 | 2013-12-06 09:00:17 +0000 | [diff] [blame] | 1 | //===- ASanStackFrameLayoutTest.cpp - Tests for ComputeASanStackFrameLayout===// |
| 2 | // |
| 3 | // The LLVM Compiler Infrastructure |
| 4 | // |
| 5 | // This file is distributed under the University of Illinois Open Source |
| 6 | // License. See LICENSE.TXT for details. |
| 7 | // |
| 8 | //===----------------------------------------------------------------------===// |
| 9 | #include "llvm/Transforms/Utils/ASanStackFrameLayout.h" |
| 10 | #include "llvm/ADT/ArrayRef.h" |
Kostya Serebryany | 4fb7801 | 2013-12-06 09:00:17 +0000 | [diff] [blame] | 11 | #include "gtest/gtest.h" |
Chandler Carruth | 8a8cd2b | 2014-01-07 11:48:04 +0000 | [diff] [blame] | 12 | #include <sstream> |
Kostya Serebryany | 4fb7801 | 2013-12-06 09:00:17 +0000 | [diff] [blame] | 13 | |
| 14 | using namespace llvm; |
| 15 | |
| 16 | static std::string |
| 17 | ShadowBytesToString(ArrayRef<uint8_t> ShadowBytes) { |
| 18 | std::ostringstream os; |
| 19 | for (size_t i = 0, n = ShadowBytes.size(); i < n; i++) { |
| 20 | switch (ShadowBytes[i]) { |
| 21 | case kAsanStackLeftRedzoneMagic: os << "L"; break; |
| 22 | case kAsanStackRightRedzoneMagic: os << "R"; break; |
| 23 | case kAsanStackMidRedzoneMagic: os << "M"; break; |
| 24 | default: os << (unsigned)ShadowBytes[i]; |
| 25 | } |
| 26 | } |
| 27 | return os.str(); |
| 28 | } |
| 29 | |
| 30 | static void TestLayout(SmallVector<ASanStackVariableDescription, 10> Vars, |
| 31 | size_t Granularity, size_t MinHeaderSize, |
| 32 | const std::string &ExpectedDescr, |
| 33 | const std::string &ExpectedShadow) { |
| 34 | ASanStackFrameLayout L; |
| 35 | ComputeASanStackFrameLayout(Vars, Granularity, MinHeaderSize, &L); |
| 36 | EXPECT_EQ(ExpectedDescr, L.DescriptionString); |
| 37 | EXPECT_EQ(ExpectedShadow, ShadowBytesToString(L.ShadowBytes)); |
| 38 | } |
| 39 | |
| 40 | TEST(ASanStackFrameLayout, Test) { |
| 41 | #define VEC1(a) SmallVector<ASanStackVariableDescription, 10>(1, a) |
| 42 | #define VEC(a) \ |
| 43 | SmallVector<ASanStackVariableDescription, 10>(a, a + sizeof(a) / sizeof(a[0])) |
| 44 | |
| 45 | #define VAR(name, size, alignment) \ |
| 46 | ASanStackVariableDescription name##size##_##alignment = { \ |
| 47 | #name #size "_" #alignment, \ |
| 48 | size, \ |
| 49 | alignment, \ |
| 50 | 0, \ |
| 51 | 0 \ |
| 52 | } |
| 53 | |
| 54 | VAR(a, 1, 1); |
| 55 | VAR(p, 1, 32); |
| 56 | VAR(p, 1, 256); |
| 57 | VAR(a, 2, 1); |
| 58 | VAR(a, 3, 1); |
| 59 | VAR(a, 4, 1); |
| 60 | VAR(a, 7, 1); |
| 61 | VAR(a, 8, 1); |
| 62 | VAR(a, 9, 1); |
| 63 | VAR(a, 16, 1); |
| 64 | VAR(a, 41, 1); |
| 65 | VAR(a, 105, 1); |
| 66 | |
| 67 | TestLayout(VEC1(a1_1), 8, 16, "1 16 1 4 a1_1", "LL1R"); |
| 68 | TestLayout(VEC1(a1_1), 64, 64, "1 64 1 4 a1_1", "L1"); |
| 69 | TestLayout(VEC1(p1_32), 8, 32, "1 32 1 5 p1_32", "LLLL1RRR"); |
| 70 | TestLayout(VEC1(p1_32), 8, 64, "1 64 1 5 p1_32", "LLLLLLLL1RRRRRRR"); |
| 71 | |
| 72 | TestLayout(VEC1(a1_1), 8, 32, "1 32 1 4 a1_1", "LLLL1RRR"); |
| 73 | TestLayout(VEC1(a2_1), 8, 32, "1 32 2 4 a2_1", "LLLL2RRR"); |
| 74 | TestLayout(VEC1(a3_1), 8, 32, "1 32 3 4 a3_1", "LLLL3RRR"); |
| 75 | TestLayout(VEC1(a4_1), 8, 32, "1 32 4 4 a4_1", "LLLL4RRR"); |
| 76 | TestLayout(VEC1(a7_1), 8, 32, "1 32 7 4 a7_1", "LLLL7RRR"); |
| 77 | TestLayout(VEC1(a8_1), 8, 32, "1 32 8 4 a8_1", "LLLL0RRR"); |
| 78 | TestLayout(VEC1(a9_1), 8, 32, "1 32 9 4 a9_1", "LLLL01RR"); |
| 79 | TestLayout(VEC1(a16_1), 8, 32, "1 32 16 5 a16_1", "LLLL00RR"); |
| 80 | TestLayout(VEC1(p1_256), 8, 32, "1 256 1 6 p1_256", |
| 81 | "LLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLL1RRR"); |
| 82 | TestLayout(VEC1(a41_1), 8, 32, "1 32 41 5 a41_1", "LLLL000001RRRRRR"); |
| 83 | TestLayout(VEC1(a105_1), 8, 32, "1 32 105 6 a105_1", |
| 84 | "LLLL00000000000001RRRRRR"); |
| 85 | |
| 86 | { |
| 87 | ASanStackVariableDescription t[] = {a1_1, p1_256}; |
| 88 | TestLayout(VEC(t), 8, 32, |
| 89 | "2 256 1 6 p1_256 272 1 4 a1_1", |
| 90 | "LLLLLLLL" "LLLLLLLL" "LLLLLLLL" "LLLLLLLL" "1M1R"); |
| 91 | } |
| 92 | |
| 93 | { |
| 94 | ASanStackVariableDescription t[] = {a1_1, a16_1, a41_1}; |
| 95 | TestLayout(VEC(t), 8, 32, |
| 96 | "3 32 1 4 a1_1 48 16 5 a16_1 80 41 5 a41_1", |
| 97 | "LLLL" "1M00" "MM00" "0001" "RRRR"); |
| 98 | } |
| 99 | #undef VEC1 |
| 100 | #undef VEC |
| 101 | #undef VAR |
| 102 | } |