sniff mode: handle USART 1 RX interrupt to show sniffer data

This commit is contained in:
Kévin Redon
2018-06-06 16:13:48 +02:00
parent baff8d2c22
commit aa70887ce0
3 changed files with 36 additions and 2 deletions

View File

@@ -54,6 +54,7 @@ static const conf_func config_func_ptrs[] = {
.init = Sniffer_init, .init = Sniffer_init,
.exit = Sniffer_exit, .exit = Sniffer_exit,
.run = Sniffer_run, .run = Sniffer_run,
.usart1_irq = Sniffer_usart1_irq,
}, },
#endif #endif
#ifdef HAVE_CCID #ifdef HAVE_CCID

View File

@@ -108,6 +108,8 @@ extern void CCID_run( void );
extern void mode_cardemu_run(void); extern void mode_cardemu_run(void);
extern void MITM_run( void ); extern void MITM_run( void );
/* IRQ functions */
extern void Sniffer_usart1_irq(void);
extern void mode_cardemu_usart0_irq(void); extern void mode_cardemu_usart0_irq(void);
extern void mode_cardemu_usart1_irq(void); extern void mode_cardemu_usart1_irq(void);

View File

@@ -58,7 +58,7 @@ static const Pin pPwr[] = {
/* Enable power converter 4.5-6V to 3.3V; low: off */ /* Enable power converter 4.5-6V to 3.3V; low: off */
{SIM_PWEN, PIOA, ID_PIOA, PIO_OUTPUT_0, PIO_DEFAULT}, {SIM_PWEN, PIOA, ID_PIOA, PIO_OUTPUT_0, PIO_DEFAULT},
/* Enable second power converter: VCC_PHONE to VCC_SIM; high: on */ /* Enable power forwarding: VCC_PHONE to VCC_SIM; high: on */
{VCC_FWD, PIOA, ID_PIOA, PIO_OUTPUT_1, PIO_DEFAULT} {VCC_FWD, PIOA, ID_PIOA, PIO_OUTPUT_1, PIO_DEFAULT}
}; };
@@ -68,10 +68,37 @@ static struct Usart_info usart_info = {
.state = USART_RCV, .state = USART_RCV,
}; };
/* Ring buffer to store sniffer communication data */
static struct ringbuf sniff_buffer;
/*------------------------------------------------------------------------------
* Global functions
*------------------------------------------------------------------------------*/
void Sniffer_usart1_irq(void)
{
/* Read channel status register */
uint32_t csr = usart_info.base->US_CSR & usart_info.base->US_IMR;
/* Verify if character has been received */
if (csr & US_CSR_RXRDY) {
/* Read communication data byte between phone and SIM */
uint8_t byte = usart_info.base->US_RHR;
/* Store sniffed data into buffer (also clear interrupt */
rbuf_write(&sniff_buffer, byte);
}
}
/*------------------------------------------------------------------------------
* Internal functions
*------------------------------------------------------------------------------*/
int check_data_from_phone(void) int check_data_from_phone(void)
{ {
TRACE_INFO("check data from phone\n\r"); /* Display sniffed data */
while (!rbuf_is_empty(&sniff_buffer)) {
uint8_t byte = rbuf_read(&sniff_buffer);
TRACE_INFO_WP("0x%02x ", byte);
}
} }
/*----------------------------------------------------------------------------- /*-----------------------------------------------------------------------------
@@ -97,6 +124,10 @@ void Sniffer_exit(void)
void Sniffer_init(void) void Sniffer_init(void)
{ {
TRACE_INFO("Sniffer Init\n\r"); TRACE_INFO("Sniffer Init\n\r");
/* Clear ring buffer containing the sniffed data */
rbuf_reset(&sniff_buffer);
/* Configure ISO7816 driver */ /* Configure ISO7816 driver */
PIO_Configure(pinsISO7816_sniff, PIO_LISTSIZE(pinsISO7816_sniff)); PIO_Configure(pinsISO7816_sniff, PIO_LISTSIZE(pinsISO7816_sniff));
PIO_Configure(pins_bus, PIO_LISTSIZE(pins_bus)); PIO_Configure(pins_bus, PIO_LISTSIZE(pins_bus));