mirror of https://gitee.com/openkylin/qemu.git
net: cadence_gem: Define access permission for interrupt registers
Q1 to Q7 ISR's are clear-on-read, IER/IDR registers are write-only, mask reg are read-only. Signed-off-by: Sai Pavan Boddu <sai.pavan.boddu@xilinx.com> Reviewed-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com> Signed-off-by: Jason Wang <jasowang@redhat.com>
This commit is contained in:
parent
86a29d4c72
commit
4c70e32f05
|
@ -458,6 +458,7 @@ static const uint8_t broadcast_addr[] = { 0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF };
|
||||||
*/
|
*/
|
||||||
static void gem_init_register_masks(CadenceGEMState *s)
|
static void gem_init_register_masks(CadenceGEMState *s)
|
||||||
{
|
{
|
||||||
|
unsigned int i;
|
||||||
/* Mask of register bits which are read only */
|
/* Mask of register bits which are read only */
|
||||||
memset(&s->regs_ro[0], 0, sizeof(s->regs_ro));
|
memset(&s->regs_ro[0], 0, sizeof(s->regs_ro));
|
||||||
s->regs_ro[GEM_NWCTRL] = 0xFFF80000;
|
s->regs_ro[GEM_NWCTRL] = 0xFFF80000;
|
||||||
|
@ -470,10 +471,19 @@ static void gem_init_register_masks(CadenceGEMState *s)
|
||||||
s->regs_ro[GEM_ISR] = 0xFFFFFFFF;
|
s->regs_ro[GEM_ISR] = 0xFFFFFFFF;
|
||||||
s->regs_ro[GEM_IMR] = 0xFFFFFFFF;
|
s->regs_ro[GEM_IMR] = 0xFFFFFFFF;
|
||||||
s->regs_ro[GEM_MODID] = 0xFFFFFFFF;
|
s->regs_ro[GEM_MODID] = 0xFFFFFFFF;
|
||||||
|
for (i = 0; i < s->num_priority_queues; i++) {
|
||||||
|
s->regs_ro[GEM_INT_Q1_STATUS + i] = 0xFFFFFFFF;
|
||||||
|
s->regs_ro[GEM_INT_Q1_ENABLE + i] = 0xFFFFF319;
|
||||||
|
s->regs_ro[GEM_INT_Q1_DISABLE + i] = 0xFFFFF319;
|
||||||
|
s->regs_ro[GEM_INT_Q1_MASK + i] = 0xFFFFFFFF;
|
||||||
|
}
|
||||||
|
|
||||||
/* Mask of register bits which are clear on read */
|
/* Mask of register bits which are clear on read */
|
||||||
memset(&s->regs_rtc[0], 0, sizeof(s->regs_rtc));
|
memset(&s->regs_rtc[0], 0, sizeof(s->regs_rtc));
|
||||||
s->regs_rtc[GEM_ISR] = 0xFFFFFFFF;
|
s->regs_rtc[GEM_ISR] = 0xFFFFFFFF;
|
||||||
|
for (i = 0; i < s->num_priority_queues; i++) {
|
||||||
|
s->regs_rtc[GEM_INT_Q1_STATUS + i] = 0x00000CE6;
|
||||||
|
}
|
||||||
|
|
||||||
/* Mask of register bits which are write 1 to clear */
|
/* Mask of register bits which are write 1 to clear */
|
||||||
memset(&s->regs_w1c[0], 0, sizeof(s->regs_w1c));
|
memset(&s->regs_w1c[0], 0, sizeof(s->regs_w1c));
|
||||||
|
@ -485,6 +495,10 @@ static void gem_init_register_masks(CadenceGEMState *s)
|
||||||
s->regs_wo[GEM_NWCTRL] = 0x00073E60;
|
s->regs_wo[GEM_NWCTRL] = 0x00073E60;
|
||||||
s->regs_wo[GEM_IER] = 0x07FFFFFF;
|
s->regs_wo[GEM_IER] = 0x07FFFFFF;
|
||||||
s->regs_wo[GEM_IDR] = 0x07FFFFFF;
|
s->regs_wo[GEM_IDR] = 0x07FFFFFF;
|
||||||
|
for (i = 0; i < s->num_priority_queues; i++) {
|
||||||
|
s->regs_wo[GEM_INT_Q1_ENABLE + i] = 0x00000CE6;
|
||||||
|
s->regs_wo[GEM_INT_Q1_DISABLE + i] = 0x00000CE6;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
Loading…
Reference in New Issue