1 #ifndef __SWM341_DIV_H__
2 #define __SWM341_DIV_H__
3
4
5 void DIV_Init(DIV_TypeDef * DIVx);
6
7
8 /******************************************************************************************************************************************
9 * 函数名称: DIV_UDiv()
10 * 功能说明: 使用硬件除法器执行无符号数除法运算
11 * 输 入: uint32_t dividend 被除数
12 * uint32_t divisor 除数
13 * 输 出: 无
14 * 注意事项: 无
15 ******************************************************************************************************************************************/
DIV_UDiv(uint32_t dividend,uint32_t divisor)16 static __INLINE void DIV_UDiv(uint32_t dividend, uint32_t divisor)
17 {
18 DIV->DIVIDEND = dividend;
19 DIV->DIVISOR = divisor;
20
21 DIV->CR = (1 << DIV_CR_DIVSIGN_Pos) | (1 << DIV_CR_DIVGO_Pos);
22 }
23
24 /******************************************************************************************************************************************
25 * 函数名称: DIV_SDiv()
26 * 功能说明: 使用硬件除法器执行有符号数除法运算
27 * 输 入: int32_t dividend 被除数
28 * int32_t divisor 除数
29 * 输 出: 无
30 * 注意事项: 无
31 ******************************************************************************************************************************************/
DIV_SDiv(int32_t dividend,int32_t divisor)32 static __INLINE void DIV_SDiv(int32_t dividend, int32_t divisor)
33 {
34 DIV->DIVIDEND = dividend;
35 DIV->DIVISOR = divisor;
36
37 DIV->CR = (0 << DIV_CR_DIVSIGN_Pos) | (1 << DIV_CR_DIVGO_Pos);
38 }
39
40 /******************************************************************************************************************************************
41 * 函数名称: DIV_Div_IsBusy()
42 * 功能说明: 硬件除法器是否正在执行除法运算
43 * 输 入: 无
44 * 输 出: uint32_t 1 硬件除法器正在执行除法运算 0 硬件除法器已完成除法运算,可取出运算结果
45 * 注意事项: 无
46 ******************************************************************************************************************************************/
DIV_Div_IsBusy(void)47 static __INLINE uint32_t DIV_Div_IsBusy(void)
48 {
49 return (DIV->SR & DIV_SR_DIVBUSY_Msk) ? 1 : 0;
50 }
51
52 /******************************************************************************************************************************************
53 * 函数名称: DIV_UDiv_Result()
54 * 功能说明: 取出硬件除法器的运算结果
55 * 输 入: 无
56 * 输 出: uint32_t *quotient 商
57 * uint32_t *remainder 余数
58 * 注意事项: 无
59 ******************************************************************************************************************************************/
DIV_UDiv_Result(uint32_t * quotient,uint32_t * remainder)60 static __INLINE void DIV_UDiv_Result(uint32_t *quotient, uint32_t *remainder)
61 {
62 *quotient = DIV->QUO;
63 *remainder = DIV->REMAIN;
64 }
65
66 /******************************************************************************************************************************************
67 * 函数名称: DIV_SDiv_Result()
68 * 功能说明: 取出硬件除法器的运算结果
69 * 输 入: 无
70 * 输 出: int32_t *quotient 商
71 * int32_t *remainder 余数
72 * 注意事项: 无
73 ******************************************************************************************************************************************/
DIV_SDiv_Result(int32_t * quotient,int32_t * remainder)74 static __INLINE void DIV_SDiv_Result(int32_t *quotient, int32_t *remainder)
75 {
76 *quotient = DIV->QUO & 0x7FFFFFFF;
77 if(DIV->QUO & (1u << 31)) *quotient = 0 - *quotient;
78
79 *remainder = DIV->REMAIN & 0x7FFFFFFF;
80 if(DIV->REMAIN & (1u << 31)) *remainder = 0 - *remainder;
81 }
82
83 /******************************************************************************************************************************************
84 * 函数名称: DIV_Root()
85 * 功能说明: 使用硬件开方模块执行开方运算
86 * 输 入: uint32_t radicand 被开方数
87 * uint32_t calcu_frac 0 开方结果为16位整数 1 开方结果为16位整数+16位小数
88 * 输 出: 无
89 * 注意事项: 无
90 ******************************************************************************************************************************************/
DIV_Root(uint32_t radicand,uint32_t calcu_fractional)91 static __INLINE void DIV_Root(uint32_t radicand, uint32_t calcu_fractional)
92 {
93 DIV->RADICAND = radicand;
94
95 DIV->CR = (1 << DIV_CR_ROOTGO_Pos) | (calcu_fractional << DIV_CR_ROOTMOD_Pos);
96 }
97
98 /******************************************************************************************************************************************
99 * 函数名称: DIV_Root_IsBusy()
100 * 功能说明: 硬件开方模块是否正在执行开方运算
101 * 输 入: 无
102 * 输 出: uint32_t 1 硬件开方模块正在执行开方运算 0 硬件开方模块已完成开方运算,可取出运算结果
103 * 注意事项: 无
104 ******************************************************************************************************************************************/
DIV_Root_IsBusy(void)105 static __INLINE uint32_t DIV_Root_IsBusy(void)
106 {
107 return (DIV->SR & DIV_SR_ROOTBUSY_Msk) ? 1 : 0;
108 }
109
110 /******************************************************************************************************************************************
111 * 函数名称: DIV_Root_Result()
112 * 功能说明: 取出硬件开方模块的运算结果
113 * 输 入: 无
114 * 输 出: uint32_t 开方结果
115 * 注意事项: 无
116 ******************************************************************************************************************************************/
DIV_Root_Result(void)117 static __INLINE uint32_t DIV_Root_Result(void)
118 {
119 if(DIV->CR & DIV_CR_ROOTMOD_Msk)
120 {
121 return DIV->ROOT;
122 }
123 else
124 {
125 return DIV->ROOT >> 16;
126 }
127 }
128
129 #endif //__SWM341_DIV_H__
130