1*eb293b8fSAndroid Build Coastguard Worker /*
2*eb293b8fSAndroid Build Coastguard Worker * Copyright (C) 2020 The Android Open Source Project
3*eb293b8fSAndroid Build Coastguard Worker *
4*eb293b8fSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License");
5*eb293b8fSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License.
6*eb293b8fSAndroid Build Coastguard Worker * You may obtain a copy of the License at
7*eb293b8fSAndroid Build Coastguard Worker *
8*eb293b8fSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0
9*eb293b8fSAndroid Build Coastguard Worker *
10*eb293b8fSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software
11*eb293b8fSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS,
12*eb293b8fSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*eb293b8fSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and
14*eb293b8fSAndroid Build Coastguard Worker * limitations under the License.
15*eb293b8fSAndroid Build Coastguard Worker */
16*eb293b8fSAndroid Build Coastguard Worker
17*eb293b8fSAndroid Build Coastguard Worker #include <sys/ptrace.h>
18*eb293b8fSAndroid Build Coastguard Worker #include <sys/uio.h>
19*eb293b8fSAndroid Build Coastguard Worker
20*eb293b8fSAndroid Build Coastguard Worker #if defined(__BIONIC__)
21*eb293b8fSAndroid Build Coastguard Worker #include <bionic/mte.h>
22*eb293b8fSAndroid Build Coastguard Worker #else
23*eb293b8fSAndroid Build Coastguard Worker #define mte_supported() false
24*eb293b8fSAndroid Build Coastguard Worker #endif
25*eb293b8fSAndroid Build Coastguard Worker
26*eb293b8fSAndroid Build Coastguard Worker #include "MemoryLocal.h"
27*eb293b8fSAndroid Build Coastguard Worker #include "MemoryRemote.h"
28*eb293b8fSAndroid Build Coastguard Worker
29*eb293b8fSAndroid Build Coastguard Worker namespace unwindstack {
30*eb293b8fSAndroid Build Coastguard Worker
ReadTag(uint64_t addr)31*eb293b8fSAndroid Build Coastguard Worker long MemoryRemote::ReadTag(uint64_t addr) {
32*eb293b8fSAndroid Build Coastguard Worker #if defined(PTRACE_PEEKMTETAGS) || defined(PT_PEEKMTETAGS)
33*eb293b8fSAndroid Build Coastguard Worker char tag;
34*eb293b8fSAndroid Build Coastguard Worker iovec iov = {&tag, 1};
35*eb293b8fSAndroid Build Coastguard Worker if (ptrace(PTRACE_PEEKMTETAGS, pid_, reinterpret_cast<void*>(addr), &iov) != 0 ||
36*eb293b8fSAndroid Build Coastguard Worker iov.iov_len != 1) {
37*eb293b8fSAndroid Build Coastguard Worker return -1;
38*eb293b8fSAndroid Build Coastguard Worker }
39*eb293b8fSAndroid Build Coastguard Worker return tag;
40*eb293b8fSAndroid Build Coastguard Worker #else
41*eb293b8fSAndroid Build Coastguard Worker (void)addr;
42*eb293b8fSAndroid Build Coastguard Worker return -1;
43*eb293b8fSAndroid Build Coastguard Worker #endif
44*eb293b8fSAndroid Build Coastguard Worker }
45*eb293b8fSAndroid Build Coastguard Worker
ReadTag(uint64_t addr)46*eb293b8fSAndroid Build Coastguard Worker long MemoryLocal::ReadTag(uint64_t addr) {
47*eb293b8fSAndroid Build Coastguard Worker #if defined(__aarch64__)
48*eb293b8fSAndroid Build Coastguard Worker // Check that the memory is readable first. This is racy with the ldg but there's not much
49*eb293b8fSAndroid Build Coastguard Worker // we can do about it.
50*eb293b8fSAndroid Build Coastguard Worker char data;
51*eb293b8fSAndroid Build Coastguard Worker if (!mte_supported() || !Read(addr, &data, 1)) {
52*eb293b8fSAndroid Build Coastguard Worker return -1;
53*eb293b8fSAndroid Build Coastguard Worker }
54*eb293b8fSAndroid Build Coastguard Worker
55*eb293b8fSAndroid Build Coastguard Worker __asm__ __volatile__(".arch_extension mte; ldg %0, [%0]" : "+r"(addr) : : "memory");
56*eb293b8fSAndroid Build Coastguard Worker return (addr >> 56) & 0xf;
57*eb293b8fSAndroid Build Coastguard Worker #else
58*eb293b8fSAndroid Build Coastguard Worker (void)addr;
59*eb293b8fSAndroid Build Coastguard Worker return -1;
60*eb293b8fSAndroid Build Coastguard Worker #endif
61*eb293b8fSAndroid Build Coastguard Worker }
62*eb293b8fSAndroid Build Coastguard Worker
63*eb293b8fSAndroid Build Coastguard Worker } // namespace unwindstack
64