/_01_STM32F4/_05_FSK通信/_05_Drive/Drive_AD9851.c
https://github.com/WittXie/STM32 · C · 163 lines · 72 code · 33 blank · 58 comment · 3 complexity · ecff277c839a8e06b376d61ff8f6eacd MD5 · raw file
- /*******************************(C) COPYRIGHT 2016 Wind£¨Ð»ÓñÉ죩*********************************/
- /**============================================================================
- * @FileName : Drive_AD9851.c
- * @Description : None
- * @Date : 2016/7/20
- * @By : Wind£¨Ð»ÓñÉ죩
- * @Email : 1659567673@ qq.com
- * @Platform : Keil uVision5 v5.15 (STM32F407ZG)
- * @Explain :
- -------------------------------------------------------------------------------
- ƵÂÊ»»ËãΪƵÂÊ×ÖϵÊý
- ÓɼÆË㹫ʽ£ºFout=(Freq*AD9851_SystemCloc)/2^32 Freq ΪƵÂÊ¿ØÖÆ×Ö
- µÃ Freq=FC*Fout
- FC=2^32/AD9851_SystemCloc
- µ±AD9851_SystemCloc=30MHz
- ʱ FC=143.16557653333333333333333333333f
- *=============================================================================*/
- /* Í·Îļþ°üº¬ ----------------------------------------------------------------*/
- #include "Drive_AD9851.h"
- /* ˽Óк궨Òå ----------------------------------------------------------------*/
- #define M20 214.7483648f
- #define M30 143.16557653333333333333333333333f
- #define M50 85.89934592f
- #define M120 35.791394133333333333333333333333f
- #define MULT 1 //6±¶Æµ 0¹Ø±Õ£¬1´ò¿ª
- #define POWER_MODE 0 //¹¦ºÄģʽ 0£ºPower-up_ mode 1:Power-down_
- #define FC M20//¼ÆË㹫ʽÔÚÎļþ˵Ã÷ÄÚ
- #define BASE_FREQ 34700000//34.7M»ùƵ
- #define BASE_FREQ_SHIFT_LIMIT 3000//5000Æ«ÒÆ·¶Î§
- /* ˽ÓУ¨¾²Ì¬£©º¯ÊýÉùÃ÷ ------------------------------------------------------*/
- static void AD9851_Write(uint8_t*Control_Word);
- /* È«¾Ö±äÁ¿¶¨Òå --------------------------------------------------------------*/
-
- /* È«¾Öº¯Êý±àд --------------------------------------------------------------*/
- /**----------------------------------------------------------------------------
- * @FunctionName : AD9851_Init()
- * @Description : AD9851³õʼ»¯³ÌÐò
- * @Data : 2016/7/20
- * @Explain
- -------------------------------------------------------------------------------
- * None
- ------------------------------------------------------------------------------*/
- void AD9851_Init(void)
- {
- GPIO_InitTypeDef GPIO_InitStructure;
- RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOG|RCC_AHB1Periph_GPIOC,ENABLE);
-
- GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3
- |GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7;
- GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;
- GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
- GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;
- GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
- GPIO_Init(GPIOG, &GPIO_InitStructure);
-
- GPIO_InitStructure.GPIO_Pin =GPIO_Pin_12|GPIO_Pin_10|GPIO_Pin_11 ;
- GPIO_Init(GPIOC, &GPIO_InitStructure);
-
- //AD9851 ³õʼ»¯
- AD9851_WCLK=0;
- AD9851_FQUD=0;
- AD9851_RESET=1; // ¸ßµçƽ¸´Î»
- OSdelay_ms(100);
- AD9851_RESET=0;
- OSdelay_ms(100);
- }
-
-
- /**----------------------------------------------------------------------------
- * @FunctionName : AD9851_Set()
- * @Description : ÉèÖÃAD9851µÄÊä³öƵÂʺÍÏàλ
- * @Data : 2016/7/20
- * @Explain
- -------------------------------------------------------------------------------
- F:ƵÂÊ ·Ö±æÂÊΪ0.04Hz,×î´óƵÂÊFmax=AD9851_SystemCloc/2.5
- Phase:Ïàλ 1¸öµ¥Î»±íʾPi/16 ¼´11.25¶È
- ------------------------------------------------------------------------------*/
- void AD9851_Set(double F,uint8_t Phase)
- {
- uint32_t Freq;
- uint8_t CW[5];
- if(MULT)Freq=FC*F/6;
- else Freq=FC*F;
-
- CW[4] = Freq & 0xff; // ƵÂÊ¿ØÖÆ×Ö×îµÍ×Ö½ÚLSB
- CW[3] = (Freq>>8) & 0xff;
- CW[2] = (Freq>>16) & 0xff;
- CW[1] = (Freq>>24) & 0xff; // ƵÂÊ¿ØÖÆ×Ö×î¸ß×Ö½ÚMSB
- CW[0] = (Phase<<3)|(POWER_MODE<<2)|MULT;
- AD9851_Write(CW);
- }
-
-
- /**----------------------------------------------------------------------------
- * @FunctionName : AD9851_FM()
- * @Description : ·¢ËÍFM
- * @Data : 2016/7/24
- * @Explain
- -------------------------------------------------------------------------------
- Vol:·ùÖµ 0~3.3V
- ------------------------------------------------------------------------------*/
- void AD9851_FM(double Vol)
- {
- u32 TempVol = Vol*10000/3.3f;//ת»»³ÉHz
- if(TempVol > BASE_FREQ_SHIFT_LIMIT*2) TempVol = BASE_FREQ_SHIFT_LIMIT*2;
- AD9851_Set((BASE_FREQ - BASE_FREQ_SHIFT_LIMIT)+TempVol,0);
- }
-
- /**----------------------------------------------------------------------------
- * @FunctionName : AD9851_Set()
- * @Description : дAD9851¿ØÖÆ×Ö£¬²¢ÐÐģʽ
- * @Data : 2016/7/20
- * @Explain
- -------------------------------------------------------------------------------
- Control_Word:¿ØÖÆ×ÖÖ¸Õë
- ------------------------------------------------------------------------------*/
- static void AD9851_Write(uint8_t*Control_Word)
- {
- AD9851_FQUD=0; // FQ_UDÖõÍ
- AD9851_WCLK=0; // w_clkÖõÍ
- /*---²¢Ðд«Êä¿ØÖÆ×Ö---*/
- AD9851_Data = Control_Word[0];
- AD9851_WCLK = 1;
- AD9851_WCLK = 0;
- AD9851_Data = Control_Word[1];
- AD9851_WCLK = 1;
- AD9851_WCLK = 0;
- AD9851_Data = Control_Word[2];
- AD9851_WCLK = 1;
- AD9851_WCLK = 0;
- AD9851_Data = Control_Word[3];
- AD9851_WCLK = 1;
- AD9851_WCLK = 0;
- AD9851_Data = Control_Word[4];
- AD9851_WCLK = 1;
- AD9851_WCLK = 0;
- AD9851_FQUD = 1; //ÉÏÉýÑØ¸üÐÂÆµÂÊ
- AD9851_FQUD = 0;
- }
-
-
- /*******************************(C) COPYRIGHT 2016 Wind£¨Ð»ÓñÉ죩*********************************/