summaryrefslogtreecommitdiffstats
path: root/src/dfu.c
diff options
context:
space:
mode:
authorGravatar Nikias Bassen2012-02-05 22:38:10 +0100
committerGravatar Nikias Bassen2012-02-05 22:38:10 +0100
commit99158d9fd32a4a7961bea09e78ab249c2c3752c9 (patch)
tree81984f39997b22a6cc9f92896452b38a3f786aa0 /src/dfu.c
parent38d2408e87fe026df316067766ad5328d4284390 (diff)
downloadidevicerestore-99158d9fd32a4a7961bea09e78ab249c2c3752c9.tar.gz
idevicerestore-99158d9fd32a4a7961bea09e78ab249c2c3752c9.tar.bz2
add support for 0x1222 wtf mode
Diffstat (limited to 'src/dfu.c')
-rw-r--r--src/dfu.c45
1 files changed, 43 insertions, 2 deletions
diff --git a/src/dfu.c b/src/dfu.c
index b044fa6..3e88a1d 100644
--- a/src/dfu.c
+++ b/src/dfu.c
@@ -83,7 +83,7 @@ void dfu_client_free(struct idevicerestore_client_t* client) {
}
}
-int dfu_check_mode() {
+int dfu_check_mode(int* mode) {
irecv_client_t dfu = NULL;
irecv_error_t dfu_error = IRECV_E_SUCCESS;
@@ -94,16 +94,40 @@ int dfu_check_mode() {
return -1;
}
- if (dfu->mode != kDfuMode) {
+ if ((dfu->mode != kDfuMode) && (dfu->mode != kWTFMode)) {
irecv_close(dfu);
return -1;
}
+ *mode = (dfu->mode == kWTFMode) ? MODE_WTF : MODE_DFU;
+
irecv_close(dfu);
return 0;
}
+int dfu_send_buffer(struct idevicerestore_client_t* client, char* buffer, uint32_t size)
+{
+ irecv_error_t error = 0;
+
+ info("Sending data (%d bytes)...\n", size);
+
+ error = irecv_send_buffer(client->dfu->client, buffer, size, 1);
+ if (error != IRECV_E_SUCCESS) {
+ error("ERROR: Unable to send data: %s\n", irecv_strerror(error));
+ return -1;
+ }
+
+ error = irecv_reset(client->dfu->client);
+ if (error != IRECV_E_SUCCESS) {
+ error("ERROR: Unable to reset device\n");
+ irecv_close(client->dfu->client);
+ return -1;
+ }
+
+ return 0;
+}
+
int dfu_send_component(struct idevicerestore_client_t* client, plist_t build_identity, const char* component) {
uint32_t size = 0;
char* data = NULL;
@@ -170,6 +194,23 @@ int dfu_send_component(struct idevicerestore_client_t* client, plist_t build_ide
return 0;
}
+int dfu_get_cpid(struct idevicerestore_client_t* client, unsigned int* cpid) {
+ irecv_error_t dfu_error = IRECV_E_SUCCESS;
+
+ if(client->dfu == NULL) {
+ if (dfu_client_new(client) < 0) {
+ return -1;
+ }
+ }
+
+ dfu_error = irecv_get_cpid(client->dfu->client, cpid);
+ if (dfu_error != IRECV_E_SUCCESS) {
+ return -1;
+ }
+
+ return 0;
+}
+
int dfu_get_nonce(struct idevicerestore_client_t* client, unsigned char** nonce, int* nonce_size) {
irecv_error_t dfu_error = IRECV_E_SUCCESS;