发新帖本帖赏金 30.00元(功能说明)我要提问
返回列表
打印
[MM32软件]

HWDIV硬件除法器底层揭秘,灵动MM32F0160新IP!

[复制链接]
959|7
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
本帖最后由 春娇霹雳娃 于 2023-6-30 11:31 编辑

#申请原创# @21小跑堂

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:
<font face="Arial">void HWDIV_EnableUsignBit(HWDIV_Type * HWDIVx, bool isUSIGN)
void HWDIV_EnableInterrupt(HWDIV_Type * HWDIVx, bool enable)
bool HWDIV_GetOVFBit(HWDIV_Type * HWDIVx)
void HWDIV_ClearOVFBit(HWDIV_Type * HWDIVx)
bool HWDIV_GetUSIGNBit(HWDIV_Type * HWDIVx)
int32_t HWDIV_CalcSign(HWDIV_Type * HWDIVx,int32_t dvdr,int32_t dvsr)
int32_t HWDIV_GetRMDRBitsSign(HWDIV_Type * HWDIVx)
uint32_t HWDIV_CalcUsign(HWDIV_Type * HWDIVx,uint32_t dvdr,uint32_t dvsr)
uint32_t HWDIV_GetRMDRBitsUsign(HWDIV_Type * HWDIVx)</font>

使能无符号除法:
<font face="Arial">/* Enable unsigned division. */
void HWDIV_EnableUsignBit(HWDIV_Type * HWDIVx, bool isUSIGN){
    if(isUSIGN){
        /* Unsigned division. */
        HWDIVx->CR |= HWDIV_CR_USIGN_MASK;}
    else{
        /* Signed division. */
        HWDIVx->CR &= (0xFFFFFFFFU & ~HWDIV_CR_USIGN_MASK);}}</font>

计算无符号除法:
<font face="Arial">/* Count the unsigned number. */
uint32_t HWDIV_CalcUsign(HWDIV_Type * HWDIVx,uint32_t dvdr,uint32_t dvsr){
    HWDIVx->DVDR = dvdr;
    HWDIVx->DVSR = dvsr;

    if(HWDIVx->SR & HWDIV_SR_OVF_MASK){
        return 0xFFFFFFFFU;}
    else{
        return HWDIVx->QUOTR;}}</font>

获取无符号除法余数:
<font face="Arial">/* Get the unsigned remainder. */
uint32_t HWDIV_GetRMDRBitsUsign(HWDIV_Type * HWDIVx){
    return (uint32_t)HWDIVx->RMDR;}</font>

4.HWDIV样例
连续除法样例
主函数:
<font face="Arial">int main(void){
    uint32_t a,b;

    BOARD_Init();

    HWDIV_EnableUsignBit(HWDIV,true);
    HWDIV_EnableInterrupt(HWDIV,false);

    printf("\r\nhwdiv_basic example.\r\n");

    a = HWDIV_CalcUsign(HWDIV,12,0);
    b = HWDIV_GetRMDRBitsUsign(HWDIV);

    if( HWDIV_GetOVFBit(HWDIV) ){
        HWDIV_ClearOVFBit(HWDIV);}

    printf("\r\nquotient = %u, remainder = %u\r\n", (unsigned)a, (unsigned)b);

    a = HWDIV_CalcUsign(HWDIV,12,6);
    b = HWDIV_GetRMDRBitsUsign(HWDIV);

    printf("\r\nquotient = %u, remainder = %u\r\n", (unsigned)a, (unsigned)b);

    a = HWDIV_CalcUsign(HWDIV,22,5);
    b = HWDIV_GetRMDRBitsUsign(HWDIV);

    printf("\r\nquotient = %u, remainder = %u\r\n", (unsigned)a, (unsigned)b);

    while (1){}}</font>

串口实验现象:


5.附件
电路图: Mini-F0160_电路图.pdf (328.33 KB)
UM网址:https://www.mindmotion.com.cn/download/products/UM_MM32F0160_SC.pdf
工程: mini-f0160_hwdiv_basic_mdk.zip (564.81 KB)


使用特权

评论回复

打赏榜单

21小跑堂 打赏了 30.00 元 2023-07-18
理由:恭喜通过原创审核!期待您更多的原创作品~

评论
21小跑堂 2023-7-18 16:36 回复TA
MM32F0163D7P,一个良心MCU,解决了M0内核单片机除法运算的困扰,引入硬件除法器,加速M0内核下的除法运算。 
沙发
yangxiaor520| | 2023-7-1 12:03 | 只看该作者
硬件除法器肯定比软件计算要好

使用特权

评论回复
板凳
春娇霹雳娃|  楼主 | 2023-7-1 12:40 | 只看该作者
yangxiaor520 发表于 2023-7-1 12:03
硬件除法器肯定比软件计算要好

使用特权

评论回复
地板
chenqianqian| | 2023-7-3 20:57 | 只看该作者
用于浮点数运算不错

使用特权

评论回复
5
春娇霹雳娃|  楼主 | 2023-7-4 09:53 | 只看该作者
chenqianqian 发表于 2023-7-3 20:57
用于浮点数运算不错

使用特权

评论回复
6
Sunriver_Yao| | 2023-7-25 14:05 | 只看该作者
yangxiaor520 发表于 2023-7-1 12:03
硬件除法器肯定比软件计算要好

"快"!

使用特权

评论回复
7
春娇霹雳娃|  楼主 | 2023-7-25 15:52 | 只看该作者

使用特权

评论回复
发新帖 本帖赏金 30.00元(功能说明)我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

认证:灵动系统开发工程师
简介:none........

19

主题

154

帖子

3

粉丝