summaryrefslogtreecommitdiff
path: root/rfid_reader_cm5121_ccid_direct.c
diff options
context:
space:
mode:
authorlaforge <laforge@e0336214-984f-0b4b-a45f-81c69e1f0ede>2005-10-29 20:42:34 +0000
committerlaforge <laforge@e0336214-984f-0b4b-a45f-81c69e1f0ede>2005-10-29 20:42:34 +0000
commitcf4cccb614340081eb690ca19676477794ee5b9c (patch)
treeb5ef955df029da4f3b344b55588b816c3e7282e4 /rfid_reader_cm5121_ccid_direct.c
parent2a35727abd8437bfa7dd22dfa08363b6c0ae1927 (diff)
Add support for native CCID driver, modularize OpenCT support (based on a patch from Werner Koch)
git-svn-id: https://svn.gnumonks.org/trunk/librfid@1597 e0336214-984f-0b4b-a45f-81c69e1f0ede
Diffstat (limited to 'rfid_reader_cm5121_ccid_direct.c')
-rw-r--r--rfid_reader_cm5121_ccid_direct.c40
1 files changed, 40 insertions, 0 deletions
diff --git a/rfid_reader_cm5121_ccid_direct.c b/rfid_reader_cm5121_ccid_direct.c
new file mode 100644
index 0000000..a88bd0b
--- /dev/null
+++ b/rfid_reader_cm5121_ccid_direct.c
@@ -0,0 +1,40 @@
+/* CM5121 backend for 'internal' CCID driver */
+#include <stdlib.h>
+#include <unistd.h>
+#include <stdio.h>
+
+#include <rfid/rfid_asic.h>
+
+#include "ccid/ccid-driver.h"
+
+/* FIXME: remove ugly global variables */
+static ccid_driver_t h;
+
+/* this is the sole function required by rfid_reader_cm5121.c */
+int
+PC_to_RDR_Escape(void *handle,
+ const unsigned char *tx_buf, unsigned int tx_len,
+ unsigned char *rx_buf, unsigned int *rx_len)
+{
+ int rc;
+ ccid_driver_t ch = handle;
+ size_t maxrxlen = *rx_len;
+
+ rc = ccid_transceive_escape (ch, tx_buf, tx_len,
+ rx_buf, maxrxlen, rx_len);
+
+ return rc;
+}
+
+int cm5121_source_init(struct rfid_asic_transport_handle *rath)
+{
+ int rc;
+
+ rc = ccid_open_reader (&h, NULL);
+ if (rc) {
+ fprintf (stderr, "failed to open CCID reader: %#x\n", rc);
+ return -1;
+ }
+ rath->data = &h;
+ return 0;
+}
personal git repositories of Harald Welte. Your mileage may vary