changed the way baseband tickets are handled (i really hope this doesn't fuck up the entire restore)

This commit is contained in:
tihmstar 2017-01-01 16:31:16 +01:00
parent da40807d6f
commit 961dbc808a
3 changed files with 82 additions and 36 deletions

View file

@ -254,8 +254,6 @@ int futurerestore::doRestore(const char *ipsw, bool noerase){
int delete_fs = 0;
char* filesystem = NULL;
plist_t buildmanifest = NULL;
plist_t sepbuildmanifest = NULL;
plist_t basebandbuildmanifest = NULL;
plist_t build_identity = NULL;
plist_t sep_build_identity = NULL;
plist_t bb_build_identity = NULL;
@ -312,16 +310,14 @@ int futurerestore::doRestore(const char *ipsw, bool noerase){
}
}
sepbuildmanifest = loadPlistFromFile(_sepManifestPath);
sep_build_identity = build_manifest_get_build_identity_for_model_with_restore_behavior(sepbuildmanifest, client->device->hardware_model, "Erase");
if (!sep_build_identity) sep_build_identity = build_manifest_get_build_identity_for_model_with_restore_behavior(sepbuildmanifest, client->device->hardware_model, "Update");
sep_build_identity = build_manifest_get_build_identity_for_model_with_restore_behavior(_sepbuildmanifest, client->device->hardware_model, "Erase");
if (!sep_build_identity) sep_build_identity = build_manifest_get_build_identity_for_model_with_restore_behavior(_sepbuildmanifest, client->device->hardware_model, "Update");
if (sep_build_identity == NULL) {
reterror(-5,"ERROR: Unable to find any build identities for sep\n");
}
basebandbuildmanifest = loadPlistFromFile(_basebandManifestPath);
bb_build_identity = build_manifest_get_build_identity_for_model_with_restore_behavior(basebandbuildmanifest, client->device->hardware_model, "Erase");
if (!bb_build_identity) bb_build_identity = build_manifest_get_build_identity_for_model_with_restore_behavior(basebandbuildmanifest, client->device->hardware_model, "Update");
bb_build_identity = build_manifest_get_build_identity_for_model_with_restore_behavior(_basebandbuildmanifest, client->device->hardware_model, "Erase");
if (!bb_build_identity) bb_build_identity = build_manifest_get_build_identity_for_model_with_restore_behavior(_basebandbuildmanifest, client->device->hardware_model, "Update");
if (bb_build_identity == NULL) {
reterror(-5,"ERROR: Unable to find any build identities for baseband\n");
}
@ -472,13 +468,16 @@ int futurerestore::doRestore(const char *ipsw, bool noerase){
reterror(-11,"ERROR: Unable to get SHSH blobs for SEP\n");
}
FILE *fsep = fopen(_sepPath, "r");
fseek(fsep, 0, SEEK_END);
client->sepfwdatasize = ftell(fsep);
fseek(fsep, 0, SEEK_SET);
client->sepfwdata = (char*)malloc(client->sepfwdatasize);
fread(client->sepfwdata, 1, client->sepfwdatasize, fsep);
fclose(fsep);
client->basebandBuildIdentity = getBuildidentity(_basebandbuildmanifest, getDeviceModelNoCopy(), noerase);
if (!_client->basebandBuildIdentity)
reterror(-55, "BasebandBuildIdentity not loaded, refusing to continue");
if (!_client->sepfwdatasize || !_client->sepfwdata)
reterror(-55, "SEP not loaded, refusing to continue");
if (client->mode->index == MODE_RESTORE) {
@ -495,8 +494,6 @@ int futurerestore::doRestore(const char *ipsw, bool noerase){
error:
safeFree(client->sepfwdata);
safePlistFree(buildmanifest);
safePlistFree(sepbuildmanifest);
safePlistFree(basebandbuildmanifest);
safePlistFree(build_identity);
safePlistFree(sep_build_identity);
safePlistFree(bb_build_identity);
@ -520,6 +517,8 @@ futurerestore::~futurerestore(){
for (auto plist : _aptickets){
safePlistFree(plist);
}
safePlistFree(_sepbuildmanifest);
safePlistFree(_basebandbuildmanifest);
}
void futurerestore::loadFirmwareTokens(){
@ -590,16 +589,56 @@ void futurerestore::loadLatestBaseband(){
info("downloading Baseband\n\n");
if (downloadPartialzip(getLatestFirmwareUrl(), pathStr, _basebandPath = BASEBAND_TMP_PATH))
reterror(-32, "could not download baseband\n");
saveStringToFile(manifeststr, _basebandManifestPath = BASEBAND_MANIFEST_TMP_PATH);
saveStringToFile(manifeststr, BASEBAND_MANIFEST_TMP_PATH);
setBasebandManifestPath(BASEBAND_TMP_PATH);
}
void futurerestore::loadLatestSep(){
char * manifeststr = getLatestManifest();
char *pathStr = getPathOfElementInManifest("SEP", manifeststr, getDeviceModelNoCopy(), 0);
info("downloading SEP\n\n");
if (downloadPartialzip(getLatestFirmwareUrl(), pathStr, _sepPath = SEP_TMP_PATH))
if (downloadPartialzip(getLatestFirmwareUrl(), pathStr, SEP_TMP_PATH))
reterror(-33, "could not download SEP\n");
saveStringToFile(manifeststr, _sepManifestPath = SEP_MANIFEST_TMP_PATH);
loadSep(SEP_TMP_PATH);
saveStringToFile(manifeststr, SEP_MANIFEST_TMP_PATH);
setSepManifestPath(SEP_MANIFEST_TMP_PATH);
}
void futurerestore::setSepManifestPath(const char *sepManifestPath){
if (!(_sepbuildmanifest = loadPlistFromFile(sepManifestPath)))
reterror(-14, "failed to load SEPManifest");
}
void futurerestore::setBasebandManifestPath(const char *basebandManifestPath){
if (!(_basebandbuildmanifest = loadPlistFromFile(basebandManifestPath)))
reterror(-14, "failed to load BasebandManifest");
};
void futurerestore::loadSep(const char *sepPath){
FILE *fsep = fopen(sepPath, "r");
if (!fsep)
reterror(-15, "failed to read SEP\n");
fseek(fsep, 0, SEEK_END);
_client->sepfwdatasize = ftell(fsep);
fseek(fsep, 0, SEEK_SET);
if (!(_client->sepfwdata = (char*)malloc(_client->sepfwdatasize)))
reterror(-15, "failed to malloc memory for SEP\n");
if (fread(_client->sepfwdata, 1, _client->sepfwdatasize, fsep) != _client->sepfwdatasize)
reterror(-15, "failed to load SEP\n");
fclose(fsep);
}
void futurerestore::setBasebandPath(const char *basebandPath){
FILE *fbb = fopen(basebandPath, "r");
if (!fbb)
reterror(-15, "failed to read Baseband");
_basebandPath = basebandPath;
fclose(fbb);
}

View file

@ -15,6 +15,7 @@
#include <vector>
#include "idevicerestore.h"
#include "jsmn.h"
#include <plist/plist.h>
using namespace std;
@ -43,11 +44,10 @@ class futurerestore {
char *__latestManifest = NULL;
char *__latestFirmwareUrl = NULL;
const char *_sepManifestPath = NULL;
const char *_basebandManifestPath = NULL;
const char *_sepPath = NULL;
const char *_basebandPath = NULL;
plist_t _sepbuildmanifest = NULL;
plist_t _basebandbuildmanifest = NULL;
const char *_basebandPath;
public:
futurerestore();
@ -69,16 +69,15 @@ public:
void loadLatestBaseband();
void loadLatestSep();
void setSepManifestPath(const char *sepManifestPath){_sepManifestPath = sepManifestPath;};
void setBasebandManifestPath(const char *basebandManifestPath){_basebandManifestPath = basebandManifestPath;};
void setSepPath(const char *sepPath){_sepPath = sepPath;};
void setBasebandPath(const char *basebandPath){_basebandPath = basebandPath;};
void setSepManifestPath(const char *sepManifestPath);
void setBasebandManifestPath(const char *basebandManifestPath);
void loadSep(const char *sepPath);
void setBasebandPath(const char *basebandPath);
const char *sepManifestPath(){return _sepManifestPath;};
const char *basebandManifestPath(){return _basebandManifestPath;};
const char *sepPath(){return _sepPath;};
const char *basebandPath(){return _basebandPath;};
plist_t sepManifest(){return _sepbuildmanifest;};
plist_t basebandManifest(){return _basebandbuildmanifest;};
uint64_t getBasebandGoldCertIDFromDevice();

View file

@ -132,6 +132,14 @@ int main(int argc, const char * argv[]) {
argv += optind;
ipsw = argv[0];
}else{
error("argument parsing failed! agrc=%d optind=%d\n",argc,optind);
if (idevicerestore_debug){
for (int i=0; i<argc; i++) {
printf("argv[%d]=%s\n",i,argv[i]);
}
}
return -5;
}
futurerestore client;
@ -163,7 +171,7 @@ int main(int argc, const char * argv[]) {
info("user specified to use latest signed sep\n");
client.loadLatestSep();
}else{
client.setSepPath(sepPath);
client.loadSep(sepPath);
client.setSepManifestPath(sepManifestPath);
}
if (flags & FLAG_LATEST_BASEBAND){
@ -178,7 +186,7 @@ int main(int argc, const char * argv[]) {
versVals.basebandMode = kBasebandModeWithoutBaseband;
if (!(isSepManifestSigned = isManifestSignedForDevice(client.sepManifestPath(), &devVals, &versVals))){
if (!(isSepManifestSigned = isManifestSignedForDevice(sepManifestPath, &devVals, &versVals))){
reterror(-3,"sep firmware isn't signed\n");
}
@ -188,7 +196,7 @@ int main(int argc, const char * argv[]) {
printf("[WARNING] using tsschecker's fallback to get BasebandGoldCertID. This might result in invalid baseband signing status information\n");
}
}
if (!(isBasebandSigned = isManifestSignedForDevice(client.basebandManifestPath(), &devVals, &versVals))) {
if (!(isBasebandSigned = isManifestSignedForDevice(basebandManifestPath, &devVals, &versVals))) {
reterror(-3,"baseband firmware isn't signed\n");
}