summaryrefslogtreecommitdiff
path: root/include/librfid/rfid_reader.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/librfid/rfid_reader.h')
-rw-r--r--include/librfid/rfid_reader.h67
1 files changed, 67 insertions, 0 deletions
diff --git a/include/librfid/rfid_reader.h b/include/librfid/rfid_reader.h
new file mode 100644
index 0000000..3581cc1
--- /dev/null
+++ b/include/librfid/rfid_reader.h
@@ -0,0 +1,67 @@
+#ifndef _RFID_READER_H
+#define _RFID_READER_H
+
+#include <librfid/rfid_asic.h>
+#include <librfid/rfid_layer2_iso14443a.h>
+
+struct rfid_reader_handle;
+
+struct rfid_reader {
+ char *name;
+ unsigned int id;
+ int (*transcieve)(struct rfid_reader_handle *h,
+ enum rfid_frametype frametype,
+ const unsigned char *tx_buf, unsigned int tx_len,
+ unsigned char *rx_buf, unsigned int *rx_len,
+ u_int64_t timeout, unsigned int flags);
+ struct rfid_reader_handle * (*open)(void *data);
+ void (*close)(struct rfid_reader_handle *h);
+
+ struct rfid_14443a_reader {
+ int (*init)(struct rfid_reader_handle *h);
+ int (*transcieve_sf)(struct rfid_reader_handle *h,
+ unsigned char cmd,
+ struct iso14443a_atqa *atqa);
+ int (*transcieve_acf)(struct rfid_reader_handle *h,
+ struct iso14443a_anticol_cmd *cmd,
+ unsigned int *bit_of_col);
+ int (*set_speed)(struct rfid_reader_handle *h,
+ unsigned int tx,
+ unsigned int speed);
+ unsigned int speed;
+ } iso14443a;
+ struct rfid_14443b_reader {
+ int (*init)(struct rfid_reader_handle *rh);
+ unsigned int speed;
+ } iso14443b;
+ struct rfid_15693_reader {
+ int (*init)(struct rfid_reader_handle *rh);
+ } iso15693;
+ struct rfid_mifare_classic_reader {
+ int (*setkey)(struct rfid_reader_handle *h, unsigned char *key);
+ int (*auth)(struct rfid_reader_handle *h, u_int8_t cmd,
+ u_int32_t serno, u_int8_t block);
+ } mifare_classic;
+ struct rfid_reader *next;
+};
+
+enum rfid_reader_id {
+ RFID_READER_CM5121,
+ RFID_READER_PEGODA,
+};
+
+struct rfid_reader_handle {
+ struct rfid_asic_handle *ah;
+
+ union {
+
+ } priv;
+ struct rfid_reader *reader;
+};
+
+
+extern struct rfid_reader_handle *
+rfid_reader_open(void *data, unsigned int id);
+
+extern void rfid_reader_close(struct rfid_reader_handle *rh);
+#endif
personal git repositories of Harald Welte. Your mileage may vary