From a783671c72aa4b9fde5bf7a2af3bf11a7c876191 Mon Sep 17 00:00:00 2001 From: Othmar Gsenger Date: Wed, 6 Feb 2013 20:56:51 +0000 Subject: moved keystore and usb/serial to seperate files stdio_ptr might need some improvement git-svn-id: https://svn.spreadspace.org/avr/trunk@134 aa12f405-d877-488e-9caf-2d797e2a1cc7 --- usb-i2c-sl018/tuer-rfid.c | 217 +++++++--------------------------------------- 1 file changed, 30 insertions(+), 187 deletions(-) (limited to 'usb-i2c-sl018/tuer-rfid.c') diff --git a/usb-i2c-sl018/tuer-rfid.c b/usb-i2c-sl018/tuer-rfid.c index 7beccb0..6823c71 100644 --- a/usb-i2c-sl018/tuer-rfid.c +++ b/usb-i2c-sl018/tuer-rfid.c @@ -25,6 +25,8 @@ #include #include #include +#include +#include "LUFA/Drivers/Peripheral/TWI.h" #include #include @@ -36,127 +38,11 @@ #include "stepper.h" #include "ledmatrix.h" #include "sl018.h" - -#include "LUFA/Drivers/Peripheral/TWI.h" -#include "LUFA/Drivers/Peripheral/Serial.h" -#include "LUFA/Drivers/Misc/RingBuffer.h" - -#include -#define EEPROM_SIZE 1024 -typedef uint8_t keyslot_t[8]; -keyslot_t EEMEM keystore[EEPROM_SIZE/sizeof(keyslot_t)]; - -FILE usb_stream; -FILE serial_stream; -FILE * stdio = &serial_stream; - -/* - LUFA Library - Copyright (C) Dean Camera, 2012. - - dean [at] fourwalledcubicle [dot] com - www.lufa-lib.org -*/ +#include "keystore.h" +#include "usb_serial.h" +FILE * * stdio_ptr = NULL; -#include -#include "lufa-descriptor-usbserial.h" - -USB_ClassInfo_CDC_Device_t VirtualSerial_CDC_Interface = - { - .Config = - { - .ControlInterfaceNumber = 0, - - .DataINEndpointNumber = CDC_TX_EPNUM, - .DataINEndpointSize = CDC_TXRX_EPSIZE, - .DataINEndpointDoubleBank = false, - - .DataOUTEndpointNumber = CDC_RX_EPNUM, - .DataOUTEndpointSize = CDC_TXRX_EPSIZE, - .DataOUTEndpointDoubleBank = false, - - .NotificationEndpointNumber = CDC_NOTIFICATION_EPNUM, - .NotificationEndpointSize = CDC_NOTIFICATION_EPSIZE, - .NotificationEndpointDoubleBank = false, - }, - }; - -void EVENT_USB_Device_ConfigurationChanged(void) -{ - CDC_Device_ConfigureEndpoints(&VirtualSerial_CDC_Interface); -} - -void EVENT_USB_Device_ControlRequest(void) -{ - CDC_Device_ProcessControlRequest(&VirtualSerial_CDC_Interface); -} - -void EVENT_CDC_Device_ControLineStateChanged(USB_ClassInfo_CDC_Device_t* const CDCInterfaceInfo) -{ - if(CDCInterfaceInfo->State.ControlLineStates.HostToDevice & CDC_CONTROL_LINE_OUT_DTR) - stdio = &usb_stream; - else - stdio = &serial_stream; -} - -void EVENT_USB_Device_Disconnect(void) -{ - stdio = &serial_stream; -} -/* end LUFA CDC-ACM specific definitions*/ - - - -int16_t stdio_bytes_received(void) -{ - if(stdio == &usb_stream) - return CDC_Device_BytesReceived(&VirtualSerial_CDC_Interface); - else - return (int16_t)Serial_IsCharReceived(); -} - - -void flash_keystore_from_stdio(void) -{ - keyslot_t ks; - uint8_t byte_pos=0; - fprintf(stdio,"Flashing keys:\n\r"); - fflush(stdio); - for(uint8_t ks_pos=0;ks_pos 0) { - ks[byte_pos++]=fgetc(stdio); - bytes_received--; - if (byte_pos == sizeof(ks)) { - byte_pos=0; - eeprom_update_block(&ks,&keystore[ks_pos],sizeof(ks)); - ks_pos++; - fputc('.', stdio); - fflush(stdio); - led_toggle(); - } - } - } - fprintf(stdio,"\n"); - fputc(0, stdio); - led_off(); -} - -void dump_keystore_to_stdio(void) -{ - keyslot_t ks; - for(uint8_t ks_pos=0;ks_pos 0) - handle_stdio(fgetc(stdio)); + handle_stdio(fgetc(*stdio_ptr)); - if (sl018_check_for_new_card(stdio)) + if (sl018_check_for_new_card(*stdio_ptr)) handle_card(); handle_heartbeat(); } -- cgit v1.2.3