[DemoCode下载] M051的硬件除法器

[复制链接]
586|5
 楼主| dongnanxibei 发表于 2019-5-25 22:39 | 显示全部楼层 |阅读模式
  1. /**************************************************************************//**
  2. * [url=home.php?mod=space&uid=288409]@file[/url]     main.c
  3. * [url=home.php?mod=space&uid=895143]@version[/url]  V2.10
  4. * $Revision: 3 $
  5. * $Date: 14/01/28 11:44a $
  6. * [url=home.php?mod=space&uid=247401]@brief[/url]    M051 Series Timer Controller and Watchdog Timer Driver Sample Code
  7. *
  8. * @note
  9. * Copyright (C) 2011 Nuvoton Technology Corp. All rights reserved.
  10. *
  11. ******************************************************************************/
  12. #include <stdio.h>
  13. #include "M051Series.h"

  14. #define PLLCON_SETTING      CLK_PLLCON_50MHz_XTAL
  15. #define PLL_CLOCK           50000000

  16. void SYS_Init(void)
  17. {
  18.     /*---------------------------------------------------------------------------------------------------------*/
  19.     /* Init System Clock                                                                                       */
  20.     /*---------------------------------------------------------------------------------------------------------*/
  21.     /* Enable External XTAL (4~24 MHz) */
  22.     CLK->PWRCON &= ~CLK_PWRCON_XTL12M_EN_Msk;
  23.     CLK->PWRCON |= (0x1 << CLK_PWRCON_XTL12M_EN_Pos); // XTAL12M (HXT) Enabled

  24.     /* Waiting for 12MHz clock ready */
  25.     while(!(CLK->CLKSTATUS & CLK_CLKSTATUS_XTL12M_STB_Msk));

  26.     /* Enable IP clock */
  27.     CLK->APBCLK |= CLK_APBCLK_UART0_EN_Msk; // UART Clock Enable

  28.     /* Select IP clock source */
  29.     CLK->CLKSEL1 &= ~CLK_CLKSEL1_UART_S_Msk;
  30.     CLK->CLKSEL1 |= (0x0 << CLK_CLKSEL1_UART_S_Pos);// Clock source from external 12 MHz

  31.     /* Set P30(RXD0),P31(TXD0) multi-function pins for UART0 RXD and TXD  */
  32.     SYS->P3_MFP = SYS_MFP_P30_RXD0 | SYS_MFP_P31_TXD0;

  33. }


  34. void UART0_Init(void)
  35. {
  36.     /*---------------------------------------------------------------------------------------------------------*/
  37.     /* Init UART                                                                                               */
  38.     /*---------------------------------------------------------------------------------------------------------*/
  39.     /* Configure UART0 and set UART0 Baudrate */
  40.     UART0->LCR = UART_WORD_LEN_8 | UART_PARITY_NONE | UART_STOP_BIT_1;
  41.     UART0->BAUD = UART_BAUD_MODE2 | UART_BAUD_MODE2_DIVIDER(__HXT, 115200);
  42. }

  43. void HDIV_Init(void)
  44. {
  45.     /* Enable Hardware Divider Clock */
  46.     CLK->AHBCLK |= CLK_AHBCLK_HDIV_EN_Msk;
  47. }


  48. /*---------------------------------------------------------------------------------------------------------*/
  49. /*  MAIN function                                                                                          */
  50. /*---------------------------------------------------------------------------------------------------------*/
  51. int main(void)
  52. {
  53.     /* Disable register write-protection function */
  54.     SYS_UnlockReg();

  55.     /* Init System, IP clock and multi-function I/O */
  56.     SYS_Init();

  57.     /* Init UART0 for printf */
  58.     UART0_Init();

  59.     /* Init Divider */
  60.     HDIV_Init();

  61.     printf("+----------------------------------------------+\n");
  62.     printf("|    M05xx Divider Sample Code                 |\n");
  63.     printf("+----------------------------------------------+\n");
  64.     printf("\n");

  65.     printf("12341 / 123 = %d\n", HDIV_Div(12341, 123));
  66.     printf("12341 %% 123 = %d\n", HDIV_Mod(12341, 123));

  67.     /* Lock protected registers */
  68.     SYS_LockReg();

  69.     printf("Done\n");

  70.     while(SYS->PDID);
  71.     return 0;
  72. }


 楼主| dongnanxibei 发表于 2019-5-25 22:39 | 显示全部楼层
初始化,只需要一条指令就可以了。
 楼主| dongnanxibei 发表于 2019-5-25 22:40 | 显示全部楼层
再通过寄存器实现一次
 楼主| dongnanxibei 发表于 2019-5-25 22:40 | 显示全部楼层
  1. /**************************************************************************//**
  2. * @file     main.c
  3. * @version  V2.10
  4. * $Revision: 3 $
  5. * $Date: 14/01/28 11:44a $
  6. * @brief    M051 Series Timer Controller and Watchdog Timer Driver Sample Code
  7. *
  8. * @note
  9. * Copyright (C) 2011 Nuvoton Technology Corp. All rights reserved.
  10. *
  11. ******************************************************************************/
  12. #include <stdio.h>
  13. #include "M051Series.h"

  14. #define PLLCON_SETTING      CLK_PLLCON_50MHz_HXT
  15. #define PLL_CLOCK           50000000

  16. void SYS_Init(void)
  17. {
  18.     int32_t i;
  19.     /*---------------------------------------------------------------------------------------------------------*/
  20.     /* Init System Clock                                                                                       */
  21.     /*---------------------------------------------------------------------------------------------------------*/

  22.     /* Enable External XTAL (4~24 MHz) */
  23.     CLK->PWRCON |= CLK_PWRCON_XTL12M_EN_Msk;

  24.     CLK->PLLCON = PLLCON_SETTING;

  25.     /* Waiting for clock ready */
  26.     i = 22000000; // For timeout
  27.     while(i-- > 0)
  28.     {
  29.         if((CLK->CLKSTATUS & (CLK_CLKSTATUS_PLL_STB_Msk | CLK_CLKSTATUS_XTL12M_STB_Msk)) ==
  30.                 (CLK_CLKSTATUS_PLL_STB_Msk | CLK_CLKSTATUS_XTL12M_STB_Msk))
  31.             break;
  32.     }

  33.     /* Switch HCLK clock source to PLL */
  34.     CLK->CLKSEL0 = CLK_CLKSEL0_HCLK_S_PLL;

  35.     /* Enable IP clock */
  36.     CLK->APBCLK = CLK_APBCLK_UART0_EN_Msk;

  37.     /* Select IP clock source */
  38.     CLK->CLKSEL1 = CLK_CLKSEL1_UART_S_PLL;

  39.     /* Update System Core Clock */
  40.     /* User can use SystemCoreClockUpdate() to calculate PllClock, SystemCoreClock and CycylesPerUs automatically. */
  41.     //SystemCoreClockUpdate();
  42.     PllClock        = PLL_CLOCK;            // PLL
  43.     SystemCoreClock = PLL_CLOCK / 1;        // HCLK
  44.     CyclesPerUs     = PLL_CLOCK / 1000000;  // For SYS_SysTickDelay()

  45.     /*---------------------------------------------------------------------------------------------------------*/
  46.     /* Init I/O Multi-function                                                                                 */
  47.     /*---------------------------------------------------------------------------------------------------------*/
  48.     /* Set P3 multi-function pins for UART0 RXD and TXD  */
  49.     SYS->P3_MFP = SYS_MFP_P30_RXD0 | SYS_MFP_P31_TXD0;
  50. }


  51. void UART0_Init(void)
  52. {
  53.     /*---------------------------------------------------------------------------------------------------------*/
  54.     /* Init UART                                                                                               */
  55.     /*---------------------------------------------------------------------------------------------------------*/
  56.     /* Reset IP */
  57.     SYS->IPRSTC2 |=  SYS_IPRSTC2_UART0_RST_Msk;
  58.     SYS->IPRSTC2 &= ~SYS_IPRSTC2_UART0_RST_Msk;

  59.     /* Configure UART0 and set UART0 Baudrate */
  60.     UART0->BAUD = UART_BAUD_MODE2 | UART_BAUD_MODE2_DIVIDER(PLL_CLOCK, 115200);
  61.     UART0->LCR = UART_WORD_LEN_8 | UART_PARITY_NONE | UART_STOP_BIT_1;
  62. }
  63. void HDIV_Init(void)
  64. {
  65.     /* Enable Hardware Divider Clock */
  66.     CLK->AHBCLK |= CLK_AHBCLK_HDIV_EN_Msk;
  67. }


  68. /*---------------------------------------------------------------------------------------------------------*/
  69. /*  MAIN function                                                                                          */
  70. /*---------------------------------------------------------------------------------------------------------*/
  71. int main(void)
  72. {
  73.     /* Disable register write-protection function */
  74.     SYS_UnlockReg();

  75.     /* Init System, IP clock and multi-function I/O */
  76.     SYS_Init();

  77.     /* Init UART0 for printf */
  78.     UART0_Init();

  79.     /* Init Divider */
  80.     HDIV_Init();

  81.     printf("+----------------------------------------------+\n");
  82.     printf("|    M05xx Divider Sample Code                 |\n");
  83.     printf("+----------------------------------------------+\n");
  84.     printf("\n");

  85.     printf("12341 / 123 = %d\n", HDIV_Div(12341, 123));
  86.     printf("12341 %% 123 = %d\n", HDIV_Mod(12341, 123));

  87.     HDIV->DIVIDEND = 12341;
  88.     HDIV->DIVISOR = 123;
  89.     printf("12341 / 123 = %d, remainder = %d\n", HDIV->DIVQUO, HDIV->DIVREM);

  90.     /* Lock protected registers */
  91.     SYS_LockReg();

  92.     printf("Done\n");

  93.     while(SYS->PDID);
  94.     return 0;
  95. }
734774645 发表于 2019-5-25 23:34 | 显示全部楼层
这个用于计算除法可以节约时间。
zhuotuzi 发表于 2019-5-26 10:57 | 显示全部楼层
使用起来好容易。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

225

主题

3848

帖子

18

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