1 /*
2 * Copyright (C) 2017 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17 #include <stdint.h>
18
19 #include <memory>
20 #include <vector>
21
22 #include <gtest/gtest.h>
23
24 #include "MemoryRange.h"
25 #include "utils/MemoryFake.h"
26
27 namespace unwindstack {
28
29 class MemoryRangeTest : public ::testing::Test {
30 protected:
SetUp()31 void SetUp() override {
32 process_memory_.reset();
33 memory_fake_ = new MemoryFake;
34 process_memory_.reset(memory_fake_);
35 }
36
37 std::shared_ptr<Memory> process_memory_;
38 MemoryFake* memory_fake_ = nullptr;
39 };
40
TEST_F(MemoryRangeTest,read_fully)41 TEST_F(MemoryRangeTest, read_fully) {
42 memory_fake_->SetMemoryBlock(9000, 2048, 0x4c);
43
44 MemoryRange range(process_memory_, 9001, 1024, 0);
45
46 std::vector<uint8_t> dst(1024);
47 ASSERT_TRUE(range.ReadFully(0, dst.data(), dst.size()));
48 for (size_t i = 0; i < dst.size(); i++) {
49 ASSERT_EQ(0x4cU, dst[i]) << "Failed at byte " << i;
50 }
51 }
52
TEST_F(MemoryRangeTest,read_fully_near_limit)53 TEST_F(MemoryRangeTest, read_fully_near_limit) {
54 memory_fake_->SetMemoryBlock(0, 8192, 0x4c);
55
56 MemoryRange range(process_memory_, 1000, 1024, 0);
57
58 std::vector<uint8_t> dst(1024);
59 ASSERT_TRUE(range.ReadFully(1020, dst.data(), 4));
60 for (size_t i = 0; i < 4; i++) {
61 ASSERT_EQ(0x4cU, dst[i]) << "Failed at byte " << i;
62 }
63
64 // Verify that reads outside of the range will fail.
65 ASSERT_FALSE(range.ReadFully(1020, dst.data(), 5));
66 ASSERT_FALSE(range.ReadFully(1024, dst.data(), 1));
67 ASSERT_FALSE(range.ReadFully(1024, dst.data(), 1024));
68
69 // Verify that reading up to the end works.
70 ASSERT_TRUE(range.ReadFully(1020, dst.data(), 4));
71 }
72
TEST_F(MemoryRangeTest,read_fully_overflow)73 TEST_F(MemoryRangeTest, read_fully_overflow) {
74 std::vector<uint8_t> buffer(100);
75
76 std::shared_ptr<Memory> process_memory(new MemoryFakeAlwaysReadZero);
77 std::unique_ptr<MemoryRange> overflow(new MemoryRange(process_memory, 100, 200, 0));
78 ASSERT_FALSE(overflow->ReadFully(UINT64_MAX - 10, buffer.data(), 100));
79 }
80
TEST_F(MemoryRangeTest,read)81 TEST_F(MemoryRangeTest, read) {
82 memory_fake_->SetMemoryBlock(0, 4096, 0x4c);
83
84 MemoryRange range(process_memory_, 1000, 1024, 0);
85
86 std::vector<uint8_t> dst(1024);
87 ASSERT_EQ(4U, range.Read(1020, dst.data(), dst.size()));
88 for (size_t i = 0; i < 4; i++) {
89 ASSERT_EQ(0x4cU, dst[i]) << "Failed at byte " << i;
90 }
91 }
92
TEST_F(MemoryRangeTest,read_non_zero_offset)93 TEST_F(MemoryRangeTest, read_non_zero_offset) {
94 memory_fake_->SetMemoryBlock(1000, 1024, 0x12);
95
96 MemoryRange range(process_memory_, 1000, 1024, 400);
97
98 std::vector<uint8_t> dst(1024);
99 ASSERT_EQ(1024U, range.Read(400, dst.data(), dst.size()));
100 for (size_t i = 0; i < dst.size(); i++) {
101 ASSERT_EQ(0x12U, dst[i]) << "Failed at byte " << i;
102 }
103 }
104
105 } // namespace unwindstack
106