Overview
Vulnerability details
1. Vulnerability Trigger Location
The vulnerability was triggered by a segment fault at the 0x00415ca8 of the buffer_copy_off_t
function.
data:image/s3,"s3://crabby-images/1f91f/1f91fd8689fc0127c1640ec3d2435976cbbda52e" alt="image.png"
2. Vulnerability Analysis
- The vulnerability must contain a link to /dws/api in the URL and the source of the vulnerability must be in the set_ws_action function called in the http_request_parse function
data:image/s3,"s3://crabby-images/a26a3/a26a3f2c5a3a45c811724e95d3b8f708ff16516d" alt="image.png"
- Before calling the set_ws_action function, the param_1 value is the 0x43c008 address in the 0x412d10 location, which is stored in the S7 register
data:image/s3,"s3://crabby-images/997ec/997ec86f267d860200733a026857c3611ec4a478" alt="image.png"
data:image/s3,"s3://crabby-images/1424b/1424bd8bfe39d5927a616c083d257186a6e78fd0" alt="image.png"
- set_ws_action function, the value of pcVar14 is stored, because the if condition is met, and all the values in the param_1 are copied to the ws_action
data:image/s3,"s3://crabby-images/3dcbe/3dcbec74265340930dc802098983483e594463c7" alt="image.png"
data:image/s3,"s3://crabby-images/1e81a/1e81ab6a4c83e6fbaaa2910605fe48f74656c9c9" alt="image.png"
- The length of the ws_action is 4 bytes, causing the buffer to overflow
data:image/s3,"s3://crabby-images/67037/6703751d226b6b4e70ea99bca2a3b8e9a12c3881" alt="image.png"
- The last overflowing byte overwrites the 0x43c008, resulting in a segment fault
data:image/s3,"s3://crabby-images/d9599/d95996f54a8b9845fd51b368f8c02a45f86fe84d" alt="image.png"
POC