[DemoCode下载] NUC029的HDIV使用方法,那么比使用CPU计算快多少呢?

[复制链接]
890|12
 楼主| huahuagg 发表于 2020-6-19 18:00 | 显示全部楼层 |阅读模式
  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: 2 $
  5. * $Date: 16/10/25 4:29p $
  6. * [url=home.php?mod=space&uid=247401]@brief[/url]    Hardware divider(HDIV) Sample Code
  7. *
  8. * @note
  9. * Copyright (C) 2016 Nuvoton Technology Corp. All rights reserved.
  10. *
  11. ******************************************************************************/
  12. #include <stdio.h>
  13. #include "NUC029xGE.h"

  14. #define PLLCON_SETTING      CLK_PLLCON_72MHz_HXT
  15. #define PLL_CLOCK           72000000

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

  21.     /* Enable HIRC clock (Internal RC 22.1184MHz) */
  22.     CLK_EnableXtalRC(CLK_PWRCTL_HIRCEN_Msk);

  23.     /* Wait for HIRC clock ready */
  24.     CLK_WaitClockReady(CLK_STATUS_HIRCSTB_Msk);

  25.     /* Select HCLK clock source as HIRC and and HCLK source divider as 1 */
  26.     CLK_SetHCLK(CLK_CLKSEL0_HCLKSEL_HIRC, CLK_CLKDIV0_HCLK(1));

  27.     /* Set PLL to Power-down mode and PLLSTB bit in CLK_STATUS register will be cleared by hardware.*/
  28.     CLK_DisablePLL();

  29.     /* Enable HXT clock (external XTAL 12MHz) */
  30.     CLK_EnableXtalRC(CLK_PWRCTL_HXTEN_Msk);

  31.     /* Wait for HXT clock ready */
  32.     CLK_WaitClockReady(CLK_STATUS_HXTSTB_Msk);

  33.     /* Set core clock as PLL_CLOCK from PLL */
  34.     CLK_SetCoreClock(PLL_CLOCK);

  35.     /* Enable UART module clock */
  36.     CLK_EnableModuleClock(UART0_MODULE);

  37.     /* Select UART module clock source as HXT and UART module clock divider as 1 */
  38.     CLK_SetModuleClock(UART0_MODULE, CLK_CLKSEL1_UARTSEL_HXT, CLK_CLKDIV0_UART(1));

  39.     /*---------------------------------------------------------------------------------------------------------*/
  40.     /* Init I/O Multi-function                                                                                 */
  41.     /*---------------------------------------------------------------------------------------------------------*/
  42.     /* Set multi-function pins for UART0 RXD and TXD */
  43.     SYS->GPA_MFPL &= ~(SYS_GPA_MFPL_PA2MFP_Msk | SYS_GPA_MFPL_PA3MFP_Msk);
  44.     SYS->GPA_MFPL |= (SYS_GPA_MFPL_PA3MFP_UART0_RXD | SYS_GPA_MFPL_PA2MFP_UART0_TXD);
  45. }

  46. void UART0_Init()
  47. {
  48.     /*---------------------------------------------------------------------------------------------------------*/
  49.     /* Init UART                                                                                               */
  50.     /*---------------------------------------------------------------------------------------------------------*/
  51.     UART_Open(UART0, 115200);
  52. }

  53. void HDIV_Init(void)
  54. {
  55.     /* Enable Hardware Divider Clock */
  56.     CLK->AHBCLK |= CLK_AHBCLK_HDIVCKEN_Msk;
  57. }

  58. /*---------------------------------------------------------------------------------------------------------*/
  59. /*  MAIN function                                                                                          */
  60. /*---------------------------------------------------------------------------------------------------------*/
  61. int main(void)
  62. {
  63.     /* Disable register write-protection function */
  64.     SYS_UnlockReg();

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

  67.     /* Init UART0 for printf */
  68.     UART0_Init();

  69.     /* Init Divider */
  70.     HDIV_Init();

  71.     printf("+----------------------------------------------+\n");
  72.     printf("|    Hardware Divider(HDIV) Sample Code        |\n");
  73.     printf("+----------------------------------------------+\n");
  74.     printf("\n");

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

  77.     /* Lock protected registers */
  78.     SYS_LockReg();

  79.     printf("Done\n");

  80.     while(SYS->PDID);
  81.     return 0;
  82. }

  83. /*** (C) COPYRIGHT 2016 Nuvoton Technology Corp. ***/


 楼主| huahuagg 发表于 2020-6-19 18:01 | 显示全部楼层
有人知道这个快多少吗,如果使用这个优势有多大
huangcunxiake 发表于 2020-6-20 09:01 | 显示全部楼层
肯定很快。
huangcunxiake 发表于 2020-6-20 09:01 | 显示全部楼层
不知道这个支持计算小数不,还是自己处理小数为整数。我去试试
 楼主| huahuagg 发表于 2020-6-21 12:33 | 显示全部楼层
快个好几倍是没问题的。
jiekou001 发表于 2020-6-21 18:26 | 显示全部楼层
之前好多指令才能完成的,现在一条指令就搞定
jasontu 发表于 2020-6-24 09:09 | 显示全部楼层
我記得用硬件除法器,只有2個CPU CLOCK的就已經可以得到結果。
dongnanxibei 发表于 2020-6-24 11:43 | 显示全部楼层
一个指令就实现了原来很多指令完成的运算。
qcliu 发表于 2020-7-6 17:21 | 显示全部楼层
这个如何计算呢
tfqi 发表于 2020-7-6 17:21 | 显示全部楼层
理论上快很多
wiba 发表于 2020-7-6 17:21 | 显示全部楼层
非常快的样子
zljiu 发表于 2020-7-6 17:22 | 显示全部楼层
可以自己试试
coshi 发表于 2020-7-6 17:22 | 显示全部楼层
这段代码很不错
您需要登录后才可以回帖 登录 | 注册

本版积分规则

159

主题

1430

帖子

2

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