MAV'RIC
|
00001 /******************************************************************************* 00002 * Copyright (c) 2009-2016, MAV'RIC Development Team 00003 * All rights reserved. 00004 * 00005 * Redistribution and use in source and binary forms, with or without 00006 * modification, are permitted provided that the following conditions are met: 00007 * 00008 * 1. Redistributions of source code must retain the above copyright notice, 00009 * this list of conditions and the following disclaimer. 00010 * 00011 * 2. Redistributions in binary form must reproduce the above copyright notice, 00012 * this list of conditions and the following disclaimer in the documentation 00013 * and/or other materials provided with the distribution. 00014 * 00015 * 3. Neither the name of the copyright holder nor the names of its contributors 00016 * may be used to endorse or promote products derived from this software without 00017 * specific prior written permission. 00018 * 00019 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 00020 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 00021 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 00022 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE 00023 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 00024 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 00025 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 00026 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 00027 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 00028 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00029 * POSSIBILITY OF SUCH DAMAGE. 00030 ******************************************************************************/ 00031 00032 /******************************************************************************* 00033 * \file spi_stm32.hpp 00034 * 00035 * \author MAV'RIC Team 00036 * \author Jean-Francois Burnier 00037 * 00038 * \brief Implementation of spi peripheral for stm32 00039 * 00040 ******************************************************************************/ 00041 00042 #ifndef SPI_STM32_HPP_ 00043 #define SPI_STM32_HPP_ 00044 00045 #include "hal/common/spi.hpp" 00046 #include "hal/stm32/gpio_stm32.hpp" 00047 00048 extern "C" 00049 { 00050 #include <libopencm3/stm32/spi.h> 00051 } 00052 00056 typedef enum 00057 { 00058 STM32_SPI1 = SPI1, 00059 STM32_SPI2 = SPI2, 00060 STM32_SPI3 = SPI3, 00061 } spi_stm32_devices_t; 00062 00063 00067 typedef enum 00068 { 00069 STM32_SPI_MODE_CPOL0_CPHA0 = 0, 00070 STM32_SPI_MODE_CPOL0_CPHA1 = 1, 00071 STM32_SPI_MODE_CPOL1_CPHA0 = 2, 00072 STM32_SPI_MODE_CPOL1_CPHA1 = 3, 00073 } spi_stm32_mode_t; 00074 00078 typedef struct 00079 { 00080 spi_stm32_devices_t spi_device; 00081 spi_stm32_mode_t mode; 00082 uint8_t clk_div; 00083 bool ss_mode_hard; 00084 gpio_stm32_conf_t miso_gpio_config; 00085 gpio_stm32_conf_t mosi_gpio_config; 00086 gpio_stm32_conf_t sck_gpio_config; 00087 } spi_stm32_conf_t; 00088 00089 00093 class Spi_stm32: public Spi 00094 { 00095 public: 00096 00102 Spi_stm32(spi_stm32_conf_t spi_config); 00103 00104 00111 bool init(void); 00112 00113 00123 bool write(uint8_t* bytes, uint32_t nbytes = 1); 00124 00125 00135 bool read(uint8_t* in_buffer, uint32_t nbytes = 1); 00136 00147 bool transfer(uint8_t* out_buffer, uint8_t* in_buffer, uint32_t nbytes); 00148 00152 void select_slave(void); 00153 00157 void unselect_slave(void); 00158 00159 00160 private: 00161 00162 spi_stm32_conf_t config_; 00163 spi_stm32_devices_t spi_; 00164 00165 }; 00166 00167 00168 #endif /* SPI_STM32_HPP_ */