aboutsummaryrefslogtreecommitdiff
path: root/src/target/riscv/debug_reg_printer.h
blob: 98226b7729dc9733bb0030b5a570c4a8af4d0603 (plain)
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
/* SPDX-License-Identifier: GPL-2.0-or-later */

#include "debug_defines.h"

enum riscv_debug_reg_show {
	RISCV_DEBUG_REG_SHOW_ALL,
	RISCV_DEBUG_REG_HIDE_ALL_0,
	RISCV_DEBUG_REG_HIDE_UNNAMED_0,
};

/**
 * This function is used to fill a buffer with a decoded string representation
 * of register's value.
 * @param buf      If non-NULL, the buffer to write the string into.
 *                 Otherwise, the function does not perform any writes,
 *                 it just calculates the number of characters used.
 * @param reg_ordinal
 *                 The ordinal of the register.
 * @param context  The structure, containing the information about the target,
 *                 necessary to decode the register.
 * @param value    The value to be decoded.
 *
 * Returns the number of characters used by the string representation
 * (excluding '\0').
 *
 * Example:
 * const struct riscv_debug_reg_ctx_t context = {
 *     .abits = { .value = <abits value>, .is_set = true }
 * };
 * char buf[riscv_debug_reg_to_s(NULL, DTM_DMI_ORDINAL, context, <dmi value>) + 1]
 * riscv_debug_reg_to_s(buf, DTM_DMI_ORDINAL, context, <dmi value>);
 */
unsigned int riscv_debug_reg_to_s(char *buf, enum riscv_debug_reg_ordinal reg_ordinal,
		riscv_debug_reg_ctx_t context, uint64_t value,
		enum riscv_debug_reg_show show);