Publish Library to my account
Dependencies: ST_INTERFACES X_NUCLEO_COMMON
Fork of LIS3MDL by
Revision 1:d85092ab306e, committed 2017-09-07
- Comitter:
- nikapov
- Date:
- Thu Sep 07 12:27:45 2017 +0000
- Parent:
- 0:7376fbeb1d4a
- Child:
- 2:b3212ad3c306
- Commit message:
- Add default init.
Changed in this revision
| lis3mdl_class.cpp | Show annotated file Show diff for this revision Revisions of this file |
| magneto.h | Show annotated file Show diff for this revision Revisions of this file |
--- a/lis3mdl_class.cpp Tue Sep 05 10:15:14 2017 +0000
+++ b/lis3mdl_class.cpp Thu Sep 07 12:27:45 2017 +0000
@@ -53,6 +53,17 @@
MAGNETO_StatusTypeDef LIS3MDL::LIS3MDL_Init(MAGNETO_InitTypeDef *LIS3MDL_Init)
{
uint8_t tmp1 = 0x00;
+ MAGNETO_InitTypeDef *initStructure = LIS3MDL_Init;
+
+ if (initStructure == NULL) {// default params
+ MAGNETO_InitTypeDef tempInit;
+ tempInit.M_FullScale = LIS3MDL_M_FS_4;
+ tempInit.M_OperatingMode = LIS3MDL_M_MD_CONTINUOUS;
+ tempInit.M_XYOperativeMode = LIS3MDL_M_OM_HP;
+ tempInit.M_OutputDataRate = LIS3MDL_M_DO_80;
+ initStructure = &tempInit;
+ }
+
/* Configure the low level interface ---------------------------------------*/
if(LIS3MDL_IO_Init() != MAGNETO_OK)
@@ -69,7 +80,7 @@
/* Conversion mode selection */
tmp1 &= ~(LIS3MDL_M_MD_MASK);
- tmp1 |= LIS3MDL_Init->M_OperatingMode;
+ tmp1 |= initStructure->M_OperatingMode;
if(LIS3MDL_IO_Write(&tmp1, LIS3MDL_M_CTRL_REG3_M, 1) != MAGNETO_OK)
{
@@ -83,11 +94,11 @@
/* Output data rate selection */
tmp1 &= ~(LIS3MDL_M_DO_MASK);
- tmp1 |= LIS3MDL_Init->M_OutputDataRate;
+ tmp1 |= initStructure->M_OutputDataRate;
/* X and Y axes Operative mode selection */
tmp1 &= ~(LIS3MDL_M_OM_MASK);
- tmp1 |= LIS3MDL_Init->M_XYOperativeMode;
+ tmp1 |= initStructure->M_XYOperativeMode;
if(LIS3MDL_IO_Write(&tmp1, LIS3MDL_M_CTRL_REG1_M, 1) != MAGNETO_OK)
{
@@ -101,7 +112,7 @@
/* Full scale selection */
tmp1 &= ~(LIS3MDL_M_FS_MASK);
- tmp1 |= LIS3MDL_Init->M_FullScale;
+ tmp1 |= initStructure->M_FullScale;
if(LIS3MDL_IO_Write(&tmp1, LIS3MDL_M_CTRL_REG2_M, 1) != MAGNETO_OK)
{
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/magneto.h Thu Sep 07 12:27:45 2017 +0000
@@ -0,0 +1,142 @@
+/**
+ ******************************************************************************
+ * @file magneto.h
+ * @author MEMS Application Team
+ * @version V1.2.0
+ * @date 28-January-2015
+ * @brief This header file contains the functions prototypes for the
+ * magneto driver.
+ ******************************************************************************
+ * @attention
+ *
+ * <h2><center>© COPYRIGHT(c) 2015 STMicroelectronics</center></h2>
+ *
+ * Redistribution and use in source and binary forms, with or without modification,
+ * are permitted provided that the following conditions are met:
+ * 1. Redistributions of source code must retain the above copyright notice,
+ * this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright notice,
+ * this list of conditions and the following disclaimer in the documentation
+ * and/or other materials provided with the distribution.
+ * 3. Neither the name of STMicroelectronics nor the names of its contributors
+ * may be used to endorse or promote products derived from this software
+ * without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+ * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ ******************************************************************************
+ */
+
+
+/* Define to prevent recursive inclusion -------------------------------------*/
+#ifndef __MAGNETO_H
+#define __MAGNETO_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+/* Includes ------------------------------------------------------------------*/
+#include <stdint.h>
+
+/** @addtogroup BSP
+ * @{
+ */
+
+/** @addtogroup Components
+ * @{
+ */
+
+/** @addtogroup MAGNETO
+ * @{
+ */
+
+/** @defgroup MAGNETO_Exported_Types
+ * @{
+ */
+
+/**
+* @brief MAGNETO init structure definition
+*/
+typedef struct
+{
+ uint8_t M_OutputDataRate;
+ uint8_t M_OperatingMode;
+ uint8_t M_FullScale;
+ uint8_t M_XYOperativeMode;
+} MAGNETO_InitTypeDef;
+
+/**
+* @brief MAGNETO status enumerator definition
+*/
+typedef enum
+{
+ MAGNETO_OK = 0,
+ MAGNETO_ERROR = 1,
+ MAGNETO_TIMEOUT = 2,
+ MAGNETO_NOT_IMPLEMENTED = 3
+} MAGNETO_StatusTypeDef;
+
+/**
+ * @brief MAGNETO component id enumerator definition
+ */
+typedef enum
+{
+ MAGNETO_NONE_COMPONENT = 0,
+ MAGNETO_LIS3MDL_COMPONENT = 1
+} MAGNETO_ComponentTypeDef;
+
+/**
+ * @brief MAGNETO driver extended structure definition
+ */
+typedef struct
+{
+ MAGNETO_ComponentTypeDef
+ id; /* This id must be unique for each component belonging to this class that wants to extend common class */
+ void *pData; /* This pointer is specific for each component */
+} MAGNETO_DrvExtTypeDef;
+
+/**
+* @brief MAGNETO driver structure definition
+*/
+typedef struct
+{
+ MAGNETO_StatusTypeDef (*Init)(MAGNETO_InitTypeDef *);
+ MAGNETO_StatusTypeDef (*Read_M_ID)(uint8_t *);
+ MAGNETO_StatusTypeDef (*Get_M_Axes)(int32_t *);
+ MAGNETO_StatusTypeDef (*Get_M_AxesRaw)(int16_t *);
+ MAGNETO_DrvExtTypeDef *extData;
+} MAGNETO_DrvTypeDef;
+
+/**
+ * @}
+ */
+
+/**
+ * @}
+ */
+
+/**
+ * @}
+ */
+
+/**
+ * @}
+ */
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif /* __MAGNETO_H */
+
+/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/
