target/riscv: make CPUCFG() macro public

The RISC-V KVM driver uses a CPUCFG() macro that calculates the offset
of a certain field in the struct RISCVCPUConfig. We're going to use this
macro in target/riscv/cpu.c as well in the next patches. Make it public.

Rename it to CPU_CFG_OFFSET() for more clarity while we're at it.

Signed-off-by: Daniel Henrique Barboza <dbarboza@ventanamicro.com>
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
Reviewed-by: Andrew Jones <ajones@ventanamicro.com>
Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
Message-ID: <20230912132423.268494-15-dbarboza@ventanamicro.com>
Signed-off-by: Alistair Francis <alistair.francis@wdc.com>
This commit is contained in:
Daniel Henrique Barboza 2023-09-12 10:24:17 -03:00 committed by Alistair Francis
parent 5f2c80f1a0
commit 238fd586e0
3 changed files with 6 additions and 6 deletions

View File

@ -48,7 +48,7 @@ struct isa_ext_data {
}; };
#define ISA_EXT_DATA_ENTRY(_name, _min_ver, _prop) \ #define ISA_EXT_DATA_ENTRY(_name, _min_ver, _prop) \
{#_name, _min_ver, offsetof(struct RISCVCPUConfig, _prop)} {#_name, _min_ver, CPU_CFG_OFFSET(_prop)}
/* /*
* From vector_helper.c * From vector_helper.c

View File

@ -62,6 +62,8 @@
const char *riscv_get_misa_ext_name(uint32_t bit); const char *riscv_get_misa_ext_name(uint32_t bit);
const char *riscv_get_misa_ext_description(uint32_t bit); const char *riscv_get_misa_ext_description(uint32_t bit);
#define CPU_CFG_OFFSET(_prop) offsetof(struct RISCVCPUConfig, _prop)
/* Privileged specification version */ /* Privileged specification version */
enum { enum {
PRIV_VERSION_1_10_0 = 0, PRIV_VERSION_1_10_0 = 0,

View File

@ -205,10 +205,8 @@ static void kvm_riscv_update_cpu_misa_ext(RISCVCPU *cpu, CPUState *cs)
} }
} }
#define CPUCFG(_prop) offsetof(struct RISCVCPUConfig, _prop)
#define KVM_EXT_CFG(_name, _prop, _reg_id) \ #define KVM_EXT_CFG(_name, _prop, _reg_id) \
{.name = _name, .offset = CPUCFG(_prop), \ {.name = _name, .offset = CPU_CFG_OFFSET(_prop), \
.kvm_reg_id = _reg_id} .kvm_reg_id = _reg_id}
static KVMCPUConfig kvm_multi_ext_cfgs[] = { static KVMCPUConfig kvm_multi_ext_cfgs[] = {
@ -285,13 +283,13 @@ static void kvm_cpu_set_multi_ext_cfg(Object *obj, Visitor *v,
static KVMCPUConfig kvm_cbom_blocksize = { static KVMCPUConfig kvm_cbom_blocksize = {
.name = "cbom_blocksize", .name = "cbom_blocksize",
.offset = CPUCFG(cbom_blocksize), .offset = CPU_CFG_OFFSET(cbom_blocksize),
.kvm_reg_id = KVM_REG_RISCV_CONFIG_REG(zicbom_block_size) .kvm_reg_id = KVM_REG_RISCV_CONFIG_REG(zicbom_block_size)
}; };
static KVMCPUConfig kvm_cboz_blocksize = { static KVMCPUConfig kvm_cboz_blocksize = {
.name = "cboz_blocksize", .name = "cboz_blocksize",
.offset = CPUCFG(cboz_blocksize), .offset = CPU_CFG_OFFSET(cboz_blocksize),
.kvm_reg_id = KVM_REG_RISCV_CONFIG_REG(zicboz_block_size) .kvm_reg_id = KVM_REG_RISCV_CONFIG_REG(zicboz_block_size)
}; };