Added STM32F4xx StdPeriph Driver sources
[fw/stlink] / example / stm32f4 / STM32F4xx_StdPeriph_Driver / src / stm32f4xx_crc.c
1 /**
2   ******************************************************************************
3   * @file    stm32f4xx_crc.c
4   * @author  MCD Application Team
5   * @version V1.0.0RC1
6   * @date    25-August-2011
7   * @brief   This file provides all the CRC firmware functions.
8   ******************************************************************************
9   * @attention
10   *
11   * THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
12   * WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
13   * TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
14   * DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
15   * FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
16   * CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
17   *
18   * <h2><center>&copy; COPYRIGHT 2011 STMicroelectronics</center></h2>
19   ******************************************************************************
20   */
21
22 /* Includes ------------------------------------------------------------------*/
23 #include "stm32f4xx_crc.h"
24
25 /** @addtogroup STM32F4xx_StdPeriph_Driver
26   * @{
27   */
28
29 /** @defgroup CRC 
30   * @brief CRC driver modules
31   * @{
32   */
33
34 /* Private typedef -----------------------------------------------------------*/
35 /* Private define ------------------------------------------------------------*/
36 /* Private macro -------------------------------------------------------------*/
37 /* Private variables ---------------------------------------------------------*/
38 /* Private function prototypes -----------------------------------------------*/
39 /* Private functions ---------------------------------------------------------*/
40
41 /** @defgroup CRC_Private_Functions
42   * @{
43   */
44
45 /**
46   * @brief  Resets the CRC Data register (DR).
47   * @param  None
48   * @retval None
49   */
50 void CRC_ResetDR(void)
51 {
52   /* Reset CRC generator */
53   CRC->CR = CRC_CR_RESET;
54 }
55
56 /**
57   * @brief  Computes the 32-bit CRC of a given data word(32-bit).
58   * @param  Data: data word(32-bit) to compute its CRC
59   * @retval 32-bit CRC
60   */
61 uint32_t CRC_CalcCRC(uint32_t Data)
62 {
63   CRC->DR = Data;
64   
65   return (CRC->DR);
66 }
67
68 /**
69   * @brief  Computes the 32-bit CRC of a given buffer of data word(32-bit).
70   * @param  pBuffer: pointer to the buffer containing the data to be computed
71   * @param  BufferLength: length of the buffer to be computed                                   
72   * @retval 32-bit CRC
73   */
74 uint32_t CRC_CalcBlockCRC(uint32_t pBuffer[], uint32_t BufferLength)
75 {
76   uint32_t index = 0;
77   
78   for(index = 0; index < BufferLength; index++)
79   {
80     CRC->DR = pBuffer[index];
81   }
82   return (CRC->DR);
83 }
84
85 /**
86   * @brief  Returns the current CRC value.
87   * @param  None
88   * @retval 32-bit CRC
89   */
90 uint32_t CRC_GetCRC(void)
91 {
92   return (CRC->DR);
93 }
94
95 /**
96   * @brief  Stores a 8-bit data in the Independent Data(ID) register.
97   * @param  IDValue: 8-bit value to be stored in the ID register                                        
98   * @retval None
99   */
100 void CRC_SetIDRegister(uint8_t IDValue)
101 {
102   CRC->IDR = IDValue;
103 }
104
105 /**
106   * @brief  Returns the 8-bit data stored in the Independent Data(ID) register
107   * @param  None
108   * @retval 8-bit value of the ID register 
109   */
110 uint8_t CRC_GetIDRegister(void)
111 {
112   return (CRC->IDR);
113 }
114
115 /**
116   * @}
117   */
118
119 /**
120   * @}
121   */
122
123 /**
124   * @}
125   */
126
127 /******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/