From 5d9d373a959271b498710817d08c2ea8e153aa6e Mon Sep 17 00:00:00 2001 From: Yves Fischer Date: Thu, 13 Oct 2011 20:33:30 +0200 Subject: correct firmware?? --- firmware/spi.c | 190 +++++++++++++++++++-------------------------------------- 1 file changed, 62 insertions(+), 128 deletions(-) (limited to 'firmware/spi.c') diff --git a/firmware/spi.c b/firmware/spi.c index b3e3a95..2b8abb1 100644 --- a/firmware/spi.c +++ b/firmware/spi.c @@ -36,24 +36,26 @@ #include "spi.h" - void spi_parser(char *buf) { switch(buf[0]) { case CMD_SPI_INIT: - spi_init_usb(buf[2], buf[3], buf[4]); - break; + spi_init_usb(); + break; case CMD_SPI_DEINIT: spi_deinit_usb(); - break; + break; + case CMD_SPI_SPEED: + spi_set_speed_usb((int)buf[2]); + break; case CMD_SPI_SEND: - spi_send_usb(buf[2], &buf[3]); - break; + spi_send_usb(&buf[2], (int)buf[1]); + break; case CMD_SPI_RECV: - spi_receive_usb((int)buf[2]); + spi_receive_usb((int)buf[1]); case CMD_SPI_SEND_AND_RECV: - spi_send_and_receive_usb(&buf[3], (int)buf[2]); - break; + spi_send_and_receive_usb(&buf[2], (int)buf[1]); + break; default: answer[0] = buf[0]; answer[1] = RSP_UNKOWN_CMD; @@ -62,111 +64,38 @@ void spi_parser(char *buf) } } -void spi_init_usb(uint8_t dord, uint8_t mode, uint8_t speed) +void spi_init_usb(void) { answer[0] = CMD_SPI_INIT; - answer[1] = (unsigned char) spi_init(dord, mode, speed); - answer[2] = 0; + answer[1] = (unsigned char) spi_init(); + answer[3] = 0; CommandAnswer(3); } -int spi_init(uint8_t dord, uint8_t mode, uint8_t speed) +int spi_init(void) { - uint8_t cpol, cpha, spr1, spr0, spi2x; - - dord = dord ? 1 : 0; - - switch(mode) - { - case 0: - cpol = 0; - cpha = 0; - break; - case 1: - cpol = 0; - cpha = 1; - break; - case 2: - cpol = 1; - cpha = 0; - break; - case 3: - cpol = 1; - cpha = 1; - break; - default: - return RSP_ERROR; - } - - switch(speed) - { - case SPI_SPEED_125kHz: - spi2x = 0; - spr1 = 1; - spr0 = 1; - break; - case SPI_SPEED_250kHz: - spi2x = 0; - spr1 = 1; - spr0 = 0; - break; - case SPI_SPEED_500kHz: - spi2x = 1; - spr1 = 1; - spr0 = 0; - break; - case SPI_SPEED_1MHz: - spi2x = 0; - spr1 = 0; - spr0 = 1; - break; - case SPI_SPEED_2MHz: - spi2x = 1; - spr1 = 0; - spr0 = 1; - break; - case SPI_SPEED_4MHz: - spi2x = 0; - spr1 = 0; - spr0 = 0; - break; - case SPI_SPEED_8MHz: - spi2x = 1; - spr1 = 0; - spr0 = 0; - break; - default: - return RSP_ERROR; - } + PORTB &= ~((1 << SCK)|(1< 1000) - return RSP_TIMEOUT; - } - buf[i] = SPDR; + while(!(SPSR & (1 << SPIF))) { timeout++; if( timeout > 1000) return RSP_TIMEOUT; } + buf[i]=SPDR; } - return RSP_OK; } @@ -236,8 +164,8 @@ void spi_send_and_receive_usb(char * txbuf, int length) { answer[0]=CMD_SPI_SEND; answer[1]=(unsigned char)spi_send_and_receive(txbuf,(char *)&answer[2],length); - answer[2+length]=0; - CommandAnswer(3+length); + answer[2]=0; + CommandAnswer(2+length); } @@ -252,3 +180,9 @@ int spi_send_and_receive(char * txbuf, char * rxbuf, int length){ } return RSP_OK; } + + + + + + -- cgit v1.2.1