A common reason for LLDB failing to attach to an already-running process on Linux is the Yama security module: https://www.kernel.org/doc/Documentation/security/Yama.txt. This patch adds an explaination and suggested fix when it detects that case happening. This was previously proposed in D106226, but hasn't been updated in a while. The last request was to put the check in a target-specific location, which is the approach this patch takes. I believe Yama only exists on Linux, so it's put in that package. This has no end-to-end test because I'm not sure how to set `ptrace_scope` in a test environment -- if there are suggestions on how to do that, I'd be happy to add it. (Also, setting it to `3` is comically irreversible). I tested this locally. Reviewed By: DavidSpickett, labath Differential Revision: https://reviews.llvm.org/D144904
39 lines
1.3 KiB
C++
39 lines
1.3 KiB
C++
//===-- Procfs.h ---------------------------------------------- -*- C++ -*-===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "lldb/lldb-types.h"
|
|
#include "llvm/Support/Error.h"
|
|
#include <vector>
|
|
|
|
namespace lldb_private {
|
|
namespace process_linux {
|
|
|
|
/// \return
|
|
/// The content of /proc/cpuinfo and cache it if errors didn't happen.
|
|
llvm::Expected<llvm::ArrayRef<uint8_t>> GetProcfsCpuInfo();
|
|
|
|
/// \return
|
|
/// A list of available logical core ids given the contents of
|
|
/// /proc/cpuinfo.
|
|
llvm::Expected<std::vector<lldb::cpu_id_t>>
|
|
GetAvailableLogicalCoreIDs(llvm::StringRef cpuinfo);
|
|
|
|
/// \return
|
|
/// A list with all the logical cores available in the system and cache it
|
|
/// if errors didn't happen.
|
|
llvm::Expected<llvm::ArrayRef<lldb::cpu_id_t>> GetAvailableLogicalCoreIDs();
|
|
|
|
/// \return
|
|
/// The current value of /proc/sys/kernel/yama/ptrace_scope, parsed as an
|
|
/// integer, or an error if the proc file cannot be read or has non-integer
|
|
/// contents.
|
|
llvm::Expected<int> GetPtraceScope();
|
|
|
|
} // namespace process_linux
|
|
} // namespace lldb_private
|