diff options
| author | 2012-07-17 16:52:33 +0200 | |
|---|---|---|
| committer | 2012-07-17 16:52:33 +0200 | |
| commit | 45dc110c6b923a8d9c4e79ab7667a13726c50699 (patch) | |
| tree | 1120b38f461684bf556918beea7d2675e7968ce0 /src | |
| parent | 7585007e35ab84750f8ace8e1cc43f6b53c75c38 (diff) | |
| download | idevicerestore-45dc110c6b923a8d9c4e79ab7667a13726c50699.tar.gz idevicerestore-45dc110c6b923a8d9c4e79ab7667a13726c50699.tar.bz2 | |
mbn: Correctly calculate offset for signature
Diffstat (limited to 'src')
| -rw-r--r-- | src/mbn.c | 7 | 
1 files changed, 1 insertions, 6 deletions
| @@ -37,7 +37,6 @@ mbn_file* mbn_parse(unsigned char* data, unsigned int size)  	/* FIXME: header parsing is not big endian safe */  	memcpy(&mbn->header, data, sizeof(mbn_header));  	mbn->parsed_size = mbn->header.data_size + sizeof(mbn_header); -	mbn->parsed_sig_offset = mbn->header.sig_offset - (mbn->header.data_size & 0xFF);  	if (mbn->parsed_size != mbn->size) {  		printf("size mismatch?!\n");  	} @@ -56,15 +55,11 @@ void mbn_free(mbn_file* mbn)  int mbn_update_sig_blob(mbn_file* mbn, const unsigned char* sigdata, unsigned int siglen)  { +	mbn->parsed_sig_offset = mbn->parsed_size - siglen;  	if (!mbn) {  		error("ERROR: %s: no data\n", __func__);  		return -1;  	} -	if (!mbn->parsed_sig_offset || (mbn->parsed_sig_offset >= mbn->parsed_size)) { -		error("ERROR: %s: invalid signature offset in mbn header\n", __func__); -		return -1; -	} -  	if ((mbn->parsed_sig_offset + siglen) > mbn->parsed_size) {  		error("ERROR: %s: signature is larger than mbn file size\n", __func__);  		return -1; | 
