Hello Marc,
Thanks for looking into this.
On 10/6/22 18:36, Marc Kleine-Budde wrote:
On 06.10.2022 18:24:50, Marc Kleine-Budde wrote:
From: Jeroen Hofstee <jhofstee@xxxxxxxxxxxxxxxxx>
The open source firmware candleLight report bus errors
unconditionally. This adds support to enable / disable bus error
reporting with the standard netlink property.
I haven't checked the candleLight firmware, yet.
If the unmodified firmware sends bus errors per default and we introduce
BERR_REPORTING as suggested in this patch, we have to modify the default
behavior for bus errors: By default the firmware will not send bus
errors, but only if GS_CAN_MODE_BERR_REPORTING is requested during
open().
I'm not sure if we want to change the default behavior of the
firmware....To work around this backwards compatibility issue we can
explicitly turn BERR reporting on or off during open via
GS_CAN_MODE_BERR_REPORTING_ON or GS_CAN_MODE_BERR_REPORTING_OFF.
What do you think?
Personally, I wouldn't care about backward compatibility, it was added
later on despite they know it should be a socketcan option, see [1] and
for most if not all users, having error frames on a bit level / crc mismatch
level is only annoying, unless you are really looking deep into problems
and then enabling a simple flag isn't your biggest problem, especially not
if it is a documented/common flag which is supposed to do exactly that.
Obviously state changes are still send after my changes to candleLight
are accepted without bit error reporting being set.
So yes afaiac berr-reporting is simply turned off by default. Unless there
really are users which need them and can't simply set a single bit; my
guess there isn't any of them.
With kind regards,
Jeroen
[1] https://github.com/candle-usb/candleLight_fw/issues/59