blob: d4cee44458c4ffed7530b01e305c9fa074229449 [file] [log] [blame]
Elliott Hughes2faa5f12012-01-30 14:42:07 -08001/*
2 * Copyright (C) 2011 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 */
Ian Rogers9651f422011-09-19 20:26:07 -070016
Brian Carlstromfc0e3212013-07-17 14:40:12 -070017#ifndef ART_RUNTIME_ASM_SUPPORT_H_
18#define ART_RUNTIME_ASM_SUPPORT_H_
Ian Rogers9651f422011-09-19 20:26:07 -070019
Ian Rogers1d8cdbc2014-09-22 22:51:09 -070020#if defined(__cplusplus)
Mathieu Chartiere401d142015-04-22 13:56:20 -070021#include "art_method.h"
Hiroshi Yamauchidc412b62015-10-15 12:26:57 -070022#include "gc/allocator/rosalloc.h"
Mathieu Chartier8261d022016-08-08 09:41:04 -070023#include "gc/heap.h"
Nicolas Geoffray274fe4a2016-04-12 16:33:24 +010024#include "jit/jit.h"
Hiroshi Yamauchie15ea082015-02-09 17:11:42 -080025#include "lock_word.h"
Ian Rogers1d8cdbc2014-09-22 22:51:09 -070026#include "mirror/class.h"
27#include "mirror/string.h"
28#include "runtime.h"
29#include "thread.h"
30#endif
31
Hiroshi Yamauchi800ac2d2014-04-02 17:32:54 -070032#include "read_barrier_c.h"
Hiroshi Yamauchi9d04a202014-01-31 13:35:49 -080033
Zheng Xu69a50302015-04-14 20:04:41 +080034#if defined(__arm__) || defined(__mips__)
35// In quick code for ARM and MIPS we make poor use of registers and perform frequent suspend
Ian Rogers1d8cdbc2014-09-22 22:51:09 -070036// checks in the event of loop back edges. The SUSPEND_CHECK_INTERVAL constant is loaded into a
37// register at the point of an up-call or after handling a suspend check. It reduces the number of
38// loads of the TLS suspend check value by the given amount (turning it into a decrement and compare
39// of a register). This increases the time for a thread to respond to requests from GC and the
40// debugger, damaging GC performance and creating other unwanted artifacts. For example, this count
41// has the effect of making loops and Java code look cold in profilers, where the count is reset
42// impacts where samples will occur. Reducing the count as much as possible improves profiler
43// accuracy in tools like traceview.
44// TODO: get a compiler that can do a proper job of loop optimization and remove this.
buzbee72be1cd2014-11-11 22:48:59 -080045#define SUSPEND_CHECK_INTERVAL 96
Ian Rogers1d8cdbc2014-09-22 22:51:09 -070046#endif
47
48#if defined(__cplusplus)
49
50#ifndef ADD_TEST_EQ // Allow #include-r to replace with their own.
51#define ADD_TEST_EQ(x, y) CHECK_EQ(x, y);
52#endif
53
54static inline void CheckAsmSupportOffsetsAndSizes() {
55#else
56#define ADD_TEST_EQ(x, y)
57#endif
58
Hiroshi Yamauchidc412b62015-10-15 12:26:57 -070059#if defined(__LP64__)
60#define POINTER_SIZE_SHIFT 3
Andreas Gampe542451c2016-07-26 09:02:02 -070061#define POINTER_SIZE art::PointerSize::k64
Hiroshi Yamauchidc412b62015-10-15 12:26:57 -070062#else
63#define POINTER_SIZE_SHIFT 2
Andreas Gampe542451c2016-07-26 09:02:02 -070064#define POINTER_SIZE art::PointerSize::k32
Hiroshi Yamauchidc412b62015-10-15 12:26:57 -070065#endif
66ADD_TEST_EQ(static_cast<size_t>(1U << POINTER_SIZE_SHIFT),
67 static_cast<size_t>(__SIZEOF_POINTER__))
68
Igor Murashkin311fdf52016-07-22 15:59:16 -070069// Import platform-independent constant defines from our autogenerated list.
70// Export new defines (for assembly use) by editing cpp-define-generator def files.
71#define DEFINE_CHECK_EQ ADD_TEST_EQ
72#include "generated/asm_support_gen.h"
Ian Rogers1d8cdbc2014-09-22 22:51:09 -070073
74// Offset of field Thread::tlsPtr_.exception.
75#define THREAD_EXCEPTION_OFFSET (THREAD_CARD_TABLE_OFFSET + __SIZEOF_POINTER__)
76ADD_TEST_EQ(THREAD_EXCEPTION_OFFSET,
Andreas Gampe542451c2016-07-26 09:02:02 -070077 art::Thread::ExceptionOffset<POINTER_SIZE>().Int32Value())
Ian Rogers1d8cdbc2014-09-22 22:51:09 -070078
79// Offset of field Thread::tlsPtr_.managed_stack.top_quick_frame_.
80#define THREAD_TOP_QUICK_FRAME_OFFSET (THREAD_CARD_TABLE_OFFSET + (3 * __SIZEOF_POINTER__))
81ADD_TEST_EQ(THREAD_TOP_QUICK_FRAME_OFFSET,
Andreas Gampe542451c2016-07-26 09:02:02 -070082 art::Thread::TopOfManagedStackOffset<POINTER_SIZE>().Int32Value())
Ian Rogers1d8cdbc2014-09-22 22:51:09 -070083
Roland Levillainca80ecc2015-07-22 17:19:28 +010084// Offset of field Thread::tlsPtr_.self.
Andreas Gampe449357d2015-06-01 22:29:51 -070085#define THREAD_SELF_OFFSET (THREAD_CARD_TABLE_OFFSET + (9 * __SIZEOF_POINTER__))
Ian Rogers1d8cdbc2014-09-22 22:51:09 -070086ADD_TEST_EQ(THREAD_SELF_OFFSET,
Andreas Gampe542451c2016-07-26 09:02:02 -070087 art::Thread::SelfOffset<POINTER_SIZE>().Int32Value())
Ian Rogers4a510d82011-10-09 14:30:24 -070088
Roland Levillain02b75802016-07-13 11:54:35 +010089// Offset of field Thread::tlsPtr_.thread_local_objects.
Roland Levillaind549c282016-07-25 12:49:15 +010090#define THREAD_LOCAL_OBJECTS_OFFSET (THREAD_CARD_TABLE_OFFSET + 197 * __SIZEOF_POINTER__)
Roland Levillain02b75802016-07-13 11:54:35 +010091ADD_TEST_EQ(THREAD_LOCAL_OBJECTS_OFFSET,
Andreas Gampe542451c2016-07-26 09:02:02 -070092 art::Thread::ThreadLocalObjectsOffset<POINTER_SIZE>().Int32Value())
Roland Levillainca80ecc2015-07-22 17:19:28 +010093// Offset of field Thread::tlsPtr_.thread_local_pos.
Roland Levillain02b75802016-07-13 11:54:35 +010094#define THREAD_LOCAL_POS_OFFSET (THREAD_LOCAL_OBJECTS_OFFSET + __SIZEOF_SIZE_T__)
Hiroshi Yamauchie01a5202015-03-19 12:35:04 -070095ADD_TEST_EQ(THREAD_LOCAL_POS_OFFSET,
Andreas Gampe542451c2016-07-26 09:02:02 -070096 art::Thread::ThreadLocalPosOffset<POINTER_SIZE>().Int32Value())
Roland Levillainca80ecc2015-07-22 17:19:28 +010097// Offset of field Thread::tlsPtr_.thread_local_end.
Hiroshi Yamauchie01a5202015-03-19 12:35:04 -070098#define THREAD_LOCAL_END_OFFSET (THREAD_LOCAL_POS_OFFSET + __SIZEOF_POINTER__)
99ADD_TEST_EQ(THREAD_LOCAL_END_OFFSET,
Andreas Gampe542451c2016-07-26 09:02:02 -0700100 art::Thread::ThreadLocalEndOffset<POINTER_SIZE>().Int32Value())
buzbee1452bee2015-03-06 14:43:04 -0800101// Offset of field Thread::tlsPtr_.mterp_current_ibase.
Roland Levillain02b75802016-07-13 11:54:35 +0100102#define THREAD_CURRENT_IBASE_OFFSET (THREAD_LOCAL_END_OFFSET + __SIZEOF_POINTER__)
buzbee1452bee2015-03-06 14:43:04 -0800103ADD_TEST_EQ(THREAD_CURRENT_IBASE_OFFSET,
Andreas Gampe542451c2016-07-26 09:02:02 -0700104 art::Thread::MterpCurrentIBaseOffset<POINTER_SIZE>().Int32Value())
buzbee1452bee2015-03-06 14:43:04 -0800105// Offset of field Thread::tlsPtr_.mterp_default_ibase.
Vladimir Marko87f3fcb2016-04-28 15:52:11 +0100106#define THREAD_DEFAULT_IBASE_OFFSET (THREAD_CURRENT_IBASE_OFFSET + __SIZEOF_POINTER__)
buzbee1452bee2015-03-06 14:43:04 -0800107ADD_TEST_EQ(THREAD_DEFAULT_IBASE_OFFSET,
Andreas Gampe542451c2016-07-26 09:02:02 -0700108 art::Thread::MterpDefaultIBaseOffset<POINTER_SIZE>().Int32Value())
buzbee1452bee2015-03-06 14:43:04 -0800109// Offset of field Thread::tlsPtr_.mterp_alt_ibase.
Vladimir Marko87f3fcb2016-04-28 15:52:11 +0100110#define THREAD_ALT_IBASE_OFFSET (THREAD_DEFAULT_IBASE_OFFSET + __SIZEOF_POINTER__)
buzbee1452bee2015-03-06 14:43:04 -0800111ADD_TEST_EQ(THREAD_ALT_IBASE_OFFSET,
Andreas Gampe542451c2016-07-26 09:02:02 -0700112 art::Thread::MterpAltIBaseOffset<POINTER_SIZE>().Int32Value())
Hiroshi Yamauchidc412b62015-10-15 12:26:57 -0700113// Offset of field Thread::tlsPtr_.rosalloc_runs.
Vladimir Marko87f3fcb2016-04-28 15:52:11 +0100114#define THREAD_ROSALLOC_RUNS_OFFSET (THREAD_ALT_IBASE_OFFSET + __SIZEOF_POINTER__)
Hiroshi Yamauchidc412b62015-10-15 12:26:57 -0700115ADD_TEST_EQ(THREAD_ROSALLOC_RUNS_OFFSET,
Andreas Gampe542451c2016-07-26 09:02:02 -0700116 art::Thread::RosAllocRunsOffset<POINTER_SIZE>().Int32Value())
Hiroshi Yamauchidc412b62015-10-15 12:26:57 -0700117// Offset of field Thread::tlsPtr_.thread_local_alloc_stack_top.
Hiroshi Yamauchi7ed9c562016-02-02 15:22:09 -0800118#define THREAD_LOCAL_ALLOC_STACK_TOP_OFFSET (THREAD_ROSALLOC_RUNS_OFFSET + 16 * __SIZEOF_POINTER__)
Hiroshi Yamauchidc412b62015-10-15 12:26:57 -0700119ADD_TEST_EQ(THREAD_LOCAL_ALLOC_STACK_TOP_OFFSET,
Andreas Gampe542451c2016-07-26 09:02:02 -0700120 art::Thread::ThreadLocalAllocStackTopOffset<POINTER_SIZE>().Int32Value())
Hiroshi Yamauchidc412b62015-10-15 12:26:57 -0700121// Offset of field Thread::tlsPtr_.thread_local_alloc_stack_end.
Hiroshi Yamauchi7ed9c562016-02-02 15:22:09 -0800122#define THREAD_LOCAL_ALLOC_STACK_END_OFFSET (THREAD_ROSALLOC_RUNS_OFFSET + 17 * __SIZEOF_POINTER__)
Hiroshi Yamauchidc412b62015-10-15 12:26:57 -0700123ADD_TEST_EQ(THREAD_LOCAL_ALLOC_STACK_END_OFFSET,
Andreas Gampe542451c2016-07-26 09:02:02 -0700124 art::Thread::ThreadLocalAllocStackEndOffset<POINTER_SIZE>().Int32Value())
Hiroshi Yamauchie01a5202015-03-19 12:35:04 -0700125
buzbee1452bee2015-03-06 14:43:04 -0800126// Offsets within ShadowFrame.
127#define SHADOWFRAME_LINK_OFFSET 0
128ADD_TEST_EQ(SHADOWFRAME_LINK_OFFSET,
129 static_cast<int32_t>(art::ShadowFrame::LinkOffset()))
130#define SHADOWFRAME_METHOD_OFFSET (SHADOWFRAME_LINK_OFFSET + 1 * __SIZEOF_POINTER__)
131ADD_TEST_EQ(SHADOWFRAME_METHOD_OFFSET,
132 static_cast<int32_t>(art::ShadowFrame::MethodOffset()))
133#define SHADOWFRAME_RESULT_REGISTER_OFFSET (SHADOWFRAME_LINK_OFFSET + 2 * __SIZEOF_POINTER__)
134ADD_TEST_EQ(SHADOWFRAME_RESULT_REGISTER_OFFSET,
135 static_cast<int32_t>(art::ShadowFrame::ResultRegisterOffset()))
136#define SHADOWFRAME_DEX_PC_PTR_OFFSET (SHADOWFRAME_LINK_OFFSET + 3 * __SIZEOF_POINTER__)
137ADD_TEST_EQ(SHADOWFRAME_DEX_PC_PTR_OFFSET,
138 static_cast<int32_t>(art::ShadowFrame::DexPCPtrOffset()))
139#define SHADOWFRAME_CODE_ITEM_OFFSET (SHADOWFRAME_LINK_OFFSET + 4 * __SIZEOF_POINTER__)
140ADD_TEST_EQ(SHADOWFRAME_CODE_ITEM_OFFSET,
141 static_cast<int32_t>(art::ShadowFrame::CodeItemOffset()))
142#define SHADOWFRAME_LOCK_COUNT_DATA_OFFSET (SHADOWFRAME_LINK_OFFSET + 5 * __SIZEOF_POINTER__)
143ADD_TEST_EQ(SHADOWFRAME_LOCK_COUNT_DATA_OFFSET,
144 static_cast<int32_t>(art::ShadowFrame::LockCountDataOffset()))
145#define SHADOWFRAME_NUMBER_OF_VREGS_OFFSET (SHADOWFRAME_LINK_OFFSET + 6 * __SIZEOF_POINTER__)
146ADD_TEST_EQ(SHADOWFRAME_NUMBER_OF_VREGS_OFFSET,
147 static_cast<int32_t>(art::ShadowFrame::NumberOfVRegsOffset()))
148#define SHADOWFRAME_DEX_PC_OFFSET (SHADOWFRAME_NUMBER_OF_VREGS_OFFSET + 4)
149ADD_TEST_EQ(SHADOWFRAME_DEX_PC_OFFSET,
150 static_cast<int32_t>(art::ShadowFrame::DexPCOffset()))
Bill Buzbee1d011d92016-04-04 16:59:29 +0000151#define SHADOWFRAME_CACHED_HOTNESS_COUNTDOWN_OFFSET (SHADOWFRAME_NUMBER_OF_VREGS_OFFSET + 8)
152ADD_TEST_EQ(SHADOWFRAME_CACHED_HOTNESS_COUNTDOWN_OFFSET,
153 static_cast<int32_t>(art::ShadowFrame::CachedHotnessCountdownOffset()))
154#define SHADOWFRAME_HOTNESS_COUNTDOWN_OFFSET (SHADOWFRAME_NUMBER_OF_VREGS_OFFSET + 10)
155ADD_TEST_EQ(SHADOWFRAME_HOTNESS_COUNTDOWN_OFFSET,
156 static_cast<int32_t>(art::ShadowFrame::HotnessCountdownOffset()))
157#define SHADOWFRAME_VREGS_OFFSET (SHADOWFRAME_NUMBER_OF_VREGS_OFFSET + 12)
buzbee1452bee2015-03-06 14:43:04 -0800158ADD_TEST_EQ(SHADOWFRAME_VREGS_OFFSET,
159 static_cast<int32_t>(art::ShadowFrame::VRegsOffset()))
160
Hiroshi Yamauchi60f63f52015-04-23 16:12:40 -0700161#if defined(USE_BROOKS_READ_BARRIER)
Ian Rogers1d8cdbc2014-09-22 22:51:09 -0700162#define MIRROR_OBJECT_HEADER_SIZE 16
Hiroshi Yamauchi9d04a202014-01-31 13:35:49 -0800163#else
Ian Rogers1d8cdbc2014-09-22 22:51:09 -0700164#define MIRROR_OBJECT_HEADER_SIZE 8
165#endif
166ADD_TEST_EQ(size_t(MIRROR_OBJECT_HEADER_SIZE), sizeof(art::mirror::Object))
Hiroshi Yamauchi9d04a202014-01-31 13:35:49 -0800167
168// Offsets within java.lang.Class.
Narayan Kamathd1ef4362015-11-12 11:49:06 +0000169#define MIRROR_CLASS_COMPONENT_TYPE_OFFSET (8 + MIRROR_OBJECT_HEADER_SIZE)
Ian Rogers1d8cdbc2014-09-22 22:51:09 -0700170ADD_TEST_EQ(MIRROR_CLASS_COMPONENT_TYPE_OFFSET,
171 art::mirror::Class::ComponentTypeOffset().Int32Value())
Przemyslaw Szczepaniak121b25e2015-11-20 11:24:33 +0000172#define MIRROR_CLASS_ACCESS_FLAGS_OFFSET (36 + MIRROR_OBJECT_HEADER_SIZE)
Hiroshi Yamauchie01a5202015-03-19 12:35:04 -0700173ADD_TEST_EQ(MIRROR_CLASS_ACCESS_FLAGS_OFFSET,
174 art::mirror::Class::AccessFlagsOffset().Int32Value())
Alex Light9c557292015-12-17 15:48:01 -0800175#define MIRROR_CLASS_OBJECT_SIZE_OFFSET (100 + MIRROR_OBJECT_HEADER_SIZE)
Hiroshi Yamauchie01a5202015-03-19 12:35:04 -0700176ADD_TEST_EQ(MIRROR_CLASS_OBJECT_SIZE_OFFSET,
177 art::mirror::Class::ObjectSizeOffset().Int32Value())
Mathieu Chartier8261d022016-08-08 09:41:04 -0700178#define MIRROR_CLASS_OBJECT_PRIMITIVE_TYPE_OFFSET (104 + MIRROR_OBJECT_HEADER_SIZE)
179ADD_TEST_EQ(MIRROR_CLASS_OBJECT_PRIMITIVE_TYPE_OFFSET,
180 art::mirror::Class::PrimitiveTypeOffset().Int32Value())
Alex Light9c557292015-12-17 15:48:01 -0800181#define MIRROR_CLASS_STATUS_OFFSET (112 + MIRROR_OBJECT_HEADER_SIZE)
Hiroshi Yamauchie01a5202015-03-19 12:35:04 -0700182ADD_TEST_EQ(MIRROR_CLASS_STATUS_OFFSET,
183 art::mirror::Class::StatusOffset().Int32Value())
184
Mathieu Chartier8261d022016-08-08 09:41:04 -0700185#define PRIMITIVE_TYPE_SIZE_SHIFT_SHIFT 16
186ADD_TEST_EQ(PRIMITIVE_TYPE_SIZE_SHIFT_SHIFT,
187 static_cast<int>(art::mirror::Class::kPrimitiveTypeSizeShiftShift))
188
Hiroshi Yamauchi9d04a202014-01-31 13:35:49 -0800189// Array offsets.
Ian Rogers1d8cdbc2014-09-22 22:51:09 -0700190#define MIRROR_ARRAY_LENGTH_OFFSET MIRROR_OBJECT_HEADER_SIZE
191ADD_TEST_EQ(MIRROR_ARRAY_LENGTH_OFFSET, art::mirror::Array::LengthOffset().Int32Value())
192
193#define MIRROR_CHAR_ARRAY_DATA_OFFSET (4 + MIRROR_OBJECT_HEADER_SIZE)
194ADD_TEST_EQ(MIRROR_CHAR_ARRAY_DATA_OFFSET,
195 art::mirror::Array::DataOffset(sizeof(uint16_t)).Int32Value())
196
buzbee1452bee2015-03-06 14:43:04 -0800197#define MIRROR_BOOLEAN_ARRAY_DATA_OFFSET MIRROR_CHAR_ARRAY_DATA_OFFSET
198ADD_TEST_EQ(MIRROR_BOOLEAN_ARRAY_DATA_OFFSET,
199 art::mirror::Array::DataOffset(sizeof(uint8_t)).Int32Value())
200
201#define MIRROR_BYTE_ARRAY_DATA_OFFSET MIRROR_CHAR_ARRAY_DATA_OFFSET
202ADD_TEST_EQ(MIRROR_BYTE_ARRAY_DATA_OFFSET,
203 art::mirror::Array::DataOffset(sizeof(int8_t)).Int32Value())
204
205#define MIRROR_SHORT_ARRAY_DATA_OFFSET MIRROR_CHAR_ARRAY_DATA_OFFSET
206ADD_TEST_EQ(MIRROR_SHORT_ARRAY_DATA_OFFSET,
207 art::mirror::Array::DataOffset(sizeof(int16_t)).Int32Value())
208
209#define MIRROR_INT_ARRAY_DATA_OFFSET MIRROR_CHAR_ARRAY_DATA_OFFSET
210ADD_TEST_EQ(MIRROR_INT_ARRAY_DATA_OFFSET,
211 art::mirror::Array::DataOffset(sizeof(int32_t)).Int32Value())
212
213#define MIRROR_WIDE_ARRAY_DATA_OFFSET (8 + MIRROR_OBJECT_HEADER_SIZE)
214ADD_TEST_EQ(MIRROR_WIDE_ARRAY_DATA_OFFSET,
215 art::mirror::Array::DataOffset(sizeof(uint64_t)).Int32Value())
216
Ian Rogers1d8cdbc2014-09-22 22:51:09 -0700217#define MIRROR_OBJECT_ARRAY_DATA_OFFSET (4 + MIRROR_OBJECT_HEADER_SIZE)
218ADD_TEST_EQ(MIRROR_OBJECT_ARRAY_DATA_OFFSET,
219 art::mirror::Array::DataOffset(
220 sizeof(art::mirror::HeapReference<art::mirror::Object>)).Int32Value())
Hiroshi Yamauchi9d04a202014-01-31 13:35:49 -0800221
Hiroshi Yamauchie01a5202015-03-19 12:35:04 -0700222#define MIRROR_OBJECT_ARRAY_COMPONENT_SIZE 4
223ADD_TEST_EQ(static_cast<size_t>(MIRROR_OBJECT_ARRAY_COMPONENT_SIZE),
224 sizeof(art::mirror::HeapReference<art::mirror::Object>))
225
Mathieu Chartiere401d142015-04-22 13:56:20 -0700226#define MIRROR_LONG_ARRAY_DATA_OFFSET (8 + MIRROR_OBJECT_HEADER_SIZE)
227ADD_TEST_EQ(MIRROR_LONG_ARRAY_DATA_OFFSET,
228 art::mirror::Array::DataOffset(sizeof(uint64_t)).Int32Value())
229
Hiroshi Yamauchi9d04a202014-01-31 13:35:49 -0800230// Offsets within java.lang.String.
Jeff Hao848f70a2014-01-15 13:49:50 -0800231#define MIRROR_STRING_COUNT_OFFSET MIRROR_OBJECT_HEADER_SIZE
Ian Rogers1d8cdbc2014-09-22 22:51:09 -0700232ADD_TEST_EQ(MIRROR_STRING_COUNT_OFFSET, art::mirror::String::CountOffset().Int32Value())
Hiroshi Yamauchi9d04a202014-01-31 13:35:49 -0800233
Jeff Hao848f70a2014-01-15 13:49:50 -0800234#define MIRROR_STRING_VALUE_OFFSET (8 + MIRROR_OBJECT_HEADER_SIZE)
235ADD_TEST_EQ(MIRROR_STRING_VALUE_OFFSET, art::mirror::String::ValueOffset().Int32Value())
Ian Rogers1d8cdbc2014-09-22 22:51:09 -0700236
Ian Rogers1d8cdbc2014-09-22 22:51:09 -0700237
Bill Buzbee1d011d92016-04-04 16:59:29 +0000238
Ian Rogers1d8cdbc2014-09-22 22:51:09 -0700239#if defined(__cplusplus)
240} // End of CheckAsmSupportOffsets.
Hiroshi Yamauchi9d04a202014-01-31 13:35:49 -0800241#endif
242
Brian Carlstromfc0e3212013-07-17 14:40:12 -0700243#endif // ART_RUNTIME_ASM_SUPPORT_H_