-
Notifications
You must be signed in to change notification settings - Fork 13
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
ComponentComparisonStamp was misinterpreted #17
Comments
Do you have example code that is broken and/or an explanation of the bad behavior as a result of this? Is it just your last sentence that describes the problem? |
The current code, src/dsp/firmware_update.c at line 641, is It should be According to the spec, when comp_options.bits.bit is not set (i.e. false), comp+comparison_stamp should be simply ignored, even though a value 0xFFFFFFFF is recommended. I've forked the code and will create a pull request soon. |
I've created a pull request #18 , but don't know how to link it to this issue. |
I noticed this issue as the product I'm working with has not to use the timestamp (bit1==false) and the timestamp == 0x00000000. Error was returned by this code. I read the specification and believe this should be allowed. |
I'm not convinced that if the corresponding options bit is set that the stamp must not be |
DSP0267 > Table 6 - Component Image Information > ComponentComparisonStamp
The spec says, "
When ComponentOptions bit 1 is not set, this field should use the value of 0xFFFFFFFF.
" "SHOULD" is a recommendation rather than a requirement (DSP0267 Section 3, Terms and definitions). Therefore, the current implementation is incorrect.However, "
When ComponentOptions bit 1 is set, this field shall contain a FD or downstream device vendor selected value to use as a comparison value in determining if a firmware component is down-level or up-level.
" Since 0xFFFFFFFF is defined asPLDM_FWUP_INVALID_COMPONENT_COMPARISON_TIMESTAMP
, it shall not be used when the bit 1 is set.The text was updated successfully, but these errors were encountered: