2022-11-20 22:16:41 +08:00
|
|
|
#ifndef _PIKA_DEV_HAL_H
|
|
|
|
#define _PIKA_DEV_HAL_H
|
|
|
|
#include <stddef.h>
|
|
|
|
#include <stdint.h>
|
2022-12-07 19:25:28 +08:00
|
|
|
#include "PikaObj.h"
|
2022-11-20 22:16:41 +08:00
|
|
|
|
|
|
|
/*
|
2022-11-21 16:37:52 +08:00
|
|
|
* pika_hal is a C Device HAL lib for PikaScript modules.
|
|
|
|
* the API of pika_hal is similar to the posix file API.
|
2022-11-20 22:16:41 +08:00
|
|
|
*/
|
|
|
|
|
2022-11-21 16:37:52 +08:00
|
|
|
typedef enum {
|
2022-11-20 23:55:03 +08:00
|
|
|
#define PIKA_HAL_TABLE_DEV_TYPE
|
|
|
|
#include "pika_hal_table.h"
|
2022-11-21 16:37:52 +08:00
|
|
|
} PIKA_HAL_DEV_TYPE;
|
|
|
|
|
2022-11-21 17:47:43 +08:00
|
|
|
typedef struct {
|
|
|
|
PIKA_HAL_DEV_TYPE type;
|
2022-12-07 19:25:28 +08:00
|
|
|
PIKA_BOOL is_enabled;
|
2022-11-21 20:49:43 +08:00
|
|
|
void* ioctl_config;
|
2022-11-21 17:47:43 +08:00
|
|
|
void* platform_data;
|
|
|
|
} pika_dev;
|
|
|
|
|
2022-11-21 16:37:52 +08:00
|
|
|
typedef enum {
|
2022-11-21 17:47:43 +08:00
|
|
|
PIKA_HAL_IOCTL_CONFIG,
|
2022-11-21 16:37:52 +08:00
|
|
|
PIKA_HAL_IOCTL_ENABLE,
|
|
|
|
PIKA_HAL_IOCTL_DISABLE,
|
2023-01-10 20:57:06 +08:00
|
|
|
_ = 0xFFFFFFFF, // make sure it is 4 byte width
|
2022-11-21 16:37:52 +08:00
|
|
|
} PIKA_HAL_IOCTL_CMD;
|
|
|
|
|
2022-11-21 18:28:10 +08:00
|
|
|
/* posix file like API */
|
|
|
|
pika_dev* pika_hal_open(PIKA_HAL_DEV_TYPE dev_type, char* name);
|
|
|
|
int pika_hal_close(pika_dev* dev);
|
|
|
|
int pika_hal_read(pika_dev* dev, void* buf, size_t len);
|
|
|
|
int pika_hal_write(pika_dev* dev, void* buf, size_t len);
|
|
|
|
int pika_hal_ioctl(pika_dev* dev, PIKA_HAL_IOCTL_CMD cmd, ...);
|
|
|
|
|
2022-11-21 16:37:52 +08:00
|
|
|
typedef enum {
|
2022-11-21 17:04:23 +08:00
|
|
|
_PIKA_HAL_GPIO_DIR_UNUSED = 0,
|
2022-11-21 16:37:52 +08:00
|
|
|
PIKA_HAL_GPIO_DIR_IN,
|
|
|
|
PIKA_HAL_GPIO_DIR_OUT,
|
|
|
|
} PIKA_HAL_GPIO_DIR;
|
|
|
|
|
|
|
|
typedef enum {
|
2022-11-21 17:04:23 +08:00
|
|
|
_PIKA_HAL_GPIO_PULL_UNUSED = 0,
|
2022-11-21 16:37:52 +08:00
|
|
|
PIKA_HAL_GPIO_PULL_NONE,
|
|
|
|
PIKA_HAL_GPIO_PULL_UP,
|
|
|
|
PIKA_HAL_GPIO_PULL_DOWN,
|
|
|
|
} PIKA_HAL_GPIO_PULL;
|
|
|
|
|
2022-11-21 17:47:43 +08:00
|
|
|
typedef enum {
|
|
|
|
_PIKA_HAL_GPIO_SPEED_UNUSED = 0,
|
2022-11-21 20:49:43 +08:00
|
|
|
PIKA_HAL_GPIO_SPEED_1M = 1000000,
|
|
|
|
PIKA_HAL_GPIO_SPEED_2M = 2000000,
|
|
|
|
PIKA_HAL_GPIO_SPEED_5M = 5000000,
|
|
|
|
PIKA_HAL_GPIO_SPEED_10M = 10000000,
|
|
|
|
PIKA_HAL_GPIO_SPEED_20M = 20000000,
|
|
|
|
PIKA_HAL_GPIO_SPEED_50M = 50000000,
|
|
|
|
PIKA_HAL_GPIO_SPEED_100M = 100000000,
|
2022-11-21 17:47:43 +08:00
|
|
|
} PIKA_HAL_GPIO_SPEED;
|
|
|
|
|
2022-12-22 14:22:39 +08:00
|
|
|
typedef enum {
|
|
|
|
_PIKA_HAL_EVENT_CALLBACK_ENA_UNUSED = 0,
|
|
|
|
PIKA_HAL_EVENT_CALLBACK_ENA_ENABLE,
|
|
|
|
PIKA_HAL_EVENT_CALLBACK_ENA_DISABLE,
|
|
|
|
} PIKA_HAL_EVENT_CALLBACK_ENA;
|
|
|
|
|
2022-12-22 14:54:51 +08:00
|
|
|
typedef enum {
|
2022-12-23 18:19:16 +08:00
|
|
|
_PIKA_HAL_GPIO_EVENT_SIGNAL_UNUSED = 0,
|
2022-12-22 14:54:51 +08:00
|
|
|
PIKA_HAL_GPIO_EVENT_SIGNAL_RISING,
|
|
|
|
PIKA_HAL_GPIO_EVENT_SIGNAL_FALLING,
|
2022-12-23 18:19:16 +08:00
|
|
|
PIKA_HAL_GPIO_EVENT_SIGNAL_ANY,
|
2022-12-22 14:54:51 +08:00
|
|
|
} PIKA_HAL_GPIO_EVENT_SIGNAL;
|
|
|
|
|
2022-11-21 16:37:52 +08:00
|
|
|
typedef struct {
|
|
|
|
PIKA_HAL_GPIO_DIR dir;
|
|
|
|
PIKA_HAL_GPIO_PULL pull;
|
2022-11-21 17:47:43 +08:00
|
|
|
PIKA_HAL_GPIO_SPEED speed;
|
2022-12-22 14:54:51 +08:00
|
|
|
void (*event_callback)(pika_dev* dev, PIKA_HAL_GPIO_EVENT_SIGNAL signal);
|
2022-12-23 18:19:16 +08:00
|
|
|
PIKA_HAL_GPIO_EVENT_SIGNAL event_callback_filter;
|
|
|
|
PIKA_HAL_EVENT_CALLBACK_ENA event_callback_ena;
|
2022-11-21 16:37:52 +08:00
|
|
|
} pika_hal_GPIO_config;
|
|
|
|
|
2022-11-21 17:47:43 +08:00
|
|
|
typedef enum {
|
|
|
|
_PIKA_HAL_UART_BAUDRATE_UNUSED = 0,
|
|
|
|
PIKA_HAL_UART_BAUDRATE_9600 = 9600,
|
|
|
|
PIKA_HAL_UART_BAUDRATE_19200 = 19200,
|
|
|
|
PIKA_HAL_UART_BAUDRATE_38400 = 38400,
|
|
|
|
PIKA_HAL_UART_BAUDRATE_57600 = 57600,
|
|
|
|
PIKA_HAL_UART_BAUDRATE_115200 = 115200,
|
|
|
|
PIKA_HAL_UART_BAUDRATE_2000000 = 2000000,
|
|
|
|
PIKA_HAL_UART_BAUDRATE_10000000 = 10000000,
|
|
|
|
} PIKA_HAL_UART_BAUDRATE;
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
_PIKA_HAL_UART_DATA_BITS_UNUSED = 0,
|
2022-11-21 19:07:31 +08:00
|
|
|
PIKA_HAL_UART_DATA_BITS_5 = 5,
|
|
|
|
PIKA_HAL_UART_DATA_BITS_6 = 6,
|
|
|
|
PIKA_HAL_UART_DATA_BITS_7 = 7,
|
|
|
|
PIKA_HAL_UART_DATA_BITS_8 = 8,
|
2022-11-21 17:47:43 +08:00
|
|
|
} PIKA_HAL_UART_DATA_BITS;
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
_PIKA_HAL_UART_STOP_BITS_UNUSED = 0,
|
2022-11-21 19:07:31 +08:00
|
|
|
PIKA_HAL_UART_STOP_BITS_1 = 1,
|
|
|
|
PIKA_HAL_UART_STOP_BITS_2 = 2,
|
2022-12-23 18:19:16 +08:00
|
|
|
PIKA_HAL_UART_STOP_BITS_1_5 = 3,
|
2022-11-21 17:47:43 +08:00
|
|
|
} PIKA_HAL_UART_STOP_BITS;
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
_PIKA_HAL_UART_PARITY_UNUSED = 0,
|
|
|
|
PIKA_HAL_UART_PARITY_NONE,
|
|
|
|
PIKA_HAL_UART_PARITY_ODD,
|
|
|
|
PIKA_HAL_UART_PARITY_EVEN,
|
|
|
|
} PIKA_HAL_UART_PARITY;
|
|
|
|
|
2022-12-22 14:54:51 +08:00
|
|
|
typedef enum {
|
2022-12-23 18:19:16 +08:00
|
|
|
_PIKA_HAL_UART_EVENT_SIGNAL_UNUSED = 0,
|
2022-12-22 14:54:51 +08:00
|
|
|
PIKA_HAL_UART_EVENT_SIGNAL_RX,
|
2022-12-23 18:19:16 +08:00
|
|
|
PIKA_HAL_UART_EVENT_SIGNAL_TX,
|
|
|
|
PIKA_HAL_UART_EVENT_SIGNAL_ANY,
|
2022-12-22 14:54:51 +08:00
|
|
|
} PIKA_HAL_UART_EVENT_SIGNAL;
|
|
|
|
|
2022-12-23 18:19:16 +08:00
|
|
|
typedef enum {
|
|
|
|
_PIKA_HAL_UART_FLOW_CONTROL_UNUSED = 0,
|
|
|
|
PIKA_HAL_UART_FLOW_CONTROL_NONE,
|
|
|
|
PIKA_HAL_UART_FLOW_CONTROL_RTS,
|
|
|
|
PIKA_HAL_UART_FLOW_CONTROL_CTS,
|
|
|
|
PIKA_HAL_UART_FLOW_CONTROL_RTS_CTS,
|
|
|
|
} PIKA_HAL_UART_FLOW_CONTROL;
|
|
|
|
|
2022-11-21 16:37:52 +08:00
|
|
|
typedef struct {
|
2022-11-21 17:47:43 +08:00
|
|
|
PIKA_HAL_UART_BAUDRATE baudrate;
|
|
|
|
PIKA_HAL_UART_DATA_BITS data_bits;
|
|
|
|
PIKA_HAL_UART_STOP_BITS stop_bits;
|
|
|
|
PIKA_HAL_UART_PARITY parity;
|
2022-12-23 18:19:16 +08:00
|
|
|
PIKA_HAL_UART_FLOW_CONTROL flow_control;
|
2022-12-22 14:54:51 +08:00
|
|
|
void (*event_callback)(pika_dev* dev, PIKA_HAL_UART_EVENT_SIGNAL signal);
|
2022-12-23 18:19:16 +08:00
|
|
|
PIKA_HAL_UART_EVENT_SIGNAL event_callback_filter;
|
|
|
|
PIKA_HAL_EVENT_CALLBACK_ENA event_callback_ena;
|
2023-01-18 12:23:30 +08:00
|
|
|
pika_dev* TX;
|
|
|
|
pika_dev* RX;
|
|
|
|
pika_dev* RTS;
|
|
|
|
pika_dev* CTS;
|
2022-11-21 16:37:52 +08:00
|
|
|
} pika_hal_UART_config;
|
|
|
|
|
2022-11-21 17:47:43 +08:00
|
|
|
typedef uint32_t PIKA_HAL_IIC_SLAVE_ADDR;
|
2022-12-07 19:25:28 +08:00
|
|
|
typedef uint32_t PIKA_HAL_IIC_MEM_ADDR;
|
|
|
|
|
|
|
|
typedef enum PIKA_HAL_IIC_MEM_ADDR_SIZE {
|
|
|
|
_PIKA_HAL_IIC_MEM_ADDR_SIZE_UNUSED = 0,
|
|
|
|
PIKA_HAL_IIC_MEM_ADDR_SIZE_8BIT = 1,
|
|
|
|
PIKA_HAL_IIC_MEM_ADDR_SIZE_16BIT = 2,
|
|
|
|
PIKA_HAL_IIC_MEM_ADDR_SIZE_24BIT = 3,
|
|
|
|
PIKA_HAL_IIC_MEM_ADDR_SIZE_32BIT = 4,
|
|
|
|
} PIKA_HAL_IIC_MEM_ADDR_SIZE;
|
|
|
|
|
|
|
|
typedef enum PIKA_HAL_IIC_MEM_ADDR_ENA {
|
|
|
|
_PIKA_HAL_IIC_MEM_ADDR_ENA_UNUSED = 0,
|
|
|
|
PIKA_HAL_IIC_MEM_ADDR_ENA_DISABLE,
|
|
|
|
PIKA_HAL_IIC_MEM_ADDR_ENA_ENABLE,
|
|
|
|
} PIKA_HAL_IIC_MEM_ADDR_ENA;
|
2022-11-21 17:47:43 +08:00
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
_PIKA_HAL_IIC_SPEED_UNUSED = 0,
|
2022-11-21 20:49:43 +08:00
|
|
|
PIKA_HAL_IIC_SPEED_100K = 100000,
|
|
|
|
PIKA_HAL_IIC_SPEED_400K = 400000,
|
|
|
|
PIKA_HAL_IIC_SPEED_1M = 1000000,
|
2022-11-21 17:47:43 +08:00
|
|
|
} PIKA_HAL_IIC_SPEED;
|
|
|
|
|
2022-12-07 19:25:28 +08:00
|
|
|
typedef enum PIKA_HAL_IIC_MASTER_OR_SLAVE {
|
|
|
|
_PIKA_HAL_IIC_MASTER_OR_SLAVE_UNUSED = 0,
|
|
|
|
PIKA_HAL_IIC_MASTER,
|
|
|
|
PIKA_HAL_IIC_SLAVE,
|
|
|
|
} PIKA_HAL_IIC_MASTER_OR_SLAVE;
|
|
|
|
|
|
|
|
typedef enum PIKA_HAL_IIC_ADDRESS_WIDTH {
|
|
|
|
_PIKA_HAL_IIC_ADDRESS_WIDTH_UNUSED = 0,
|
|
|
|
PIKA_HAL_IIC_ADDRESS_WIDTH_7BIT = 7,
|
|
|
|
PIKA_HAL_IIC_ADDRESS_WIDTH_10BIT = 10,
|
|
|
|
} PIKA_HAL_IIC_ADDRESS_WIDTH;
|
|
|
|
|
|
|
|
typedef enum PIKA_HAL_IIC_TIMEOUT {
|
|
|
|
_PIKA_HAL_IIC_TIMEOUT_UNUSED = 0,
|
|
|
|
PIKA_HAL_IIC_TIMEOUT_1MS = 1,
|
|
|
|
PIKA_HAL_IIC_TIMEOUT_2MS = 2,
|
|
|
|
PIKA_HAL_IIC_TIMEOUT_5MS = 5,
|
|
|
|
PIKA_HAL_IIC_TIMEOUT_10MS = 10,
|
|
|
|
PIKA_HAL_IIC_TIMEOUT_20MS = 20,
|
|
|
|
PIKA_HAL_IIC_TIMEOUT_50MS = 50,
|
|
|
|
PIKA_HAL_IIC_TIMEOUT_100MS = 100,
|
|
|
|
PIKA_HAL_IIC_TIMEOUT_200MS = 200,
|
|
|
|
PIKA_HAL_IIC_TIMEOUT_500MS = 500,
|
|
|
|
PIKA_HAL_IIC_TIMEOUT_1000MS = 1000,
|
|
|
|
} PIKA_HAL_IIC_TIMEOUT;
|
|
|
|
|
2022-11-21 16:37:52 +08:00
|
|
|
typedef struct {
|
2022-12-07 19:25:28 +08:00
|
|
|
PIKA_HAL_IIC_ADDRESS_WIDTH address_width;
|
|
|
|
PIKA_HAL_IIC_MASTER_OR_SLAVE master_or_slave;
|
|
|
|
PIKA_HAL_IIC_SLAVE_ADDR slave_addr;
|
|
|
|
PIKA_HAL_IIC_MEM_ADDR_ENA mem_addr_ena;
|
|
|
|
PIKA_HAL_IIC_MEM_ADDR mem_addr;
|
|
|
|
PIKA_HAL_IIC_MEM_ADDR_SIZE mem_addr_size;
|
2022-11-21 17:47:43 +08:00
|
|
|
PIKA_HAL_IIC_SPEED speed;
|
2022-12-07 19:25:28 +08:00
|
|
|
PIKA_HAL_IIC_TIMEOUT timeout;
|
2022-11-21 17:47:43 +08:00
|
|
|
} pika_hal_IIC_config;
|
2022-11-21 16:37:52 +08:00
|
|
|
|
2022-12-07 19:25:28 +08:00
|
|
|
typedef enum PIKA_HAL_SPI_TIMEOUT {
|
|
|
|
_PIKA_HAL_SPI_TIMEOUT_UNUSED = 0,
|
|
|
|
PIKA_HAL_SPI_TIMEOUT_1MS = 1,
|
|
|
|
PIKA_HAL_SPI_TIMEOUT_2MS = 2,
|
|
|
|
PIKA_HAL_SPI_TIMEOUT_5MS = 5,
|
|
|
|
PIKA_HAL_SPI_TIMEOUT_10MS = 10,
|
|
|
|
PIKA_HAL_SPI_TIMEOUT_20MS = 20,
|
|
|
|
PIKA_HAL_SPI_TIMEOUT_50MS = 50,
|
|
|
|
PIKA_HAL_SPI_TIMEOUT_100MS = 100,
|
|
|
|
PIKA_HAL_SPI_TIMEOUT_200MS = 200,
|
|
|
|
PIKA_HAL_SPI_TIMEOUT_500MS = 500,
|
|
|
|
PIKA_HAL_SPI_TIMEOUT_1000MS = 1000,
|
|
|
|
} PIKA_HAL_SPI_TIMEOUT;
|
|
|
|
|
2022-11-21 16:37:52 +08:00
|
|
|
typedef enum {
|
2022-11-21 17:04:23 +08:00
|
|
|
_PIKA_HAL_SPI_LSB_OR_MSB_UNUSED = 0,
|
2022-11-21 16:37:52 +08:00
|
|
|
PIKA_HAL_SPI_LSB,
|
|
|
|
PIKA_HAL_SPI_MSB,
|
|
|
|
} PIKA_HAL_SPI_LSB_OR_MSB;
|
|
|
|
|
|
|
|
typedef enum {
|
2022-11-21 17:04:23 +08:00
|
|
|
_PIKA_HAL_SPI_MASTER_OR_SLAVE_UNUSED = 0,
|
2022-11-21 16:37:52 +08:00
|
|
|
PIKA_HAL_SPI_MASTER,
|
|
|
|
PIKA_HAL_SPI_SLAVE,
|
|
|
|
} PIKA_HAL_SPI_MASTER_OR_SLAVE;
|
|
|
|
|
|
|
|
typedef enum {
|
2022-11-21 17:04:23 +08:00
|
|
|
_PIKA_HAL_SPI_MODE_UNUSED = 0,
|
2022-11-21 16:37:52 +08:00
|
|
|
PIKA_HAL_SPI_MODE_0,
|
|
|
|
PIKA_HAL_SPI_MODE_1,
|
|
|
|
PIKA_HAL_SPI_MODE_2,
|
|
|
|
PIKA_HAL_SPI_MODE_3,
|
|
|
|
} PIKA_HAL_SPI_MODE;
|
|
|
|
|
|
|
|
typedef enum {
|
2022-11-21 17:04:23 +08:00
|
|
|
_PIKA_HAL_SPI_DATA_UNUSED = 0,
|
2022-11-21 20:49:43 +08:00
|
|
|
PIKA_HAL_SPI_DATA_WIDTH_8 = 8,
|
|
|
|
PIKA_HAL_SPI_DATA_WIDTH_16 = 16,
|
2022-11-21 16:37:52 +08:00
|
|
|
} PIKA_HAL_SPI_DATA_WIDTH;
|
|
|
|
|
|
|
|
typedef enum {
|
2022-11-21 17:04:23 +08:00
|
|
|
_PIKA_HAL_SPI_SPEED_UNUSED = 0,
|
2022-11-21 20:49:43 +08:00
|
|
|
PIKA_HAL_SPI_SPEED_1M = 1000000,
|
|
|
|
PIKA_HAL_SPI_SPEED_2M = 2000000,
|
|
|
|
PIKA_HAL_SPI_SPEED_5M = 5000000,
|
|
|
|
PIKA_HAL_SPI_SPEED_10M = 10000000,
|
|
|
|
PIKA_HAL_SPI_SPEED_20M = 20000000,
|
|
|
|
PIKA_HAL_SPI_SPEED_50M = 50000000,
|
|
|
|
PIKA_HAL_SPI_SPEED_100M = 100000000,
|
2022-11-21 16:37:52 +08:00
|
|
|
} PIKA_HAL_SPI_SPEED;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
PIKA_HAL_SPI_LSB_OR_MSB lsb_or_msb;
|
|
|
|
PIKA_HAL_SPI_MASTER_OR_SLAVE master_or_slave;
|
|
|
|
PIKA_HAL_SPI_MODE mode;
|
|
|
|
PIKA_HAL_SPI_DATA_WIDTH data_width;
|
|
|
|
PIKA_HAL_SPI_SPEED speed;
|
2022-12-07 19:25:28 +08:00
|
|
|
PIKA_HAL_SPI_TIMEOUT timeout;
|
2022-11-21 16:37:52 +08:00
|
|
|
} pika_hal_SPI_config;
|
|
|
|
|
2022-12-27 18:53:26 +08:00
|
|
|
typedef struct {
|
|
|
|
PIKA_HAL_SPI_LSB_OR_MSB lsb_or_msb;
|
|
|
|
PIKA_HAL_SPI_MASTER_OR_SLAVE master_or_slave;
|
|
|
|
PIKA_HAL_SPI_MODE mode;
|
|
|
|
PIKA_HAL_SPI_DATA_WIDTH data_width;
|
|
|
|
PIKA_HAL_SPI_SPEED speed;
|
|
|
|
PIKA_HAL_SPI_TIMEOUT timeout;
|
|
|
|
pika_dev* CS;
|
|
|
|
pika_dev* SCK;
|
|
|
|
pika_dev* MOSI;
|
|
|
|
pika_dev* MISO;
|
|
|
|
} pika_hal_SOFT_SPI_config;
|
|
|
|
|
2022-11-21 17:47:43 +08:00
|
|
|
typedef enum {
|
|
|
|
_PIKA_HAL_ADC_RESOLUTION_UNUSED = 0,
|
2022-11-21 20:49:43 +08:00
|
|
|
PIKA_HAL_ADC_RESOLUTION_8 = 8,
|
|
|
|
PIKA_HAL_ADC_RESOLUTION_10 = 10,
|
|
|
|
PIKA_HAL_ADC_RESOLUTION_12 = 12,
|
|
|
|
PIKA_HAL_ADC_RESOLUTION_14 = 14,
|
|
|
|
PIKA_HAL_ADC_RESOLUTION_16 = 16,
|
2022-11-21 17:47:43 +08:00
|
|
|
} PIKA_HAL_ADC_RESOLUTION;
|
|
|
|
|
2022-12-07 19:25:28 +08:00
|
|
|
typedef enum PIKA_HAL_ADC_SAMPLING_FREQ {
|
|
|
|
_PIKA_HAL_ADC_SAMPLING_FREQ_UNUSED = 0,
|
|
|
|
PIKA_HAL_ADC_SAMPLING_FREQ_100 = 100,
|
|
|
|
PIKA_HAL_ADC_SAMPLING_FREQ_1K = 1000,
|
|
|
|
PIKA_HAL_ADC_SAMPLING_FREQ_10K = 10000,
|
|
|
|
PIKA_HAL_ADC_SAMPLING_FREQ_100K = 100000,
|
|
|
|
PIKA_HAL_ADC_SAMPLING_FREQ_1M = 1000000,
|
|
|
|
PIKA_HAL_ADC_SAMPLING_FREQ_10M = 10000000,
|
|
|
|
} PIKA_HAL_ADC_SAMPLING_FREQ;
|
|
|
|
|
|
|
|
typedef enum PIKA_HAL_ADC_CONTINUOU_OR_SINGLE {
|
|
|
|
_PIKA_HAL_ADC_CONTINUOU_OR_SINGLE_UNUSED = 0,
|
|
|
|
PIKA_HAL_ADC_SINGLE,
|
|
|
|
PIKA_HAL_ADC_CONTINUOU,
|
|
|
|
} PIKA_HAL_ADC_CONTINUOU_OR_SINGLE;
|
|
|
|
|
|
|
|
typedef pika_float PIKA_HAL_ADC_VREF;
|
|
|
|
typedef uint32_t PIKA_HAL_ADC_MAX;
|
|
|
|
|
2022-11-21 16:37:52 +08:00
|
|
|
typedef struct {
|
2022-12-07 19:25:28 +08:00
|
|
|
PIKA_HAL_ADC_RESOLUTION sampling_resolution;
|
|
|
|
PIKA_HAL_ADC_SAMPLING_FREQ sampling_freq;
|
|
|
|
PIKA_HAL_ADC_CONTINUOU_OR_SINGLE continue_or_single;
|
|
|
|
PIKA_HAL_ADC_MAX max;
|
|
|
|
PIKA_HAL_ADC_VREF vref;
|
2022-11-21 16:37:52 +08:00
|
|
|
} pika_hal_ADC_config;
|
|
|
|
|
2022-12-07 19:25:28 +08:00
|
|
|
typedef enum {
|
|
|
|
_PIKA_HAL_DAC_RESOLUTION_UNUSED = 0,
|
|
|
|
PIKA_HAL_DAC_RESOLUTION_8 = 8,
|
|
|
|
PIKA_HAL_DAC_RESOLUTION_10 = 10,
|
|
|
|
PIKA_HAL_DAC_RESOLUTION_12 = 12,
|
|
|
|
PIKA_HAL_DAC_RESOLUTION_14 = 14,
|
|
|
|
PIKA_HAL_DAC_RESOLUTION_16 = 16,
|
|
|
|
} PIKA_HAL_DAC_RESOLUTION;
|
|
|
|
|
|
|
|
typedef enum PIKA_HAL_DAC_SPEED {
|
|
|
|
_PIKA_HAL_DAC_SPEED_UNUSED = 0,
|
|
|
|
PIKA_HAL_DAC_SPEED_100 = 100,
|
|
|
|
PIKA_HAL_DAC_SPEED_1K = 1000,
|
|
|
|
PIKA_HAL_DAC_SPEED_10K = 10000,
|
|
|
|
PIKA_HAL_DAC_SPEED_100K = 100000,
|
|
|
|
PIKA_HAL_DAC_SPEED_1M = 1000000,
|
|
|
|
PIKA_HAL_DAC_SPEED_10M = 10000000,
|
|
|
|
PIKA_HAL_DAC_SPEED_20M = 20000000,
|
|
|
|
PIKA_HAL_DAC_SPEED_50M = 50000000,
|
|
|
|
PIKA_HAL_DAC_SPEED_100M = 100000000,
|
|
|
|
} PIKA_HAL_DAC_SPEED;
|
|
|
|
|
|
|
|
typedef pika_float PIKA_HAL_DAC_VREF;
|
|
|
|
typedef uint32_t PIKA_HAL_DAC_MAX;
|
|
|
|
|
|
|
|
typedef struct pika_hal_DAC_config {
|
|
|
|
PIKA_HAL_DAC_RESOLUTION sampling_resolution;
|
|
|
|
PIKA_HAL_DAC_SPEED speed;
|
|
|
|
PIKA_HAL_DAC_MAX max;
|
|
|
|
PIKA_HAL_DAC_VREF vref;
|
|
|
|
} pika_hal_DAC_config;
|
|
|
|
|
2022-11-21 17:47:43 +08:00
|
|
|
typedef enum {
|
|
|
|
_PIKA_HAL_DAC_UNUSED = 0,
|
|
|
|
PIKA_HAL_PWM_CHANNEL_0,
|
|
|
|
PIKA_HAL_PWM_CHANNEL_1,
|
|
|
|
PIKA_HAL_PWM_CHANNEL_2,
|
|
|
|
PIKA_HAL_PWM_CHANNEL_3,
|
|
|
|
PIKA_HAL_PWM_CHANNEL_4,
|
|
|
|
PIKA_HAL_PWM_CHANNEL_5,
|
|
|
|
PIKA_HAL_PWM_CHANNEL_6,
|
|
|
|
PIKA_HAL_PWM_CHANNEL_7,
|
|
|
|
} PIKA_HAL_PWM_CHANNEL;
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
PIKA_HAL_PWM_PERIOD_1NS = 1,
|
|
|
|
PIKA_HAL_PWM_PERIOD_1US = 1000,
|
|
|
|
PIKA_HAL_PWM_PERIOD_1MS = 1000000,
|
|
|
|
PIKA_HAL_PWM_PERIOD_1S = 1000000000,
|
|
|
|
} PIKA_HAL_PWM_PERIOD;
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
PIKA_HAL_PWM_DUTY_1NS = 1,
|
|
|
|
PIKA_HAL_PWM_DUTY_1US = 1000,
|
|
|
|
PIKA_HAL_PWM_DUTY_1MS = 1000000,
|
|
|
|
PIKA_HAL_PWM_DUTY_1S = 1000000000,
|
|
|
|
} PIKA_HAL_PWM_DUTY;
|
2022-11-21 16:37:52 +08:00
|
|
|
|
|
|
|
typedef struct {
|
2022-11-21 17:47:43 +08:00
|
|
|
PIKA_HAL_PWM_PERIOD period;
|
|
|
|
PIKA_HAL_PWM_DUTY duty;
|
|
|
|
} pika_hal_PWM_config;
|
2022-11-20 22:16:41 +08:00
|
|
|
|
|
|
|
typedef struct pika_dev_impl {
|
2022-11-21 16:37:52 +08:00
|
|
|
int (*open)(pika_dev* dev, char* name);
|
2022-11-20 22:16:41 +08:00
|
|
|
int (*close)(pika_dev* dev);
|
2022-11-21 16:37:52 +08:00
|
|
|
int (*read)(pika_dev* dev, void* buf, size_t count);
|
|
|
|
int (*write)(pika_dev* dev, void* buf, size_t count);
|
2022-11-21 20:49:43 +08:00
|
|
|
int (*ioctl)(pika_dev* dev, PIKA_HAL_IOCTL_CMD cmd, void* cfg);
|
2022-11-20 22:16:41 +08:00
|
|
|
} pika_dev_impl;
|
|
|
|
|
2022-11-21 16:37:52 +08:00
|
|
|
/* platform API */
|
|
|
|
#define PIKA_HAL_TABLE_PLATFORM_API
|
|
|
|
#include "pika_hal_table.h"
|
2022-11-20 22:16:41 +08:00
|
|
|
|
2022-11-21 20:49:43 +08:00
|
|
|
/* config merge headers */
|
|
|
|
#define PIKA_HAL_TABLE_IOCTL_MERGE_CONFIG_HEADER
|
|
|
|
#include "pika_hal_table.h"
|
|
|
|
|
2022-11-20 22:16:41 +08:00
|
|
|
#endif
|