mirror of
https://gitee.com/Lyon1998/pikapython.git
synced 2025-01-15 17:02:53 +08:00
130 lines
4.3 KiB
C
130 lines
4.3 KiB
C
#include <hosal_spi.h>
|
|
#include "../PikaStdDevice/pika_hal.h"
|
|
|
|
static int _num2pin(int num, uint8_t* mosi, uint8_t* miso, uint8_t* scli) {
|
|
/*********************** BL602 **************************
|
|
* SPI0 -----> MOSI:P20, MISO:P0, SCLK:P22
|
|
*/
|
|
switch (num) {
|
|
case 0:
|
|
*mosi = 20;
|
|
*miso = 0;
|
|
*scli = 22;
|
|
break;
|
|
default:
|
|
return -1;
|
|
}
|
|
#if PIKA_DEBUG_ENABLE
|
|
__platform_printf("SPI%d: mosi:%d, miso:%d, scli:%d\r\n", num, *mosi, *miso,
|
|
*scli);
|
|
#endif
|
|
return 0;
|
|
}
|
|
|
|
int pika_hal_platform_SPI_open(pika_dev* dev, char* name) {
|
|
hosal_spi_dev_t* platform_spi = pikaMalloc(sizeof(hosal_spi_dev_t));
|
|
memset(platform_spi, 0, sizeof(hosal_spi_dev_t));
|
|
dev->platform_data = platform_spi;
|
|
/* Support SPI0, SPI1, SPI2 */
|
|
if (name[0] == 'S' && name[1] == 'P' && name[2] == 'I') {
|
|
int spi_num = fast_atoi(name + 3);
|
|
platform_spi->port = 0;
|
|
if (0 == _num2pin(spi_num, &platform_spi->config.pin_mosi,
|
|
&platform_spi->config.pin_miso,
|
|
&platform_spi->config.pin_clk)) {
|
|
return 0;
|
|
} else {
|
|
__platform_printf("SPI: Open SPI%d failed\r\n", spi_num);
|
|
return -1;
|
|
}
|
|
}
|
|
return -1;
|
|
}
|
|
|
|
int pika_hal_platform_SPI_close(pika_dev* dev) {
|
|
hosal_spi_dev_t* platform_spi = (hosal_spi_dev_t*)dev->platform_data;
|
|
if (NULL != platform_spi) {
|
|
pikaFree(platform_spi, sizeof(hosal_spi_dev_t));
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
int pika_hal_platform_SPI_ioctl_config(pika_dev* dev,
|
|
pika_hal_SPI_config* cfg) {
|
|
hosal_spi_dev_t* platform_spi = (hosal_spi_dev_t*)dev->platform_data;
|
|
if (!dev->is_enabled) {
|
|
platform_spi->port = 0;
|
|
platform_spi->config.dma_enable = 0;
|
|
platform_spi->config.freq = cfg->speed;
|
|
platform_spi->p_arg = NULL;
|
|
switch (cfg->master_or_slave) {
|
|
case PIKA_HAL_SPI_MASTER:
|
|
platform_spi->config.mode = HOSAL_SPI_MODE_MASTER;
|
|
break;
|
|
case PIKA_HAL_SPI_SLAVE:
|
|
platform_spi->config.mode = HOSAL_SPI_MODE_SLAVE;
|
|
break;
|
|
default:
|
|
return -1;
|
|
}
|
|
switch (cfg->mode) {
|
|
case PIKA_HAL_SPI_MODE_0:
|
|
platform_spi->config.polar_phase = 0;
|
|
break;
|
|
case PIKA_HAL_SPI_MODE_1:
|
|
platform_spi->config.polar_phase = 1;
|
|
break;
|
|
case PIKA_HAL_SPI_MODE_2:
|
|
platform_spi->config.polar_phase = 2;
|
|
break;
|
|
case PIKA_HAL_SPI_MODE_3:
|
|
platform_spi->config.polar_phase = 3;
|
|
break;
|
|
default:
|
|
return -1;
|
|
}
|
|
#if PIKA_DEBUG_ENABLE
|
|
__platform_printf("SPI: freq:%d, mode:%d, polar_phase:%d\r\n",
|
|
platform_spi->config.freq, platform_spi->config.mode,
|
|
platform_spi->config.polar_phase);
|
|
#endif
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
int pika_hal_platform_SPI_ioctl_enable(pika_dev* dev) {
|
|
if (!dev->is_enabled) {
|
|
hosal_spi_dev_t* platform_spi = (hosal_spi_dev_t*)dev->platform_data;
|
|
#if PIKA_DEBUG_ENABLE
|
|
__platform_printf(
|
|
"SPI: Open SPI%d, freq:%d, mode:%d, polar_phase:%d\r\n",
|
|
platform_spi->port, platform_spi->config.freq,
|
|
platform_spi->config.mode, platform_spi->config.polar_phase);
|
|
#endif
|
|
hosal_spi_init(platform_spi);
|
|
return 0;
|
|
}
|
|
return -1;
|
|
}
|
|
|
|
int pika_hal_platform_SPI_ioctl_disable(pika_dev* dev) {
|
|
if (dev->is_enabled) {
|
|
hosal_spi_dev_t* platform_spi = (hosal_spi_dev_t*)dev->platform_data;
|
|
hosal_spi_finalize(platform_spi);
|
|
return 0;
|
|
}
|
|
return -1;
|
|
}
|
|
|
|
int pika_hal_platform_SPI_write(pika_dev* dev, void* buf, size_t count) {
|
|
hosal_spi_dev_t* platform_spi = (hosal_spi_dev_t*)dev->platform_data;
|
|
pika_hal_SPI_config* cfg = (pika_hal_SPI_config*)dev->ioctl_config;
|
|
return hosal_spi_send(platform_spi, buf, count, cfg->timeout);
|
|
}
|
|
|
|
int pika_hal_platform_SPI_read(pika_dev* dev, void* buf, size_t count) {
|
|
hosal_spi_dev_t* platform_spi = (hosal_spi_dev_t*)dev->platform_data;
|
|
pika_hal_SPI_config* cfg = (pika_hal_SPI_config*)dev->ioctl_config;
|
|
return hosal_spi_recv(platform_spi, buf, count, cfg->timeout);
|
|
}
|