1
    2
    3
    4
    5
    6
    7
    8
    9
   10
   11
   12
   13
   14
   15
   16
   17
   18
   19
   20
   21
   22
   23
   24
   25
   26
   27
   28
   29
   30
   31
   32
   33
   34
   35

base / profiler / stack_base_address_posix.h [blame]

// Copyright 2022 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef BASE_PROFILER_STACK_BASE_ADDRESS_POSIX_H_
#define BASE_PROFILER_STACK_BASE_ADDRESS_POSIX_H_

#include <pthread.h>
#include <stdint.h>

#include <optional>

#include "base/base_export.h"
#include "base/threading/platform_thread.h"

namespace base {

// Returns the base address of the stack for the given thread. (The address of
// the start of the stack, the highest addressable byte, where the frame of the
// first function on the thread is.)
//
// |id| and |pthread_id| must refer to the same thread.
//
// On Linux & ChromeOS, if the sandbox has been engaged, this may crash if
// |id| and |pthread_id| refer to any thread except the current one.
//
// May return nullopt on Android if the thread's memory range is not found in
// /proc/self/maps.
BASE_EXPORT std::optional<uintptr_t> GetThreadStackBaseAddress(
    PlatformThreadId id,
    pthread_t pthread_id);

}  // namespace base

#endif  // BASE_PROFILER_STACK_BASE_ADDRESS_POSIX_H_