mirror of
https://github.com/tihmstar/futurerestore.git
synced 2025-01-09 20:35:29 +00:00
fixed bug when futurerestore would send another stock iBEC when restoring to iOS 10 in pwndfu
This commit is contained in:
parent
17839c1019
commit
e740b28b1d
|
@ -440,6 +440,7 @@ void futurerestore::enterPwnRecovery(plist_t build_identity, string bootargs){
|
||||||
reterror(-91,"Unable to connect to DFU device\n");
|
reterror(-91,"Unable to connect to DFU device\n");
|
||||||
irecv_get_mode(_client->dfu->client, &mode);
|
irecv_get_mode(_client->dfu->client, &mode);
|
||||||
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
iBSSKeys = libipatcher::getFirmwareKey(_client->device->product_type, _client->build, "iBSS");
|
iBSSKeys = libipatcher::getFirmwareKey(_client->device->product_type, _client->build, "iBSS");
|
||||||
iBECKeys = libipatcher::getFirmwareKey(_client->device->product_type, _client->build, "iBEC");
|
iBECKeys = libipatcher::getFirmwareKey(_client->device->product_type, _client->build, "iBEC");
|
||||||
|
@ -736,7 +737,7 @@ int futurerestore::doRestore(const char *ipsw){
|
||||||
//check for enterpwnrecovery, because we could be in DFU mode
|
//check for enterpwnrecovery, because we could be in DFU mode
|
||||||
if (_enterPwnRecoveryRequested){
|
if (_enterPwnRecoveryRequested){
|
||||||
if (getDeviceMode(true) != MODE_DFU)
|
if (getDeviceMode(true) != MODE_DFU)
|
||||||
reterror(-6, "unexpected device mode");
|
reterror(-6, "unexpected device mode\n");
|
||||||
enterPwnRecovery(build_identity);
|
enterPwnRecovery(build_identity);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -863,9 +864,10 @@ int futurerestore::doRestore(const char *ipsw){
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (_enterPwnRecoveryRequested && strncmp(client->version, "10.", 3)) //if pwnrecovery send all components decrypted, unless we're dealing with iOS 10
|
if (_enterPwnRecoveryRequested){ //if pwnrecovery send all components decrypted, unless we're dealing with iOS 10
|
||||||
client->recovery_custom_component_function = get_custom_component;
|
if (strncmp(client->version, "10.", 3))
|
||||||
else if (!_rerestoreiOS9){
|
client->recovery_custom_component_function = get_custom_component;
|
||||||
|
}else if (!_rerestoreiOS9){
|
||||||
/* now we load the iBEC */
|
/* now we load the iBEC */
|
||||||
if (recovery_send_ibec(client, build_identity) < 0) {
|
if (recovery_send_ibec(client, build_identity) < 0) {
|
||||||
reterror(-8,"ERROR: Unable to send iBEC\n");
|
reterror(-8,"ERROR: Unable to send iBEC\n");
|
||||||
|
@ -996,7 +998,7 @@ int futurerestore::doJustBoot(const char *ipsw, string bootargs){
|
||||||
reterror(-6, "enterPwnRecoveryRequested is not set, but required");
|
reterror(-6, "enterPwnRecoveryRequested is not set, but required");
|
||||||
|
|
||||||
if (getDeviceMode(true) != MODE_DFU && getDeviceMode(false) != MODE_RECOVERY)
|
if (getDeviceMode(true) != MODE_DFU && getDeviceMode(false) != MODE_RECOVERY)
|
||||||
reterror(-6, "unexpected device mode");
|
reterror(-6, "unexpected device mode\n");
|
||||||
enterPwnRecovery(build_identity, bootargs);
|
enterPwnRecovery(build_identity, bootargs);
|
||||||
|
|
||||||
client->recovery_custom_component_function = get_custom_component;
|
client->recovery_custom_component_function = get_custom_component;
|
||||||
|
|
Loading…
Reference in a new issue