A denial-of-service issue was discovered in the MQTT library in Arm Mbed OS 2017-11-02. The function readMQTTLenString() is called by the function MQTTDeserialize_publish() to get the length and content of the MQTT topic name. In the function readMQTTLenString(), mqttstring->lenstring.len is a part of user input, which can be manipulated. An attacker can simply change it to a larger value to invalidate the if statement so that the statements inside the if statement are skipped, letting the value of mqttstring->lenstring.data default to zero. Later, curn is accessed, which points to mqttstring->lenstring.data. On an Arm Cortex-M chip, the value at address 0x0 is actually the initialization value for the MSP register. It is highly dependent on the actual firmware. Therefore, the behavior of the program is unpredictable from this time on.
References
Link | Resource |
---|---|
https://github.com/ARMmbed/mbed-os/issues/11802 | Issue Tracking Third Party Advisory |
https://github.com/ARMmbed/mbed-os/issues/11802 | Issue Tracking Third Party Advisory |
Configurations
Configuration 1 (hide)
AND |
|
History
21 Nov 2024, 04:31
Type | Values Removed | Values Added |
---|---|---|
References | () https://github.com/ARMmbed/mbed-os/issues/11802 - Issue Tracking, Third Party Advisory |
Information
Published : 2019-11-04 20:15
Updated : 2024-11-21 04:31
NVD link : CVE-2019-17210
Mitre link : CVE-2019-17210
CVE.ORG link : CVE-2019-17210
JSON object : View
Products Affected
arm
- mbed-os
- mbed-mqtt
CWE
CWE-20
Improper Input Validation