接口设计
Driver 层接口设计
以下接口是 GPAI 设备驱动框架的标准接口。
struct rt_adc_ops { rt_err_t (*enabled)(struct rt_adc_device *device, rt_uint32_t channel, rt_bool_t enabled); rt_err_t (*convert)(struct rt_adc_device *device, rt_uint32_t channel, rt_uint32_t *value); rt_uint8_t (*get_resolution)(struct rt_adc_device *device); rt_int16_t (*get_vref) (struct rt_adc_device *device); };
其中的 get_vref() 暂未支持。
函数原型 | rt_err_t drv_gpai_enabled(struct rt_adc_device *dev, rt_uint32_t ch, rt_bool_t enabled) |
---|---|
功能说明 | 使能一个 ADC 通道 |
参数定义 | dev - 指向 ADC 设备 ch - 指定 ADC 通道的通道编号 enable - 使能 |
返回值 | 0,成功; < 0,失败 |
注意事项 | - |
函数原型 | rt_err_t drv_gpai_convert(struct rt_adc_device *dev, rt_uint32_t ch, rt_uint32_t *value) |
---|---|
功能说明 | 读取一个 ADC 通道的当前数据 |
参数定义 | dev - 指向 ADC 设备 ch - 指定 ADC 通道的通道编号 value - 用于保存返回的 ADC 数据 |
返回值 | 0,成功; < 0,失败 |
注意事项 | - |
函数原型 | rt_err_t drv_gpai_resolution(struct rt_adc_device *dev) |
---|---|
功能说明 | 获取 GPAI 控制器的采样精度 |
参数定义 | dev - 指向 ADC 设备 |
返回值 | 12,表示 12bit 的采样精度 |
注意事项 | - |
HAL 层接口设计
HAL 层的函数接口声明存放在 hal_gpai.h
中,主要接口有:
void aich_gpai_enable(int enable); void aich_gpai_ch_enable(u32 ch, int enable); int aich_gpai_ch_init(struct aic_gpai_ch *chan, u32 pclk); irqreturn_t aich_gpai_isr(int irq, void *arg); int aich_gpai_read(struct aic_gpai_ch *chan, u32 *val, u32 timeout); s32 aich_gpai_data2vol(u16 data); struct aic_gpai_ch *hal_gpai_ch_is_valid(u32 ch); void hal_gpai_set_ch_num(u32 num); void aich_gpai_status_show(struct aic_gpai_ch *chan);