mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-10 19:14:58 -06:00
ppc/pnv: move nest_regs[] to PnvPHB4
stack->nest_regs[] is used in several XSCOM functions and it's one of the main culprits of having to deal with stack->phb pointers around the code. Sure, we're having to add 2 extra stack->phb pointers to ease nest_regs[] migration to PnvPHB4. They'll be dealt with shortly. Signed-off-by: Daniel Henrique Barboza <danielhb413@gmail.com> Reviewed-by: Cédric Le Goater <clg@kaod.org> Message-Id: <20220113192952.911188-8-danielhb413@gmail.com> Signed-off-by: Cédric Le Goater <clg@kaod.org>
This commit is contained in:
parent
1293d73521
commit
98f0833343
2 changed files with 31 additions and 28 deletions
|
@ -862,10 +862,11 @@ static uint64_t pnv_pec_stk_nest_xscom_read(void *opaque, hwaddr addr,
|
||||||
unsigned size)
|
unsigned size)
|
||||||
{
|
{
|
||||||
PnvPhb4PecStack *stack = PNV_PHB4_PEC_STACK(opaque);
|
PnvPhb4PecStack *stack = PNV_PHB4_PEC_STACK(opaque);
|
||||||
|
PnvPHB4 *phb = stack->phb;
|
||||||
uint32_t reg = addr >> 3;
|
uint32_t reg = addr >> 3;
|
||||||
|
|
||||||
/* TODO: add list of allowed registers and error out if not */
|
/* TODO: add list of allowed registers and error out if not */
|
||||||
return stack->nest_regs[reg];
|
return phb->nest_regs[reg];
|
||||||
}
|
}
|
||||||
|
|
||||||
static void pnv_phb4_update_regions(PnvPHB4 *phb)
|
static void pnv_phb4_update_regions(PnvPHB4 *phb)
|
||||||
|
@ -897,7 +898,7 @@ static void pnv_pec_stk_update_map(PnvPhb4PecStack *stack)
|
||||||
PnvPhb4PecState *pec = stack->pec;
|
PnvPhb4PecState *pec = stack->pec;
|
||||||
PnvPHB4 *phb = stack->phb;
|
PnvPHB4 *phb = stack->phb;
|
||||||
MemoryRegion *sysmem = get_system_memory();
|
MemoryRegion *sysmem = get_system_memory();
|
||||||
uint64_t bar_en = stack->nest_regs[PEC_NEST_STK_BAR_EN];
|
uint64_t bar_en = phb->nest_regs[PEC_NEST_STK_BAR_EN];
|
||||||
uint64_t bar, mask, size;
|
uint64_t bar, mask, size;
|
||||||
char name[64];
|
char name[64];
|
||||||
|
|
||||||
|
@ -933,8 +934,8 @@ static void pnv_pec_stk_update_map(PnvPhb4PecStack *stack)
|
||||||
/* Handle maps */
|
/* Handle maps */
|
||||||
if (!memory_region_is_mapped(&phb->mmbar0) &&
|
if (!memory_region_is_mapped(&phb->mmbar0) &&
|
||||||
(bar_en & PEC_NEST_STK_BAR_EN_MMIO0)) {
|
(bar_en & PEC_NEST_STK_BAR_EN_MMIO0)) {
|
||||||
bar = stack->nest_regs[PEC_NEST_STK_MMIO_BAR0] >> 8;
|
bar = phb->nest_regs[PEC_NEST_STK_MMIO_BAR0] >> 8;
|
||||||
mask = stack->nest_regs[PEC_NEST_STK_MMIO_BAR0_MASK];
|
mask = phb->nest_regs[PEC_NEST_STK_MMIO_BAR0_MASK];
|
||||||
size = ((~mask) >> 8) + 1;
|
size = ((~mask) >> 8) + 1;
|
||||||
snprintf(name, sizeof(name), "pec-%d.%d-phb-%d-mmio0",
|
snprintf(name, sizeof(name), "pec-%d.%d-phb-%d-mmio0",
|
||||||
pec->chip_id, pec->index, stack->stack_no);
|
pec->chip_id, pec->index, stack->stack_no);
|
||||||
|
@ -945,8 +946,8 @@ static void pnv_pec_stk_update_map(PnvPhb4PecStack *stack)
|
||||||
}
|
}
|
||||||
if (!memory_region_is_mapped(&phb->mmbar1) &&
|
if (!memory_region_is_mapped(&phb->mmbar1) &&
|
||||||
(bar_en & PEC_NEST_STK_BAR_EN_MMIO1)) {
|
(bar_en & PEC_NEST_STK_BAR_EN_MMIO1)) {
|
||||||
bar = stack->nest_regs[PEC_NEST_STK_MMIO_BAR1] >> 8;
|
bar = phb->nest_regs[PEC_NEST_STK_MMIO_BAR1] >> 8;
|
||||||
mask = stack->nest_regs[PEC_NEST_STK_MMIO_BAR1_MASK];
|
mask = phb->nest_regs[PEC_NEST_STK_MMIO_BAR1_MASK];
|
||||||
size = ((~mask) >> 8) + 1;
|
size = ((~mask) >> 8) + 1;
|
||||||
snprintf(name, sizeof(name), "pec-%d.%d-phb-%d-mmio1",
|
snprintf(name, sizeof(name), "pec-%d.%d-phb-%d-mmio1",
|
||||||
pec->chip_id, pec->index, stack->stack_no);
|
pec->chip_id, pec->index, stack->stack_no);
|
||||||
|
@ -957,7 +958,7 @@ static void pnv_pec_stk_update_map(PnvPhb4PecStack *stack)
|
||||||
}
|
}
|
||||||
if (!memory_region_is_mapped(&phb->phbbar) &&
|
if (!memory_region_is_mapped(&phb->phbbar) &&
|
||||||
(bar_en & PEC_NEST_STK_BAR_EN_PHB)) {
|
(bar_en & PEC_NEST_STK_BAR_EN_PHB)) {
|
||||||
bar = stack->nest_regs[PEC_NEST_STK_PHB_REGS_BAR] >> 8;
|
bar = phb->nest_regs[PEC_NEST_STK_PHB_REGS_BAR] >> 8;
|
||||||
size = PNV_PHB4_NUM_REGS << 3;
|
size = PNV_PHB4_NUM_REGS << 3;
|
||||||
snprintf(name, sizeof(name), "pec-%d.%d-phb-%d",
|
snprintf(name, sizeof(name), "pec-%d.%d-phb-%d",
|
||||||
pec->chip_id, pec->index, stack->stack_no);
|
pec->chip_id, pec->index, stack->stack_no);
|
||||||
|
@ -966,7 +967,7 @@ static void pnv_pec_stk_update_map(PnvPhb4PecStack *stack)
|
||||||
}
|
}
|
||||||
if (!memory_region_is_mapped(&phb->intbar) &&
|
if (!memory_region_is_mapped(&phb->intbar) &&
|
||||||
(bar_en & PEC_NEST_STK_BAR_EN_INT)) {
|
(bar_en & PEC_NEST_STK_BAR_EN_INT)) {
|
||||||
bar = stack->nest_regs[PEC_NEST_STK_INT_BAR] >> 8;
|
bar = phb->nest_regs[PEC_NEST_STK_INT_BAR] >> 8;
|
||||||
size = PNV_PHB4_MAX_INTs << 16;
|
size = PNV_PHB4_MAX_INTs << 16;
|
||||||
snprintf(name, sizeof(name), "pec-%d.%d-phb-%d-int",
|
snprintf(name, sizeof(name), "pec-%d.%d-phb-%d-int",
|
||||||
stack->pec->chip_id, stack->pec->index, stack->stack_no);
|
stack->pec->chip_id, stack->pec->index, stack->stack_no);
|
||||||
|
@ -982,34 +983,35 @@ static void pnv_pec_stk_nest_xscom_write(void *opaque, hwaddr addr,
|
||||||
uint64_t val, unsigned size)
|
uint64_t val, unsigned size)
|
||||||
{
|
{
|
||||||
PnvPhb4PecStack *stack = PNV_PHB4_PEC_STACK(opaque);
|
PnvPhb4PecStack *stack = PNV_PHB4_PEC_STACK(opaque);
|
||||||
|
PnvPHB4 *phb = stack->phb;
|
||||||
PnvPhb4PecState *pec = stack->pec;
|
PnvPhb4PecState *pec = stack->pec;
|
||||||
uint32_t reg = addr >> 3;
|
uint32_t reg = addr >> 3;
|
||||||
|
|
||||||
switch (reg) {
|
switch (reg) {
|
||||||
case PEC_NEST_STK_PCI_NEST_FIR:
|
case PEC_NEST_STK_PCI_NEST_FIR:
|
||||||
stack->nest_regs[PEC_NEST_STK_PCI_NEST_FIR] = val;
|
phb->nest_regs[PEC_NEST_STK_PCI_NEST_FIR] = val;
|
||||||
break;
|
break;
|
||||||
case PEC_NEST_STK_PCI_NEST_FIR_CLR:
|
case PEC_NEST_STK_PCI_NEST_FIR_CLR:
|
||||||
stack->nest_regs[PEC_NEST_STK_PCI_NEST_FIR] &= val;
|
phb->nest_regs[PEC_NEST_STK_PCI_NEST_FIR] &= val;
|
||||||
break;
|
break;
|
||||||
case PEC_NEST_STK_PCI_NEST_FIR_SET:
|
case PEC_NEST_STK_PCI_NEST_FIR_SET:
|
||||||
stack->nest_regs[PEC_NEST_STK_PCI_NEST_FIR] |= val;
|
phb->nest_regs[PEC_NEST_STK_PCI_NEST_FIR] |= val;
|
||||||
break;
|
break;
|
||||||
case PEC_NEST_STK_PCI_NEST_FIR_MSK:
|
case PEC_NEST_STK_PCI_NEST_FIR_MSK:
|
||||||
stack->nest_regs[PEC_NEST_STK_PCI_NEST_FIR_MSK] = val;
|
phb->nest_regs[PEC_NEST_STK_PCI_NEST_FIR_MSK] = val;
|
||||||
break;
|
break;
|
||||||
case PEC_NEST_STK_PCI_NEST_FIR_MSKC:
|
case PEC_NEST_STK_PCI_NEST_FIR_MSKC:
|
||||||
stack->nest_regs[PEC_NEST_STK_PCI_NEST_FIR_MSK] &= val;
|
phb->nest_regs[PEC_NEST_STK_PCI_NEST_FIR_MSK] &= val;
|
||||||
break;
|
break;
|
||||||
case PEC_NEST_STK_PCI_NEST_FIR_MSKS:
|
case PEC_NEST_STK_PCI_NEST_FIR_MSKS:
|
||||||
stack->nest_regs[PEC_NEST_STK_PCI_NEST_FIR_MSK] |= val;
|
phb->nest_regs[PEC_NEST_STK_PCI_NEST_FIR_MSK] |= val;
|
||||||
break;
|
break;
|
||||||
case PEC_NEST_STK_PCI_NEST_FIR_ACT0:
|
case PEC_NEST_STK_PCI_NEST_FIR_ACT0:
|
||||||
case PEC_NEST_STK_PCI_NEST_FIR_ACT1:
|
case PEC_NEST_STK_PCI_NEST_FIR_ACT1:
|
||||||
stack->nest_regs[reg] = val;
|
phb->nest_regs[reg] = val;
|
||||||
break;
|
break;
|
||||||
case PEC_NEST_STK_PCI_NEST_FIR_WOF:
|
case PEC_NEST_STK_PCI_NEST_FIR_WOF:
|
||||||
stack->nest_regs[reg] = 0;
|
phb->nest_regs[reg] = 0;
|
||||||
break;
|
break;
|
||||||
case PEC_NEST_STK_ERR_REPORT_0:
|
case PEC_NEST_STK_ERR_REPORT_0:
|
||||||
case PEC_NEST_STK_ERR_REPORT_1:
|
case PEC_NEST_STK_ERR_REPORT_1:
|
||||||
|
@ -1017,39 +1019,39 @@ static void pnv_pec_stk_nest_xscom_write(void *opaque, hwaddr addr,
|
||||||
/* Flag error ? */
|
/* Flag error ? */
|
||||||
break;
|
break;
|
||||||
case PEC_NEST_STK_PBCQ_MODE:
|
case PEC_NEST_STK_PBCQ_MODE:
|
||||||
stack->nest_regs[reg] = val & 0xff00000000000000ull;
|
phb->nest_regs[reg] = val & 0xff00000000000000ull;
|
||||||
break;
|
break;
|
||||||
case PEC_NEST_STK_MMIO_BAR0:
|
case PEC_NEST_STK_MMIO_BAR0:
|
||||||
case PEC_NEST_STK_MMIO_BAR0_MASK:
|
case PEC_NEST_STK_MMIO_BAR0_MASK:
|
||||||
case PEC_NEST_STK_MMIO_BAR1:
|
case PEC_NEST_STK_MMIO_BAR1:
|
||||||
case PEC_NEST_STK_MMIO_BAR1_MASK:
|
case PEC_NEST_STK_MMIO_BAR1_MASK:
|
||||||
if (stack->nest_regs[PEC_NEST_STK_BAR_EN] &
|
if (phb->nest_regs[PEC_NEST_STK_BAR_EN] &
|
||||||
(PEC_NEST_STK_BAR_EN_MMIO0 |
|
(PEC_NEST_STK_BAR_EN_MMIO0 |
|
||||||
PEC_NEST_STK_BAR_EN_MMIO1)) {
|
PEC_NEST_STK_BAR_EN_MMIO1)) {
|
||||||
phb_pec_error(pec, "Changing enabled BAR unsupported\n");
|
phb_pec_error(pec, "Changing enabled BAR unsupported\n");
|
||||||
}
|
}
|
||||||
stack->nest_regs[reg] = val & 0xffffffffff000000ull;
|
phb->nest_regs[reg] = val & 0xffffffffff000000ull;
|
||||||
break;
|
break;
|
||||||
case PEC_NEST_STK_PHB_REGS_BAR:
|
case PEC_NEST_STK_PHB_REGS_BAR:
|
||||||
if (stack->nest_regs[PEC_NEST_STK_BAR_EN] & PEC_NEST_STK_BAR_EN_PHB) {
|
if (phb->nest_regs[PEC_NEST_STK_BAR_EN] & PEC_NEST_STK_BAR_EN_PHB) {
|
||||||
phb_pec_error(pec, "Changing enabled BAR unsupported\n");
|
phb_pec_error(pec, "Changing enabled BAR unsupported\n");
|
||||||
}
|
}
|
||||||
stack->nest_regs[reg] = val & 0xffffffffffc00000ull;
|
phb->nest_regs[reg] = val & 0xffffffffffc00000ull;
|
||||||
break;
|
break;
|
||||||
case PEC_NEST_STK_INT_BAR:
|
case PEC_NEST_STK_INT_BAR:
|
||||||
if (stack->nest_regs[PEC_NEST_STK_BAR_EN] & PEC_NEST_STK_BAR_EN_INT) {
|
if (phb->nest_regs[PEC_NEST_STK_BAR_EN] & PEC_NEST_STK_BAR_EN_INT) {
|
||||||
phb_pec_error(pec, "Changing enabled BAR unsupported\n");
|
phb_pec_error(pec, "Changing enabled BAR unsupported\n");
|
||||||
}
|
}
|
||||||
stack->nest_regs[reg] = val & 0xfffffff000000000ull;
|
phb->nest_regs[reg] = val & 0xfffffff000000000ull;
|
||||||
break;
|
break;
|
||||||
case PEC_NEST_STK_BAR_EN:
|
case PEC_NEST_STK_BAR_EN:
|
||||||
stack->nest_regs[reg] = val & 0xf000000000000000ull;
|
phb->nest_regs[reg] = val & 0xf000000000000000ull;
|
||||||
pnv_pec_stk_update_map(stack);
|
pnv_pec_stk_update_map(stack);
|
||||||
break;
|
break;
|
||||||
case PEC_NEST_STK_DATA_FRZ_TYPE:
|
case PEC_NEST_STK_DATA_FRZ_TYPE:
|
||||||
case PEC_NEST_STK_PBCQ_TUN_BAR:
|
case PEC_NEST_STK_PBCQ_TUN_BAR:
|
||||||
/* Not used for now */
|
/* Not used for now */
|
||||||
stack->nest_regs[reg] = val;
|
phb->nest_regs[reg] = val;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
qemu_log_mask(LOG_UNIMP, "phb4_pec: nest_xscom_write 0x%"HWADDR_PRIx
|
qemu_log_mask(LOG_UNIMP, "phb4_pec: nest_xscom_write 0x%"HWADDR_PRIx
|
||||||
|
|
|
@ -112,6 +112,10 @@ struct PnvPHB4 {
|
||||||
uint64_t pci_regs[PHB4_PEC_PCI_STK_REGS_COUNT];
|
uint64_t pci_regs[PHB4_PEC_PCI_STK_REGS_COUNT];
|
||||||
MemoryRegion pci_regs_mr;
|
MemoryRegion pci_regs_mr;
|
||||||
|
|
||||||
|
/* Nest registers */
|
||||||
|
#define PHB4_PEC_NEST_STK_REGS_COUNT 0x17
|
||||||
|
uint64_t nest_regs[PHB4_PEC_NEST_STK_REGS_COUNT];
|
||||||
|
|
||||||
/* Memory windows from PowerBus to PHB */
|
/* Memory windows from PowerBus to PHB */
|
||||||
MemoryRegion phbbar;
|
MemoryRegion phbbar;
|
||||||
MemoryRegion intbar;
|
MemoryRegion intbar;
|
||||||
|
@ -165,9 +169,6 @@ struct PnvPhb4PecStack {
|
||||||
/* My own stack number */
|
/* My own stack number */
|
||||||
uint32_t stack_no;
|
uint32_t stack_no;
|
||||||
|
|
||||||
/* Nest registers */
|
|
||||||
#define PHB4_PEC_NEST_STK_REGS_COUNT 0x17
|
|
||||||
uint64_t nest_regs[PHB4_PEC_NEST_STK_REGS_COUNT];
|
|
||||||
MemoryRegion nest_regs_mr;
|
MemoryRegion nest_regs_mr;
|
||||||
|
|
||||||
/* PHB pass-through XSCOM */
|
/* PHB pass-through XSCOM */
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue