SAR使用参考

Version 1.0


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;
}