【ARM】ADC·FS2410数模转换

简介:

开发环境


       1、硬件平台:FS2410

       2、主机:Ubuntu 12.04



ADC寄存器配置


      1、初始化ADC(ADCCON)

       设置预分频,预分频因子,选择A/D转换通道,并选择正常模式且启动转换

      2、判断转换是否结束(ADCCON[5])

      3、读取转换结果(ADCDATn)



串口的初始化


       见《串口通信·FS2410》:http://infohacker.blog.51cto.com/6751239/1223137



源代码


      //adc.c

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
#include "2410addr.h"      //头文件,包含寄存器的设置
                                       
void  putc ( char  ch)       //发送字符
{
     while (!(rUTRSTAT0 & 0X2));     //判断发送缓冲区是否为空
                                            
     rUTXH0 = ch;         //发送
}
                                       
char  getc ( void )        //接收字符
{
     while (!(rUTRSTAT0 & 0X1));      //判断接收缓冲区是否为空
                                           
     return  rURXH0;       //接收
}
                                       
void  putstr( char  *str)       //发送字符串
{
     while (*str !=  '\0' )
     {
         if (*str ==  '\n' )
         {
             putc ( '\n' );
             putc ( '\r' );
         }
         else
             putc (*str);
                                               
         str++;
     }
}
                                       
void  wait( long  long  max)       //延迟函数
{
     for (; max > 0; max--)
         ;
}
                                       
void  itoa(unsigned  long  value)     //进行字符转换
{
     unsigned  long  temp;
     int  i, flag = 0;
     char  data[4];
                                           
     for (i = 0; i < 4; i++)     //清空数组
         data[i] =  '\0' ;
                                       
     for (i = 0; i < 3; i++)
     {
         temp = (value >> 4 * i) & 0xf;
                                               
         if (temp < 10)
             data[2 - i] =  '0'  + temp;
         else
         {
             if (temp <= 0xf)
                 data[2 - i] =  'a'  + temp - 10;
         }
     }
                                       
     putstr( " Value of AIN0 is 0x" );
     putstr(data);
                                           
     putstr( "\r" );
     putstr( "\n" );
}
                                       
int  main( void )
{
     rGPHCON = rGPHCON & ~(0xf << 4) | (0xa << 4);     //配置RDX0与TDX0
     rGPHUP = 0X0c;      //设置上拉电阻
                                       
     rUFCON0 = 0;     //不用FIFO</span></span>
     rUMCON0 = 0;     //不用流控</span></span>
     rULCON0 = 0X3;   //8位数据,1个停止位,无校验,正常模式
     rUCON0 = 0X5;    //时钟源位PCLK,中断方式为查询
     rUBRDIV0 = (( int )(50000000 / 115200 / 16) - 1);  //设置波特率为115200
     rADCCON = 0x4c41;   //初始化ADC
                                       
     putstr( "\nThis is ADC test:\n" );
                                       
     unsigned  long  temp = 0;
                                           
     while (1)
     {
         while ((rADCCON & (1 << 15)) == 0);      //判断是否转换结束
                                       
         temp = rADCDAT0;      //读取转换值
         itoa(temp);
                                               
         rADCCON = 0x4c41;      //再启动ADC
         wait(200000);
     }
                                       
     return  0;
}


     //start.S

1
2
3
4
5
6
7
8
9
10
11
12
13
.text
.global _start
_start:
#define WATCHDOG 0x53000000
     ldr r0, =WATCHDOG
     mov r1, #0
     str r1, [r0]
                                   
     ldr sp, =1024*4
     bl main
                                   
loop:
     b loop


     //Makefile

1
2
3
4
5
6
7
8
adc.bin: start.S adc.c
     arm-linux-gcc -c start.S -o start.o
     arm-linux-gcc -c adc.c -o adc.o
     arm-linux-ld -Ttext 0x30008000 start.o adc.o -o adc
     arm-linux-objcopy -O binary -S adc adc.bin
                                 
clean:
     rm  -f *.o adc.bin




编译链接


     OK,成功!



本文转自infohacker 51CTO博客,原文链接:http://blog.51cto.com/liucw/1224923


相关文章
|
11天前
|
机器学习/深度学习 弹性计算 人工智能
阿里云服务器架构有啥区别?X86计算、Arm、GPU异构、裸金属和高性能计算对比
阿里云ECS涵盖x86、ARM、GPU/FPGA/ASIC、弹性裸金属及高性能计算等多种架构。x86架构采用Intel/AMD处理器,适用于广泛企业级应用;ARM架构低功耗,适合容器与微服务;GPU/FPGA/ASIC专为AI、图形处理设计;弹性裸金属提供物理机性能;高性能计算则针对大规模并行计算优化。
|
2月前
|
编解码 弹性计算 应用服务中间件
阿里云服务器Arm计算架构解析:Arm计算架构云服务器租用收费标准价格参考
阿里云服务器架构分为X86计算、Arm计算、高性能计算等多种架构,其中Arm计算架构以其低功耗、高效率的特点受到广泛关注。本文将深入解析阿里云Arm计算架构云服务器的技术特点、适用场景以及包年包月与按量付费的收费标准与最新活动价格情况,以供选择参考。
|
2月前
|
机器学习/深度学习 弹性计算 编解码
阿里云服务器计算架构X86/ARM/GPU/FPGA/ASIC/裸金属/超级计算集群有啥区别?
阿里云服务器ECS提供了多种计算架构,包括X86、ARM、GPU/FPGA/ASIC、弹性裸金属服务器及超级计算集群。X86架构常见且通用,适合大多数应用场景;ARM架构具备低功耗优势,适用于长期运行环境;GPU/FPGA/ASIC则针对深度学习、科学计算、视频处理等高性能需求;弹性裸金属服务器与超级计算集群则分别提供物理机级别的性能和高速RDMA互联,满足高性能计算和大规模训练需求。
|
2月前
|
存储 Docker 容器
ARM架构鲲鹏主机BClinux离线安装docker步骤
下载并安装适用于ARM架构的Docker CE二进制文件,解压后移动至/usr/bin目录。创建docker组,配置systemd服务脚本(docker.service、docker.socket、containerd.service),重载systemd配置,启动并启用docker服务。编辑daemon.json配置存储驱动、镜像加速地址等,最后拉取所需镜像。
53 0
|
2月前
|
NoSQL MongoDB Docker
求助,有没有大神可以找到arm64架构下mongodb的3.6.8版本的docker镜像?
在Docker Hub受限的情况下,寻求适用于ARM架构的docker镜像资源或拉取链接,以便在x86架构上获取;内网中的机器为ARM架构,因此优先请求适合ARM的Docker镜像或Dockerfile,非常感激您的帮助。
|
4月前
|
编解码 安全 Linux
基于arm64架构国产操作系统|Linux下的RTMP|RTSP低延时直播播放器开发探究
这段内容讲述了国产操作系统背景下,大牛直播SDK针对国产操作系统与Linux平台发布的RTMP/RTSP直播播放SDK。此SDK支持arm64架构,基于X协议输出视频,采用PulseAudio和Alsa Lib处理音频,具备实时静音、快照、缓冲时间设定等功能,并支持H.265编码格式。此外,提供了示例代码展示如何实现多实例播放器的创建与管理,包括窗口布局调整、事件监听、视频分辨率变化和实时快照回调等关键功能。这一技术实现有助于提高直播服务的稳定性和响应速度,适应国产操作系统在各行业中的应用需求。
122 3
|
3月前
ARM64架构提供的Cache操作
ARM64架构提供的Cache操作