2021-11-21 23:59:44 +00:00
|
|
|
// Copyright (c) Meta Platforms, Inc. and affiliates.
|
2021-04-03 09:10:35 +01:00
|
|
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
2019-10-25 23:23:02 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
*
|
|
|
|
* Helpers implemented in C.
|
|
|
|
*
|
|
|
|
* Most drgn helpers are implemented in Python. However, there are a few that we
|
|
|
|
* need internally in libdrgn, so they are implemented in C, instead.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef DRGN_HELPERS_H
|
|
|
|
#define DRGN_HELPERS_H
|
|
|
|
|
2020-09-24 00:02:02 +01:00
|
|
|
#include <stddef.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
|
2021-12-18 00:56:00 +00:00
|
|
|
#include "drgn.h"
|
|
|
|
|
2020-09-24 00:02:02 +01:00
|
|
|
struct drgn_object;
|
|
|
|
struct drgn_program;
|
|
|
|
|
2020-05-06 02:21:36 +01:00
|
|
|
struct drgn_error *linux_helper_read_vm(struct drgn_program *prog,
|
|
|
|
uint64_t pgtable, uint64_t virt_addr,
|
|
|
|
void *buf, size_t count);
|
|
|
|
|
2021-12-21 22:39:50 +00:00
|
|
|
struct drgn_error *linux_helper_per_cpu_ptr(struct drgn_object *res,
|
|
|
|
const struct drgn_object *ptr,
|
|
|
|
uint64_t cpu);
|
|
|
|
|
2021-12-22 00:03:25 +00:00
|
|
|
struct drgn_error *linux_helper_idle_task(struct drgn_object *res,
|
|
|
|
uint64_t cpu);
|
2021-12-21 22:40:57 +00:00
|
|
|
|
2019-10-25 23:23:02 +01:00
|
|
|
struct drgn_error *
|
|
|
|
linux_helper_radix_tree_lookup(struct drgn_object *res,
|
|
|
|
const struct drgn_object *root, uint64_t index);
|
|
|
|
|
|
|
|
struct drgn_error *linux_helper_idr_find(struct drgn_object *res,
|
|
|
|
const struct drgn_object *idr,
|
|
|
|
uint64_t id);
|
|
|
|
|
|
|
|
struct drgn_error *linux_helper_find_pid(struct drgn_object *res,
|
|
|
|
const struct drgn_object *ns,
|
|
|
|
uint64_t pid);
|
|
|
|
|
|
|
|
struct drgn_error *linux_helper_pid_task(struct drgn_object *res,
|
|
|
|
const struct drgn_object *pid,
|
|
|
|
uint64_t pid_type);
|
|
|
|
|
|
|
|
struct drgn_error *linux_helper_find_task(struct drgn_object *res,
|
|
|
|
const struct drgn_object *ns,
|
|
|
|
uint64_t pid);
|
|
|
|
|
2021-12-18 00:56:00 +00:00
|
|
|
struct linux_helper_task_iterator {
|
|
|
|
struct drgn_object task;
|
|
|
|
struct drgn_qualified_type task_struct_type;
|
|
|
|
uint64_t init_task_address;
|
|
|
|
uint64_t thread_group_address;
|
|
|
|
bool done;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct drgn_error *
|
|
|
|
linux_helper_task_iterator_init(struct linux_helper_task_iterator *it,
|
|
|
|
struct drgn_program *prog);
|
|
|
|
|
|
|
|
void linux_helper_task_iterator_deinit(struct linux_helper_task_iterator *it);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the next task from a @ref linux_helper_task_iterator.
|
|
|
|
*
|
2021-11-19 00:46:59 +00:00
|
|
|
* @param[out] ret Returned `struct task_struct *` object. This is valid until
|
|
|
|
* the next call to this function on the same @p it or until @p it is destroyed.
|
2021-12-18 00:56:00 +00:00
|
|
|
*/
|
|
|
|
struct drgn_error *
|
|
|
|
linux_helper_task_iterator_next(struct linux_helper_task_iterator *it,
|
2021-11-19 00:46:59 +00:00
|
|
|
const struct drgn_object **ret);
|
2021-12-18 00:56:00 +00:00
|
|
|
|
2019-10-25 23:23:02 +01:00
|
|
|
#endif /* DRGN_HELPERS_H */
|