[OpenWrt-Devel] [PATCH v3 0/3] libubox: Enhance robustness of blobmsg parsing
Tobias Schramm
tobleminer at gmail.com
Tue Nov 27 20:35:20 EST 2018
Hi,
this patch set makes parsing of blobmsg messages more robust against
malformed data.
Previously blobmsg_parse would crash due to out of bounds reads when
provied with malformed blobs containing invalid blob length specifications.
I've introduced a _safe variant of all blobmsg_check_* methods that takes
an additional length argument that allows it to verify that all performed
reads will be inside the buffer containing the struct attr* to be checked.
Since we do already get the actual buffer length for free in a few places
(namely blobmsg_parse, blobmsg_parse_array) I've adjusted those methods to
use the _safe attribute checking variants.
I've not changed the semantics of the old, unsafe blobmsg_check_* functions
to include a compiler-level deprecation warning to ensure it does not break
builds of existing packages depending on libubox compiled with -Werror.
Best Regards,
Tobias Schramm
Changelog:
v2:
- Add documentation to attribute checking methods in blobmsg.h
v3:
- Inline attribute checking methods
- Fix orthography
Tobias Schramm (3):
Ensure blob_attr length check does not perform out of bounds reads
Replace use of blobmsg_check_attr by blobmsg_check_attr_safe
Add _safe variants for all attribute checking methods
blob.h | 4 +--
blobmsg.c | 36 ++++++++++++++++++++------
blobmsg.h | 75 ++++++++++++++++++++++++++++++++++++++++++++++++++++---
3 files changed, 102 insertions(+), 13 deletions(-)
--
2.19.2
_______________________________________________
openwrt-devel mailing list
openwrt-devel at lists.openwrt.org
https://lists.openwrt.org/mailman/listinfo/openwrt-devel
More information about the openwrt-devel
mailing list