On Wed, 27 Oct 2021 05:17:43 +0000 Ariel Elior wrote:
You may recall we had a discussion on this during our last FW upgrade too.
"During our last FW upgrade" is pretty misleading here. The discussion seems to have been after user reported that you broke their systems:
https://lore.kernel.org/netdev/ffbcf99c-8274-eca1-5166-efc0828ca05b@molgen.m...
Now you want to make your users' lives even more miserable by pushing your changes into stable.
Please note this is not FW which resides in flash, which may or may not be updated during the life cycle of a specific board deployment, but rather an initialization sequence recipe which happens to contain FW content (as well as many other register and memory initializations) which is activated when driver loads. We do have Flash based FW as well, with which we are fully backwards and forwards compatible. There is no method to build the init sequence in a backwards compatible mode for these devices - it would basically mean duplicating most of the device interaction logic (control plane and data plane). To support these products we need to be able to update this from time to time.
And the driver can't support two versions of init sequence because...?
Please note these devices are EOLing, and therefore this may well be the last update to this FW.
Solid argument.
The only theoretical way we can think of getting around this if we had to is adding the entire thing as a huge header file and have the driver compile with it. This would detach the dependency on the FW file being present on disk, but has big disadvantages of making the compiled driver huge, and bloating the kernel with redundant headers filled with what is essentially a binary blob. We do make sure to add the FW files to the FW sub tree in advance of modifying the drivers to use them.
All the patch is doing is changing some offsets. Why can't you just make the offset the driver uses dependent on the FW version?
Would be great if the engineer who wrote the code could answer that.