SAR使用参考
1. 概述¶
公板提供2组Sar接口,SAR口的ADC精度是8bit(回读的数据是10bit)。
本文主要介绍sar口如何配置以及如何在用户层使用sar口。
2. Dts配置¶
2.1. Demo 板支持的SAR adc接口¶
Sar interface | PAD |
---|---|
Sar 0 | PAD_SAR_GPIO0 |
Sar 1 | PAD_SAR_GPIO1 |
2.2. 配置SAR节点属性¶
pioneer3 -demo.dtsi:
2.3. Padmux中将对应的pin配置成sar mode¶
pioneer3-ssc020a-s01a-padmux.dtsi
3. Kernel配置¶
Kernel config中打开CONFIG_MS_SAR
配置完成后,重新编译kernel,替换kernel image到project烧录
4. SAR控制¶
4.1. SAR控制概述¶
SAR驱动程序为用户提供ioctl接口,用做初始化SAR并获取SAR_ADC值。
4.2. 用户层使用SAR¶
4.2.1. SAR 设备¶
"/dev/sar”
4.2.2. SAR IOCTL 命令¶
IOCTL 命令 | 参 | 描述 |
---|---|---|
IOCTL_SAR_INIT | NULL | initialize |
IOCTL_SAR_SET_CHANNEL_READ_VALUE | typedef struct { int channel_value; //[IN] int adc_value; //[OUT] } SAR_ADC_CONFIG_READ; channel_value: sar channel number(possible value: 0 or 1) adc_value: sar adc value | Get sar adc value |
4.2.3. 举例¶
#include <stdio.h> #include <unistd.h> #include <string.h> #include <fcntl.h> #include <errno.h> #include <sys/types.h> #include <sys/stat.h> #include <sys/ioctl.h> typedef struct { int channel_value; int adc_value; } SAR_ADC_CONFIG_READ; #define SARADC_IOC_MAGIC 'a' #define IOCTL_SAR_INIT _IO(SARADC_IOC_MAGIC, 0) #define IOCTL_SAR_SET_CHANNEL_READ_VALUE _IO(SARADC_IOC_MAGIC, 1) int main(void) { int i; SAR_ADC_CONFIG_READ adcCfg; adcCfg.channel_value = 0; //注意:PAD_SAR_GPIO0 = 0 PAD_SAR_GPIO1 = 1 PAD_SAR_GPIO2 = 2 int fd = open("/dev/sar", O_WRONLY); if(fd == -1) { int err = errno; printf("\n!!! FAILED to open /dev/sar, errno: %d %s\n", err, strerror(err)); return -1; } if (ioctl(fd, IOCTL_SAR_INIT, NULL) < 0) { int err = errno; printf("\n!!! IOCTL_SAR_INIT FAILED, errno: %d, %s\n", err, strerror(err)); } for (i=0; i < 500; i++) { if (ioctl(fd, IOCTL_SAR_SET_CHANNEL_READ_VALUE, &adcCfg) < 0) { int err = errno; printf("\n!!! IOCTL_SAR_SET_CHANNEL_READ_VALUE FAILED, errno: %d, %s\n", err, strerror(err)); } else { printf("SAR: get value %04d, 0x%03x \n", adcCfg.adc_value, adcCfg.adc_value); } usleep(100000); } return 0; }