/_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

  1. /*******************************(C) COPYRIGHT 2016 Wind£¨Ð»ÓñÉ죩*********************************/
  2. /**============================================================================
  3. * @FileName : Drive_AD9851.c
  4. * @Description : None
  5. * @Date : 2016/7/20
  6. * @By : Wind£¨Ð»ÓñÉ죩
  7. * @Email : 1659567673@ qq.com
  8. * @Platform : Keil uVision5 v5.15 (STM32F407ZG)
  9. * @Explain :
  10. -------------------------------------------------------------------------------
  11. ƵÂÊ»»ËãΪƵÂÊ×ÖϵÊý
  12. ÓɼÆË㹫ʽ£ºFout=(Freq*AD9851_SystemCloc)/2^32 Freq ΪƵÂÊ¿ØÖÆ×Ö
  13. µÃ Freq=FC*Fout
  14. FC=2^32/AD9851_SystemCloc
  15. µ±AD9851_SystemCloc=30MHz
  16. ʱ FC=143.16557653333333333333333333333f
  17. *=============================================================================*/
  18. /* Í·Îļþ°üº¬ ----------------------------------------------------------------*/
  19. #include "Drive_AD9851.h"
  20. /* ˽Óк궨Òå ----------------------------------------------------------------*/
  21. #define M20 214.7483648f
  22. #define M30 143.16557653333333333333333333333f
  23. #define M50 85.89934592f
  24. #define M120 35.791394133333333333333333333333f
  25. #define MULT 1 //6±¶Æµ 0¹Ø±Õ£¬1´ò¿ª
  26. #define POWER_MODE 0 //¹¦ºÄģʽ 0£ºPower-up_ mode 1:Power-down_
  27. #define FC M20//¼ÆË㹫ʽÔÚÎļþ˵Ã÷ÄÚ
  28. #define BASE_FREQ 34700000//34.7M»ùƵ
  29. #define BASE_FREQ_SHIFT_LIMIT 3000//5000Æ«ÒÆ·¶Î§
  30. /* ˽ÓУ¨¾²Ì¬£©º¯ÊýÉùÃ÷ ------------------------------------------------------*/
  31. static void AD9851_Write(uint8_t*Control_Word);
  32. /* È«¾Ö±äÁ¿¶¨Òå --------------------------------------------------------------*/
  33. /* È«¾Öº¯Êý±àд --------------------------------------------------------------*/
  34. /**----------------------------------------------------------------------------
  35. * @FunctionName : AD9851_Init()
  36. * @Description : AD9851³õʼ»¯³ÌÐò
  37. * @Data : 2016/7/20
  38. * @Explain
  39. -------------------------------------------------------------------------------
  40. * None
  41. ------------------------------------------------------------------------------*/
  42. void AD9851_Init(void)
  43. {
  44. GPIO_InitTypeDef GPIO_InitStructure;
  45. RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOG|RCC_AHB1Periph_GPIOC,ENABLE);
  46. GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0|GPIO_Pin_1|GPIO_Pin_2|GPIO_Pin_3
  47. |GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_6|GPIO_Pin_7;
  48. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;
  49. GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
  50. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;
  51. GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
  52. GPIO_Init(GPIOG, &GPIO_InitStructure);
  53. GPIO_InitStructure.GPIO_Pin =GPIO_Pin_12|GPIO_Pin_10|GPIO_Pin_11 ;
  54. GPIO_Init(GPIOC, &GPIO_InitStructure);
  55. //AD9851 ³õʼ»¯
  56. AD9851_WCLK=0;
  57. AD9851_FQUD=0;
  58. AD9851_RESET=1; // ¸ßµçƽ¸´Î»
  59. OSdelay_ms(100);
  60. AD9851_RESET=0;
  61. OSdelay_ms(100);
  62. }
  63. /**----------------------------------------------------------------------------
  64. * @FunctionName : AD9851_Set()
  65. * @Description : ÉèÖÃAD9851µÄÊä³öƵÂʺÍÏàλ
  66. * @Data : 2016/7/20
  67. * @Explain
  68. -------------------------------------------------------------------------------
  69. F:ƵÂÊ ·Ö±æÂÊΪ0.04Hz,×î´óƵÂÊFmax=AD9851_SystemCloc/2.5
  70. Phase:Ïàλ 1¸öµ¥Î»±íʾPi/16 ¼´11.25¶È
  71. ------------------------------------------------------------------------------*/
  72. void AD9851_Set(double F,uint8_t Phase)
  73. {
  74. uint32_t Freq;
  75. uint8_t CW[5];
  76. if(MULT)Freq=FC*F/6;
  77. else Freq=FC*F;
  78. CW[4] = Freq & 0xff; // ƵÂÊ¿ØÖÆ×Ö×îµÍ×Ö½ÚLSB
  79. CW[3] = (Freq>>8) & 0xff;
  80. CW[2] = (Freq>>16) & 0xff;
  81. CW[1] = (Freq>>24) & 0xff; // ƵÂÊ¿ØÖÆ×Ö×î¸ß×Ö½ÚMSB
  82. CW[0] = (Phase<<3)|(POWER_MODE<<2)|MULT;
  83. AD9851_Write(CW);
  84. }
  85. /**----------------------------------------------------------------------------
  86. * @FunctionName : AD9851_FM()
  87. * @Description : ·¢ËÍFM
  88. * @Data : 2016/7/24
  89. * @Explain
  90. -------------------------------------------------------------------------------
  91. Vol:·ùÖµ 0~3.3V
  92. ------------------------------------------------------------------------------*/
  93. void AD9851_FM(double Vol)
  94. {
  95. u32 TempVol = Vol*10000/3.3f;//ת»»³ÉHz
  96. if(TempVol > BASE_FREQ_SHIFT_LIMIT*2) TempVol = BASE_FREQ_SHIFT_LIMIT*2;
  97. AD9851_Set((BASE_FREQ - BASE_FREQ_SHIFT_LIMIT)+TempVol,0);
  98. }
  99. /**----------------------------------------------------------------------------
  100. * @FunctionName : AD9851_Set()
  101. * @Description : дAD9851¿ØÖÆ×Ö£¬²¢ÐÐģʽ
  102. * @Data : 2016/7/20
  103. * @Explain
  104. -------------------------------------------------------------------------------
  105. Control_Word:¿ØÖÆ×ÖÖ¸Õë
  106. ------------------------------------------------------------------------------*/
  107. static void AD9851_Write(uint8_t*Control_Word)
  108. {
  109. AD9851_FQUD=0; // FQ_UDÖõÍ
  110. AD9851_WCLK=0; // w_clkÖõÍ
  111. /*---²¢Ðд«Êä¿ØÖÆ×Ö---*/
  112. AD9851_Data = Control_Word[0];
  113. AD9851_WCLK = 1;
  114. AD9851_WCLK = 0;
  115. AD9851_Data = Control_Word[1];
  116. AD9851_WCLK = 1;
  117. AD9851_WCLK = 0;
  118. AD9851_Data = Control_Word[2];
  119. AD9851_WCLK = 1;
  120. AD9851_WCLK = 0;
  121. AD9851_Data = Control_Word[3];
  122. AD9851_WCLK = 1;
  123. AD9851_WCLK = 0;
  124. AD9851_Data = Control_Word[4];
  125. AD9851_WCLK = 1;
  126. AD9851_WCLK = 0;
  127. AD9851_FQUD = 1; //ÉÏÉýÑØ¸üÐÂÆµÂÊ
  128. AD9851_FQUD = 0;
  129. }
  130. /*******************************(C) COPYRIGHT 2016 Wind£¨Ð»ÓñÉ죩*********************************/