2015-01-24 23:34:20 -05:00
|
|
|
#ifndef __PLOADER_H__
|
|
|
|
#define __PLOADER_H__
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C"
|
|
|
|
{
|
|
|
|
#endif
|
|
|
|
|
2015-01-24 23:39:22 -05:00
|
|
|
#include <stdint.h>
|
|
|
|
|
2015-02-08 08:21:46 -05:00
|
|
|
#define LOAD_PHASE_HANDSHAKE 0
|
|
|
|
#define LOAD_PHASE_RESPONSE 1
|
|
|
|
#define LOAD_PHASE_VERSION 2
|
|
|
|
#define LOAD_PHASE_HANDSHAKE_DONE 3
|
|
|
|
#define LOAD_PHASE_PROGRAM 4
|
|
|
|
#define LOAD_PHASE_EEPROM_WRITE 5
|
|
|
|
#define LOAD_PHASE_EEPROM_VERIFY 6
|
|
|
|
#define LOAD_PHASE_DONE 7
|
2015-01-24 23:34:20 -05:00
|
|
|
|
2015-02-08 08:21:46 -05:00
|
|
|
#define LOAD_STS_OK 0
|
|
|
|
#define LOAD_STS_ERROR -1
|
|
|
|
#define LOAD_STS_TIMEOUT -2
|
|
|
|
|
|
|
|
#define LOAD_TYPE_SHUTDOWN 0
|
|
|
|
#define LOAD_TYPE_RUN 1
|
|
|
|
#define LOAD_TYPE_EEPROM 2
|
|
|
|
#define LOAD_TYPE_EEPROM_RUN 3
|
|
|
|
|
|
|
|
/* loader state structure - filled in by the loader functions */
|
2015-01-24 23:34:20 -05:00
|
|
|
typedef struct {
|
2015-02-08 08:21:46 -05:00
|
|
|
|
|
|
|
/* serial driver interface */
|
2015-01-24 23:34:20 -05:00
|
|
|
void (*reset)(void *data);
|
|
|
|
int (*tx)(void *data, uint8_t* buf, int n);
|
|
|
|
int (*rx_timeout)(void *data, uint8_t* buf, int n, int timeout);
|
|
|
|
void *serialData;
|
2015-02-08 08:21:46 -05:00
|
|
|
|
|
|
|
/* load progress interface */
|
2015-02-08 08:29:52 -05:00
|
|
|
void (*progress)(void *data, int phase, int current);
|
2015-02-08 08:21:46 -05:00
|
|
|
void *progressData;
|
|
|
|
|
|
|
|
/* internal variables */
|
2015-01-24 23:34:20 -05:00
|
|
|
uint8_t txbuf[1024];
|
|
|
|
int txcnt;
|
|
|
|
uint8_t rxbuf[1024];
|
|
|
|
int rxnext;
|
|
|
|
int rxcnt;
|
|
|
|
uint8_t lfsr;
|
|
|
|
} PL_state;
|
|
|
|
|
|
|
|
/* PL_Init - Initializes the loader state structure. */
|
2015-02-08 08:21:46 -05:00
|
|
|
void PL_Init(PL_state *state);
|
2015-02-07 22:49:50 -05:00
|
|
|
|
2015-01-24 23:34:20 -05:00
|
|
|
/* PL_HardwareFound - Sends the handshake sequence and returns non-zero if a Propeller
|
|
|
|
chip is found on the serial interface and also sets the version parameter to the
|
|
|
|
chip version.
|
|
|
|
*/
|
|
|
|
int PL_HardwareFound(PL_state *state, int *pVersion);
|
|
|
|
|
|
|
|
/* PL_LoadSpinBinary - Loads a Spin binary image. Must be called immediatel following a
|
|
|
|
successful call to PL_HardwareFound.
|
|
|
|
*/
|
|
|
|
int PL_LoadSpinBinary(PL_state *state, int loadType, uint8_t *image, int size);
|
|
|
|
|
2015-02-08 08:21:46 -05:00
|
|
|
/* PL_Shutdown - Shutdown the loader.*/
|
|
|
|
void PL_Shutdown(PL_state *state);
|
|
|
|
|
2015-01-24 23:34:20 -05:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|