From 3491ef9c41f1cd867028881a8beebf1ad55373c7 Mon Sep 17 00:00:00 2001 From: Joshua Hill Date: Sun, 16 May 2010 14:15:26 -0400 Subject: Added irecv_set_configuration() and irecv_set_interface() functions and implemented bulk read --- include/libirecovery.h | 67 ++++++++++++++++++++++++++++---------------------- 1 file changed, 38 insertions(+), 29 deletions(-) (limited to 'include') diff --git a/include/libirecovery.h b/include/libirecovery.h index e3360f0..822d0e1 100644 --- a/include/libirecovery.h +++ b/include/libirecovery.h @@ -18,48 +18,57 @@ #include -#define IRECV_SUCCESS 0 -#define IRECV_ERROR_NO_DEVICE -1 -#define IRECV_ERROR_OUT_OF_MEMORY -2 -#define IRECV_ERROR_UNABLE_TO_CONNECT -3 -#define IRECV_ERROR_INVALID_INPUT -4 -#define IRECV_ERROR_UNKNOWN -5 -#define IRECV_ERROR_FILE_NOT_FOUND -6 -#define IRECV_ERROR_USB_UPLOAD -7 -#define IRECV_ERROR_USB_STATUS -8 +typedef enum { + IRECV_SUCCESS = 0, + IRECV_ERROR_NO_DEVICE = -1, + IRECV_ERROR_OUT_OF_MEMORY = -2, + IRECV_ERROR_UNABLE_TO_CONNECT = -3, + IRECV_ERROR_INVALID_INPUT = -4, + IRECV_ERROR_UNKNOWN = -5, + IRECV_ERROR_FILE_NOT_FOUND = -6, + IRECV_ERROR_USB_UPLOAD = -7, + IRECV_ERROR_USB_STATUS = -8, + IRECV_ERROR_USB_INTERFACE = -9, + IRECV_ERROR_USB_CONFIGURATION = -10 +} irecv_error_t; -enum { +typedef enum { kAppleId = 0x05AC, kKernelMode = 0x1294, kRecoveryMode = 0x1281, kDfuMode = 0x1227 -}; +} irecv_mode_t; struct irecv_device; typedef struct irecv_device irecv_device_t; -typedef int(*irecv_send_callback)(irecv_device_t* device, unsigned char* data, unsigned int size); -typedef int(*irecv_receive_callback)(irecv_device_t* device, unsigned char* data, unsigned int size); +typedef int(*irecv_send_callback)(irecv_device_t* device, unsigned char* data, int size); +typedef int(*irecv_receive_callback)(irecv_device_t* device, unsigned char* data, int size); struct irecv_device { - unsigned int mode; - unsigned int debug; - struct libusb_context* context; - struct libusb_device_handle* handle; - irecv_receive_callback receive_callback; + int debug; + int config; + int interface; + int alt_interface; + irecv_mode_t mode; + libusb_context* context; + libusb_device_handle* handle; irecv_send_callback send_callback; + irecv_receive_callback receive_callback; }; irecv_device_t* irecv_init(); -int irecv_open(irecv_device_t* device); -int irecv_exit(irecv_device_t* device); -int irecv_reset(irecv_device_t* device); -int irecv_close(irecv_device_t* device); -void irecv_update(irecv_device_t* device); -void irecv_set_debug(irecv_device_t* device, int level); -int irecv_send_file(irecv_device_t* device, const char* filename); -int irecv_send_command(irecv_device_t* device, unsigned char* command); -int irecv_send_buffer(irecv_device_t* device, unsigned char* buffer, int length); -int irecv_set_sender(irecv_device_t* device, irecv_send_callback callback); -int irecv_set_receiver(irecv_device_t* device, irecv_receive_callback callback); +irecv_error_t irecv_open(irecv_device_t* device); +irecv_error_t irecv_exit(irecv_device_t* device); +irecv_error_t irecv_reset(irecv_device_t* device); +irecv_error_t irecv_close(irecv_device_t* device); +irecv_error_t irecv_update(irecv_device_t* device); +irecv_error_t irecv_set_debug(irecv_device_t* device, int level); +irecv_error_t irecv_send_file(irecv_device_t* device, const char* filename); +irecv_error_t irecv_send_command(irecv_device_t* device, unsigned char* command); +irecv_error_t irecv_set_configuration(irecv_device_t* device, int configuration); +irecv_error_t irecv_set_sender(irecv_device_t* device, irecv_send_callback callback); +irecv_error_t irecv_set_receiver(irecv_device_t* device, irecv_receive_callback callback); +irecv_error_t irecv_set_interface(irecv_device_t* device, int interface, int alt_interface); +irecv_error_t irecv_send_buffer(irecv_device_t* device, unsigned char* buffer, unsigned int length); -- cgit v1.1-32-gdbae