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