Re: [PATCH 1/1] can: sja1000: clear interrupts on start
From: Mirza Krak
Date: Wed Nov 11 2015 - 04:54:37 EST
2015-11-11 9:04 GMT+01:00 Marc Kleine-Budde <mkl@xxxxxxxxxxxxxx>:
> This problem occurs only an hardware, where the SJA1000 is powered
> during system suspend?
Correct, and the controller is in UP state.
> Doesn't the SJA1000 trigger an interrupt that is detected after
> resuming? You add the fix to the open() function, which is triggered
> during $(ifconfig up), how is related to suspend/resume? Does the
> network layer call $(ifconfig down) during shutdown?
It does not trigger another interrupt.
In our tests we have seen that IE and EPI flags are set in the IR
registered when we resume the system. If we do not clear these two
flags it does not produce any other interrupts. Setting the controller
in to reset mode does not clear the IE and EPI flags, I can understand
that IE flag is not cleared as this is stated in the data-sheet, can
not explain why EPI flag is not cleared though as data-sheet states 0
(reset) for both hardware reset and SETTING MOD.0 BY SOFTWARE (which
is the reset-mode)
Reason I put it in open() is so at least a DOWN/UP procedure returns
the controller to an operating state. Also if we do an UP we should
clear any earlier states that might exist in the registers like we do
with error counters and error code capture.
Network layer does not call $(ifconfig down) during shutdown.
> There isn't any suspend/resume code in the sja1000 driver, for me it
> seems that we should add resume code that handles this problem.
Yes, resume code should be implemented to handle this and other
problems (receive data). But still a DOWN/UP procedure should clear
any previous state that could exist in the controller registers.
--
Med VÃnliga HÃlsningar / Best Regards
*******************************************************************
Mirza Krak
Host Mobility AB
mirza.krak@xxxxxxxxxxxxxxxx
Anders Personsgatan 12, 416 64 GÃteborg
Sweden
http://www.hostmobility.com
Direct: +46 31 31 32 704
Phone: +46 31 31 32 700
Fax: +46 31 80 67 51
Mobile: +46 730 28 06 22
*******************************************************************
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/