summaryrefslogtreecommitdiffstats
path: root/dev/afccheck.c
diff options
context:
space:
mode:
Diffstat (limited to 'dev/afccheck.c')
-rw-r--r--dev/afccheck.c133
1 files changed, 133 insertions, 0 deletions
diff --git a/dev/afccheck.c b/dev/afccheck.c
new file mode 100644
index 0000000..028110a
--- /dev/null
+++ b/dev/afccheck.c
@@ -0,0 +1,133 @@
+/*
+ * afccheck.c
+ * creates threads and check communication through AFC is done rigth
+ *
+ * Copyright (c) 2008 Jonathan Beck All Rights Reserved.
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+#include <stdio.h>
+#include <string.h>
+#include <glib.h>
+
+#include <libiphone/libiphone.h>
+
+#define BUFFER_SIZE 20000
+#define NB_THREADS 10
+
+
+typedef struct {
+ iphone_afc_client_t afc;
+ int id;
+} param;
+
+
+void check_afc(gpointer data)
+{
+ //prepare a buffer
+ int buffersize = BUFFER_SIZE * sizeof(int);
+ int *buf = (int *) malloc(buffersize);
+ int *buf2 = (int *) malloc(buffersize);
+ int bytes = 0;
+ //fill buffer
+ int i = 0;
+ for (i = 0; i < BUFFER_SIZE; i++) {
+ buf[i] = ((param *) data)->id * i;
+ }
+
+ //now writes buffer on iphone
+ iphone_afc_file_t file = NULL;
+ char path[50];
+ sprintf(path, "/Buf%i", ((param *) data)->id);
+ iphone_afc_open_file(((param *) data)->afc, path, IPHONE_AFC_FILE_WRITE, &file);
+ iphone_afc_write_file(((param *) data)->afc, file, (char *) buf, buffersize, &bytes);
+ iphone_afc_close_file(((param *) data)->afc, file);
+ file = NULL;
+ if (bytes != buffersize)
+ printf("Write operation failed\n");
+
+ //now read it
+ bytes = 0;
+ iphone_afc_open_file(((param *) data)->afc, path, IPHONE_AFC_FILE_READ, &file);
+ iphone_afc_read_file(((param *) data)->afc, file, (char *) buf2, buffersize, &bytes);
+ iphone_afc_close_file(((param *) data)->afc, file);
+ if (bytes != buffersize)
+ printf("Read operation failed\n");
+
+ //compare buffers
+ for (i = 0; i < BUFFER_SIZE; i++) {
+ if (buf[i] != buf2[i]) {
+ printf("Buffers are differents, stream corrupted\n");
+ break;
+ }
+ }
+
+ //cleanup
+ iphone_afc_delete_file(((param *) data)->afc, path);
+ g_thread_exit(0);
+}
+
+int main(int argc, char *argv[])
+{
+ iphone_lckd_client_t control = NULL;
+ iphone_device_t phone = NULL;
+ GError *err;
+ int port = 0;
+ iphone_afc_client_t afc = NULL;
+
+ if (IPHONE_E_SUCCESS != iphone_get_device(&phone)) {
+ printf("No iPhone found, is it plugged in?\n");
+ return 1;
+ }
+
+ if (IPHONE_E_SUCCESS != iphone_lckd_new_client(phone, &control)) {
+ iphone_free_device(phone);
+ return 1;
+ }
+
+ if (IPHONE_E_SUCCESS == iphone_lckd_start_service(control, "com.apple.afc", &port) && !port) {
+ iphone_lckd_free_client(control);
+ iphone_free_device(phone);
+ fprintf(stderr, "Something went wrong when starting AFC.");
+ return 1;
+ }
+
+ iphone_afc_new_client(phone, 3432, port, &afc);
+
+ //makes sure thread environment is available
+ if (!g_thread_supported())
+ g_thread_init(NULL);
+
+ GThread *threads[NB_THREADS];
+ param data[NB_THREADS];
+
+ int i = 0;
+ for (i = 0; i < NB_THREADS; i++) {
+ data[i].afc = afc;
+ data[i].id = i + 1;
+ threads[i] = g_thread_create((GThreadFunc) check_afc, data + i, TRUE, &err);
+ }
+
+ for (i = 0; i < NB_THREADS; i++) {
+ g_thread_join(threads[i]);
+ }
+
+
+ iphone_lckd_free_client(control);
+ iphone_free_device(phone);
+
+ return 0;
+}