[Atmel] 跑一下XMEGA-B1程序(13)进一步时钟配置

[复制链接]
 楼主| ddllxxrr 发表于 2016-1-7 19:01 | 显示全部楼层 |阅读模式
这个例子展示了一个更进一步的使用系统时钟服务的例子。这个例子将主系统时钟配置到2MHz,使用内部RC振荡器校准2MHz内部32kHz振荡器。外设总线时钟将运行在同CPU时钟一样的频率,USB时钟将被配置成使用内部32MHz(通常)RC效验到48MHz带有USB启始帧作为效验参考。

配置为conf_clock.h

当在程序中加入sysclk_init();

时自动就配置了。

#define CONFIG_SYSCLK_SOURCE                SYSCLK_SRC_RC2MHZ
#define CONFIG_OSC_AUTOCAL_RC2MHZ_REF_OSC   OSC_ID_RC32KHZ
#define CONFIG_USBCLK_SOURCE                USBCLK_SRC_RCOSC
#define CONFIG_OSC_RC32_CAL                 48000000UL
#define CONFIG_OSC_AUTOCAL_RC32MHZ_REF_OSC  OSC_ID_USBSOF

实际的配置为:

  1. #ifndef CONF_CLOCK_H_INCLUDED
  2. #define CONF_CLOCK_H_INCLUDED

  3. #define CONFIG_SYSCLK_SOURCE        SYSCLK_SRC_RC2MHZ
  4. //#define CONFIG_SYSCLK_SOURCE        SYSCLK_SRC_RC32MHZ
  5. //#define CONFIG_SYSCLK_SOURCE        SYSCLK_SRC_RC32KHZ
  6. //#define CONFIG_SYSCLK_SOURCE        SYSCLK_SRC_XOSC
  7. //#define CONFIG_SYSCLK_SOURCE        SYSCLK_SRC_PLL
  8. #define CONFIG_OSC_AUTOCAL_RC2MHZ_REF_OSC   OSC_ID_RC32KHZ

  9. /* Fbus = Fsys / (2 ^ BUS_div) */
  10. #define CONFIG_SYSCLK_PSADIV          SYSCLK_PSADIV_1
  11. #define CONFIG_SYSCLK_PSBCDIV         SYSCLK_PSBCDIV_1_2

  12. //#define CONFIG_PLL0_SOURCE          PLL_SRC_XOSC
  13. #define CONFIG_PLL0_SOURCE          PLL_SRC_RC2MHZ
  14. //#define CONFIG_PLL0_SOURCE          PLL_SRC_RC32MHZ

  15. /* Fpll = (Fclk * PLL_mul) / PLL_div */
  16. #define CONFIG_PLL0_MUL             (32000000UL / BOARD_XOSC_HZ)
  17. #define CONFIG_PLL0_DIV             1

  18. /* External oscillator frequency range */
  19. /** 0.4 to 2 MHz frequency range */
  20. //#define CONFIG_XOSC_RANGE XOSC_RANGE_04TO2
  21. /** 2 to 9 MHz frequency range */
  22. //#define CONFIG_XOSC_RANGE XOSC_RANGE_2TO9
  23. /** 9 to 12 MHz frequency range */
  24. //#define CONFIG_XOSC_RANGE XOSC_RANGE_9TO12
  25. /** 12 to 16 MHz frequency range */
  26. //#define CONFIG_XOSC_RANGE XOSC_RANGE_12TO16

  27. /* DFLL autocalibration */
  28. //#define CONFIG_OSC_AUTOCAL_RC2MHZ_REF_OSC  OSC_ID_RC32KHZ
  29. //#define CONFIG_OSC_AUTOCAL_RC32MHZ_REF_OSC OSC_ID_XOSC

  30. /* The following example clock configuration definitions can be used in XMEGA
  31. * devices that contain a USB controller. It configures the USB controller clock
  32. * source to use the internal (nominally) 32MHz RC oscillator, up-calibrated to
  33. * run at 48MHz via the periodic 1ms USB Start Of Frame packets sent by the
  34. * host. The USB controller requires 48MHz for Full Speed operation, or 6MHz
  35. * for USB Low Speed operation.
  36. *
  37. * Note that when the 32MHz RC oscillator is tuned to 48MHz, it cannot be used
  38. * directly as the system clock source; it must either be prescaled down to a
  39. * speed below the maximum operating frequency given in the datasheet, or an
  40. * alternative clock source (e.g. the internal 2MHz RC Oscillator, multiplied
  41. * to a higher frequency via the internal PLL module) must be used instead.
  42. */
  43. #define CONFIG_USBCLK_SOURCE                USBCLK_SRC_RCOSC
  44. #define CONFIG_OSC_RC32_CAL                 48000000UL
  45. #define CONFIG_OSC_AUTOCAL_RC32MHZ_REF_OSC  OSC_ID_USBSOF
  46. //#define CONFIG_OSC_AUTOCAL          OSC_ID_RC32MHZ

  47. /* Use to enable and select RTC clock source */
  48. //#define CONFIG_RTC_SOURCE           SYSCLK_RTCSRC_ULP

  49. #endif /* CONF_CLOCK_H_INCLUDED */

上述编译一下,通过说明没有问题

墨鱼腌肉 发表于 2020-1-8 15:08 来自手机 | 显示全部楼层
楼主,如果使用外部时钟改怎样配置?
您需要登录后才可以回帖 登录 | 注册

本版积分规则

个人签名:http://shop34182318.taobao.com/ http://shop562064536.taobao.com

2403

主题

6994

帖子

68

粉丝
快速回复 在线客服 返回列表 返回顶部