X-Git-Url: http://git.rot13.org/?a=blobdiff_plain;f=firmware%2Fapps%2Fspi%2Fspi.c;h=bb1753a056fb6c21d7ed9642b6e01d44c2775d20;hb=f7fdc48f01ada713d5034763a2f3395fe2a7c51b;hp=aa3c5ecff4154876534705e2f2fffbea56fdfc9a;hpb=854dba571fe62948dfb23a396be3299225fcbb05;p=goodfet diff --git a/firmware/apps/spi/spi.c b/firmware/apps/spi/spi.c index aa3c5ec..bb1753a 100644 --- a/firmware/apps/spi/spi.c +++ b/firmware/apps/spi/spi.c @@ -5,15 +5,23 @@ //Higher level left to client application. -#include "platform.h" + #include "command.h" +#ifdef __MSPGCC__ +#include +#else #include -#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, @@ -48,10 +56,10 @@ void spisetup(){ SPIDIR|=MOSI+SCK+BIT0; //BIT0 might be SS SPIDIR&=~MISO; DIRSS; - + //Begin a new transaction. - - CLRSS; + + CLRSS; SETSS; } @@ -61,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) @@ -69,11 +77,11 @@ unsigned char spitrans8(unsigned char byte){ else CLRMOSI; byte <<= 1; - + //SPIDELAY(100); SETCLK; //SPIDELAY(100); - + /* read MISO on trailing edge */ byte |= READMISO; CLRCLK; @@ -124,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); @@ -170,7 +178,7 @@ void spiflash_pokeblock(unsigned long adr, for(i=0;i0x100?0x100:len-off); @@ -208,14 +216,14 @@ void spiflash_peek(unsigned char app, len=3;//write 3 byte pointer for(i=0;i