SimpleNetwork
SimpleNetwork copied to clipboard
Double Free in TCPServer
Hi there!
I was running my fuzzer in the background when I discovered a double free in the SimpleNetwork TCPServer.
Impact
Triggering the double free will allow client to crash any SimpleNetwork TCP server remotely. In other situations, double free vulnerabilities can cause undefined behavior and potentially code execution in the right circumstances.
Reproduction
Create a file with a large amount of random characters
data:image/s3,"s3://crabby-images/aefef/aefef75c4f4d1aab553d6f21480cd63f47f9cb00" alt="Screen Shot 2022-07-14 at 4 27 10 PM"
Start a TCP server and send the large file to the server a few consecutive times
data:image/s3,"s3://crabby-images/9067c/9067c7fa9d7a3631cc386757402651903d1c570a" alt="Screen Shot 2022-07-14 at 5 06 48 PM"
View the crash and gdb backtrace
data:image/s3,"s3://crabby-images/9110b/9110b44ef191dc89c81106fdeb570bdef42595d4" alt="Screen Shot 2022-07-14 at 4 30 14 PM"
data:image/s3,"s3://crabby-images/a0151/a0151e21ea7e63c4ecf9cc0605b0b8e6d2545a00" alt="Screen Shot 2022-07-14 at 5 06 14 PM"
Extra Resources
- https://owasp.org/www-community/vulnerabilities/Doubly_freeing_memory
- https://cwe.mitre.org/data/definitions/415.html
Here is the valgrind output showing the invalid double free:
This issue was assigned CVE-2022-36234. Proof of concept Python3 code can be found here:
https://github.com/Halcy0nic/CVE-2022-36234