2010-10-02 02:17:22 +00:00
|
|
|
#ifndef AHRS_SPI_PROGRAM_H
|
|
|
|
#define AHRS_SPI_PROGRAM_H
|
|
|
|
|
|
|
|
/* Special packets to enter programming mode.
|
|
|
|
Note: these must both be SPI_PROGRAM_REQUEST_LENGTH long.
|
|
|
|
Pad with spaces if needed.
|
|
|
|
*/
|
|
|
|
#define SPI_PROGRAM_REQUEST "AHRS START PROGRAMMING "
|
|
|
|
#define SPI_PROGRAM_ACK "AHRS PROGRAMMING STARTED"
|
|
|
|
#define SPI_PROGRAM_REQUEST_LENGTH 24
|
|
|
|
|
|
|
|
/**Proposed programming protocol:
|
|
|
|
In the master:
|
|
|
|
1) Send a AhrsProgramPacket containing the relevant data.
|
|
|
|
Note crc is a CRC32 as the CRC8 used in hardware can be fooled.
|
|
|
|
2) Keep sending PROGRAM_NULL packets and wait for an ack.
|
|
|
|
Time out if we waited too long.
|
|
|
|
3) Compare ack packet with transmitted packet. The data
|
|
|
|
should be the bitwise inverse of the data transmitted.
|
|
|
|
4) repeat for next packet until finished
|
|
|
|
5) Repeat using verify packets with data all zeros
|
|
|
|
Returned data should be exactly as read from memory
|
|
|
|
|
|
|
|
In the slave:
|
|
|
|
1) Wait for an AhrsProgramPacket
|
|
|
|
2) Check CRC then write to memory
|
|
|
|
3) Bitwise invert data
|
|
|
|
4) Transmit packet.
|
|
|
|
5) repeat until we receive a verify packet
|
|
|
|
6) verify until we receive a reboot packet
|
|
|
|
Reboot packets had better have some sort of magic number in the data,
|
|
|
|
just to be absolutely sure
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
typedef enum { PROGRAM_NULL, PROGRAM_DATA, PROGRAM_ACK, PROGRAM_VERIFY, PROGRAM_REBOOT } ProgramType;
|
|
|
|
#define SPI_MAX_PROGRAM_DATA_SIZE 256 //max 256 bytes per packet
|
|
|
|
|
|
|
|
/** Proposed program packet defintion
|
|
|
|
*/
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
ProgramType type;
|
|
|
|
uint32_t address; //base address to place data
|
|
|
|
uint32_t size; //Size of data
|
|
|
|
uint8_t data[SPI_MAX_PROGRAM_DATA_SIZE];
|
|
|
|
uint32_t crc; //CRC32 - hardware CRC8 can be fooled
|
|
|
|
} AhrsProgramPacket;
|
|
|
|
|
|
|
|
#endif
|