| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344 |
- #include "pika_hal_utils.h"
- /* error handler */
- PIKA_WEAK void pika_hal_utils_error_handler(int err,
- const char* file,
- int line,
- const char* func) {
- pika_platform_printf("Error code %d: %s()\r\n", err, func);
- pika_platform_printf("AT: %s:%d\r\n", file, line);
- }
- #define pika_hal_utils_raise_error(err) \
- pika_hal_utils_error_handler(err, __FILE__, __LINE__, __func__)
- /* common utils */
- int pika_hal_utils_enable(pika_dev* dev) {
- int ret = pika_hal_ioctl(dev, PIKA_HAL_IOCTL_ENABLE);
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- }
- return ret;
- }
- int pika_hal_utils_disable(pika_dev* dev) {
- int ret = pika_hal_ioctl(dev, PIKA_HAL_IOCTL_DISABLE);
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- }
- return ret;
- }
- /* GPIO utils */
- int pika_hal_utils_GPIO_config(pika_dev* dev, pika_hal_GPIO_config* cfg) {
- int ret = pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, cfg);
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- }
- return ret;
- }
- int pika_hal_utils_GPIO_set_mode(pika_dev* dev,
- PIKA_HAL_GPIO_DIR dir,
- PIKA_HAL_GPIO_PULL pull) {
- pika_hal_GPIO_config cfg = {0};
- cfg.dir = dir;
- cfg.pull = pull;
- int ret = pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, &cfg);
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- }
- return ret;
- }
- int pika_hal_utils_GPIO_set_dir(pika_dev* dev, PIKA_HAL_GPIO_DIR dir) {
- pika_hal_GPIO_config cfg = {0};
- cfg.dir = dir;
- int ret = pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, &cfg);
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- }
- return ret;
- }
- int pika_hal_utils_GPIO_set_pull(pika_dev* dev, PIKA_HAL_GPIO_PULL pull) {
- pika_hal_GPIO_config cfg = {0};
- cfg.pull = pull;
- int ret = pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, &cfg);
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- }
- return ret;
- }
- int pika_hal_utils_GPIO_write(pika_dev* dev, uint32_t val) {
- int ret = pika_hal_write(dev, &val, sizeof(uint32_t));
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- }
- return 0;
- }
- uint32_t pika_hal_utils_GPIO_read(pika_dev* dev) {
- uint32_t val = 0;
- int ret = pika_hal_read(dev, &val, sizeof(uint32_t));
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- return 0;
- }
- return val;
- }
- /* UART utils */
- int pika_hal_utils_UART_config(pika_dev* dev, pika_hal_UART_config* cfg) {
- int ret = pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, cfg);
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- }
- return ret;
- }
- /* IIC utils */
- int pika_hal_utils_IIC_config(pika_dev* dev, pika_hal_IIC_config* cfg) {
- int ret = pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, cfg);
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- }
- return ret;
- }
- /* IIC mem read/write utils */
- int pika_hal_utils_IIC_mem_read(pika_dev* dev,
- uint32_t mem_addr,
- uint32_t mem_addr_size,
- uint8_t* data,
- uint32_t size) {
- pika_hal_IIC_config* iic_config = (pika_hal_IIC_config*)dev->ioctl_config;
- iic_config->mem_addr = mem_addr;
- iic_config->mem_addr_size = mem_addr_size;
- iic_config->mem_addr_ena = PIKA_HAL_IIC_MEM_ADDR_ENA_ENABLE;
- if (pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, dev->ioctl_config) < 0) {
- return -1;
- }
- return pika_hal_read(dev, data, size);
- }
- /* IIC mem read/write utils */
- int pika_hal_utils_IIC_mem_write(pika_dev* dev,
- uint32_t mem_addr,
- uint32_t mem_addr_size,
- uint8_t* data,
- uint32_t size) {
- pika_hal_IIC_config* iic_config = (pika_hal_IIC_config*)dev->ioctl_config;
- iic_config->mem_addr = mem_addr;
- iic_config->mem_addr_size = mem_addr_size;
- iic_config->mem_addr_ena = PIKA_HAL_IIC_MEM_ADDR_ENA_ENABLE;
- if (pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, dev->ioctl_config) < 0) {
- return -1;
- }
- return pika_hal_write(dev, data, size);
- }
- int pika_hal_utils_IIC_read(pika_dev* dev, uint8_t* data, uint32_t size) {
- pika_hal_IIC_config* iic_config = (pika_hal_IIC_config*)dev->ioctl_config;
- iic_config->mem_addr_ena = PIKA_HAL_IIC_MEM_ADDR_ENA_DISABLE;
- if (pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, dev->ioctl_config) < 0) {
- return -1;
- }
- return pika_hal_read(dev, data, size);
- }
- int pika_hal_utils_IIC_write(pika_dev* dev, uint8_t* data, uint32_t size) {
- pika_hal_IIC_config* iic_config = (pika_hal_IIC_config*)dev->ioctl_config;
- iic_config->mem_addr_ena = PIKA_HAL_IIC_MEM_ADDR_ENA_DISABLE;
- if (pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, dev->ioctl_config) < 0) {
- return -1;
- }
- return pika_hal_write(dev, data, size);
- }
- int pika_hal_utils_IIC_set_slave_addr(pika_dev* dev, uint32_t slave_addr) {
- pika_hal_IIC_config* iic_config = (pika_hal_IIC_config*)dev->ioctl_config;
- iic_config->slave_addr = slave_addr;
- return pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, dev->ioctl_config);
- }
- /* SPI utils */
- int pika_hal_utils_SPI_config(pika_dev* dev, pika_hal_SPI_config* cfg) {
- int ret = pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, cfg);
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- }
- return ret;
- }
- int pika_hal_utils_SPI_transfer(pika_dev* dev,
- uint8_t* txbuff,
- uint8_t* rxbuff,
- uint32_t size) {
- // Modify parameter check logic: allow unidirectional transfer
- if (dev == NULL || (txbuff == NULL && rxbuff == NULL)) {
- return -1; // Parameter check failed
- }
- pika_hal_SPI_config* cfg = (pika_hal_SPI_config*)dev->ioctl_config;
- uint32_t transferred = 0; // Amount of data transferred
- uint32_t remaining = size; // Amount of data remaining
- uint32_t chunkSize; // Amount of data for the current batch transfer
- while (remaining > 0) {
- chunkSize = remaining > PIKA_HAL_SPI_RX_BUFFER_SIZE
- ? PIKA_HAL_SPI_RX_BUFFER_SIZE
- : remaining;
- // Call SPI_write to transfer data only if txbuff is not NULL
- if (txbuff != NULL) {
- pika_hal_write(dev, &txbuff[transferred], chunkSize);
- }
- // Call hal_read instead of directly retrieving data from
- // transfer_rx_buffer only if rxbuff is not NULL
- if (rxbuff != NULL) {
- if (txbuff == NULL) {
- // Perform data reception only
- pika_hal_read(dev, &rxbuff[transferred], chunkSize);
- } else {
- // Handle both data sending and receiving, assuming hal_write
- // already includes reading logic
- for (uint32_t i = 0; i < chunkSize; i++) {
- rxbuff[transferred + i] =
- cfg->tranfer_rx_buffer[i % PIKA_HAL_SPI_RX_BUFFER_SIZE];
- }
- }
- }
- transferred += chunkSize; // Update the amount of data transferred
- remaining -= chunkSize; // Update the amount of data remaining
- }
- return 0; // Successfully completed the transfer
- }
- /* ADC utils */
- int pika_hal_utils_ADC_config(pika_dev* dev, pika_hal_ADC_config* cfg) {
- int ret = pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, cfg);
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- }
- return ret;
- }
- uint32_t pika_hal_utils_ADC_read(pika_dev* dev) {
- uint32_t val = 0;
- int ret = pika_hal_read(dev, &val, sizeof(uint32_t));
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- return 0;
- }
- return val;
- }
- /* DAC utils */
- int pika_hal_utils_DAC_config(pika_dev* dev, pika_hal_DAC_config* cfg) {
- int ret = pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, cfg);
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- }
- return ret;
- }
- int pika_hal_utils_DAC_write(pika_dev* dev, uint32_t val) {
- int ret = pika_hal_write(dev, &val, sizeof(uint32_t));
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- }
- return ret;
- }
- /* PWM utils */
- int pika_hal_utils_PWM_config(pika_dev* dev, pika_hal_PWM_config* cfg) {
- int ret = pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, cfg);
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- }
- return ret;
- }
- int pika_hal_utils_PWM_set_period(pika_dev* dev,
- PIKA_HAL_PWM_PERIOD period_ns) {
- pika_hal_PWM_config cfg = {0};
- cfg.period = period_ns;
- /* keep duty unchanged because duty has no unused field */
- cfg.duty = ((pika_hal_PWM_config*)dev->ioctl_config)->duty;
- int ret = pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, &cfg);
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- }
- return ret;
- }
- int pika_hal_utils_PWM_set_duty(pika_dev* dev, PIKA_HAL_PWM_DUTY duty_ns) {
- pika_hal_PWM_config cfg = {0};
- cfg.duty = duty_ns;
- int ret = pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, &cfg);
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- }
- return ret;
- }
- /* SOFT_SPI utils */
- int pika_hal_utils_SOFT_SPI_config(pika_dev* dev,
- pika_hal_SOFT_SPI_config* cfg) {
- int ret = pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, cfg);
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- }
- return ret;
- }
- /* SOFT_IIC utils */
- int pika_hal_utils_SOFT_IIC_config(pika_dev* dev,
- pika_hal_SOFT_IIC_config* cfg) {
- int ret = pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, cfg);
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- }
- return ret;
- }
- /* WIFI utils */
- int pika_hal_utils_WIFI_config(pika_dev* dev, pika_hal_WIFI_config* cfg) {
- int ret = pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, cfg);
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- }
- return ret;
- }
- /* SG utils */
- int pika_hal_utils_SG_config(pika_dev* dev, pika_hal_SG_config* cfg) {
- int ret = pika_hal_ioctl(dev, PIKA_HAL_IOCTL_CONFIG, cfg);
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- }
- return ret;
- }
- pika_float pika_hal_utils_SG_read(pika_dev* dev) {
- pika_float val = 0;
- int ret = pika_hal_read(dev, &val, sizeof(pika_float));
- if (ret < 0) {
- pika_hal_utils_raise_error(ret);
- return -1;
- }
- return val;
- }
|