Difference between revisions of "Bootrom Dumper Utility"

From The iPhone Wiki
Jump to: navigation, search
(Info / Instructions: there is no 1.0.9 released yet, so that's wrong)
m
 
(4 intermediate revisions by 2 users not shown)
Line 10: Line 10:
 
* libusb 1.0.8 required
 
* libusb 1.0.8 required
 
* execute it with root privileges (sudo ./bdu)
 
* execute it with root privileges (sudo ./bdu)
* by default compatible only with A4 devices: (iPhone 4, iPod 4G, iPad, AppleTV 2)
+
* by default compatible only with A4 devices: ([[iPhone 4]], [[iPod touch (4th generation)]], [[K66AP|iPad]], [[Apple TV (2nd generation)]])
   
It's possible to extend the compatibility to older devices as well (iPhone 3GS, iPod 3G) by changing:
+
It's possible to extend the compatibility to older devices as well (iPhone 3GS, iPod (3rd generation)) by changing:
 
* the offset to the call of usb_wait_for_image in payload.S
 
* the offset to the call of usb_wait_for_image in payload.S
   
0x7ef @ A4 devices: iPad 1, iPhone 4 (GSM+CDMA), Apple TV 2G, iPod touch 4G
+
0x7ef @ A4 devices: iPad, iPhone 4, Apple TV (2nd generation), iPod touch (4th generation)
0x8b7 @ iPod touch 3G
+
0x8b7 @ iPod touch (3rd generation)
 
0x8b7 @ iPhone 3GS new bootrom
 
0x8b7 @ iPhone 3GS new bootrom
 
0x8b7 @ iPhone 3GS old bootrom
 
0x8b7 @ iPhone 3GS old bootrom
0x8b7 @ iPod touch 2G new bootrom (0x30F1 according to other sources)
+
0x82c @ iPod touch (2nd generation) new bootrom
0x8b7 @ iPod touch 2G old bootrom (0x30E9 according to other sources)
+
0x82d @ iPod touch (2nd generation) old bootrom
   
 
* exploit offsets in bdu.c
 
* exploit offsets in bdu.c
Line 27: Line 27:
 
#define EXPLOIT_LR 0x8403BF9C
 
#define EXPLOIT_LR 0x8403BF9C
 
#define LOADADDR_SIZE 0x2C000
 
#define LOADADDR_SIZE 0x2C000
// iPod touch 2G:
+
// iPod touch (2nd generation):
 
#define EXPLOIT_LR 0x22000000
 
#define EXPLOIT_LR 0x22000000
 
#define LOADADDR_SIZE 0x24000
 
#define LOADADDR_SIZE 0x24000
// iPod touch 3G:
+
// iPod touch (3rd generation):
 
#define EXPLOIT_LR 0x84033F98
 
#define EXPLOIT_LR 0x84033F98
 
#define LOADADDR_SIZE 0x24000
 
#define LOADADDR_SIZE 0x24000

Latest revision as of 09:32, 26 March 2017

The Bootrom Dumper Utility (short BDU) is an application that will create a copy (aka dump) of the Bootrom of compatible devices on the local machine from where the application is run.

Credit

Pod2g

Geohot for limera1n

Info / Instructions

It's possible to extend the compatibility to older devices as well (iPhone 3GS, iPod (3rd generation)) by changing:

  • the offset to the call of usb_wait_for_image in payload.S
0x7ef @ A4 devices: iPad, iPhone 4, Apple TV (2nd generation), iPod touch (4th generation)
0x8b7 @ iPod touch (3rd generation)
0x8b7 @ iPhone 3GS new bootrom
0x8b7 @ iPhone 3GS old bootrom
0x82c @ iPod touch (2nd generation) new bootrom
0x82d @ iPod touch (2nd generation) old bootrom
  • exploit offsets in bdu.c
// A4:
#define EXPLOIT_LR 0x8403BF9C
#define LOADADDR_SIZE 0x2C000
// iPod touch (2nd generation):
#define EXPLOIT_LR 0x22000000
#define LOADADDR_SIZE 0x24000
// iPod touch (3rd generation):
#define EXPLOIT_LR 0x84033F98
#define LOADADDR_SIZE 0x24000
// iPhone 3GS new bootrom:
#define EXPLOIT_LR 0x84033FA4
#define LOADADDR_SIZE 0x24000

Links

Github