Princess of Persia

Life is unpredictable...It doesnt announce itself...It just happens...You cant control what happens...You can only live it...One moment at a time...And smile...For the moment...

Saturday, January 20, 2024

Reversing Some C++ Io Operations

In general decompilers are not friendly with c++ let's analyse a simple program to get familiar with it.
Let's implement a simple code that loads a file into a vector and then save the vector with following functions:

  • err
  • load
  • save
  • main


Lets identify the typical way in C++ to print to stdout with the operator "<<"


The basic_ostream is initialized writing the word "error" to the cout, and then the operator<< again to add the endl.




The Main function simply calls  "vec = load(filename)"  but the compiler modified it and passed the vector pointer as a parámeter. Then it bulds and prints "loaded  " << size << " users".
And finally saves the vector to /tmp/pwd and print "saved".
Most of the mess is basically the operator "<<" to concat and print values.
Also note that the vectors and strings are automatically deallocated when exit the function.


And here is the code:


Let's take a look to the load function, which iterates the ifs.getline() and push to the vector.
First of all there is a mess on the function definition, __return_storage_ptr is the vector.
the ifstream object ifs is initialized as a basic_ifstream and then operator! checks if it wasn't possible to open the file and in that case calls err()
We see the memset and a loop, getline read a cstr like line from the file, and then is converted to a string before pushing it to the vector. lVar1 is the stack canary value.

In this situations dont obfuscate with the vector pointer vec initialization at the begining, in this case the logic is quite clear.



The function save is a bit more tricky, but it's no more than a vector iteration and ofs writing.
Looping a simple "for (auto s : *vec)" in the decompiler is quite dense, but we can see clearly two write, the second write DAT_0010400b is a "\n"



As we see, save implememtation is quite straightforward.




Continue reading
  1. Hacker Tools Online
  2. Hacker Tools For Windows
  3. Pentest Tools For Windows
  4. Hacking Tools And Software
  5. Pentest Automation Tools
  6. Tools For Hacker
  7. Hacker Tools 2019
  8. Pentest Tools Download
  9. Hacker Tools
  10. Pentest Tools For Android
  11. Game Hacking
  12. Pentest Tools Tcp Port Scanner
  13. Easy Hack Tools
  14. Pentest Tools Website Vulnerability
  15. Hacker Tool Kit
  16. Hacking Tools For Kali Linux
  17. Pentest Tools Free
  18. Hack Tools For Mac
  19. Hack Tools For Pc
  20. New Hack Tools
  21. Tools Used For Hacking
  22. Hack Tool Apk
  23. Hacking Tools Name
  24. Game Hacking
  25. Computer Hacker
  26. Hack Tool Apk No Root
  27. Hacking Tools Hardware
  28. Free Pentest Tools For Windows
  29. Pentest Automation Tools
  30. Tools For Hacker
  31. Pentest Tools Github
  32. Pentest Tools Website
  33. Nsa Hacker Tools
  34. Hack App
  35. How To Install Pentest Tools In Ubuntu
  36. Hacker Tools Free
  37. Hacker
  38. Pentest Tools Free
  39. Hacking Tools Download
  40. Pentest Tools Linux
  41. Hack Tools Mac
  42. Github Hacking Tools
  43. Pentest Tools Url Fuzzer
  44. Hacker Tools For Ios
  45. Usb Pentest Tools
  46. Best Hacking Tools 2019
  47. Pentest Tools Kali Linux
  48. Hacking Tools For Beginners
  49. Install Pentest Tools Ubuntu
  50. Hacker Tools For Mac
  51. Hacker Tools Online
  52. Hacking Tools Online
  53. Computer Hacker
  54. Hack Tools For Pc

0 Comments:

Post a Comment

Subscribe to Post Comments [Atom]

<< Home