2020-04-18 05:11:32 +10:00
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
bool selected;
|
|
|
|
// Initialization status. 0 == not woken 8 == woken 9 == CMD0 received
|
|
|
|
// 10 == CMD8 received, 11 == CMD55 received, 12 == CMD41 received (fully
|
|
|
|
// initialized).
|
|
|
|
unsigned int initstat;
|
|
|
|
// We receive commands into this buffer.
|
|
|
|
uint8_t recvbuf[6];
|
|
|
|
// Where the next SPI byte should be stored in recvbuf.
|
|
|
|
unsigned int recvidx;
|
|
|
|
// Buffer to the arguments for a response
|
|
|
|
uint8_t sendbuf[5];
|
|
|
|
// Index of the next byte from sendbuf we should return. If -1, buffer is
|
|
|
|
// empty.
|
|
|
|
int sendidx;
|
|
|
|
// One byte response. When all other response buffers are empty, return
|
|
|
|
// this.
|
|
|
|
uint8_t resp;
|
2020-04-18 09:10:22 +10:00
|
|
|
// File used for contents read/write
|
|
|
|
FILE *fp;
|
|
|
|
// number of bytes read into the current CMD17. -1 means no CMD17 active.
|
|
|
|
int cmd17bytes;
|
2020-04-18 10:19:55 +10:00
|
|
|
// number of bytes received for the current CMD24. -2 means no CMD24 active.
|
|
|
|
// -1 means we're still waiting for the data token.
|
|
|
|
int cmd24bytes;
|
2020-04-18 09:10:22 +10:00
|
|
|
// running crc16 during read and write operations.
|
|
|
|
uint16_t crc16;
|
2020-04-18 05:11:32 +10:00
|
|
|
} SDC;
|
|
|
|
|
|
|
|
void sdc_init(SDC *sdc);
|
2020-09-17 23:36:16 +10:00
|
|
|
void sdc_ctl_wr(SDC *sdc, uint8_t val);
|
2020-04-18 05:11:32 +10:00
|
|
|
void sdc_spi_wr(SDC *sdc, uint8_t val);
|
|
|
|
uint8_t sdc_spi_rd(SDC *sdc);
|