X-Git-Url: http://git.rot13.org/?p=goodfet;a=blobdiff_plain;f=firmware%2Fapps%2Fspi%2Fspi.c;h=b552ae7617a8cbca64a554898fbfd767144b3ba7;hp=3da313539d8a9059a93f7d32d8454d0586b7c005;hb=350c674c6bcd97ec2f883b07e0cf49eb8a480183;hpb=ba4e9392ba615ed84d47576fe973057f89bb8998 diff --git a/firmware/apps/spi/spi.c b/firmware/apps/spi/spi.c index 3da3135..b552ae7 100644 --- a/firmware/apps/spi/spi.c +++ b/firmware/apps/spi/spi.c @@ -5,30 +5,61 @@ //Higher level left to client application. -#include "platform.h" + #include "command.h" +#ifdef __MSPGCC__ +#include +#else #include #include #include +#endif #include "spi.h" +#define SPIAPPLICATION + +#include "platform.h" + +//! Handles a monitor command. +void spi_handle_fn( uint8_t const app, + uint8_t const verb, + uint32_t const len); + +// define the spi app's app_t +app_t const spi_app = { + + /* app number */ + SPI, + + /* handle fn */ + spi_handle_fn, + + /* name */ + "SPI", + + /* desc */ + "\tThe SPI app handles the SPI bus protocol, turning\n" + "\tyour GoodFET into a USB-to-SPI adapter.\n" +}; + //This could be more accurate. //Does it ever need to be? #define SPISPEED 0 -#define SPIDELAY(x) -//delay(x) +#define SPIDELAY(x) delay(x) //! Set up the pins for SPI mode. void spisetup(){ SETSS; - P5DIR|=MOSI+SCK+BIT0; //BIT0 might be SS - P5DIR&=~MISO; - + SPIDIR|=MOSI+SCK+BIT0; //BIT0 might be SS + SPIDIR&=~MISO; + DIRSS; + //Begin a new transaction. - CLRSS; + + CLRSS; SETSS; } @@ -38,7 +69,7 @@ unsigned char spitrans8(unsigned char byte){ register unsigned int bit; //This function came from the SPI Wikipedia article. //Minor alterations. - + for (bit = 0; bit < 8; bit++) { /* write MOSI on trailing edge of previous clock */ if (byte & 0x80) @@ -46,14 +77,15 @@ unsigned char spitrans8(unsigned char byte){ else CLRMOSI; byte <<= 1; - + + //SPIDELAY(100); SETCLK; - + //SPIDELAY(100); + /* read MISO on trailing edge */ byte |= READMISO; CLRCLK; } - return byte; } @@ -100,16 +132,16 @@ void spiflash_peekblock(unsigned long adr, unsigned char *buf, unsigned int len){ unsigned char i; - + SETSS; CLRSS; //Drop !SS to begin transaction. spitrans8(0x03);//Flash Read Command - + //Send address spitrans8((adr&0xFF0000)>>16); spitrans8((adr&0xFF00)>>8); spitrans8(adr&0xFF); - + for(i=0;i>16); spitrans8((adr&0xFF00)>>8); @@ -146,7 +178,7 @@ void spiflash_pokeblock(unsigned long adr, for(i=0;i0x100?0x100:len-off); @@ -184,14 +216,14 @@ void spiflash_peek(unsigned char app, len=3;//write 3 byte pointer for(i=0;i