You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Hi,
we have detected that your project may be vulnerable to Insufficient Information in the function of decode_static_field in the file of lib/transport/pb_decode.c. It shares similarities to a recent CVE disclosure https://nvd.nist.gov/vuln/detail/CVE-2020-26243 in the https://github.com/nanopb/nanopb. The source vulnerability information is as follows:
Vulnerability Detail:
CVE Identifier:CVE-2020-26243
Description: Nanopb is a small code-size Protocol Buffers implementation. In Nanopb before versions 0.4.4 and 0.3.9.7, decoding specifically formed message can leak memory if dynamic allocation is enabled and an oneof field contains a static submessage that contains a dynamic field, and the message being decoded contains the submessage multiple times. This is rare in normal messages, but it is a concern when untrusted data is parsed. This is fixed in versions 0.3.9.7 and 0.4.4. The following workarounds are available: 1) Set the option no_unions for the oneof field. This will generate fields as separate instead of C union, and avoids triggering the problematic code. 2) Set the type of the submessage field inside oneof to FT_POINTER. This way the whole submessage will be dynamically allocated and the problematic code is not executed. 3) Use an arena allocator for nanopb, to make sure all memory can be released afterwards.
Reference: https://nvd.nist.gov/vuln/detail/CVE-2020-26243
Patch: nanopb/nanopb@4fe2359
Would you help to check if this bug is true? If it's true, I'd like to open a PR for that if necessary. Thank you for your effort and patience!
The text was updated successfully, but these errors were encountered:
Independent security researcher here, not affiliated with the Keepkey project.
See #354 (comment)
I think the official firmware builds used the no-longer-vulnerable nanopb 0.3.9.8 since mid-2021, likely mitigating this.
Based on this quick look, I would say that the documentation should be fixed, but I doubt this is or was exploitable in any recent version of the Keepkey firmware.
Hi,
we have detected that your project may be vulnerable to Insufficient Information in the function of
decode_static_field
in the file oflib/transport/pb_decode.c
. It shares similarities to a recent CVE disclosure https://nvd.nist.gov/vuln/detail/CVE-2020-26243 in the https://github.com/nanopb/nanopb.The source vulnerability information is as follows:
Would you help to check if this bug is true? If it's true, I'd like to open a PR for that if necessary. Thank you for your effort and patience!
The text was updated successfully, but these errors were encountered: