Init
This commit is contained in:
		
						commit
						14269a4716
					
				|  | @ -0,0 +1,36 @@ | |||
| //
 | ||||
| // Created by cfif on 28.09.22.
 | ||||
| //
 | ||||
| 
 | ||||
| #ifndef SPIPORT_ARTERY_H | ||||
| #define SPIPORT_ARTERY_H | ||||
| 
 | ||||
| #include "SpiPort.h" | ||||
| #include CMSIS_device_header | ||||
| #include "cmsis_os2.h" | ||||
| #include "GpioPinInterface.h" | ||||
| 
 | ||||
| typedef struct { | ||||
|     spi_type *spi; | ||||
|     //решение на случай одного чипа на шине
 | ||||
|     tGpioPin *chipSelect; | ||||
| } tSpiPortArtery; | ||||
| 
 | ||||
| tSpiPortArtery vSpiPortInit( | ||||
|         spi_type *spi, | ||||
|         spi_frame_bit_num_type spiFrameBit, | ||||
|         spi_mclk_freq_div_type mclkDIV, | ||||
|         spi_clock_polarity_type clockPolarity, | ||||
|         spi_clock_phase_type clockPhase, | ||||
|         crm_periph_clock_type spiClock, | ||||
|         tGpioPin *chipSelect | ||||
| ); | ||||
| 
 | ||||
| 
 | ||||
| #define vSpiPortInitName(NAME, spiFrameBit, mclkDIV, clockPolarity, clockPhase, CS) \ | ||||
| vSpiPortInit(NAME, spiFrameBit, mclkDIV, clockPolarity, clockPhase, CRM_##NAME##_PERIPH_CLOCK, CS) | ||||
| 
 | ||||
| 
 | ||||
| tSpiPortIO vSpiPortGetIo(tSpiPortArtery *env); | ||||
| 
 | ||||
| #endif //SPIPORT_ARTERY_H
 | ||||
|  | @ -0,0 +1,137 @@ | |||
| //
 | ||||
| // Created by cfif on 16.09.22.
 | ||||
| //
 | ||||
| #include <SystemDelayInterface.h> | ||||
| #include "SpiPortArtery.h" | ||||
| 
 | ||||
| 
 | ||||
| tSpiPortArtery vSpiPortInit( | ||||
|         spi_type *spi, | ||||
|         spi_frame_bit_num_type spiFrameBit, | ||||
|         spi_mclk_freq_div_type mclkDIV, | ||||
|         spi_clock_polarity_type clockPolarity, | ||||
|         spi_clock_phase_type clockPhase, | ||||
|         crm_periph_clock_type spiClock, | ||||
|         tGpioPin *chipSelect | ||||
| ) { | ||||
|     spi_i2s_reset(spi); | ||||
| 
 | ||||
|     spi_init_type spi_init_struct; | ||||
| 
 | ||||
|     crm_periph_clock_enable(spiClock, TRUE); | ||||
| 
 | ||||
|     spi_default_para_init(&spi_init_struct); | ||||
|     spi_init_struct.transmission_mode = SPI_TRANSMIT_FULL_DUPLEX; | ||||
|     spi_init_struct.master_slave_mode = SPI_MODE_MASTER; | ||||
|     spi_init_struct.mclk_freq_division = mclkDIV; | ||||
|     spi_init_struct.first_bit_transmission = SPI_FIRST_BIT_MSB; | ||||
|     spi_init_struct.frame_bit_num = spiFrameBit; | ||||
| 
 | ||||
| //    spi_init_struct.clock_polarity = SPI_CLOCK_POLARITY_LOW;
 | ||||
| //    spi_init_struct.clock_phase = SPI_CLOCK_PHASE_1EDGE;
 | ||||
|     spi_init_struct.clock_polarity = clockPolarity; | ||||
|     spi_init_struct.clock_phase = clockPhase; | ||||
| 
 | ||||
| 
 | ||||
|     spi_crc_polynomial_set(spi, 7); | ||||
|     spi_crc_enable(spi, TRUE); | ||||
| 
 | ||||
| 
 | ||||
|     spi_init_struct.cs_mode_selection = SPI_CS_SOFTWARE_MODE; | ||||
| 
 | ||||
|     spi_init(spi, &spi_init_struct); | ||||
| 
 | ||||
|     spi_enable(spi, TRUE); | ||||
| 
 | ||||
| 
 | ||||
|     tSpiPortArtery spiPort = { | ||||
|             .spi = spi, | ||||
|             .chipSelect = chipSelect | ||||
|     }; | ||||
| 
 | ||||
|     return spiPort; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| static uint16_t vSpiPortReceive(tSpiPortArtery *env, uint16_t *data, uint32_t timeout) { | ||||
|     uint16_t received = 0; | ||||
| 
 | ||||
|     uint32_t endMs = SystemGetMs() + timeout; | ||||
| 
 | ||||
|     while ((timeout == SystemWaitForever) || (endMs > SystemGetMs())) { | ||||
|         // В буфере приемника еcть данные
 | ||||
|         if (spi_i2s_flag_get(env->spi, SPI_I2S_RDBF_FLAG)) { | ||||
|             *data = spi_i2s_data_receive(env->spi); | ||||
|             ++received; | ||||
|             break; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     return received; | ||||
| } | ||||
| 
 | ||||
| static uint16_t vSpiPortTransmit(tSpiPortArtery *env, uint16_t *data, uint32_t timeout) { | ||||
|     uint16_t sent = 0; | ||||
| 
 | ||||
|     uint32_t endMs = SystemGetMs() + timeout; | ||||
| 
 | ||||
|     while ((timeout == SystemWaitForever) || (endMs > SystemGetMs())) { | ||||
|         // Буфер передатчика пуст
 | ||||
|         if (spi_i2s_flag_get(env->spi, SPI_I2S_TDBE_FLAG)) { | ||||
|             spi_i2s_data_transmit(env->spi, *data); | ||||
|             ++sent; | ||||
|             break; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     return sent; | ||||
| } | ||||
| 
 | ||||
| static bool vSpiPortSovTransmit(tSpiPortArtery *env, const uint16_t *data, uint32_t timeout) { | ||||
| 
 | ||||
|     uint32_t endMs = SystemGetMs() + timeout; | ||||
| 
 | ||||
|     while ((timeout == SystemWaitForever) || (endMs > SystemGetMs())) { | ||||
|         // Буфер передатчика пуст
 | ||||
|         if (spi_i2s_flag_get(env->spi, SPI_I2S_TDBE_FLAG)) { | ||||
|             spi_i2s_data_transmit(env->spi, *data);vSpiPortReceive (env,data,timeout); | ||||
|             return true; | ||||
|         } | ||||
|     } | ||||
|     return false; | ||||
| } | ||||
| 
 | ||||
| static bool vSpiPortSovReceive(tSpiPortArtery *env, uint16_t *data, uint32_t timeout) { | ||||
|     uint32_t endMs = SystemGetMs() + timeout; | ||||
|     vSpiPortTransmit (env,data,timeout); | ||||
|     while ((timeout == SystemWaitForever) || (endMs > SystemGetMs())) { | ||||
|         // В буфере приемника еcть данные
 | ||||
|         if (spi_i2s_flag_get(env->spi, SPI_I2S_RDBF_FLAG)) { | ||||
|             *data = spi_i2s_data_receive(env->spi); | ||||
|             return true; | ||||
|         } | ||||
|     } | ||||
|     return false; | ||||
| } | ||||
| 
 | ||||
| //простая реализация chipSelect для одного утройства на шине
 | ||||
| static bool vSpiPortChipSelectMono(tSpiPortArtery *env, uint32_t timeout) { | ||||
|     GpioPinEnable(env->chipSelect); | ||||
|     return true; | ||||
| } | ||||
| 
 | ||||
| static bool vSpiPortChipReleaseMono(tSpiPortArtery *env, uint32_t timeout) { | ||||
|     GpioPinDisable(env->chipSelect); | ||||
|     return true; | ||||
| } | ||||
| 
 | ||||
| tSpiPortIO vSpiPortGetIo(tSpiPortArtery *env) { | ||||
|     tSpiPortIO io = { | ||||
|             .env = env, | ||||
|             .receive = (SpiPortIOTransaction) vSpiPortSovReceive, | ||||
|             .transmit = (SpiPortIOTransaction) vSpiPortSovTransmit, | ||||
|             .chipSelect =(SpiPortChipArbitrage) vSpiPortChipSelectMono, | ||||
|             .chipRelease =(SpiPortChipArbitrage) vSpiPortChipReleaseMono | ||||
|     }; | ||||
|     return io; | ||||
| } | ||||
|  | @ -0,0 +1,22 @@ | |||
| { | ||||
|   "dep": [ | ||||
|     { | ||||
|       "type": "git", | ||||
|       "provider": "Smart_Components_Aurus", | ||||
|       "repo": "SpiPort" | ||||
|     }, | ||||
|     { | ||||
|       "type": "git", | ||||
|       "provider": "Smart_Components_Aurus", | ||||
|       "repo": "SystemDelayInterface" | ||||
|     } | ||||
|   ], | ||||
|   "cmake": { | ||||
|     "inc_dirs": [ | ||||
|       "Inc" | ||||
|     ], | ||||
|     "srcs": [ | ||||
|       "Src/**.c" | ||||
|     ] | ||||
|   } | ||||
| } | ||||
		Loading…
	
		Reference in New Issue