在好例子网,分享、交流、成长!
您当前所在位置:首页C/C++ 开发实例C/C++语言基础 → AD9854 入门级示例源码

AD9854 入门级示例源码

C/C++语言基础

下载此实例
  • 开发语言:C/C++
  • 实例大小:0.37M
  • 下载次数:5
  • 浏览次数:208
  • 发布时间:2019-07-18
  • 实例类别:C/C++语言基础
  • 发 布 人:crazycode
  • 文件格式:.zip
  • 所需积分:2
 相关标签: 入门级 示例 入门 源码

实例介绍

【实例简介】

【实例截图】

from clipboard

【核心代码】

#include  <msp430x16x.h>
#include "AD9854.h"
#include "key.h"
#include "cryfucns.h"

#define uint unsigned int
#define uchar unsigned char
#define ulong unsigned long

#define us _NOP();_NOP();_NOP();_NOP();_NOP();_NOP();_NOP();_NOP();_NOP();_NOP();
#define data_out P6OUT    //data P6
#define data_in P6IN
#define data_dir P6DIR  
#define add_out P5OUT//add P5
#define add_dir P5DIR
#define ctrl_out P4OUT//ctl P4
#define ctrl_dir P4DIR
#define UDCLK BIT6  
#define WR BIT5
#define RD BIT4
#define FBH BIT3//
#define SK BIT2//
#define SP BIT1//
#define RST BIT0

void init();
void init_9854();
void time_set();
void send_byte(uchar add,uchar data);
uchar read_byte(uchar add);
void delayus(int t);
void set_fre(long int freq);



uchar FTW1,FTW2,FTW3,FTW4,FTW5,FTW6,P_D,REF_CLK,UD_CLK1,UD_CLK2,UD_CLK3,UD_CLK4,OSKS,M_D;


//*************************clk*********************
void time_set()
{
    uchar i;
    BCSCTL1&=~XT2OFF;  //打开XT2振荡器
    do
    {
        IFG1 &= ~OFIFG;                 //清除晶振失败标志
        for (i = 0xFF; i > 0; i--);     //等待8MHz晶体起振
    }
    while ((IFG1 & OFIFG));             //晶振失效标志仍然存在?
    BCSCTL2 |= SELM_2   SELS;           //MCLK和SMCLK选择高频晶振
    IFG1&=~OFIFG;
    //P6DIR |= BIT2;P6OUT |= BIT2;    //关闭电平转换
   // P5OUT &= ~BIT7;
}

void set_fre(long int freq)			  //freq单位是赫兹,用48位寄存器编程控制
{
  unsigned char w[6];	
  //unsigned char i;
  long double fre;
  fre=(double)(freq*1407374.88355328);		//固定频率为2M
  w[0]=(int)(fre/1099511627776.0);
  w[1]=(int)(fre/4294967296.0)%256;
  w[2]=(long int)(fre/16777216.0)%256;
  w[3]=(long int)(fre/65536.0)%256;
  w[4]=(long int)(fre/256.0)%256;
  w[5]=(long int)fre%256;
  send_byte(FTW1_6,w[0]);		
  send_byte(FTW1_5,w[1]);
  send_byte(FTW1_4,w[2]);
  send_byte(FTW1_3,w[3]);
  send_byte(FTW1_2,w[4]);
  send_byte(FTW1_1,w[5]);
  //i=XBYTE[0x8000];   
}

void main(void)
{
  // Stop watchdog timer to prevent time out reset
  WDTCTL = WDTPW   WDTHOLD;
  init();
  init_9854();
  //send_byte(PD,0X00);      //turn to I dac and dig,but still off Q DAC,PD:DC,DC,DC,COMP0,QDAC,DAC,DIG
  ctrl_out &= ~UDCLK;
  
  set_fre(10000000);
  send_byte(OSKI_2,0X0f);          //设置I通道幅度
  send_byte(OSKI_1,0Xff);
        
  send_byte(OSKQ_2,0X0f);          //设置Q通道幅度
  send_byte(OSKQ_1,0Xff);
  
  _NOP();
  ctrl_out |= UDCLK;
  ctrl_out &= ~UDCLK;
  
  send_byte(PAR1_H,0x00);  
  send_byte(PAR1_L,0x00);
  send_byte(PAR2_H,0x00);
  send_byte(PAR2_L,0xff);
  
  ctrl_out |= UDCLK;
  ctrl_out &= ~UDCLK;
  _NOP();
  while(1);
  /*
  set_fre(20000000);
  delayus(100);
  while(1)
 {
  set_fre(20);
  delayus(100);
  set_fre(100);
  delayus(100);
  set_fre(500);
  delayus(100);
  set_fre(1000);
  delayus(100);
  set_fre(5000);
  delayus(100);
  set_fre(10000);
  delayus(100);
  set_fre(50000);
  delayus(100);
  set_fre(100000);
  delayus(100);	 
  set_fre(500000);
  delayus(100);
  set_fre(1000000);
  delayus(100);
  set_fre(5000000);
  delayus(100);
  set_fre(10000000);
  delayus(100);
  set_fre(20000000);
  delayus(100);
  set_fre(30000000);
  delayus(100);
  set_fre(40000000);
  delayus(100);
  set_fre(50000000);
  delayus(100);
 
 }
 */
  /*
  send_byte(FTW1_6,0x15);   //10M
  send_byte(FTW1_5,0x55);
  send_byte(FTW1_4,0x46);
  send_byte(FTW1_3,0x8c);
  send_byte(FTW1_2,0x40);
  send_byte(FTW1_1,0x00);
  */
  /*
  send_byte(FTW1_6,0x02);    //1M
  send_byte(FTW1_5,0x22);
  send_byte(FTW1_4,0x22);
  send_byte(FTW1_3,0x00);
  send_byte(FTW1_2,0x00);
  send_byte(FTW1_1,0x00);
  */
}
  

void init()
{
  time_set();
  data_dir = 0xff;
  add_dir = 0xff;
  ctrl_dir = 0xff;
  ctrl_out = 0x36;   //CP,UDCLK,F/B/H,RST=0;WR,RD,S/P,(O)SK=1; 0 UDCLK:0 WR:1 RD:1, FBH:0 SK:1 SP:1 RST:0  并行模式
}
#define UDCLK BIT6  
#define WR BIT5
#define RD BIT4
#define FBH BIT3//
#define SK BIT2//
#define SP BIT1//
#define RST BIT0//master  reset

void init_9854()
{
  //ctrl_out &= ~RST;
  //delayus(1);
  ctrl_out |= RST;
  delayus(10);
  ctrl_out &= ~RST;
  
  _NOP();
  ctrl_out &= ~UDCLK;
   
  send_byte(MOD,0x02);          //010
  send_byte(REFCLK,0x4A);          //
  send_byte(PD,0x10);          //          
  send_byte(OSK_S,0x60);          //
 
    /* 
  send_byte(REFCLK,0X4a);               //外部晶振为20M,AD9854系统时钟为200M,需10倍频
  delayus(4);
  send_byte(MOD,0x00);
  send_byte(UDCLK_1,0X20);
  delayus(2);
  
  send_byte(PD,0X17);
  send_byte(OSK_S,0X00);
 */
  ctrl_out |= UDCLK;
  _NOP();
  ctrl_out &= ~UDCLK;
}


void send_byte(uchar add,uchar data)
{
  data_dir = 0xff;
  ctrl_out |= WR;
  add_out = add;
  _NOP();          //add one nop
  ctrl_out &= ~WR;
  data_out = data;
  _NOP();          //add one nop
  ctrl_out |= WR;
  delayus(1);
}


uchar read_byte(uchar add)
{
  uchar dat;
  data_dir = 0x00;
  ctrl_out |= RD;
  add_out = add;
  //_NOP();       //newadd
  ctrl_out &= ~RD;
  _NOP();
  dat = data_in;
  ctrl_out |= RD;
  return dat;
}



void delayus(int t)
{
  while(t--)
    us;
}


实例下载地址

AD9854 入门级示例源码

不能下载?内容有错? 点击这里报错 + 投诉 + 提问

好例子网口号:伸出你的我的手 — 分享

网友评论

发表评论

(您的评论需要经过审核才能显示)

查看所有0条评论>>

小贴士

感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。

  • 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
  • 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
  • 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
  • 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。

关于好例子网

本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明

;
报警