rocprofiler-sdk/amd_detail/rocprofiler-sdk-codeobj/segment.hpp Source File

rocprofiler-sdk/amd_detail/rocprofiler-sdk-codeobj/segment.hpp Source File#

Rocprofiler SDK Developer API: rocprofiler-sdk/amd_detail/rocprofiler-sdk-codeobj/segment.hpp Source File
Rocprofiler SDK Developer API 0.4.0
ROCm Profiling API and tools
segment.hpp
Go to the documentation of this file.
1// MIT License
2//
3// Copyright (c) 2024 Advanced Micro Devices, Inc. All rights reserved.
4//
5// Permission is hereby granted, free of charge, to any person obtaining a copy
6// of this software and associated documentation files (the "Software"), to deal
7// in the Software without restriction, including without limitation the rights
8// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9// copies of the Software, and to permit persons to whom the Software is
10// furnished to do so, subject to the following conditions:
11//
12// The above copyright notice and this permission notice shall be included in all
13// copies or substantial portions of the Software.
14//
15// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21// SOFTWARE.
22
23#pragma once
24#include <algorithm>
25#include <iostream>
26#include <random>
27#include <set>
28#include <string>
29#include <unordered_set>
30#include <vector>
31
32namespace rocprofiler
33{
34namespace codeobj
35{
36namespace segment
37{
38using marker_id_t = size_t;
39
41{
42 uint64_t addr{0};
43 uint64_t size{0};
45
46 bool operator==(const address_range_t& other) const
47 {
48 return (addr >= other.addr && addr < other.addr + other.size) ||
49 (other.addr >= addr && other.addr < addr + size);
50 }
51 bool operator<(const address_range_t& other) const
52 {
53 if(*this == other) return false;
54 return addr < other.addr;
55 }
56 bool inrange(uint64_t _addr) const { return addr <= _addr && addr + size > _addr; };
57};
58
59/**
60 * @brief Finds a candidate codeobj for the given vaddr
61 */
62class CodeobjTableTranslator : public std::set<address_range_t>
63{
64 using Super = std::set<address_range_t>;
65
66public:
68 {
69 if(!cached_segment.inrange(addr))
70 {
71 auto it = this->find(address_range_t{addr, 0, 0});
72 if(it == this->end()) throw std::exception();
73 cached_segment = *it;
74 }
75 return cached_segment;
76 }
77
78 void clear_cache() { cached_segment = {}; }
79 bool remove(const address_range_t& range)
80 {
82 return this->erase(range) != 0;
83 }
84 bool remove(uint64_t addr) { return remove(address_range_t{addr, 0, 0}); }
85
86private:
87 address_range_t cached_segment{};
88};
89
90} // namespace segment
91} // namespace codeobj
92} // namespace rocprofiler
Finds a candidate codeobj for the given vaddr.
Definition segment.hpp:63
bool remove(const address_range_t &range)
Definition segment.hpp:79
address_range_t find_codeobj_in_range(uint64_t addr)
Definition segment.hpp:67
bool operator<(const address_range_t &other) const
Definition segment.hpp:51
bool operator==(const address_range_t &other) const
Definition segment.hpp:46