xref: /aosp_15_r20/external/stg/elf_dwarf_handle.h (revision 9e3b08ae94a55201065475453d799e8b1378bea6)
1*9e3b08aeSAndroid Build Coastguard Worker // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
2*9e3b08aeSAndroid Build Coastguard Worker // -*- mode: C++ -*-
3*9e3b08aeSAndroid Build Coastguard Worker //
4*9e3b08aeSAndroid Build Coastguard Worker // Copyright 2022-2024 Google LLC
5*9e3b08aeSAndroid Build Coastguard Worker //
6*9e3b08aeSAndroid Build Coastguard Worker // Licensed under the Apache License v2.0 with LLVM Exceptions (the
7*9e3b08aeSAndroid Build Coastguard Worker // "License"); you may not use this file except in compliance with the
8*9e3b08aeSAndroid Build Coastguard Worker // License.  You may obtain a copy of the License at
9*9e3b08aeSAndroid Build Coastguard Worker //
10*9e3b08aeSAndroid Build Coastguard Worker //     https://llvm.org/LICENSE.txt
11*9e3b08aeSAndroid Build Coastguard Worker //
12*9e3b08aeSAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software
13*9e3b08aeSAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS,
14*9e3b08aeSAndroid Build Coastguard Worker // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15*9e3b08aeSAndroid Build Coastguard Worker // See the License for the specific language governing permissions and
16*9e3b08aeSAndroid Build Coastguard Worker // limitations under the License.
17*9e3b08aeSAndroid Build Coastguard Worker //
18*9e3b08aeSAndroid Build Coastguard Worker // Author: Aleksei Vetrov
19*9e3b08aeSAndroid Build Coastguard Worker 
20*9e3b08aeSAndroid Build Coastguard Worker #ifndef STG_ELF_DWARF_HANDLE_H_
21*9e3b08aeSAndroid Build Coastguard Worker #define STG_ELF_DWARF_HANDLE_H_
22*9e3b08aeSAndroid Build Coastguard Worker 
23*9e3b08aeSAndroid Build Coastguard Worker #include <elfutils/libdw.h>
24*9e3b08aeSAndroid Build Coastguard Worker #include <elfutils/libdwfl.h>
25*9e3b08aeSAndroid Build Coastguard Worker #include <libelf.h>
26*9e3b08aeSAndroid Build Coastguard Worker 
27*9e3b08aeSAndroid Build Coastguard Worker #include <cstddef>
28*9e3b08aeSAndroid Build Coastguard Worker #include <functional>
29*9e3b08aeSAndroid Build Coastguard Worker #include <memory>
30*9e3b08aeSAndroid Build Coastguard Worker #include <string>
31*9e3b08aeSAndroid Build Coastguard Worker 
32*9e3b08aeSAndroid Build Coastguard Worker namespace stg {
33*9e3b08aeSAndroid Build Coastguard Worker 
34*9e3b08aeSAndroid Build Coastguard Worker class ElfDwarfHandle {
35*9e3b08aeSAndroid Build Coastguard Worker  public:
36*9e3b08aeSAndroid Build Coastguard Worker   explicit ElfDwarfHandle(const std::string& path);
37*9e3b08aeSAndroid Build Coastguard Worker   ElfDwarfHandle(char* data, size_t size);
38*9e3b08aeSAndroid Build Coastguard Worker 
39*9e3b08aeSAndroid Build Coastguard Worker   Elf& GetElf();
40*9e3b08aeSAndroid Build Coastguard Worker   Dwarf* GetDwarf();  // Returns nullptr if DWARF is not available.
41*9e3b08aeSAndroid Build Coastguard Worker 
42*9e3b08aeSAndroid Build Coastguard Worker  private:
43*9e3b08aeSAndroid Build Coastguard Worker   struct DwflDeleter {
operatorDwflDeleter44*9e3b08aeSAndroid Build Coastguard Worker     void operator()(Dwfl* dwfl) {
45*9e3b08aeSAndroid Build Coastguard Worker       dwfl_end(dwfl);
46*9e3b08aeSAndroid Build Coastguard Worker     }
47*9e3b08aeSAndroid Build Coastguard Worker   };
48*9e3b08aeSAndroid Build Coastguard Worker   using DwflUniquePtr = std::unique_ptr<Dwfl, DwflDeleter>;
49*9e3b08aeSAndroid Build Coastguard Worker 
50*9e3b08aeSAndroid Build Coastguard Worker   ElfDwarfHandle(const char* module_name,
51*9e3b08aeSAndroid Build Coastguard Worker                  const std::function<Dwfl_Module*()>& add_module);
52*9e3b08aeSAndroid Build Coastguard Worker 
53*9e3b08aeSAndroid Build Coastguard Worker   DwflUniquePtr dwfl_;
54*9e3b08aeSAndroid Build Coastguard Worker   // Lifetime of Dwfl_Module is controlled by Dwfl.
55*9e3b08aeSAndroid Build Coastguard Worker   Dwfl_Module* dwfl_module_ = nullptr;
56*9e3b08aeSAndroid Build Coastguard Worker };
57*9e3b08aeSAndroid Build Coastguard Worker 
58*9e3b08aeSAndroid Build Coastguard Worker }  // namespace stg
59*9e3b08aeSAndroid Build Coastguard Worker 
60*9e3b08aeSAndroid Build Coastguard Worker 
61*9e3b08aeSAndroid Build Coastguard Worker #endif  // STG_ELF_DWARF_HANDLE_H_
62