A vulnerability was found in MicroPython 1.22.2. It has been declared as critical. Affected by this vulnerability is an unknown functionality of the file py/objarray.c. The manipulation leads to use after free. The attack can be launched remotely. The complexity of an attack is rather high. The exploitation appears to be difficult. Upgrading to version 1.23.0 is able to address this issue. The identifier of the patch is 4bed614e707c0644c06e117f848fa12605c711cd. It is recommended to upgrade the affected component. In micropython objarray component, when a bytes object is resized and copied into itself, it may reference memory that has already been freed.
The product reuses or references memory after it has been freed. At some point afterward, the memory may be allocated again and saved in another pointer, while the original pointer references a location somewhere within the new allocation. Any operations using the original pointer are no longer valid because the memory "belongs" to the code that operates on the new pointer.
Link | Tags |
---|---|
https://vuldb.com/?id.277765 | third party advisory vdb entry |
https://vuldb.com/?ctiid.277765 | signature permissions required |
https://vuldb.com/?submit.409316 | third party advisory |
https://github.com/micropython/micropython/issues/13283 | third party advisory issue tracking exploit |
https://github.com/micropython/micropython/issues/13283#issuecomment-1918479709 | third party advisory issue tracking exploit |
https://github.com/micropython/micropython/commit/4bed614e707c0644c06e117f848fa12605c711cd | patch |
https://github.com/micropython/micropython/releases/tag/v1.23.0 | patch release notes |