bluenrg_interface
stm32l4xx_hal_msp.c@0:fb1547f2354e, 2018-11-12 (annotated)
- Committer:
- Ciesarik3
- Date:
- Mon Nov 12 18:36:18 2018 +0000
- Revision:
- 0:fb1547f2354e
crc;
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
Ciesarik3 | 0:fb1547f2354e | 1 | /** |
Ciesarik3 | 0:fb1547f2354e | 2 | ****************************************************************************** |
Ciesarik3 | 0:fb1547f2354e | 3 | * @file stm32l4xx_hal_msp.c |
Ciesarik3 | 0:fb1547f2354e | 4 | * @author MCD Application Team |
Ciesarik3 | 0:fb1547f2354e | 5 | * @version V1.3.0 |
Ciesarik3 | 0:fb1547f2354e | 6 | * @date 29-January-2016 |
Ciesarik3 | 0:fb1547f2354e | 7 | * @brief HAL MSP module. |
Ciesarik3 | 0:fb1547f2354e | 8 | ****************************************************************************** |
Ciesarik3 | 0:fb1547f2354e | 9 | * @attention |
Ciesarik3 | 0:fb1547f2354e | 10 | * |
Ciesarik3 | 0:fb1547f2354e | 11 | * <h2><center>© COPYRIGHT(c) 2016 STMicroelectronics</center></h2> |
Ciesarik3 | 0:fb1547f2354e | 12 | * |
Ciesarik3 | 0:fb1547f2354e | 13 | * Redistribution and use in source and binary forms, with or without modification, |
Ciesarik3 | 0:fb1547f2354e | 14 | * are permitted provided that the following conditions are met: |
Ciesarik3 | 0:fb1547f2354e | 15 | * 1. Redistributions of source code must retain the above copyright notice, |
Ciesarik3 | 0:fb1547f2354e | 16 | * this list of conditions and the following disclaimer. |
Ciesarik3 | 0:fb1547f2354e | 17 | * 2. Redistributions in binary form must reproduce the above copyright notice, |
Ciesarik3 | 0:fb1547f2354e | 18 | * this list of conditions and the following disclaimer in the documentation |
Ciesarik3 | 0:fb1547f2354e | 19 | * and/or other materials provided with the distribution. |
Ciesarik3 | 0:fb1547f2354e | 20 | * 3. Neither the name of STMicroelectronics nor the names of its contributors |
Ciesarik3 | 0:fb1547f2354e | 21 | * may be used to endorse or promote products derived from this software |
Ciesarik3 | 0:fb1547f2354e | 22 | * without specific prior written permission. |
Ciesarik3 | 0:fb1547f2354e | 23 | * |
Ciesarik3 | 0:fb1547f2354e | 24 | * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" |
Ciesarik3 | 0:fb1547f2354e | 25 | * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
Ciesarik3 | 0:fb1547f2354e | 26 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE |
Ciesarik3 | 0:fb1547f2354e | 27 | * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE |
Ciesarik3 | 0:fb1547f2354e | 28 | * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL |
Ciesarik3 | 0:fb1547f2354e | 29 | * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR |
Ciesarik3 | 0:fb1547f2354e | 30 | * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER |
Ciesarik3 | 0:fb1547f2354e | 31 | * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, |
Ciesarik3 | 0:fb1547f2354e | 32 | * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
Ciesarik3 | 0:fb1547f2354e | 33 | * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
Ciesarik3 | 0:fb1547f2354e | 34 | * |
Ciesarik3 | 0:fb1547f2354e | 35 | ****************************************************************************** |
Ciesarik3 | 0:fb1547f2354e | 36 | */ |
Ciesarik3 | 0:fb1547f2354e | 37 | |
Ciesarik3 | 0:fb1547f2354e | 38 | /* Includes ------------------------------------------------------------------*/ |
Ciesarik3 | 0:fb1547f2354e | 39 | #include "stm32l4xx_nucleo_bluenrg.h" |
Ciesarik3 | 0:fb1547f2354e | 40 | |
Ciesarik3 | 0:fb1547f2354e | 41 | /** @addtogroup X-CUBE-BLE1_Applications |
Ciesarik3 | 0:fb1547f2354e | 42 | * @{ |
Ciesarik3 | 0:fb1547f2354e | 43 | */ |
Ciesarik3 | 0:fb1547f2354e | 44 | |
Ciesarik3 | 0:fb1547f2354e | 45 | /** @addtogroup SensorDemo |
Ciesarik3 | 0:fb1547f2354e | 46 | * @{ |
Ciesarik3 | 0:fb1547f2354e | 47 | */ |
Ciesarik3 | 0:fb1547f2354e | 48 | |
Ciesarik3 | 0:fb1547f2354e | 49 | /** @defgroup STM32L4XX_HAL_MSP |
Ciesarik3 | 0:fb1547f2354e | 50 | * @{ |
Ciesarik3 | 0:fb1547f2354e | 51 | */ |
Ciesarik3 | 0:fb1547f2354e | 52 | |
Ciesarik3 | 0:fb1547f2354e | 53 | /* Private typedef -----------------------------------------------------------*/ |
Ciesarik3 | 0:fb1547f2354e | 54 | /* Private define ------------------------------------------------------------*/ |
Ciesarik3 | 0:fb1547f2354e | 55 | /* Private macro -------------------------------------------------------------*/ |
Ciesarik3 | 0:fb1547f2354e | 56 | /* Private variables ---------------------------------------------------------*/ |
Ciesarik3 | 0:fb1547f2354e | 57 | /* Private function prototypes -----------------------------------------------*/ |
Ciesarik3 | 0:fb1547f2354e | 58 | /* Private functions ---------------------------------------------------------*/ |
Ciesarik3 | 0:fb1547f2354e | 59 | |
Ciesarik3 | 0:fb1547f2354e | 60 | /** @defgroup STM32L4XX_HAL_MSP_Private_Functions |
Ciesarik3 | 0:fb1547f2354e | 61 | * @{ |
Ciesarik3 | 0:fb1547f2354e | 62 | */ |
Ciesarik3 | 0:fb1547f2354e | 63 | |
Ciesarik3 | 0:fb1547f2354e | 64 | /** |
Ciesarik3 | 0:fb1547f2354e | 65 | * @brief This function is used for low level initialization of the SPI |
Ciesarik3 | 0:fb1547f2354e | 66 | * communication with the BlueNRG Expansion Board. |
Ciesarik3 | 0:fb1547f2354e | 67 | * @param hspi: SPI handle. |
Ciesarik3 | 0:fb1547f2354e | 68 | * @retval None |
Ciesarik3 | 0:fb1547f2354e | 69 | */ |
Ciesarik3 | 0:fb1547f2354e | 70 | void HAL_SPI_MspInit(SPI_HandleTypeDef* hspi) |
Ciesarik3 | 0:fb1547f2354e | 71 | { |
Ciesarik3 | 0:fb1547f2354e | 72 | GPIO_InitTypeDef GPIO_InitStruct; |
Ciesarik3 | 0:fb1547f2354e | 73 | if(hspi->Instance==BNRG_SPI_INSTANCE) |
Ciesarik3 | 0:fb1547f2354e | 74 | { |
Ciesarik3 | 0:fb1547f2354e | 75 | /* Enable peripherals clock */ |
Ciesarik3 | 0:fb1547f2354e | 76 | |
Ciesarik3 | 0:fb1547f2354e | 77 | /* Enable GPIO Ports Clock */ |
Ciesarik3 | 0:fb1547f2354e | 78 | BNRG_SPI_RESET_CLK_ENABLE(); |
Ciesarik3 | 0:fb1547f2354e | 79 | BNRG_SPI_SCLK_CLK_ENABLE(); |
Ciesarik3 | 0:fb1547f2354e | 80 | BNRG_SPI_MISO_CLK_ENABLE(); |
Ciesarik3 | 0:fb1547f2354e | 81 | BNRG_SPI_MOSI_CLK_ENABLE(); |
Ciesarik3 | 0:fb1547f2354e | 82 | BNRG_SPI_CS_CLK_ENABLE(); |
Ciesarik3 | 0:fb1547f2354e | 83 | BNRG_SPI_IRQ_CLK_ENABLE(); |
Ciesarik3 | 0:fb1547f2354e | 84 | |
Ciesarik3 | 0:fb1547f2354e | 85 | /* Enable SPI clock */ |
Ciesarik3 | 0:fb1547f2354e | 86 | BNRG_SPI_CLK_ENABLE(); |
Ciesarik3 | 0:fb1547f2354e | 87 | |
Ciesarik3 | 0:fb1547f2354e | 88 | /* Reset */ |
Ciesarik3 | 0:fb1547f2354e | 89 | GPIO_InitStruct.Pin = BNRG_SPI_RESET_PIN; |
Ciesarik3 | 0:fb1547f2354e | 90 | GPIO_InitStruct.Mode = BNRG_SPI_RESET_MODE; |
Ciesarik3 | 0:fb1547f2354e | 91 | GPIO_InitStruct.Pull = BNRG_SPI_RESET_PULL; |
Ciesarik3 | 0:fb1547f2354e | 92 | GPIO_InitStruct.Speed = BNRG_SPI_RESET_SPEED; |
Ciesarik3 | 0:fb1547f2354e | 93 | GPIO_InitStruct.Alternate = BNRG_SPI_RESET_ALTERNATE; |
Ciesarik3 | 0:fb1547f2354e | 94 | HAL_GPIO_Init(BNRG_SPI_RESET_PORT, &GPIO_InitStruct); |
Ciesarik3 | 0:fb1547f2354e | 95 | HAL_GPIO_WritePin(BNRG_SPI_RESET_PORT, BNRG_SPI_RESET_PIN, GPIO_PIN_RESET); /*Added to avoid spurious interrupt from the BlueNRG */ |
Ciesarik3 | 0:fb1547f2354e | 96 | |
Ciesarik3 | 0:fb1547f2354e | 97 | /* SCLK */ |
Ciesarik3 | 0:fb1547f2354e | 98 | GPIO_InitStruct.Pin = BNRG_SPI_SCLK_PIN; |
Ciesarik3 | 0:fb1547f2354e | 99 | GPIO_InitStruct.Mode = BNRG_SPI_SCLK_MODE; |
Ciesarik3 | 0:fb1547f2354e | 100 | GPIO_InitStruct.Pull = BNRG_SPI_SCLK_PULL; |
Ciesarik3 | 0:fb1547f2354e | 101 | GPIO_InitStruct.Speed = BNRG_SPI_SCLK_SPEED; |
Ciesarik3 | 0:fb1547f2354e | 102 | GPIO_InitStruct.Alternate = BNRG_SPI_SCLK_ALTERNATE; |
Ciesarik3 | 0:fb1547f2354e | 103 | HAL_GPIO_Init(BNRG_SPI_SCLK_PORT, &GPIO_InitStruct); |
Ciesarik3 | 0:fb1547f2354e | 104 | |
Ciesarik3 | 0:fb1547f2354e | 105 | /* MISO */ |
Ciesarik3 | 0:fb1547f2354e | 106 | GPIO_InitStruct.Pin = BNRG_SPI_MISO_PIN; |
Ciesarik3 | 0:fb1547f2354e | 107 | GPIO_InitStruct.Mode = BNRG_SPI_MISO_MODE; |
Ciesarik3 | 0:fb1547f2354e | 108 | GPIO_InitStruct.Pull = BNRG_SPI_MISO_PULL; |
Ciesarik3 | 0:fb1547f2354e | 109 | GPIO_InitStruct.Speed = BNRG_SPI_MISO_SPEED; |
Ciesarik3 | 0:fb1547f2354e | 110 | GPIO_InitStruct.Alternate = BNRG_SPI_MISO_ALTERNATE; |
Ciesarik3 | 0:fb1547f2354e | 111 | HAL_GPIO_Init(BNRG_SPI_MISO_PORT, &GPIO_InitStruct); |
Ciesarik3 | 0:fb1547f2354e | 112 | |
Ciesarik3 | 0:fb1547f2354e | 113 | /* MOSI */ |
Ciesarik3 | 0:fb1547f2354e | 114 | GPIO_InitStruct.Pin = BNRG_SPI_MOSI_PIN; |
Ciesarik3 | 0:fb1547f2354e | 115 | GPIO_InitStruct.Mode = BNRG_SPI_MOSI_MODE; |
Ciesarik3 | 0:fb1547f2354e | 116 | GPIO_InitStruct.Pull = BNRG_SPI_MOSI_PULL; |
Ciesarik3 | 0:fb1547f2354e | 117 | GPIO_InitStruct.Speed = BNRG_SPI_MOSI_SPEED; |
Ciesarik3 | 0:fb1547f2354e | 118 | GPIO_InitStruct.Alternate = BNRG_SPI_MOSI_ALTERNATE; |
Ciesarik3 | 0:fb1547f2354e | 119 | HAL_GPIO_Init(BNRG_SPI_MOSI_PORT, &GPIO_InitStruct); |
Ciesarik3 | 0:fb1547f2354e | 120 | |
Ciesarik3 | 0:fb1547f2354e | 121 | /* NSS/CSN/CS */ |
Ciesarik3 | 0:fb1547f2354e | 122 | GPIO_InitStruct.Pin = BNRG_SPI_CS_PIN; |
Ciesarik3 | 0:fb1547f2354e | 123 | GPIO_InitStruct.Mode = BNRG_SPI_CS_MODE; |
Ciesarik3 | 0:fb1547f2354e | 124 | GPIO_InitStruct.Pull = BNRG_SPI_CS_PULL; |
Ciesarik3 | 0:fb1547f2354e | 125 | GPIO_InitStruct.Speed = BNRG_SPI_CS_SPEED; |
Ciesarik3 | 0:fb1547f2354e | 126 | GPIO_InitStruct.Alternate = BNRG_SPI_CS_ALTERNATE; |
Ciesarik3 | 0:fb1547f2354e | 127 | HAL_GPIO_Init(BNRG_SPI_CS_PORT, &GPIO_InitStruct); |
Ciesarik3 | 0:fb1547f2354e | 128 | HAL_GPIO_WritePin(BNRG_SPI_CS_PORT, BNRG_SPI_CS_PIN, GPIO_PIN_SET); |
Ciesarik3 | 0:fb1547f2354e | 129 | |
Ciesarik3 | 0:fb1547f2354e | 130 | /* IRQ -- INPUT */ |
Ciesarik3 | 0:fb1547f2354e | 131 | GPIO_InitStruct.Pin = BNRG_SPI_IRQ_PIN; |
Ciesarik3 | 0:fb1547f2354e | 132 | GPIO_InitStruct.Mode = BNRG_SPI_IRQ_MODE; |
Ciesarik3 | 0:fb1547f2354e | 133 | GPIO_InitStruct.Pull = BNRG_SPI_IRQ_PULL; |
Ciesarik3 | 0:fb1547f2354e | 134 | GPIO_InitStruct.Speed = BNRG_SPI_IRQ_SPEED; |
Ciesarik3 | 0:fb1547f2354e | 135 | GPIO_InitStruct.Alternate = BNRG_SPI_IRQ_ALTERNATE; |
Ciesarik3 | 0:fb1547f2354e | 136 | HAL_GPIO_Init(BNRG_SPI_IRQ_PORT, &GPIO_InitStruct); |
Ciesarik3 | 0:fb1547f2354e | 137 | |
Ciesarik3 | 0:fb1547f2354e | 138 | /* Configure the NVIC for SPI */ |
Ciesarik3 | 0:fb1547f2354e | 139 | HAL_NVIC_SetPriority(BNRG_SPI_EXTI_IRQn, 3, 0); |
Ciesarik3 | 0:fb1547f2354e | 140 | HAL_NVIC_EnableIRQ(BNRG_SPI_EXTI_IRQn); |
Ciesarik3 | 0:fb1547f2354e | 141 | } |
Ciesarik3 | 0:fb1547f2354e | 142 | } |
Ciesarik3 | 0:fb1547f2354e | 143 | |
Ciesarik3 | 0:fb1547f2354e | 144 | /** |
Ciesarik3 | 0:fb1547f2354e | 145 | * @} |
Ciesarik3 | 0:fb1547f2354e | 146 | */ |
Ciesarik3 | 0:fb1547f2354e | 147 | |
Ciesarik3 | 0:fb1547f2354e | 148 | /** |
Ciesarik3 | 0:fb1547f2354e | 149 | * @} |
Ciesarik3 | 0:fb1547f2354e | 150 | */ |
Ciesarik3 | 0:fb1547f2354e | 151 | |
Ciesarik3 | 0:fb1547f2354e | 152 | /** |
Ciesarik3 | 0:fb1547f2354e | 153 | * @} |
Ciesarik3 | 0:fb1547f2354e | 154 | */ |
Ciesarik3 | 0:fb1547f2354e | 155 | |
Ciesarik3 | 0:fb1547f2354e | 156 | /** |
Ciesarik3 | 0:fb1547f2354e | 157 | * @} |
Ciesarik3 | 0:fb1547f2354e | 158 | */ |
Ciesarik3 | 0:fb1547f2354e | 159 | |
Ciesarik3 | 0:fb1547f2354e | 160 | /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ |