#9 Nsec21 - Tom's Hut part2
data:image/s3,"s3://crabby-images/0aaab/0aaabcfeeefd700fe832b46c2696bbc8fc9743e5" alt=""
If you want to fully understand this post I can only recommand you to read the previous one (Flag 8 part1)
RE102 Reverse
Like the previous one, the architecture is Xtensa, but this time I already have the right module for Ghidra !
data:image/s3,"s3://crabby-images/3fade/3fade10a9edee0a6549d470d97ea562902ebc449" alt=""
Using Ghidra I’m doing the import and the analysis of the binary.
data:image/s3,"s3://crabby-images/e514f/e514fac232a66d2d4e8e8136d5c7a2e2bebc3df3" alt=""
App Main
The app_main
function is very similar to RE101
, so this time let’s jump on the verify
function !
data:image/s3,"s3://crabby-images/49d77/49d7711fa117456d1291ff10cb488256d31496b2" alt=""
Verify
This time its different, as we can see the user input is stored inside user_code
and the check is done using a8
registry.
In the first example, the first element of the input is checked with 0x66
which is a f
.
data:image/s3,"s3://crabby-images/2181f/2181f90653fe926dd4963db65e94e5a3133554da" alt=""
We just need to jump into each function and check which element is checked and with which character.
Flag
The final FLAG isf219e6cdb1fa4a48b160d00d61118f93
data:image/s3,"s3://crabby-images/ecabf/ecabf35df96f3eb4d4042e119660f0ee2c0da100" alt=""