All of lore.kernel.org
 help / color / mirror / Atom feed
* IMX FEC model- modification in interrupts
@ 2021-03-10  9:58 Olek, Adam
  2021-03-11 19:06 ` Peter Maydell
  0 siblings, 1 reply; 3+ messages in thread
From: Olek, Adam @ 2021-03-10  9:58 UTC (permalink / raw)
  To: qemu-devel

[-- Attachment #1: Type: text/plain, Size: 1251 bytes --]

Dear QEMU Team,
We have tried to up and running QNX 7.0 on QEMU 5.2.0 Sabrelite model. The QNX reach the prompt and was responsive to user command.
However, starting the network caused a QNX freeze. After debugging the problem at QNX and QEMU sites we end up with a solution which requires a slight QEMU source code modification.
It seem that the hw/net/imx_fec.c is source of the problem. To fix the issue we changed the condition in line 442 from:
if (s->regs[ENET_EIR] & s->regs[ENET_EIMR] &
     (ENET_INT_MAC | ENET_INT_TS_TIMER)) {
to:
if (s->regs[ENET_EIR] & s->regs[ENET_EIMR] & ENET_INT_TS_TIMER) {
Without this modification the PTP (Precise Time Protocol, 1588 IRQ) interrupt was generated each time any of the network interrupts occurred.
This was making QNX freeze when ifconfig has been called, because QNX was flooded by PTP interrupts that haven't occurred.
With this modification QEMU will generate PTP interrupt when it actually occurs. Just to cross check, this modification does not impact the Linux performance in any way.
Can anyone take a closer look at this condition and confirm that this modification make sense and it hasn't negative impact on anything else?
Regards,
Adam Olek
Senior Software Engineer
APTIV

[-- Attachment #2: Type: text/html, Size: 5316 bytes --]

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2021-03-15 14:23 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-03-10  9:58 IMX FEC model- modification in interrupts Olek, Adam
2021-03-11 19:06 ` Peter Maydell
2021-03-15 14:18   ` EXT SENDER - " Olek, Adam

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.