Christina Quast | c0aa769 | 2015-02-25 14:02:01 +0100 | [diff] [blame] | 1 | #ifndef SIMTRACE_H |
| 2 | #define SIMTRACE_H |
Christina Quast | 32906bb | 2015-02-24 11:35:19 +0100 | [diff] [blame] | 3 | |
Christina Quast | 4db82e0 | 2015-04-11 18:14:41 +0200 | [diff] [blame] | 4 | #include "ringbuffer.h" |
Harald Welte | 1605564 | 2016-03-03 11:02:45 +0100 | [diff] [blame] | 5 | #include "board.h" |
Christina Quast | 4db82e0 | 2015-04-11 18:14:41 +0200 | [diff] [blame] | 6 | |
Christina Quast | 4ba4d22 | 2015-03-02 16:14:09 +0100 | [diff] [blame] | 7 | /* Endpoint numbers */ |
| 8 | #define DATAOUT 1 |
| 9 | #define DATAIN 2 |
| 10 | #define INT 3 |
| 11 | |
Christina Quast | 235409a | 2015-06-24 16:05:09 +0200 | [diff] [blame] | 12 | #define BUFLEN 512 |
Christina Quast | 7123425 | 2015-04-03 11:35:59 +0200 | [diff] [blame] | 13 | |
Christina Quast | b65b881 | 2015-04-04 10:51:37 +0200 | [diff] [blame] | 14 | #define PHONE_DATAOUT 4 |
| 15 | #define PHONE_DATAIN 5 |
| 16 | #define PHONE_INT 6 |
Christina Quast | 7123425 | 2015-04-03 11:35:59 +0200 | [diff] [blame] | 17 | |
Harald Welte | 57b3a25 | 2016-03-02 15:20:27 +0100 | [diff] [blame] | 18 | #define CARDEM_USIM2_DATAOUT DATAOUT |
| 19 | #define CARDEM_USIM2_DATAIN DATAIN |
| 20 | #define CARDEM_USIM2_INT INT |
| 21 | |
Christina Quast | ec9c09e | 2015-04-16 10:45:39 +0200 | [diff] [blame] | 22 | #define CLK_MASTER true |
| 23 | #define CLK_SLAVE false |
| 24 | |
| 25 | /* ===================================================*/ |
| 26 | /* Taken from iso7816_4.c */ |
| 27 | /* ===================================================*/ |
| 28 | /** Flip flop for send and receive char */ |
| 29 | #define USART_SEND 0 |
| 30 | #define USART_RCV 1 |
| 31 | |
Christina Quast | 3eab56e | 2015-04-10 15:38:49 +0200 | [diff] [blame] | 32 | |
Christina Quast | 4db82e0 | 2015-04-11 18:14:41 +0200 | [diff] [blame] | 33 | extern volatile ringbuf sim_rcv_buf; |
Christina Quast | 95d6616 | 2015-04-09 22:38:47 +0200 | [diff] [blame] | 34 | |
| 35 | extern volatile bool rcvdChar; |
| 36 | extern volatile uint32_t char_stat; |
Christina Quast | 4ba4d22 | 2015-03-02 16:14:09 +0100 | [diff] [blame] | 37 | |
Christina Quast | e4cbfe6 | 2015-04-20 13:07:28 +0200 | [diff] [blame] | 38 | extern const Pin pinPhoneRST; |
| 39 | |
Christina Quast | 10b2e5a | 2015-02-25 18:40:15 +0100 | [diff] [blame] | 40 | enum confNum { |
Harald Welte | 1605564 | 2016-03-03 11:02:45 +0100 | [diff] [blame] | 41 | CFG_NUM_NONE = 0, |
| 42 | #ifdef HAVE_SNIFFER |
| 43 | CFG_NUM_SNIFF, |
| 44 | #endif |
| 45 | #ifdef HAVE_CCID |
| 46 | CFG_NUM_CCID, |
| 47 | #endif |
| 48 | #ifdef HAVE_CARDEM |
| 49 | CFG_NUM_PHONE, |
| 50 | #endif |
| 51 | #ifdef HAVE_MITM |
| 52 | CFG_NUM_MITM, |
| 53 | #endif |
| 54 | NUM_CONF |
Christina Quast | 10b2e5a | 2015-02-25 18:40:15 +0100 | [diff] [blame] | 55 | }; |
| 56 | |
Christina Quast | db7b1ab | 2015-03-03 12:34:36 +0100 | [diff] [blame] | 57 | /// CCIDDriverConfiguration Descriptors |
| 58 | /// List of descriptors that make up the configuration descriptors of a |
| 59 | /// device using the CCID driver. |
| 60 | typedef struct { |
| 61 | |
| 62 | /// Configuration descriptor |
| 63 | USBConfigurationDescriptor configuration; |
| 64 | /// Interface descriptor |
| 65 | USBInterfaceDescriptor interface; |
| 66 | /// CCID descriptor |
| 67 | CCIDDescriptor ccid; |
| 68 | /// Bulk OUT endpoint descriptor |
| 69 | USBEndpointDescriptor bulkOut; |
| 70 | /// Bulk IN endpoint descriptor |
| 71 | USBEndpointDescriptor bulkIn; |
| 72 | /// Interrupt OUT endpoint descriptor |
| 73 | USBEndpointDescriptor interruptIn; |
| 74 | } __attribute__ ((packed)) CCIDDriverConfigurationDescriptors; |
| 75 | |
Christina Quast | 4b1e98d | 2015-04-06 23:28:02 +0200 | [diff] [blame] | 76 | extern const USBConfigurationDescriptor *configurationDescriptorsArr[]; |
| 77 | |
Christina Quast | 2b8a18b | 2015-04-12 09:31:36 +0200 | [diff] [blame] | 78 | int check_data_from_phone(); |
Christina Quast | cb646bc | 2015-05-03 14:21:26 +0200 | [diff] [blame] | 79 | void update_fidi(uint8_t fidi); |
Christina Quast | be23527 | 2015-05-02 17:56:32 +0200 | [diff] [blame] | 80 | |
Christina Quast | e4cbfe6 | 2015-04-20 13:07:28 +0200 | [diff] [blame] | 81 | void ISR_PhoneRST( const Pin *pPin); |
Christina Quast | db7b1ab | 2015-03-03 12:34:36 +0100 | [diff] [blame] | 82 | |
Christina Quast | 95d6616 | 2015-04-09 22:38:47 +0200 | [diff] [blame] | 83 | /* Configure functions */ |
| 84 | extern void Sniffer_configure( void ); |
| 85 | extern void CCID_configure( void ); |
Harald Welte | 2a6d3af | 2016-02-28 19:29:14 +0100 | [diff] [blame] | 86 | extern void mode_cardemu_configure(void); |
Christina Quast | 95d6616 | 2015-04-09 22:38:47 +0200 | [diff] [blame] | 87 | extern void MITM_configure( void ); |
| 88 | |
Christina Quast | 1edf350 | 2015-02-27 13:33:52 +0100 | [diff] [blame] | 89 | /* Init functions */ |
Christina Quast | 95d6616 | 2015-04-09 22:38:47 +0200 | [diff] [blame] | 90 | extern void Sniffer_init( void ); |
Christina Quast | db7b1ab | 2015-03-03 12:34:36 +0100 | [diff] [blame] | 91 | extern void CCID_init( void ); |
Harald Welte | 2a6d3af | 2016-02-28 19:29:14 +0100 | [diff] [blame] | 92 | extern void mode_cardemu_init(void); |
Christina Quast | 1edf350 | 2015-02-27 13:33:52 +0100 | [diff] [blame] | 93 | extern void MITM_init( void ); |
Christina Quast | 27c643d | 2015-02-24 19:09:08 +0100 | [diff] [blame] | 94 | |
Christina Quast | c0aa769 | 2015-02-25 14:02:01 +0100 | [diff] [blame] | 95 | extern void SIMtrace_USB_Initialize( void ); |
Christina Quast | c0aa769 | 2015-02-25 14:02:01 +0100 | [diff] [blame] | 96 | |
Christina Quast | 95d6616 | 2015-04-09 22:38:47 +0200 | [diff] [blame] | 97 | /* Exit functions */ |
| 98 | extern void Sniffer_exit( void ); |
| 99 | extern void CCID_exit( void ); |
Harald Welte | 2a6d3af | 2016-02-28 19:29:14 +0100 | [diff] [blame] | 100 | extern void mode_cardemu_exit(void); |
Christina Quast | 95d6616 | 2015-04-09 22:38:47 +0200 | [diff] [blame] | 101 | extern void MITM_exit( void ); |
| 102 | |
Christina Quast | 1edf350 | 2015-02-27 13:33:52 +0100 | [diff] [blame] | 103 | /* Run functions */ |
| 104 | extern void Sniffer_run( void ); |
Christina Quast | db7b1ab | 2015-03-03 12:34:36 +0100 | [diff] [blame] | 105 | extern void CCID_run( void ); |
Harald Welte | 2a6d3af | 2016-02-28 19:29:14 +0100 | [diff] [blame] | 106 | extern void mode_cardemu_run(void); |
Christina Quast | 1edf350 | 2015-02-27 13:33:52 +0100 | [diff] [blame] | 107 | extern void MITM_run( void ); |
| 108 | |
Harald Welte | 3bafe43 | 2016-03-20 16:43:12 +0100 | [diff] [blame] | 109 | extern void mode_cardemu_usart0_irq(void); |
| 110 | extern void mode_cardemu_usart1_irq(void); |
| 111 | |
Christina Quast | 531d10b | 2015-03-19 19:27:04 +0100 | [diff] [blame] | 112 | /* Timer helper function */ |
| 113 | void Timer_Init( void ); |
| 114 | void TC0_Counter_Reset( void ); |
| 115 | |
Harald Welte | 54cb3d0 | 2016-02-29 14:12:40 +0100 | [diff] [blame] | 116 | struct llist_head; |
| 117 | int usb_refill_to_host(struct llist_head *queue, uint32_t ep); |
| 118 | int usb_refill_from_host(struct llist_head *queue, int ep); |
Harald Welte | 2a6d3af | 2016-02-28 19:29:14 +0100 | [diff] [blame] | 119 | |
Christina Quast | 1edf350 | 2015-02-27 13:33:52 +0100 | [diff] [blame] | 120 | #endif /* SIMTRACE_H */ |