mirror of
https://github.com/tihmstar/futurerestore.git
synced 2025-01-24 07:00:58 +00:00
now using bbgcid from device instead of tsschecker's fallback
this should fix "baseband not signed" issue
This commit is contained in:
parent
49ed57c7ca
commit
b991cfa441
|
@ -225,6 +225,26 @@ void futurerestore::loadAPTickets(const vector<const char *> &apticketPaths){
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint64_t futurerestore::getBasebandGoldCertIDFromDevice(){
|
||||||
|
if (!_client->preflight_info){
|
||||||
|
normal_get_preflight_info(_client, &_client->preflight_info);
|
||||||
|
}
|
||||||
|
plist_t node;
|
||||||
|
node = plist_dict_get_item(_client->preflight_info, "CertID");
|
||||||
|
if (!node || plist_get_node_type(node) != PLIST_UINT) {
|
||||||
|
error("Unable to find required BbGoldCertId in parameters\n");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
uint64_t val = 0;
|
||||||
|
plist_get_uint_val(node, &val);
|
||||||
|
return val;
|
||||||
|
}
|
||||||
|
|
||||||
|
const char *futurerestore::getDeviceModelNoCopy(){
|
||||||
|
return _client->device->product_type;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
int futurerestore::doRestore(const char *ipsw, bool noerase){
|
int futurerestore::doRestore(const char *ipsw, bool noerase){
|
||||||
int err = 0;
|
int err = 0;
|
||||||
//some memory might not get freed if this function throws an exception, but you probably don't want to catch that anyway.
|
//some memory might not get freed if this function throws an exception, but you probably don't want to catch that anyway.
|
||||||
|
|
|
@ -80,6 +80,8 @@ public:
|
||||||
const char *sepPath(){return _sepPath;};
|
const char *sepPath(){return _sepPath;};
|
||||||
const char *basebandPath(){return _basebandPath;};
|
const char *basebandPath(){return _basebandPath;};
|
||||||
|
|
||||||
|
uint64_t getBasebandGoldCertIDFromDevice();
|
||||||
|
const char *getDeviceModelNoCopy();
|
||||||
|
|
||||||
int doRestore(const char *ipsw, bool noerase);
|
int doRestore(const char *ipsw, bool noerase);
|
||||||
|
|
||||||
|
|
|
@ -164,16 +164,21 @@ int main(int argc, const char * argv[]) {
|
||||||
client.setBasebandManifestPath(basebandManifestPath);
|
client.setBasebandManifestPath(basebandManifestPath);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
devVals.deviceModel = (char*)client.getDeviceModelNoCopy();
|
||||||
|
|
||||||
versVals.basebandMode = kBasebandModeWithoutBaseband;
|
versVals.basebandMode = kBasebandModeWithoutBaseband;
|
||||||
if (!(isSepManifestSigned = isManifestSignedForDevice(client.sepManifestPath(), NULL, &devVals, &versVals))){
|
if (!(isSepManifestSigned = isManifestSignedForDevice(client.sepManifestPath(), &devVals, &versVals))){
|
||||||
reterror(-3,"sep firmware isn't signed\n");
|
reterror(-3,"sep firmware isn't signed\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
versVals.basebandMode = kBasebandModeOnlyBaseband;
|
versVals.basebandMode = kBasebandModeOnlyBaseband;
|
||||||
if (!(isBasebandSigned = isManifestSignedForDevice(client.basebandManifestPath(), NULL, &devVals, &versVals))){
|
if ((devVals.bbgcid = client.getBasebandGoldCertIDFromDevice())){
|
||||||
|
if (!(isBasebandSigned = isManifestSignedForDevice(client.basebandManifestPath(), &devVals, &versVals))) {
|
||||||
reterror(-3,"baseband firmware isn't signed\n");
|
reterror(-3,"baseband firmware isn't signed\n");
|
||||||
}
|
}
|
||||||
|
}else{
|
||||||
|
reterror(-3,"unable to get bbgcid from device\n");
|
||||||
|
}
|
||||||
|
|
||||||
client.putDeviceIntoRecovery();
|
client.putDeviceIntoRecovery();
|
||||||
if (flags & FLAG_WAIT){
|
if (flags & FLAG_WAIT){
|
||||||
|
|
Loading…
Reference in a new issue