forked from SZV10X_Software/SZV103_FM33A0xxEV_SiZhu

jinlicong
2024-04-30 ee3c90168f81ce19529904d80f9c9de4fed23bb8
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
/**
  ******************************************************************************
  * @file    fm33a0xxev_rng.c
  * @author  FM33A0XXEV Application Team
  * @version V1.0.0
  * @date    16-April-2020
  * @brief   This file provides firmware functions to manage the following 
  *          functionalities of....:
  *
*/
 
/* Includes ------------------------------------------------------------------*/
 
#include "fm33a0xxev_rng.h"
 
/** @addtogroup fm33a0xxev_StdPeriph_Driver
  * @{
  */
 
/** @defgroup RNG 
  * @brief RNG driver modules
  * @{
  */ 
 
/* RNGʹÄܼĴæÆ÷£¬Èí¼þд1Æô¶¯ (RNG enable)
1£ºÆô¶¯RNG
0£º¹Ø±ÕRNG Ïà¹Øº¯Êý */
void RNG_CR_EN_Setable(FunState NewState)
{
    if (NewState == ENABLE)
    {
        RNG->CR |= (RNG_CR_EN_Msk);
    }
    else
    {
        RNG->CR &= ~(RNG_CR_EN_Msk);
    }
}
 
FunState RNG_CR_EN_Getable(void)
{
    if (RNG->CR & (RNG_CR_EN_Msk))
    {
        return ENABLE;
    }
    else
    {
        return DISABLE;
    }
}
 
/* Ëæ»úÊýÉú³É½á¹û»òCRCÔËËã½á¹û¼Ä´æÆ÷£¬Ö»¶Á
(RNG output) Ïà¹Øº¯Êý */
uint32_t RNG_DOR_Read(void)
{
    return (RNG->DOR);
}
 
/* LFSR״̬±êÖ¾£¬Ö»¶Á (LFSR enable)
1£ºLFSRÔÚÔËÐÐÖУ¬²»¿É½øÐÐCRCÑéÖ¤
0£ºLFSR²»ÔÚÔËÐÐÖУ¬¿É½øÐÐCRCÑéÖ¤
×¢£º±¾¼Ä´æÆ÷²»»áÒýÆðÄ£¿éÖжϣ¬½ö¹©²éѯ Ïà¹Øº¯Êý */
FlagStatus RNG_SR_LFSREN_Chk(void)
{
    if (RNG->SR & (RNG_SR_LFSREN_Msk))
    {
        return SET;
    }
    else
    {
        return RESET;
    }
}
 
/* Ëæ»úÊýÉú³Éʧ°Ü±êÖ¾£¬Èí¼þд1ÇåÁã (Random Number Fail)
1£ºËæ»úÊýδÄÜͨ¹ýÖÊÁ¿¼ì²â
0£ºËæ»úÊýͨ¹ýÖÊÁ¿¼ì²â Ïà¹Øº¯Êý */
void RNG_SR_RNF_Clr(void)
{
    RNG->SR = RNG_SR_RNF_Msk;
}
 
FlagStatus RNG_SR_RNF_Chk(void)
{
    if (RNG->SR & RNG_SR_RNF_Msk)
    {
        return SET;
    }
    else
    {
        return RESET;
    }
}
 
/* CRCʹÄÜ¿ØÖƼĴæÆ÷£¬Èí¼þд1Æô¶¯CRC£¬ÔËËãÍê³ÉºóÓ²¼þ×Ô¶¯ÇåÁã (CRC enable)
1£ºCRCʹÄÜ
0£ºCRC¹Ø±Õ Ïà¹Øº¯Êý */
void RNG_CRC_CR_CRCEN_Setable(FunState NewState)
{
    if (NewState == ENABLE)
    {
        RNG->CRC_CR |= (RNG_CRC_CR_CRCEN_Msk);
    }
    else
    {
        RNG->CRC_CR &= ~(RNG_CRC_CR_CRCEN_Msk);
    }
}
 
FunState RNG_CRC_CR_CRCEN_Getable(void)
{
    if (RNG->CRC_CR & (RNG_CRC_CR_CRCEN_Msk))
    {
        return ENABLE;
    }
    else
    {
        return DISABLE;
    }
}
 
/* CRCÔËËãÊý¾ÝÊäÈë¼Ä´æÆ÷ (CRC data input) Ïà¹Øº¯Êý */
void RNG_CRC_DIR_Write(uint32_t SetValue)
{
    RNG->CRC_DIR = (SetValue);
}
 
uint32_t RNG_CRC_DIR_Read(void)
{
    return (RNG->CRC_DIR);
}
 
/* CRC¼ÆËãÍê³É±êÖ¾£¬Èí¼þд0ÇåÁã (CRC calculation done)
1£ºCRC¼ÆËãÍê³É
0£ºCRC¼ÆËãδÍê³É Ïà¹Øº¯Êý */
void RNG_CRC_SR_CRCDONE_Clr(void)
{
    RNG->CRC_SR &= ~(RNG_CRC_SR_CRCDONE_Msk);
}
 
FlagStatus RNG_CRC_SR_CRCDONE_Chk(void)
{
    if (RNG->CRC_SR & RNG_CRC_SR_CRCDONE_Msk)
    {
        return SET;
    }
    else
    {
        return RESET;
    }
}
 
 
void RNG_Deinit(void)
{
    //RNG->CR = 0x00000000;
    //RNG->DOR = 0x00000000;
    //RNG->SR = 0x00000000;
    //RNG->CRC_CR = 0x00000000;
    //RNG->CRC_DIR = 0xFFFFFFFF;
    //RNG->CRC_SR = 0x00000000;
}
 
/******END OF FILE****/