Rating:
# Super Encryption!
**60 points**
```
My friend sent me a flag encrypted with an encryption program.
Unfortunately, the decryption doesn't seem to work.
Please help me decrypt this: dufhyuc>bi{{f0|;vwh<~b5p5thjq6goj}
```
data:image/s3,"s3://crabby-images/50f70/50f70a3be66e6269822336bd06e86b182e05512d" alt=""
The decryption is not implemented in the attached file (`superencrypt`) so the inverse of the encryption has to be handcrafted.
**The entrypoint(`main`) in IDA**
data:image/s3,"s3://crabby-images/2f085/2f0857db99bfbd955c817fd69e561cf0927abef4" alt=""
A very straight forward branch is made to `encrypt` and `decrypt` based on the user input.
data:image/s3,"s3://crabby-images/bc485/bc48571545cc26511e55988b861c441cd0d17672" alt=""
As expected, nothing happens in the `decrypt` function.
data:image/s3,"s3://crabby-images/ccc10/ccc106bc2d7ba64aa76b49ae0825e9437884088a" alt=""
Prior to calling `encrypt`, the parameters are copied to `rsi` and `rdi` and later on copied to the stack in the function entrypoint.
data:image/s3,"s3://crabby-images/0aed5/0aed5e4a52cdecfde4527fde2679cf31a3b337e9" alt=""
`rdi` points to the given string
`rsi` holds `0x100` which is probably the buffer length
data:image/s3,"s3://crabby-images/38566/38566dc1a936601b38cfff93ad61af061b28748a" alt=""
Although there are 3 loops in the function, the encryption itself is done in the first one. To be specific, a key is derived from the loop counter(`i`) and added to each character.
data:image/s3,"s3://crabby-images/7e9a5/7e9a5dc94550f03333fe4738a76146882f86f081" alt=""
The second and third loops are responsible for reversing the order of the cipher in chunks of 5 and 3 respectively.
The following steps need to be taken for decryption.
1. Reverse order by chunks of 3
2. Reverse order by chunks of 5
3. Derive key from loop counter and subtract from each character
One thing to note is that instead of deriving the key myself, I ripped the key by logging the values stored in `v13`(`xmm0`).