blob: 0430c7362fcec2ffaaa5b21e4896917c836dddab [file] [log] [blame]
Alexandre Rames9dd6fa32016-10-12 13:26:54 +01001// Copyright 2016, VIXL authors
2// All rights reserved.
3//
4// Redistribution and use in source and binary forms, with or without
5// modification, are permitted provided that the following conditions are met:
6//
7// * Redistributions of source code must retain the above copyright notice,
8// this list of conditions and the following disclaimer.
9// * Redistributions in binary form must reproduce the above copyright notice,
10// this list of conditions and the following disclaimer in the documentation
11// and/or other materials provided with the distribution.
12// * Neither the name of ARM Limited nor the names of its contributors may be
13// used to endorse or promote products derived from this software without
14// specific prior written permission.
15//
16// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS CONTRIBUTORS "AS IS" AND
17// ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19// DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
20// FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21// DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
22// SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
23// CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
24// OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
25// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26
27#include "test-runner.h"
28
29#include "aarch64/macro-assembler-aarch64.h"
30
31#define TEST(name) TEST_(SCOPES_##name)
32#define __ masm.
33
34namespace vixl {
35
36// This file contains tests for code generation scopes.
37
38TEST(CodeBufferCheckScope_basic) {
39 aarch64::MacroAssembler masm;
40
41 {
42 CodeBufferCheckScope scope(&masm, aarch64::kInstructionSize);
43 __ Mov(aarch64::x0, 0);
44 }
45
46 masm.FinalizeCode();
47}
48
49
50TEST(CodeBufferCheckScope_Open) {
51 aarch64::MacroAssembler masm;
52
53 {
54 CodeBufferCheckScope scope;
55 __ Mov(aarch64::x0, 0);
56 scope.Open(&masm, aarch64::kInstructionSize);
57 __ Mov(aarch64::x1, 1);
58 }
59
60 masm.FinalizeCode();
61}
62
63
64TEST(CodeBufferCheckScope_Close) {
65 aarch64::MacroAssembler masm;
66
67 {
68 CodeBufferCheckScope scope(&masm, aarch64::kInstructionSize);
69 __ Mov(aarch64::x0, 0);
70 scope.Close();
71 __ Mov(aarch64::x1, 1);
72 }
73
74 masm.FinalizeCode();
75}
76
77
78TEST(CodeBufferCheckScope_Open_Close) {
79 aarch64::MacroAssembler masm;
80
81 {
82 CodeBufferCheckScope scope;
83 __ Mov(aarch64::x0, 0);
84 scope.Open(&masm, aarch64::kInstructionSize);
85 __ Mov(aarch64::x1, 1);
86 scope.Close();
87 __ Mov(aarch64::x2, 2);
88 }
89
90 masm.FinalizeCode();
91}
92
93
Alexandre Ramesc0b25f22016-10-19 13:53:55 +010094TEST(EmissionCheckScope_basic) {
95 aarch64::MacroAssembler masm;
96
97 {
98 EmissionCheckScope scope(&masm, aarch64::kInstructionSize);
99 __ Mov(aarch64::x0, 0);
100 }
101
102 masm.FinalizeCode();
103}
104
105
106TEST(EmissionCheckScope_Open) {
107 aarch64::MacroAssembler masm;
108
109 {
110 EmissionCheckScope scope;
111 __ Mov(aarch64::x0, 0);
112 scope.Open(&masm, aarch64::kInstructionSize);
113 __ Mov(aarch64::x1, 1);
114 }
115
116 masm.FinalizeCode();
117}
118
119
120TEST(EmissionCheckScope_Close) {
121 aarch64::MacroAssembler masm;
122
123 {
124 EmissionCheckScope scope(&masm, aarch64::kInstructionSize);
125 __ Mov(aarch64::x0, 0);
126 scope.Close();
127 __ Mov(aarch64::x1, 1);
128 }
129
130 masm.FinalizeCode();
131}
132
133
134TEST(EmissionCheckScope_Open_Close) {
135 aarch64::MacroAssembler masm;
136
137 {
138 EmissionCheckScope scope;
139 __ Mov(aarch64::x0, 0);
140 scope.Open(&masm, aarch64::kInstructionSize);
141 __ Mov(aarch64::x1, 1);
142 scope.Close();
143 __ Mov(aarch64::x2, 2);
144 }
145
146 masm.FinalizeCode();
147}
148
149
150#define ASSERT_LITERAL_POOL_SIZE(expected) \
151 VIXL_CHECK( \
152 (expected + aarch64::kInstructionSize) == (masm.GetLiteralPoolSize()))
153
154TEST(EmissionCheckScope_emit_pool) {
155 aarch64::MacroAssembler masm;
156
157 // Make sure the pool is empty;
158 masm.EmitLiteralPool(aarch64::LiteralPool::kBranchRequired);
159 ASSERT_LITERAL_POOL_SIZE(0);
160
161 __ Ldr(aarch64::x0, 0x1234567890abcdef);
162 ASSERT_LITERAL_POOL_SIZE(8);
163
164 {
165 // Check that opening the scope with a reserved space well below the limit
166 // at which can generate the literal pool does not force the emission of
167 // the pool.
168 EmissionCheckScope scope(&masm,
169 10 * aarch64::kInstructionSize,
170 EmissionCheckScope::kMaximumSize);
171 ASSERT_LITERAL_POOL_SIZE(8);
172 }
173
174 {
175 // Check that the scope forces emission of the pool if necessary.
176 EmissionCheckScope scope(&masm,
177 aarch64::kMaxLoadLiteralRange + 1,
178 EmissionCheckScope::kMaximumSize);
179 ASSERT_LITERAL_POOL_SIZE(0);
180 }
181
182 masm.FinalizeCode();
183}
184
185
186TEST(EmissionCheckScope_emit_pool_on_Open) {
187 aarch64::MacroAssembler masm;
188
189 // Make sure the pool is empty;
190 masm.EmitLiteralPool(aarch64::LiteralPool::kBranchRequired);
191 ASSERT_LITERAL_POOL_SIZE(0);
192
193 __ Ldr(aarch64::x0, 0x1234567890abcdef);
194 ASSERT_LITERAL_POOL_SIZE(8);
195
196 {
197 // Check that opening the scope with a reserved space well below the limit
198 // at which can generate the literal pool does not force the emission of
199 // the pool.
200 EmissionCheckScope scope;
201 scope.Open(&masm,
202 10 * aarch64::kInstructionSize,
203 EmissionCheckScope::kMaximumSize);
204 ASSERT_LITERAL_POOL_SIZE(8);
205 }
206
207 {
208 // Check that the scope forces emission of the pool if necessary.
209 EmissionCheckScope scope;
210 scope.Open(&masm,
211 aarch64::kMaxLoadLiteralRange + 1,
212 EmissionCheckScope::kMaximumSize);
213 ASSERT_LITERAL_POOL_SIZE(0);
214 }
215
216 masm.FinalizeCode();
217}
218
219
Alexandre Rames9dd6fa32016-10-12 13:26:54 +0100220} // namespace vixl
221