hw/intc/loongson_ipi: Add more input parameter for cpu_by_arch_id

Add logic cpu index input parameter for function cpu_by_arch_id,
CPUState::cpu_index is logic cpu slot index for possible_cpus.

At the same time it is logic index with LoongsonIPICommonState::IPICore,
here hide access for CPUState::cpu_index directly, it comes from
function cpu_by_arch_id().

Signed-off-by: Bibo Mao <maobibo@loongson.cn>
Reviewed-by: Bibo Mao <maobibo@loongson.cn>
This commit is contained in:
Bibo Mao 2025-01-07 11:08:18 +08:00
parent 1b3aa34704
commit 999b112d90
4 changed files with 51 additions and 15 deletions

View File

@ -38,17 +38,28 @@ static CPUArchId *find_cpu_by_archid(MachineState *ms, uint32_t id)
return found_cpu; return found_cpu;
} }
static CPUState *loongarch_cpu_by_arch_id(int64_t arch_id) static int loongarch_cpu_by_arch_id(LoongsonIPICommonState *lics,
int64_t arch_id, int *index, CPUState **pcs)
{ {
MachineState *machine = MACHINE(qdev_get_machine()); MachineState *machine = MACHINE(qdev_get_machine());
CPUArchId *archid; CPUArchId *archid;
CPUState *cs;
archid = find_cpu_by_archid(machine, arch_id); archid = find_cpu_by_archid(machine, arch_id);
if (archid) { if (archid && archid->cpu) {
return CPU(archid->cpu); cs = archid->cpu;
if (index) {
*index = cs->cpu_index;
}
if (pcs) {
*pcs = cs;
}
return MEMTX_OK;
} }
return NULL; return MEMTX_ERROR;
} }
static void loongarch_ipi_realize(DeviceState *dev, Error **errp) static void loongarch_ipi_realize(DeviceState *dev, Error **errp)

View File

@ -20,6 +20,27 @@ static AddressSpace *get_iocsr_as(CPUState *cpu)
return NULL; return NULL;
} }
static int loongson_cpu_by_arch_id(LoongsonIPICommonState *lics,
int64_t arch_id, int *index, CPUState **pcs)
{
CPUState *cs;
cs = cpu_by_arch_id(arch_id);
if (cs == NULL) {
return MEMTX_ERROR;
}
if (index) {
*index = cs->cpu_index;
}
if (pcs) {
*pcs = cs;
}
return MEMTX_OK;
}
static const MemoryRegionOps loongson_ipi_core_ops = { static const MemoryRegionOps loongson_ipi_core_ops = {
.read_with_attrs = loongson_ipi_core_readl, .read_with_attrs = loongson_ipi_core_readl,
.write_with_attrs = loongson_ipi_core_writel, .write_with_attrs = loongson_ipi_core_writel,
@ -92,7 +113,7 @@ static void loongson_ipi_class_init(ObjectClass *klass, void *data)
&lic->parent_unrealize); &lic->parent_unrealize);
device_class_set_props(dc, loongson_ipi_properties); device_class_set_props(dc, loongson_ipi_properties);
licc->get_iocsr_as = get_iocsr_as; licc->get_iocsr_as = get_iocsr_as;
licc->cpu_by_arch_id = cpu_by_arch_id; licc->cpu_by_arch_id = loongson_cpu_by_arch_id;
} }
static const TypeInfo loongson_ipi_types[] = { static const TypeInfo loongson_ipi_types[] = {

View File

@ -103,16 +103,17 @@ static MemTxResult mail_send(LoongsonIPICommonState *ipi,
uint32_t cpuid; uint32_t cpuid;
hwaddr addr; hwaddr addr;
CPUState *cs; CPUState *cs;
int cpu, ret;
cpuid = extract32(val, 16, 10); cpuid = extract32(val, 16, 10);
cs = licc->cpu_by_arch_id(cpuid); ret = licc->cpu_by_arch_id(ipi, cpuid, &cpu, &cs);
if (cs == NULL) { if (ret != MEMTX_OK) {
return MEMTX_DECODE_ERROR; return MEMTX_DECODE_ERROR;
} }
/* override requester_id */ /* override requester_id */
addr = SMP_IPI_MAILBOX + CORE_BUF_20 + (val & 0x1c); addr = SMP_IPI_MAILBOX + CORE_BUF_20 + (val & 0x1c);
attrs.requester_id = cs->cpu_index; attrs.requester_id = cpu;
return send_ipi_data(ipi, cs, val, addr, attrs); return send_ipi_data(ipi, cs, val, addr, attrs);
} }
@ -123,16 +124,17 @@ static MemTxResult any_send(LoongsonIPICommonState *ipi,
uint32_t cpuid; uint32_t cpuid;
hwaddr addr; hwaddr addr;
CPUState *cs; CPUState *cs;
int cpu, ret;
cpuid = extract32(val, 16, 10); cpuid = extract32(val, 16, 10);
cs = licc->cpu_by_arch_id(cpuid); ret = licc->cpu_by_arch_id(ipi, cpuid, &cpu, &cs);
if (cs == NULL) { if (ret != MEMTX_OK) {
return MEMTX_DECODE_ERROR; return MEMTX_DECODE_ERROR;
} }
/* override requester_id */ /* override requester_id */
addr = val & 0xffff; addr = val & 0xffff;
attrs.requester_id = cs->cpu_index; attrs.requester_id = cpu;
return send_ipi_data(ipi, cs, val, addr, attrs); return send_ipi_data(ipi, cs, val, addr, attrs);
} }
@ -146,6 +148,7 @@ MemTxResult loongson_ipi_core_writel(void *opaque, hwaddr addr, uint64_t val,
uint32_t cpuid; uint32_t cpuid;
uint8_t vector; uint8_t vector;
CPUState *cs; CPUState *cs;
int cpu, ret;
addr &= 0xff; addr &= 0xff;
trace_loongson_ipi_write(size, (uint64_t)addr, val); trace_loongson_ipi_write(size, (uint64_t)addr, val);
@ -176,11 +179,11 @@ MemTxResult loongson_ipi_core_writel(void *opaque, hwaddr addr, uint64_t val,
cpuid = extract32(val, 16, 10); cpuid = extract32(val, 16, 10);
/* IPI status vector */ /* IPI status vector */
vector = extract8(val, 0, 5); vector = extract8(val, 0, 5);
cs = licc->cpu_by_arch_id(cpuid); ret = licc->cpu_by_arch_id(ipi, cpuid, &cpu, &cs);
if (cs == NULL || cs->cpu_index >= ipi->num_cpu) { if (ret != MEMTX_OK || cpu >= ipi->num_cpu) {
return MEMTX_DECODE_ERROR; return MEMTX_DECODE_ERROR;
} }
loongson_ipi_core_writel(&ipi->cpu[cs->cpu_index], CORE_SET_OFF, loongson_ipi_core_writel(&ipi->cpu[cpu], CORE_SET_OFF,
BIT(vector), 4, attrs); BIT(vector), 4, attrs);
break; break;
default: default:

View File

@ -46,7 +46,8 @@ struct LoongsonIPICommonClass {
DeviceRealize parent_realize; DeviceRealize parent_realize;
DeviceUnrealize parent_unrealize; DeviceUnrealize parent_unrealize;
AddressSpace *(*get_iocsr_as)(CPUState *cpu); AddressSpace *(*get_iocsr_as)(CPUState *cpu);
CPUState *(*cpu_by_arch_id)(int64_t id); int (*cpu_by_arch_id)(LoongsonIPICommonState *lics, int64_t id,
int *index, CPUState **pcs);
}; };
MemTxResult loongson_ipi_core_readl(void *opaque, hwaddr addr, uint64_t *data, MemTxResult loongson_ipi_core_readl(void *opaque, hwaddr addr, uint64_t *data,