When a PRIVMSG arrives, the vulnerable function is called to copy the nickname to a buffer:
data:image/s3,"s3://crabby-images/d463c/d463cd3a2d2340cd67f5101302c2466b54ef2417" alt=""
let's see the pseudocode of the call: (dest, bytes to copy, src)
data:image/s3,"s3://crabby-images/bfee4/bfee41084285c33638283859b5b8c9c4e74dcbaf" alt=""
Let's see the vulnerable memory zero fill:
data:image/s3,"s3://crabby-images/cea4c/cea4ce30f901c4a44d7d2e974d581a95e21ae863" alt=""
ESI is the "bytes to copy", we dont jump becouse is greatter than 10, and then ...
the first rep start to copy 0x00 at [edi++] ecx times (309 times) then we write in other vars and out of the page.
Explotation vector: the nick, well, you must be the server becouse servers dont allow large nicknames. (a privmsg with a 315 bytes nick -> DoS)
let's see the pseudocode of the call: (dest, bytes to copy, src)
Let's see the vulnerable memory zero fill:
ESI is the "bytes to copy", we dont jump becouse is greatter than 10, and then ...
the first rep start to copy 0x00 at [edi++] ecx times (309 times) then we write in other vars and out of the page.
Explotation vector: the nick, well, you must be the server becouse servers dont allow large nicknames. (a privmsg with a 315 bytes nick -> DoS)
Comentarios