1435bb4887
Add base debug class and attach/detach operations.
Signed-off-by: Jonathan Kim <jonathan.kim@amd.com>
Change-Id: I60f3c166646f05838fec208ac2f59bba998c63f8
[ROCm/ROCR-Runtime commit: dd56b38c2f]
99 строки
2.9 KiB
C++
99 строки
2.9 KiB
C++
/*
|
|
* Copyright (C) 2023 Advanced Micro Devices, Inc. All Rights Reserved.
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a
|
|
* copy of this software and associated documentation files (the "Software"),
|
|
* to deal in the Software without restriction, including without limitation
|
|
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
* and/or sell copies of the Software, and to permit persons to whom the
|
|
* Software is furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in
|
|
* all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
|
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
|
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
|
* OTHER DEALINGS IN THE SOFTWARE.
|
|
*
|
|
*/
|
|
|
|
#include "BaseDebug.hpp"
|
|
#include <string.h>
|
|
#include <sys/mman.h>
|
|
#include <sys/types.h>
|
|
#include <sys/stat.h>
|
|
#include <linux/kfd_ioctl.h>
|
|
#include <fcntl.h>
|
|
#include "unistd.h"
|
|
|
|
BaseDebug::BaseDebug(void) {
|
|
}
|
|
|
|
BaseDebug::~BaseDebug(void) {
|
|
/*
|
|
* If the process is still attached, close and destroy the polling file
|
|
* descriptor. Note that on process termination, the KFD automatically
|
|
* disables processes that are still runtime enabled and debug enabled
|
|
* so we don't do it here.
|
|
*/
|
|
if (m_Pid) {
|
|
close(m_Fd.fd);
|
|
unlink(m_Fd_Name);
|
|
}
|
|
}
|
|
|
|
// Creates temp file descriptor and debug attaches.
|
|
HSAKMT_STATUS BaseDebug::Attach(struct kfd_runtime_info *rInfo,
|
|
int rInfoSize,
|
|
unsigned int pid,
|
|
uint64_t exceptionEnable) {
|
|
struct kfd_ioctl_dbg_trap_args args = {0};
|
|
char fd_name[32];
|
|
|
|
memset(&args, 0x00, sizeof(args));
|
|
|
|
mkfifo(m_Fd_Name, 0666);
|
|
m_Fd.fd = open(m_Fd_Name, O_CLOEXEC | O_NONBLOCK | O_RDWR);
|
|
m_Fd.events = POLLIN | POLLRDNORM;
|
|
|
|
args.pid = pid;
|
|
args.op = KFD_IOC_DBG_TRAP_ENABLE;
|
|
args.enable.rinfo_ptr = (uint64_t)rInfo;
|
|
args.enable.rinfo_size = rInfoSize;
|
|
args.enable.dbg_fd = m_Fd.fd;
|
|
args.enable.exception_mask = exceptionEnable;
|
|
|
|
if (hsaKmtDebugTrapIoctl(&args, NULL)) {
|
|
close(m_Fd.fd);
|
|
unlink(m_Fd_Name);
|
|
return HSAKMT_STATUS_ERROR;
|
|
}
|
|
|
|
m_Pid = pid;
|
|
|
|
return HSAKMT_STATUS_SUCCESS;
|
|
}
|
|
|
|
|
|
void BaseDebug::Detach(void) {
|
|
struct kfd_ioctl_dbg_trap_args args = {0};
|
|
|
|
memset(&args, 0x00, sizeof(args));
|
|
|
|
args.pid = m_Pid;
|
|
args.op = KFD_IOC_DBG_TRAP_DISABLE;
|
|
|
|
hsaKmtDebugTrapIoctl(&args, NULL);
|
|
|
|
close(m_Fd.fd);
|
|
unlink(m_Fd_Name);
|
|
|
|
m_Pid = 0;
|
|
m_Fd.fd = 0;
|
|
m_Fd.events = 0;
|
|
}
|