实例介绍
【实例简介】
【实例截图】
【核心代码】
#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; }
好例子网口号:伸出你的我的手 — 分享!
小贴士
感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。
- 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
- 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
- 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
- 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。
关于好例子网
本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明
网友评论
我要评论