|
- #ifndef _SPIFIFO_h_
- #define _SPIFIFO_h_
-
- #include "avr_emulation.h"
-
- #ifdef KINETISK
-
- #if F_BUS == 120000000
- #define HAS_SPIFIFO
- #define SPI_CLOCK_24MHz (SPI_CTAR_PBR(3) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_16MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(2))
- #define SPI_CLOCK_12MHz (SPI_CTAR_PBR(3) | SPI_CTAR_BR(0))
- #define SPI_CLOCK_8MHz (SPI_CTAR_PBR(3) | SPI_CTAR_BR(4) | SPI_CTAR_DBR)
- #define SPI_CLOCK_6MHz (SPI_CTAR_PBR(3) | SPI_CTAR_BR(2))
- #define SPI_CLOCK_4MHz (SPI_CTAR_PBR(3) | SPI_CTAR_BR(4))
-
- #elif F_BUS == 108000000
- #define HAS_SPIFIFO
- #define SPI_CLOCK_24MHz (SPI_CTAR_PBR(3) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_16MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(2))
- #define SPI_CLOCK_12MHz (SPI_CTAR_PBR(1) | SPI_CTAR_BR(4) | SPI_CTAR_DBR)
- #define SPI_CLOCK_8MHz (SPI_CTAR_PBR(3) | SPI_CTAR_BR(4) | SPI_CTAR_DBR)
- #define SPI_CLOCK_6MHz (SPI_CTAR_PBR(1) | SPI_CTAR_BR(4))
- #define SPI_CLOCK_4MHz (SPI_CTAR_PBR(5) | SPI_CTAR_BR(2))
-
- #elif F_BUS == 96000000
- #define HAS_SPIFIFO
- #define SPI_CLOCK_24MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0))
- #define SPI_CLOCK_16MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(4) | SPI_CTAR_DBR)
- #define SPI_CLOCK_12MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(6) | SPI_CTAR_DBR)
- #define SPI_CLOCK_8MHz (SPI_CTAR_PBR(1) | SPI_CTAR_BR(2))
- #define SPI_CLOCK_6MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(6))
- #define SPI_CLOCK_4MHz (SPI_CTAR_PBR(1) | SPI_CTAR_BR(6))
-
- #elif F_BUS == 90000000
- #define HAS_SPIFIFO
- #define SPI_CLOCK_24MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0))
- #define SPI_CLOCK_16MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(4) | SPI_CTAR_DBR)
- #define SPI_CLOCK_12MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(6) | SPI_CTAR_DBR)
- #define SPI_CLOCK_8MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(4))
- #define SPI_CLOCK_6MHz (SPI_CTAR_PBR(3) | SPI_CTAR_BR(4) | SPI_CTAR_DBR)
- #define SPI_CLOCK_4MHz (SPI_CTAR_PBR(1) | SPI_CTAR_BR(6))
-
- #elif F_BUS == 80000000
- #define HAS_SPIFIFO
- #define SPI_CLOCK_24MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0))
- #define SPI_CLOCK_16MHz (SPI_CTAR_PBR(3) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_12MHz (SPI_CTAR_PBR(5) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_8MHz (SPI_CTAR_PBR(3) | SPI_CTAR_BR(0))
- #define SPI_CLOCK_6MHz (SPI_CTAR_PBR(5) | SPI_CTAR_BR(0))
- #define SPI_CLOCK_4MHz (SPI_CTAR_PBR(3) | SPI_CTAR_BR(2))
-
- #elif F_BUS == 72000000
- #define HAS_SPIFIFO
- #define SPI_CLOCK_24MHz (SPI_CTAR_PBR(1) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_16MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(4) | SPI_CTAR_DBR)
- #define SPI_CLOCK_12MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(4) | SPI_CTAR_DBR)
- #define SPI_CLOCK_8MHz (SPI_CTAR_PBR(1) | SPI_CTAR_BR(4) | SPI_CTAR_DBR)
- #define SPI_CLOCK_6MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(4))
- #define SPI_CLOCK_4MHz (SPI_CTAR_PBR(1) | SPI_CTAR_BR(4))
-
- #elif F_BUS == 64000000
- #define HAS_SPIFIFO
- #define SPI_CLOCK_24MHz (SPI_CTAR_PBR(1) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_16MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0))
- #define SPI_CLOCK_12MHz (SPI_CTAR_PBR(1) | SPI_CTAR_BR(0))
- #define SPI_CLOCK_8MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(2))
- #define SPI_CLOCK_6MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(4))
- #define SPI_CLOCK_4MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(6))
-
- #elif F_BUS == 60000000
- #define HAS_SPIFIFO
- #define SPI_CLOCK_24MHz (SPI_CTAR_PBR(1) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_16MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0))
- #define SPI_CLOCK_12MHz (SPI_CTAR_PBR(2) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_8MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(1))
- #define SPI_CLOCK_6MHz (SPI_CTAR_PBR(2) | SPI_CTAR_BR(0))
- #define SPI_CLOCK_4MHz (SPI_CTAR_PBR(2) | SPI_CTAR_BR(2) | SPI_CTAR_DBR)
-
- #elif F_BUS == 56000000
- #define HAS_SPIFIFO
- #define SPI_CLOCK_24MHz (SPI_CTAR_PBR(1) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_16MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0))
- #define SPI_CLOCK_12MHz (SPI_CTAR_PBR(2) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_8MHz (SPI_CTAR_PBR(3) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_6MHz (SPI_CTAR_PBR(2) | SPI_CTAR_BR(0))
- #define SPI_CLOCK_4MHz (SPI_CTAR_PBR(3) | SPI_CTAR_BR(0))
-
- #elif F_BUS == 48000000
- #define HAS_SPIFIFO
- #define SPI_CLOCK_24MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_16MHz (SPI_CTAR_PBR(1) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_12MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0))
- #define SPI_CLOCK_8MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(2) | SPI_CTAR_DBR)
- #define SPI_CLOCK_6MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(1))
- #define SPI_CLOCK_4MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(2))
-
- #elif F_BUS == 40000000
- #define HAS_SPIFIFO
- #define SPI_CLOCK_24MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_16MHz (SPI_CTAR_PBR(1) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_12MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0))
- #define SPI_CLOCK_8MHz (SPI_CTAR_PBR(2) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_6MHz (SPI_CTAR_PBR(3) | SPI_CTAR_BR(1) | SPI_CTAR_DBR)
- #define SPI_CLOCK_4MHz (SPI_CTAR_PBR(2) | SPI_CTAR_BR(1))
-
- #elif F_BUS == 36000000
- #define HAS_SPIFIFO
- #define SPI_CLOCK_24MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_16MHz (SPI_CTAR_PBR(1) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_12MHz (SPI_CTAR_PBR(1) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_8MHz (SPI_CTAR_PBR(2) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_6MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(2) | SPI_CTAR_DBR)
- #define SPI_CLOCK_4MHz (SPI_CTAR_PBR(1) | SPI_CTAR_BR(2) | SPI_CTAR_DBR)
-
- #elif F_BUS == 24000000
- #define HAS_SPIFIFO
- #define SPI_CLOCK_24MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_16MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_12MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_8MHz (SPI_CTAR_PBR(1) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_6MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0))
- #define SPI_CLOCK_4MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(2) | SPI_CTAR_DBR)
-
- #elif F_BUS == 16000000
- #define HAS_SPIFIFO
- #define SPI_CLOCK_24MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(3) | SPI_CTAR_DBR)
- #define SPI_CLOCK_16MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(3) | SPI_CTAR_DBR)
- #define SPI_CLOCK_12MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(3) | SPI_CTAR_DBR)
- #define SPI_CLOCK_8MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(3) | SPI_CTAR_DBR)
- #define SPI_CLOCK_6MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(3) | SPI_CTAR_DBR)
- #define SPI_CLOCK_4MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(3) | SPI_CTAR_DBR)
-
- #elif F_BUS == 8000000
- #define HAS_SPIFIFO
- #define SPI_CLOCK_24MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(1) | SPI_CTAR_DBR)
- #define SPI_CLOCK_16MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(1) | SPI_CTAR_DBR)
- #define SPI_CLOCK_12MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(1) | SPI_CTAR_DBR)
- #define SPI_CLOCK_8MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(1) | SPI_CTAR_DBR)
- #define SPI_CLOCK_6MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(1) | SPI_CTAR_DBR)
- #define SPI_CLOCK_4MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(1) | SPI_CTAR_DBR)
-
- #elif F_BUS == 4000000
- #define HAS_SPIFIFO
- #define SPI_CLOCK_24MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_16MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_12MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_8MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_6MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_4MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
-
- #elif F_BUS == 2000000
- #define HAS_SPIFIFO
- #define SPI_CLOCK_24MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_16MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_12MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_8MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_6MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
- #define SPI_CLOCK_4MHz (SPI_CTAR_PBR(0) | SPI_CTAR_BR(0) | SPI_CTAR_DBR)
-
- #endif
-
- #endif
-
-
-
-
-
-
-
-
-
- #ifdef HAS_SPIFIFO
-
- #ifndef SPI_MODE0
- #define SPI_MODE0 0x00
- #define SPI_MODE1 0x04
- #define SPI_MODE2 0x08
- #define SPI_MODE3 0x0C
- #endif
-
- #define SPI_CONTINUE 1
-
- class SPIFIFOclass
- {
- public:
- inline void begin(uint8_t pin, uint32_t speed, uint32_t mode=SPI_MODE0) __attribute__((always_inline)) {
- uint32_t p, ctar = speed;
- SIM_SCGC6 |= SIM_SCGC6_SPI0;
-
- KINETISK_SPI0.MCR = SPI_MCR_MSTR | SPI_MCR_MDIS | SPI_MCR_HALT | SPI_MCR_PCSIS(0x1F);
- if (mode & 0x08) ctar |= SPI_CTAR_CPOL;
- if (mode & 0x04) {
- ctar |= SPI_CTAR_CPHA;
- ctar |= (ctar & 0x0F) << 8;
- } else {
- ctar |= (ctar & 0x0F) << 12;
- }
- KINETISK_SPI0.CTAR0 = ctar | SPI_CTAR_FMSZ(7);
- KINETISK_SPI0.CTAR1 = ctar | SPI_CTAR_FMSZ(15);
- if (pin == 10) {
- CORE_PIN10_CONFIG = PORT_PCR_MUX(2);
- p = 0x01;
- } else if (pin == 2) {
- CORE_PIN2_CONFIG = PORT_PCR_MUX(2);
- p = 0x01;
- } else if (pin == 9) {
- CORE_PIN9_CONFIG = PORT_PCR_MUX(2);
- p = 0x02;
- } else if (pin == 6) {
- CORE_PIN6_CONFIG = PORT_PCR_MUX(2);
- p = 0x02;
- } else if (pin == 20) {
- CORE_PIN20_CONFIG = PORT_PCR_MUX(2);
- p = 0x04;
- } else if (pin == 23) {
- CORE_PIN23_CONFIG = PORT_PCR_MUX(2);
- p = 0x04;
- } else if (pin == 21) {
- CORE_PIN21_CONFIG = PORT_PCR_MUX(2);
- p = 0x08;
- } else if (pin == 22) {
- CORE_PIN22_CONFIG = PORT_PCR_MUX(2);
- p = 0x08;
- } else if (pin == 15) {
- CORE_PIN15_CONFIG = PORT_PCR_MUX(2);
- p = 0x10;
- #if defined(__MK64FX512__) || defined(__MK66FX1M0__)
- } else if (pin == 26) {
- CORE_PIN26_CONFIG = PORT_PCR_MUX(2);
- p = 0x01;
- #endif
- } else {
- reg = portOutputRegister(pin);
- pinMode(pin, OUTPUT);
- *reg = 1;
- p = 0;
- }
- pcs = p;
- clear();
- SPCR.enable_pins();
- }
- inline void write(uint32_t b, uint32_t cont=0) __attribute__((always_inline)) {
- uint32_t pcsbits = pcs << 16;
- if (pcsbits) {
- KINETISK_SPI0.PUSHR = (b & 0xFF) | pcsbits | (cont ? SPI_PUSHR_CONT : 0);
- while (((KINETISK_SPI0.SR) & (15 << 12)) > (3 << 12)) ;
- } else {
- *reg = 0;
- KINETISK_SPI0.SR = SPI_SR_EOQF;
- KINETISK_SPI0.PUSHR = (b & 0xFF) | (cont ? 0 : SPI_PUSHR_EOQ);
- if (cont) {
- while (((KINETISK_SPI0.SR) & (15 << 12)) > (3 << 12)) ;
- } else {
- while (!(KINETISK_SPI0.SR & SPI_SR_EOQF)) ;
- *reg = 1;
- }
- }
- }
- inline void write16(uint32_t b, uint32_t cont=0) __attribute__((always_inline)) {
- uint32_t pcsbits = pcs << 16;
- if (pcsbits) {
- KINETISK_SPI0.PUSHR = (b & 0xFFFF) | (pcs << 16) |
- (cont ? SPI_PUSHR_CONT : 0) | SPI_PUSHR_CTAS(1);
- while (((KINETISK_SPI0.SR) & (15 << 12)) > (3 << 12)) ;
- } else {
- *reg = 0;
- KINETISK_SPI0.SR = SPI_SR_EOQF;
- KINETISK_SPI0.PUSHR = (b & 0xFFFF) | (cont ? 0 : SPI_PUSHR_EOQ) | SPI_PUSHR_CTAS(1);
- if (cont) {
- while (((KINETISK_SPI0.SR) & (15 << 12)) > (3 << 12)) ;
- } else {
- while (!(KINETISK_SPI0.SR & SPI_SR_EOQF)) ;
- *reg = 1;
- }
- }
- }
- inline uint32_t read(void) __attribute__((always_inline)) {
- while ((KINETISK_SPI0.SR & (15 << 4)) == 0) ;
- return KINETISK_SPI0.POPR;
- }
- inline void clear(void) __attribute__((always_inline)) {
- KINETISK_SPI0.MCR = SPI_MCR_MSTR | SPI_MCR_PCSIS(0x1F) | SPI_MCR_CLR_TXF | SPI_MCR_CLR_RXF;
- }
- private:
- static uint8_t pcs;
- static volatile uint8_t *reg;
- };
- extern SPIFIFOclass SPIFIFO;
-
- #endif
-
- #endif
|