In radare2 through 4.0, there is an integer overflow for the variable newtokensize in the function rasmmassemble at libr/asm/asm.c. This integer overflow will result in a Use-After-Free for the buffer tokens, which can be filled with arbitrary malicious data after the free. This allows remote attackers to cause a denial of service (application crash) or possibly execute arbitrary code via crafted input.
{
"binaries": [
{
"binary_name": "libradare2-0.9.6",
"binary_version": "0.9.6-3.1ubuntu1"
},
{
"binary_name": "libradare2-common",
"binary_version": "0.9.6-3.1ubuntu1"
},
{
"binary_name": "libradare2-dev",
"binary_version": "0.9.6-3.1ubuntu1"
},
{
"binary_name": "radare2",
"binary_version": "0.9.6-3.1ubuntu1"
},
{
"binary_name": "radare2-plugins",
"binary_version": "0.9.6-3.1ubuntu1"
}
]
}
{
"binaries": [
{
"binary_name": "libradare2-2.3",
"binary_version": "2.3.0+dfsg-2"
},
{
"binary_name": "libradare2-common",
"binary_version": "2.3.0+dfsg-2"
},
{
"binary_name": "libradare2-dev",
"binary_version": "2.3.0+dfsg-2"
},
{
"binary_name": "radare2",
"binary_version": "2.3.0+dfsg-2"
}
]
}