当前位置:   article > 正文

[MM32软件]HWDIV硬件除法器底层揭秘,灵动MM32F0160新IP!_hw division

hw division

1.简介
1.1 MiniBoard (MM32F0163D7P)
使用高性能的 Arm® Cortex-M0 为内核的 32 位微控制器,最高工作频率可达 72MHz,内置高速存储器,丰富的增强型 I/O 端口和多种外设。128KB Flash,16KB SRAM。1 个 I2C 接口、 1 个 I3C 从机接口,2 个 SPI 或 I2S 接口、 4 个 UART 接口、 1 个低功耗 UART。工作温度范围(环境温度)包含 -40℃ ∼ +85℃的工业级和 -40℃ ∼ +105℃ 的扩展工业级(尾缀 V)。适合于多种应用场合:工业物联网设备、PC 外设、电子门锁控制、医疗和保健设备、手持设备及游戏娱乐等。


电路原理图:


1.2 HWDIV简介
硬件除法器能自动执行有符号或者无符号的 32 位整数除法运算。

  • 硬件除法单元包括 4 个 32 位数据寄存器,分别为被除数,除数,商和余数,可以做有符号或者无符号的 32 位除法运算
  • 通过硬件除法控制寄存器 HWDIV_CR 的 USIGN 位可以选择是有符号除法还是无符号除法
  • 每次写除数寄存器,会自动触发除法运算,在运算结束后,结果会写入到商和余数寄存器里。如果在运算结束前读商寄存器、余数寄存器或者状态寄存器,读操作会保持,直到当前运算结束才返回运算结果
  • 如果除数为零,会产生溢出中断标志位
  • 每次必须先初始化除数与被除数寄存器,才能读取商、余数、状态寄存器的值

     





HWDIV features:

  • 32 位除数和被除数,输出 32 位的商和余数
  • 如果除数为零,会产生溢出中断标志位
  • 写除数寄存器自动执行除法运算
  • 读商和余数寄存器时硬件自动等待运算结束


2.HWDIV底层
2.1 时钟
AHB1 总线的外设(RCC,HWDIV,GPIO 和 CRC)通过 AHB 互联矩阵与系统总线连接


2.2 寄存器
硬件除法单元包括 4 个 32 位数据寄存器,分别为被除数,除数,商和余数,可以做有符号或者无符号的 32 位除法运算。除数寄存器位 (Divisor data),写完该寄存器后,自动触发除法运算。


除数为0时SR寄存器的状态:


3.HWDIV驱动搭建
使用以下API:

  1. <font face="Arial">void HWDIV_EnableUsignBit(HWDIV_Type * HWDIVx, bool isUSIGN)
  2. void HWDIV_EnableInterrupt(HWDIV_Type * HWDIVx, bool enable)
  3. bool HWDIV_GetOVFBit(HWDIV_Type * HWDIVx)
  4. void HWDIV_ClearOVFBit(HWDIV_Type * HWDIVx)
  5. bool HWDIV_GetUSIGNBit(HWDIV_Type * HWDIVx)
  6. int32_t HWDIV_CalcSign(HWDIV_Type * HWDIVx,int32_t dvdr,int32_t dvsr)
  7. int32_t HWDIV_GetRMDRBitsSign(HWDIV_Type * HWDIVx)
  8. uint32_t HWDIV_CalcUsign(HWDIV_Type * HWDIVx,uint32_t dvdr,uint32_t dvsr)
  9. uint32_t HWDIV_GetRMDRBitsUsign(HWDIV_Type * HWDIVx)</font>


使能无符号除法:

  1. <font face="Arial">/* Enable unsigned division. */
  2. void HWDIV_EnableUsignBit(HWDIV_Type * HWDIVx, bool isUSIGN){
  3.     if(isUSIGN){
  4.         /* Unsigned division. */
  5.         HWDIVx->CR |= HWDIV_CR_USIGN_MASK;}
  6.     else{
  7.         /* Signed division. */
  8.         HWDIVx->CR &= (0xFFFFFFFFU & ~HWDIV_CR_USIGN_MASK);}}</font>


计算无符号除法:

  1. <font face="Arial">/* Count the unsigned number. */
  2. uint32_t HWDIV_CalcUsign(HWDIV_Type * HWDIVx,uint32_t dvdr,uint32_t dvsr){
  3.     HWDIVx->DVDR = dvdr;
  4.     HWDIVx->DVSR = dvsr;
  5.     if(HWDIVx->SR & HWDIV_SR_OVF_MASK){
  6.         return 0xFFFFFFFFU;}
  7.     else{
  8.         return HWDIVx->QUOTR;}}</font>


获取无符号除法余数:

  1. <font face="Arial">/* Get the unsigned remainder. */
  2. uint32_t HWDIV_GetRMDRBitsUsign(HWDIV_Type * HWDIVx){
  3.     return (uint32_t)HWDIVx->RMDR;}</font>


4.HWDIV样例
连续除法样例
主函数:

  1. <font face="Arial">int main(void){
  2.     uint32_t a,b;
  3.     BOARD_Init();
  4.     HWDIV_EnableUsignBit(HWDIV,true);
  5.     HWDIV_EnableInterrupt(HWDIV,false);
  6.     printf("\r\nhwdiv_basic example.\r\n");
  7.     a = HWDIV_CalcUsign(HWDIV,12,0);
  8.     b = HWDIV_GetRMDRBitsUsign(HWDIV);
  9.     if( HWDIV_GetOVFBit(HWDIV) ){
  10.         HWDIV_ClearOVFBit(HWDIV);}
  11.     printf("\r\nquotient = %u, remainder = %u\r\n", (unsigned)a, (unsigned)b);
  12.     a = HWDIV_CalcUsign(HWDIV,12,6);
  13.     b = HWDIV_GetRMDRBitsUsign(HWDIV);
  14.     printf("\r\nquotient = %u, remainder = %u\r\n", (unsigned)a, (unsigned)b);
  15.     a = HWDIV_CalcUsign(HWDIV,22,5);
  16.     b = HWDIV_GetRMDRBitsUsign(HWDIV);
  17.     printf("\r\nquotient = %u, remainder = %u\r\n", (unsigned)a, (unsigned)b);
  18.     while (1){}}</font>


串口实验现象:

---------------------
作者:春娇霹雳娃
链接:https://bbs.21ic.com/icview-3311868-1-1.html
来源:21ic.com
此文章已获得原创/原创奖标签,著作权归21ic所有,任何人未经允许禁止转载。 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/菜鸟追梦旅行/article/detail/658868
推荐阅读
相关标签
  

闽ICP备14008679号