📄 复件 main.c
字号:
/*
*Author hejun
*Date 2006_7_12
*/
/*SystemClock=180MHz*/
//F_out=10MHz FrqDWord=238609294; W1=0x0e; W2=0x38; W3=0xe3; W4=0x83;//(W1=Freq–b31__Freq–b3Freq–b24)
//F_out=5MHz FrqDWord=119304647; W1=0x07; W2=0x1c; W3=0x71; W4=0xc7;//(W1=Freq–b31__Freq–b3Freq–b24)
//F_out=1MHz FrqDWord=23860929; W1=0x01; W2=0x6c; W3=0x16; W4=0xc1;//(W1=Freq–b31__Freq–b3Freq–b24)
//F_out=100kHz FrqDWord=2386093; W1=0x00; W2=0x24; W3=0x68; W4=0xad;//(W1=Freq–b31__Freq–b3Freq–b24)
//F_out=50kHz FrqDWord=1193046; W1=0x00; W2=0x12; W3=0x34; W4=0x56;//(W1=Freq–b31__Freq–b3Freq–b24)
//F_out=10kHz FrqDWord=238609; W1=0x00; W2=0x03; W3=0xa4; W4=0x11;//(W1=Freq–b31__Freq–b3Freq–b24)
//F_out=5kHz FrqDWord=119305; W1=0x00; W2=0x01; W3=0xd2; W4=0x09;//(W1=Freq–b31__Freq–b3Freq–b24)
//F_out=1kHz FrqDWord=23861; W1=0x00; W2=0x00; W3=0x5d; W4=0x35;//(W1=Freq–b31__Freq–b3Freq–b24)
//F_out=100Hz FrqDWord=2386; W1=0x00; W2=0x00; W3=0x09; W4=0x52;//(W1=Freq–b31__Freq–b3Freq–b24)
#include <at89X52.h>
#define RESET P1_0
#define W_CLK P1_1
#define FQ_UD P1_2
#define DDSData P2
#define CLR_WCLK() W_CLK = 0
#define CLR_FQUD() FQ_UD = 0
#define CLR_RESET() RESET = 0
#define SET_WCLK() W_CLK = 1
#define SET_FQUD() FQ_UD = 1
#define SET_RESET() RESET = 1
unsigned char W0,W1,W2,W3,W4;
void delay()
{
unsigned char i;
for (i=1;i<=0xff;i++);
}
void init()
{
CLR_RESET();
delay();
SET_RESET();
delay();
delay();
delay();
delay();
delay();
CLR_RESET(); //AD9851复位
}
void load_40bit_data()
{
CLR_WCLK();
CLR_FQUD();
CLR_WCLK(); //Load W1 to shifting register
DDSData= W0;
delay();
SET_WCLK();
delay();
CLR_WCLK(); //Load W1 to shifting register
DDSData= W1;
delay();
SET_WCLK();
delay();
CLR_WCLK(); //Load W2 to shifting register
DDSData= W2;
delay();
SET_WCLK();
delay();
CLR_WCLK(); //Load W3 to shifting register
DDSData= W3;
delay();
SET_WCLK();
delay();
CLR_WCLK(); //Load W4 to shifting register
DDSData= W4;
delay();
SET_WCLK();
delay();
CLR_WCLK();
delay();
delay();
delay();
SET_FQUD();
delay();
delay();
delay();
delay();
delay();
delay();
CLR_FQUD(); //Load 40_bit data to the dds core register
}
void main()
{
W0 = 0x01; //Enable 6′ REFCLK Multiplier
W1=0x01; W2=0x6c; W3=0x16; W4=0xc1; //f_out=1MHz
init();
delay();
delay();
delay();
delay();
delay();
delay();
load_40bit_data();
while(1);
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -