打印

关于ADC转换问题

[复制链接]
1302|13
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
Snow7|  楼主 | 2017-11-18 10:57 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

以下是厂家提供的例程,注释部分是自己查资料加的
/*********************************************************************
** Module Name:  AD               **
** Author:          CTH              **
** Version:      1.0              **
** CreateDate:      2009-8-10            **
** Description:                         **
** Remark:                     **
** Revision History: 2009-8-10            **
**  Web:    http://www.study-kit.com     **
**********************************************************************/
/*********************************************************************
** 实验目的: 测试与使用dsp内部资源AD两个通道                       **
** 实验说明:nADC0通道0存放数据   nADC1 通道1存放数据               **
**********************************************************************/

/*ADC寄存器*/
ioport unsigned int *ADCCTL1=(unsigned int *)0x6800;  //ADC控制寄存器1
ioport unsigned int *ADCDATA1=(unsigned int *)0x6801; //ADC数据寄存器1
ioport unsigned int *ADCclkDIV1=(unsigned int *)0x6802; //ADC时钟分频寄存器1
ioport unsigned int *ADCCLKCTL1=(unsigned int *)0x6803; //ADC时钟控制寄存器1
/*寄存器值宏定义*/
#define ADCCTL (*ADCCTL1)
#define ADCDATA (*ADCDATA1)
#define ADCCLKDIV (*ADCCLKDIV1)
#define ADCCLKCTL (*ADCCLKCTL1)
/*配置函数声明*/
void interrupt tint( void );
void CLK_init( void );
void sdram_init( void );
void INTR_init( void );
void TIME_init(void);
void TMCR_Reset( void );
void SetDSPpll(unsigned int uPLL);
void InitADC();
void wait( unsigned int cycles );
void EnableAPLL( );
unsigned int nADC0[256],nADC1[256]; //10位数据位,可能的离散值有1024个,为什么是256?
main()
{
int i;
unsigned int uWork;

    EnableAPLL();   //使能数字锁相环
InitADC();      //ADC初始化
    PLL_Init(132);  //锁相环初始化
while ( 1 )
{
  for ( i=0;i<256;i++ )
  {
   ADCCTL=0x8000; // 启动AD转换,通道0
   do
   {
    uWork=ADCDATA;        //数据寄存器的值赋给uwork 变量
   } while ( uWork&0x8000 ); //模数转换开始,转换结束的标志是ADstart=0
   nADC0=uWork&0x0fff;
  }
  for ( i=0;i<256;i++ )
  {
   ADCCTL=0x9000; // 启动AD转换,通道1
   do
   {
    uWork=ADCDATA;
   } while ( uWork&0x8000 );
   nADC1=uWork&0x0fff; //这里的&表示什么含义?
  }
  asm( " nop");  // break point 在这里设断点
}
}
/**********************************************************************************
**(1) 模数转换器时钟ADCclk=144/(35+1)=4MHz
**(2) 模数转换时钟 ADC conversion clk = ADC clk/(2*(ConvRateDiv+1)=2MHz(最大)
      ADC 转换时间=13*(1/ADC conversion clk)=13*(1/2)=6.5us
**(3)采样保持时间=(1/ADCclk)/(2*(ConvRateDiv+1+SampTimeDiv))
                 =(1/4)/(2*(0+1+79))
     =250ns*(2*(0+1+79))=40us
由此:整个转换时间=采样保持时间+转换时间=40+6.5=46.5us
      采样率=1/46.5=21.5KHz
***********************************************************************************/
void InitADC()
{
ADCCLKCTL=0x23;    // 4MHz ADCLK 系统主时钟分频 cpuCLkDiv=35
ADCCLKDIV=0x4f00; // 采样和保持时间设置 SampTimeDiv=79,ConvRateDiv=0
}
void wait( unsigned int cycles )
{
    int i;
    for ( i = 0 ; i < cycles ; i++ ){ }
}
/* 访问DSP I/O空间,借助关键字ioport来实现
   访问DSP 片上外设方法是借助外设的映射寄存器地址
   定义借助 volatile关键字       */
void EnableAPLL( )
{
    /* Enusre DPLL is running */
    *( ioport volatile unsigned short* )0x1f00 = 4;
    wait( 25 );
    *( ioport volatile unsigned short* )0x1f00 = 0;
    // MULITPLY
    *( ioport volatile unsigned short* )0x1f00 = 0x3000;
    // COUNT
    *( ioport volatile unsigned short* )0x1f00 |= 0x4F8;
    wait( 25 );
    //*( ioport volatile unsigned short* )0x1f00 |= 0x800
    // MODE
    *( ioport volatile unsigned short* )0x1f00 |= 2;
    wait( 30000 );
    // APLL Select
    *( ioport volatile unsigned short* )0x1e80 = 1;
    // DELAY
    wait( 60000 );
}

不明白的是
(1)EnableApLL()函数的作用是什么?里面的代码又该如何解释?
(2)ADC转换后是10位数据位,应该有2的10次方,共1024个离散值,但是nADC0[256],nADC1[256]是256,也就是只采样256次,这样模数转换之后的数据不是丢失了一部分?还是说表示其他含义?

相关帖子

沙发
android2| | 2017-11-18 11:19 | 只看该作者
EnableApLL()函数的作用是什么?里面的代码又该如何解释?
應該是倍頻除頻成ADC Module可用的CLOCK訊號

使用特权

评论回复
板凳
拉克丝| | 2017-11-18 11:27 | 只看该作者
ADC转换后是10位数据位,应该有2的10次方,共1024个离散值,但是nADC0[256],nADC1[256]是256,也就是只采样256次,这样模数转换之后的数据不是丢失了一部分?还是说表示其他含义?
10bit ADC 每次轉換後可以得到 0xOOO 資料
nADC0[256],nADC1[256] 是ARRAY吧, 可以放 256筆 0XOOO資料

使用特权

评论回复
地板
lefeng| | 2017-11-18 11:36 | 只看该作者
大概猜到是设置系统时钟的问题,但是代码里面的语句该如何解释?

使用特权

评论回复
5
CaLipton| | 2017-11-18 11:43 | 只看该作者
用PLL_config结构体不行吗?

使用特权

评论回复
6
Rospiers| | 2017-11-18 17:29 | 只看该作者
ready是什么意思?

使用特权

评论回复
7
Lewisnx| | 2017-11-18 17:39 | 只看该作者
程式碼就看你怎麼寫,
你可以寫得很結構化,例如將所有參數寫成PLL_Config
也可以如您貼的**,一個一個暫存器去初始化

使用特权

评论回复
8
CCompton| | 2017-11-18 17:48 | 只看该作者
ARRAY= C語言陣列 = 用來存放相同資料型態的資料集合
大大可能要在溫習一下C語言,與8051,DSP書

使用特权

评论回复
9
usysm| | 2017-11-19 21:37 | 只看该作者
EnableAPLL( ); //使能模块的模拟锁相环

使用特权

评论回复
10
typeof| | 2017-11-19 21:37 | 只看该作者
楼主的参考电压是多大?

使用特权

评论回复
11
yujielun| | 2017-11-19 21:38 | 只看该作者
nADC1[256]是256可能跟你的数值大小有关系。

使用特权

评论回复
12
usysm| | 2017-11-19 21:51 | 只看该作者
楼主对这个PLL有什么问题吗?

使用特权

评论回复
13
typeof| | 2017-11-19 21:52 | 只看该作者
是不是参考电压的问题吗?

使用特权

评论回复
14
yujielun| | 2017-11-19 21:52 | 只看该作者
EnableApLL就是使能锁相环。

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

173

主题

926

帖子

3

粉丝