From e1e1e0a8dbc3baed6a192fec05fc29920c162fb0 Mon Sep 17 00:00:00 2001 From: raiden00pl Date: Sun, 28 Apr 2019 12:36:55 +0000 Subject: [PATCH] Merged in raiden00/nuttx_h7/sensors (pull request #863) Add some I2C devices to nucleo-h743zi and a few small fixes configs/nucleo-h743zi: add support for ssd1306 configs/nucleo-h743zi: add support for pca9635 configs/nucleo-h743zi: add support for i2ctools include/nuttx/sensors/lsm6dsl.h: remove whitespaces configs/stm32f103-minimum/src/stm32_ssd1306.c: cosmetics Documentation/NuttxPortingGuide.html: vsyslog return none drivers/syslog/README.txt: vsyslog return none Approved-by: Gregory Nutt --- Documentation/NuttxPortingGuide.html | 2 +- configs/nucleo-h743zi/include/board.h | 12 +- configs/nucleo-h743zi/nxlines_oled/defconfig | 76 ++++++ configs/nucleo-h743zi/src/Makefile | 12 + configs/nucleo-h743zi/src/nucleo-h743zi.h | 35 +++ configs/nucleo-h743zi/src/stm32_bringup.c | 84 ++++++ configs/nucleo-h743zi/src/stm32_lsm6dsl.c | 2 +- configs/nucleo-h743zi/src/stm32_lsm9ds1.c | 114 ++++++++ configs/nucleo-h743zi/src/stm32_pca9635.c | 98 +++++++ configs/nucleo-h743zi/src/stm32_ssd1306.c | 123 +++++++++ configs/stm32f103-minimum/src/stm32_ssd1306.c | 4 +- drivers/syslog/README.txt | 2 +- include/nuttx/sensors/lsm6dsl.h | 244 +++++++++--------- 13 files changed, 678 insertions(+), 130 deletions(-) create mode 100644 configs/nucleo-h743zi/nxlines_oled/defconfig create mode 100644 configs/nucleo-h743zi/src/stm32_lsm9ds1.c create mode 100644 configs/nucleo-h743zi/src/stm32_pca9635.c create mode 100644 configs/nucleo-h743zi/src/stm32_ssd1306.c diff --git a/Documentation/NuttxPortingGuide.html b/Documentation/NuttxPortingGuide.html index dedb90c32c..bca2f785d7 100644 --- a/Documentation/NuttxPortingGuide.html +++ b/Documentation/NuttxPortingGuide.html @@ -6470,7 +6470,7 @@ int kbd_decode(FAR struct lib_instream_s *stream, FAR struct kbd_getstate_s *sta

Description: syslog() generates a log message. The priority argument is formed by ORing the facility and the level values (see include/syslog.h). The remaining arguments are a format, as in printf() and any arguments to the format. diff --git a/configs/nucleo-h743zi/include/board.h b/configs/nucleo-h743zi/include/board.h index 95d445fe9e..f6f1ffe7db 100644 --- a/configs/nucleo-h743zi/include/board.h +++ b/configs/nucleo-h743zi/include/board.h @@ -321,10 +321,16 @@ #define GPIO_USART6_RX GPIO_USART6_RX_2 /* PG9 */ #define GPIO_USART6_TX GPIO_USART6_TX_2 /* PG14 */ -/* I2C1 Use Nucleo I2C pins */ +/* I2C1 Use Nucleo I2C1 pins */ -#define GPIO_I2C1_SCL GPIO_I2C1_SCL_2 /* PB8 */ -#define GPIO_I2C1_SDA GPIO_I2C1_SDA_2 /* PB9 */ +#define GPIO_I2C1_SCL GPIO_I2C1_SCL_2 /* PB8 - D15 */ +#define GPIO_I2C1_SDA GPIO_I2C1_SDA_2 /* PB9 - D14 */ + +/* I2C2 Use Nucleo I2C2 pins */ + +#define GPIO_I2C2_SCL GPIO_I2C2_SCL_2 /* PF1 - D69 */ +#define GPIO_I2C2_SDA GPIO_I2C2_SDA_2 /* PF0 - D68 */ +#define GPIO_I2C2_SMBA GPIO_I2C2_SMBA_2 /* PF2 - D70 */ /* SPI3 */ diff --git a/configs/nucleo-h743zi/nxlines_oled/defconfig b/configs/nucleo-h743zi/nxlines_oled/defconfig new file mode 100644 index 0000000000..0b6828fad3 --- /dev/null +++ b/configs/nucleo-h743zi/nxlines_oled/defconfig @@ -0,0 +1,76 @@ +# +# This file is autogenerated: PLEASE DO NOT EDIT IT. +# +# You can use "make menuconfig" to make any modifications to the installed .config file. +# You can then do "make savedefconfig" to generate a new defconfig file that includes your +# modifications. +# +# CONFIG_ARCH_FPU is not set +# CONFIG_EXAMPLES_NXLINES_DEFAULT_COLORS is not set +# CONFIG_NSH_DISABLE_IFCONFIG is not set +# CONFIG_NSH_DISABLE_PS is not set +# CONFIG_NX_DISABLE_1BPP is not set +# CONFIG_STANDARD_SERIAL is not set +CONFIG_ARCH="arm" +CONFIG_ARCH_BOARD="nucleo-h743zi" +CONFIG_ARCH_BOARD_NUCLEO_H743ZI=y +CONFIG_ARCH_CHIP_STM32H743ZI=y +CONFIG_ARCH_CHIP_STM32H7=y +CONFIG_ARCH_STACKDUMP=y +CONFIG_ARMV7M_DCACHE=y +CONFIG_ARMV7M_DCACHE_WRITETHROUGH=y +CONFIG_ARMV7M_DTCM=y +CONFIG_ARMV7M_ICACHE=y +CONFIG_BOARD_LOOPSPERMSEC=43103 +CONFIG_BUILTIN=y +CONFIG_DEBUG_NOOPT=y +CONFIG_DISABLE_POLL=y +CONFIG_EXAMPLES_NXLINES=y +CONFIG_EXAMPLES_NXLINES_BORDERWIDTH=1 +CONFIG_EXAMPLES_NXLINES_BPP=1 +CONFIG_EXAMPLES_NXLINES_LINECOLOR=0xff +CONFIG_EXAMPLES_NXLINES_LINEWIDTH=1 +CONFIG_EXPERIMENTAL=y +CONFIG_HAVE_CXX=y +CONFIG_HAVE_CXXINITIALIZE=y +CONFIG_INTELHEX_BINARY=y +CONFIG_LCD=y +CONFIG_LCD_MAXCONTRAST=255 +CONFIG_LCD_SH1106_OLED_132=y +CONFIG_LCD_SSD1306_I2C=y +CONFIG_MAX_TASKS=16 +CONFIG_MAX_WDOGPARMS=2 +CONFIG_MM_REGIONS=3 +CONFIG_MQ_MAXMSGSIZE=128 +CONFIG_NFILE_DESCRIPTORS=8 +CONFIG_NFILE_STREAMS=8 +CONFIG_NSH_ARCHINIT=y +CONFIG_NSH_BUILTIN_APPS=y +CONFIG_NSH_FILEIOSIZE=512 +CONFIG_NSH_LINELEN=64 +CONFIG_NSH_READLINE=y +CONFIG_NX=y +CONFIG_NXFONTS_DISABLE_1BPP=y +CONFIG_NXFONT_MONO5X8=y +CONFIG_NX_BLOCKING=y +CONFIG_PREALLOC_MQ_MSGS=4 +CONFIG_PREALLOC_TIMERS=4 +CONFIG_PREALLOC_WDOGS=4 +CONFIG_RAM_SIZE=245760 +CONFIG_RAM_START=0x20010000 +CONFIG_RAW_BINARY=y +CONFIG_RR_INTERVAL=200 +CONFIG_SCHED_WAITPID=y +CONFIG_SDCLONE_DISABLE=y +CONFIG_START_DAY=6 +CONFIG_START_MONTH=12 +CONFIG_START_YEAR=2011 +CONFIG_STM32H7_I2C2=y +CONFIG_STM32H7_USART3=y +CONFIG_SYSLOG_NONE=y +CONFIG_SYSTEM_NSH=y +CONFIG_SYSTEM_NSH_CXXINITIALIZE=y +CONFIG_TASK_NAME_SIZE=0 +CONFIG_USART3_SERIAL_CONSOLE=y +CONFIG_USER_ENTRYPOINT="nsh_main" +CONFIG_WDOG_INTRESERVE=0 diff --git a/configs/nucleo-h743zi/src/Makefile b/configs/nucleo-h743zi/src/Makefile index 3d08897b27..dc896ccd7a 100644 --- a/configs/nucleo-h743zi/src/Makefile +++ b/configs/nucleo-h743zi/src/Makefile @@ -60,10 +60,22 @@ ifeq ($(CONFIG_SENSORS_LSM6DSL),y) CSRCS += stm32_lsm6dsl.c endif +ifeq ($(CONFIG_SENSORS_LSM9DS1),y) +CSRCS += stm32_lsm9ds1.c +endif + ifeq ($(CONFIG_SENSORS_LSM303AGR),y) CSRCS += stm32_lsm303agr.c endif +ifeq ($(CONFIG_PCA9635PW),y) +CSRCS += stm32_pca9635.c +endif + +ifeq ($(CONFIG_LCD_SSD1306),y) +CSRCS += stm32_ssd1306.c +endif + ifeq ($(CONFIG_LIB_BOARDCTL),y) CSRCS += stm32_appinitialize.c endif diff --git a/configs/nucleo-h743zi/src/nucleo-h743zi.h b/configs/nucleo-h743zi/src/nucleo-h743zi.h index e57bd96f86..f9812324d1 100644 --- a/configs/nucleo-h743zi/src/nucleo-h743zi.h +++ b/configs/nucleo-h743zi/src/nucleo-h743zi.h @@ -133,6 +133,19 @@ GPIO_OUTPUT_CLEAR | GPIO_PORTF | GPIO_PIN12) #define GPIO_NRF24L01_IRQ (GPIO_INPUT | GPIO_FLOAT | GPIO_PORTD | GPIO_PIN15) +/* LMS9DS1 configuration */ + +#define LMS9DS1_I2CBUS 1 + +/* PCA9635 configuration */ + +#define PCA9635_I2CBUS 1 +#define PCA9635_I2CADDR 0x40 + +/* Oled configuration */ + +#define OLED_I2C_PORT 2 + /************************************************************************************ * Public Functions ************************************************************************************/ @@ -225,4 +238,26 @@ int stm32_lsm303agr_initialize(char *devpath); int stm32_wlinitialize(void); #endif +/***************************************************************************** + * Name: stm32_lsm9ds1_initialize + * + * Description: + * Initialize I2C-based LSM9DS1. + ****************************************************************************/ + +#ifdef CONFIG_SENSORS_LSM9DS1 +int stm32_lsm9ds1_initialize(char *devpath); +#endif + +/**************************************************************************** + * Name: stm32_pca9635_initialize + * + * Description: + * Initialize I2C-based PCA9635PW LED driver. + ****************************************************************************/ + +#ifdef CONFIG_PCA9635PW +int stm32_pca9635_initialize(void); +#endif + #endif /* __CONFIGS_NUCLEO_H743ZI_SRC_NUCLEO_H743ZI_H */ diff --git a/configs/nucleo-h743zi/src/stm32_bringup.c b/configs/nucleo-h743zi/src/stm32_bringup.c index 36e571030b..6aa9fec9b7 100644 --- a/configs/nucleo-h743zi/src/stm32_bringup.c +++ b/configs/nucleo-h743zi/src/stm32_bringup.c @@ -50,6 +50,68 @@ # include #endif +/**************************************************************************** + * Private Functions + ****************************************************************************/ + +/**************************************************************************** + * Name: stm32_i2c_register + * + * Description: + * Register one I2C drivers for the I2C tool. + * + ****************************************************************************/ + +#if defined(CONFIG_I2C) && defined(CONFIG_SYSTEM_I2CTOOL) +static void stm32_i2c_register(int bus) +{ + FAR struct i2c_master_s *i2c; + int ret; + + i2c = stm32_i2cbus_initialize(bus); + if (i2c == NULL) + { + syslog(LOG_ERR, "ERROR: Failed to get I2C%d interface\n", bus); + } + else + { + ret = i2c_register(i2c, bus); + if (ret < 0) + { + syslog(LOG_ERR, "ERROR: Failed to register I2C%d driver: %d\n", + bus, ret); + stm32_i2cbus_uninitialize(i2c); + } + } +} +#endif + +/**************************************************************************** + * Name: stm32_i2ctool + * + * Description: + * Register I2C drivers for the I2C tool. + * + ****************************************************************************/ + +#if defined(CONFIG_I2C) && defined(CONFIG_SYSTEM_I2CTOOL) +static void stm32_i2ctool(void) +{ +#ifdef CONFIG_STM32H7_I2C1 + stm32_i2c_register(1); +#endif +#ifdef CONFIG_STM32H7_I2C2 + stm32_i2c_register(2); +#endif +#ifdef CONFIG_STM32H7_I2C3 + stm32_i2c_register(3); +#endif +#ifdef CONFIG_STM32H7_I2C4 + stm32_i2c_register(4); +#endif +} +#endif + /**************************************************************************** * Public Functions ****************************************************************************/ @@ -74,6 +136,10 @@ int stm32_bringup(void) UNUSED(ret); +#if defined(CONFIG_I2C) && defined(CONFIG_SYSTEM_I2CTOOL) + stm32_i2ctool(); +#endif + #ifdef CONFIG_FS_PROCFS #ifdef CONFIG_STM32_CCM_PROCFS /* Register the CCM procfs entry. This must be done before the procfs is @@ -122,6 +188,14 @@ int stm32_bringup(void) } #endif /* CONFIG_SENSORS_LSM6DSL */ +#ifdef CONFIG_SENSORS_LSM9DS1 + ret = stm32_lsm9ds1_initialize(); + if (ret < 0) + { + syslog(LOG_ERR, "ERROR: Failed to initialize LSM9DS1 driver: %d\n", ret); + } +#endif /* CONFIG_SENSORS_LSM6DSL */ + #ifdef CONFIG_SENSORS_LSM303AGR ret = stm32_lsm303agr_initialize("/dev/lsm303mag0"); if (ret < 0) @@ -130,6 +204,16 @@ int stm32_bringup(void) } #endif /* CONFIG_SENSORS_LSM303AGR */ +#ifdef CONFIG_PCA9635PW + /* Initialize the PCA9635 chip */ + + ret = stm32_pca9635_initialize(); + if (ret < 0) + { + syslog(LOG_ERR, "ERROR: stm32_pca9635_initialize failed: %d\n", ret); + } +#endif + #ifdef CONFIG_WL_NRF24L01 ret = stm32_wlinitialize(); if (ret < 0) diff --git a/configs/nucleo-h743zi/src/stm32_lsm6dsl.c b/configs/nucleo-h743zi/src/stm32_lsm6dsl.c index 826695c6dd..c23c6ece59 100644 --- a/configs/nucleo-h743zi/src/stm32_lsm6dsl.c +++ b/configs/nucleo-h743zi/src/stm32_lsm6dsl.c @@ -86,7 +86,7 @@ int stm32_lsm6dsl_initialize(char *devpath) sninfo("INFO: Initializing LMS6DSL accelero-gyro sensor over I2C%d\n", ret); - ret = lsm6dsl_sensor_register("/dev/lsm6dsl0", i2c, LSM6DSLACCEL_ADDR1); + ret = lsm6dsl_sensor_register(devpath, i2c, LSM6DSLACCEL_ADDR1); if (ret < 0) { snerr("ERROR: Failed to initialize LMS6DSL accelero-gyro driver %s\n", devpath); diff --git a/configs/nucleo-h743zi/src/stm32_lsm9ds1.c b/configs/nucleo-h743zi/src/stm32_lsm9ds1.c new file mode 100644 index 0000000000..b4ca3155ed --- /dev/null +++ b/configs/nucleo-h743zi/src/stm32_lsm9ds1.c @@ -0,0 +1,114 @@ +/***************************************************************************** + * configs/nucleo-h743zi/src/stm32_lsm9ds1.c + * + * Copyright (C) 2019 Greg Nutt. All rights reserved. + * Author: Mateusz Szafoni + * + * 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 NuttX 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 OWNER 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. + ****************************************************************************/ + +/***************************************************************************** + * Included Files + ****************************************************************************/ + +#include +#include + +#include +#include + +#include +#include "stm32.h" +#include +#include + +/***************************************************************************** + * Pre-processor Definitions + ****************************************************************************/ + +#ifndef CONFIG_STM32H7_I2C1 +# error "LSM9DS1 driver requires CONFIG_STM32H7_I2C1 to be enabled" +#endif + +#define LSM9DS1MAG_DEVPATH "/dev/lsm9ds1mag0" +#define LSM9DS1ACC_DEVPATH "/dev/lsm9ds1acc0" +#define LSM9DS1GYR_DEVPATH "/dev/lsm9ds1gyr0" + +/***************************************************************************** + * Public Functions + ****************************************************************************/ + +/***************************************************************************** + * Name: stm32_lsm9ds1_initialize + * + * Description: + * Initialize I2C-based LSM9DS1. + ****************************************************************************/ + +int stm32_lsm9ds1_initialize(void) +{ + FAR struct i2c_master_s *i2c; + int ret = OK; + + sninfo("Initializing LMS9DS1!\n"); + +#if defined(CONFIG_STM32H7_I2C1) + i2c = stm32_i2cbus_initialize(LMS9DS1_I2CBUS); + if (i2c == NULL) + { + return -ENODEV; + } + + sninfo("INFO: Initializing LMS9DS1 9DoF sensor over I2C%d\n", LMS9DS1_I2CBUS); + + ret = lsm9ds1mag_register(LSM9DS1MAG_DEVPATH, i2c, LSM9DS1MAG_ADDR1); + if (ret < 0) + { + snerr("ERROR: Failed to initialize LMS9DS1 mag driver %s\n", LSM9DS1MAG_DEVPATH); + return -ENODEV; + } + + ret = lsm9ds1gyro_register(LSM9DS1GYR_DEVPATH, i2c, LSM9DS1GYRO_ADDR1); + if (ret < 0) + { + snerr("ERROR: Failed to initialize LMS9DS1 gyro driver %s\n", LSM9DS1MAG_DEVPATH); + return -ENODEV; + } + + ret = lsm9ds1accel_register(LSM9DS1ACC_DEVPATH, i2c, LSM9DS1ACCEL_ADDR1); + if (ret < 0) + { + snerr("ERROR: Failed to initialize LMS9DS1 accel driver %s\n", LSM9DS1MAG_DEVPATH); + return -ENODEV; + } + + sninfo("INFO: LMS9DS1 sensor has been initialized successfully\n"); +#endif + + return ret; +} diff --git a/configs/nucleo-h743zi/src/stm32_pca9635.c b/configs/nucleo-h743zi/src/stm32_pca9635.c new file mode 100644 index 0000000000..386c28ae98 --- /dev/null +++ b/configs/nucleo-h743zi/src/stm32_pca9635.c @@ -0,0 +1,98 @@ +/************************************************************************************ + * configs/nucleo-h743zi/src/stm32_pca9635.c + * + * Copyright (C) 2019 Gregory Nutt. All rights reserved. + * Author: Mateusz Szafoni + * + * 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 NuttX 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 OWNER 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. + * + ************************************************************************************/ + +/**************************************************************************** + * Included Files + ****************************************************************************/ + +#include + +#include +#include +#include +#include + +#include +#include + +#include + +#include "stm32.h" +#include "nucleo-h743zi.h" + +/**************************************************************************** + * Public Functions + ****************************************************************************/ + +/**************************************************************************** + * Name: stm32_pca9635_initialize + * + * Description: + * This function is called by board initialization logic to configure the + * LED PWM chip. This function will register the driver as /dev/leddrv0. + * + * Input Parameters: + * None + * + * Returned Value: + * Zero is returned on success. Otherwise, a negated errno value is + * returned to indicate the nature of the failure. + * + ****************************************************************************/ + +int stm32_pca9635_initialize(void) +{ + + FAR struct i2c_master_s *i2c; + int ret; + + /* Get the I2C driver that interfaces with the pca9635 */ + + i2c = stm32_i2cbus_initialize(PCA9635_I2CBUS); + if (!i2c) + { + _err("ERROR: Failed to initialize I2C%d\n", PCA9635_I2CBUS); + return -1; + } + + ret = pca9635pw_register("/dev/leddrv0", i2c, PCA9635_I2CADDR); + if (ret < 0) + { + snerr("ERROR: Failed to register PCA9635 driver: %d\n", ret); + return ret; + } + + return OK; +} diff --git a/configs/nucleo-h743zi/src/stm32_ssd1306.c b/configs/nucleo-h743zi/src/stm32_ssd1306.c new file mode 100644 index 0000000000..7c61546d8f --- /dev/null +++ b/configs/nucleo-h743zi/src/stm32_ssd1306.c @@ -0,0 +1,123 @@ +/**************************************************************************** + * config/nucleo-h743zi/src/stm32_ssd1306.c + * + * Copyright (C) 2019 Gregory Nutt. All rights reserved. + * Author: Mateusz Szafoni + * + * 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 NuttX 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 OWNER 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. + * + ****************************************************************************/ + +/**************************************************************************** + * Included Files + ****************************************************************************/ + +#include + +#include + +#include +#include +#include +#include + +#include "stm32.h" +#include "nucleo-h743zi.h" + +/**************************************************************************** + * Pre-processor Definitions + ****************************************************************************/ +/* Configuration ************************************************************/ + +#ifndef CONFIG_LCD_MAXPOWER +# define CONFIG_LCD_MAXPOWER 1 +#endif + +/**************************************************************************** + * Private Data + ****************************************************************************/ + +FAR struct i2c_master_s *g_i2c; +FAR struct lcd_dev_s *g_lcddev; + +/**************************************************************************** + * Public Functions + ****************************************************************************/ + +/**************************************************************************** + * Name: board_lcd_initialize + ****************************************************************************/ + +int board_lcd_initialize(void) +{ + /* Initialize I2C */ + + g_i2c = stm32_i2cbus_initialize(OLED_I2C_PORT); + if (!g_i2c) + { + lcderr("ERROR: Failed to initialize I2C port %d\n", OLED_I2C_PORT); + return -ENODEV; + } + + return OK; +} + +/**************************************************************************** + * Name: board_lcd_getdev + ****************************************************************************/ + +FAR struct lcd_dev_s *board_lcd_getdev(int devno) +{ + /* Bind the I2C port to the OLED */ + + g_lcddev = ssd1306_initialize(g_i2c, NULL, devno); + if (!g_lcddev) + { + lcderr("ERROR: Failed to bind I2C port 1 to OLED %d: %d\n", devno); + } + else + { + lcdinfo("Bound I2C port %d to OLED %d\n", OLED_I2C_PORT, devno); + + /* And turn the OLED on */ + + (void)g_lcddev->setpower(g_lcddev, CONFIG_LCD_MAXPOWER); + return g_lcddev; + } + + return NULL; +} + +/**************************************************************************** + * Name: board_lcd_uninitialize + ****************************************************************************/ + +void board_lcd_uninitialize(void) +{ + /* TO-FIX */ +} diff --git a/configs/stm32f103-minimum/src/stm32_ssd1306.c b/configs/stm32f103-minimum/src/stm32_ssd1306.c index da1048cdfa..9ca05e6113 100644 --- a/configs/stm32f103-minimum/src/stm32_ssd1306.c +++ b/configs/stm32f103-minimum/src/stm32_ssd1306.c @@ -1,5 +1,5 @@ /**************************************************************************** - * config/stm32f103-minimum/src/sam_ug2832hsweg04.c + * config/stm32f103-minimum/src/stm32_ssd1306.c * * Copyright (C) 2014 Gregory Nutt. All rights reserved. * Author: Gregory Nutt @@ -105,7 +105,7 @@ FAR struct lcd_dev_s *board_lcd_getdev(int devno) g_lcddev = ssd1306_initialize(g_i2c, NULL, devno); if (!g_lcddev) { - lcderr("ERROR: Failed to bind SPI port 1 to OLED %d: %d\n", devno); + lcderr("ERROR: Failed to bind I2C port 1 to OLED %d: %d\n", devno); } else { diff --git a/drivers/syslog/README.txt b/drivers/syslog/README.txt index 024e4ce434..93cd1709f8 100644 --- a/drivers/syslog/README.txt +++ b/drivers/syslog/README.txt @@ -16,7 +16,7 @@ SYSLOG Interfaces Prototypes: int syslog(int priority, FAR const IPTR char *format, ...); - int vsyslog(int priority, FAR const IPTR char *src, va_list ap); + void vsyslog(int priority, FAR const IPTR char *src, va_list ap); Description: diff --git a/include/nuttx/sensors/lsm6dsl.h b/include/nuttx/sensors/lsm6dsl.h index c6ea728169..6ce568e1c4 100644 --- a/include/nuttx/sensors/lsm6dsl.h +++ b/include/nuttx/sensors/lsm6dsl.h @@ -221,10 +221,10 @@ functions (r/w). */ #define LSM6DSL_SENSOR_SYNC_RES_RATIO_SHIFT 0 #define LSM6DSL_SENSOR_SYNC_RES_RATIO_MASK (3 << LSM6DSL_SENSOR_SYNC_RES_RATIO_SHIFT) -#define LSM6DSL_SENSOR_SYNC_RES_RATIO_RR_2_11 (0 << LSM6DSL_SENSOR_SYNC_RES_RATIO_SHIFT) -#define LSM6DSL_SENSOR_SYNC_RES_RATIO_RR_2_12 (1 << LSM6DSL_SENSOR_SYNC_RES_RATIO_SHIFT) -#define LSM6DSL_SENSOR_SYNC_RES_RATIO_RR_2_13 (2 << LSM6DSL_SENSOR_SYNC_RES_RATIO_SHIFT) -#define LSM6DSL_SENSOR_SYNC_RES_RATIO_RR_2_14 (3 << LSM6DSL_SENSOR_SYNC_RES_RATIO_SHIFT) +#define LSM6DSL_SENSOR_SYNC_RES_RATIO_RR_2_11 (0 << LSM6DSL_SENSOR_SYNC_RES_RATIO_SHIFT) +#define LSM6DSL_SENSOR_SYNC_RES_RATIO_RR_2_12 (1 << LSM6DSL_SENSOR_SYNC_RES_RATIO_SHIFT) +#define LSM6DSL_SENSOR_SYNC_RES_RATIO_RR_2_13 (2 << LSM6DSL_SENSOR_SYNC_RES_RATIO_SHIFT) +#define LSM6DSL_SENSOR_SYNC_RES_RATIO_RR_2_14 (3 << LSM6DSL_SENSOR_SYNC_RES_RATIO_SHIFT) #define LSM6DSL_FIFO_CTRL1_SHIFT 0 #define LSM6DSL_FIFO_CTRL1_MASK (255 << LSM6DSL_FIFO_CTRL1_SHIFT) @@ -289,14 +289,14 @@ functions (r/w). */ #define LSM6DSL_CTRL1_XL_LPF1_BW_SEL (1 << 1) #define LSM6DSL_CTRL1_XL_FS_XL_SHIFT 2 #define LSM6DSL_CTRL1_XL_FS_XL_MASK (3 << LSM6DSL_CTRL1_XL_FS_XL_SHIFT) -#define LSM6DSL_CTRL1_XL_FS_XL_2G (0 << LSM6DSL_CTRL1_XL_FS_XL_SHIFT) -#define LSM6DSL_CTRL1_XL_FS_XL_16G (1 << LSM6DSL_CTRL1_XL_FS_XL_SHIFT) -#define LSM6DSL_CTRL1_XL_FS_XL_4G (2 << LSM6DSL_CTRL1_XL_FS_XL_SHIFT) -#define LSM6DSL_CTRL1_XL_FS_XL_8G (3 << LSM6DSL_CTRL1_XL_FS_XL_SHIFT) +#define LSM6DSL_CTRL1_XL_FS_XL_2G (0 << LSM6DSL_CTRL1_XL_FS_XL_SHIFT) +#define LSM6DSL_CTRL1_XL_FS_XL_16G (1 << LSM6DSL_CTRL1_XL_FS_XL_SHIFT) +#define LSM6DSL_CTRL1_XL_FS_XL_4G (2 << LSM6DSL_CTRL1_XL_FS_XL_SHIFT) +#define LSM6DSL_CTRL1_XL_FS_XL_8G (3 << LSM6DSL_CTRL1_XL_FS_XL_SHIFT) #define LSM6DSL_CTRL1_XL_ODR_XL_SHIFT 4 #define LSM6DSL_CTRL1_XL_ODR_XL_MASK (15 << LSM6DSL_CTRL1_XL_ODR_XL_SHIFT) -#define LSM6DSL_CTRL1_XL_ODR_XL_POWER_DOWN (0 << LSM6DSL_CTRL1_XL_ODR_XL_SHIFT) +#define LSM6DSL_CTRL1_XL_ODR_XL_POWER_DOWN (0 << LSM6DSL_CTRL1_XL_ODR_XL_SHIFT) #define LSM6DSL_CTRL1_XL_ODR_XL_1_6HZ_12_5HZ (11 << LSM6DSL_CTRL1_XL_ODR_XL_SHIFT) #define LSM6DSL_CTRL1_XL_ODR_XL_12_5HZ_12_5HZ (1 << LSM6DSL_CTRL1_XL_ODR_XL_SHIFT) #define LSM6DSL_CTRL1_XL_ODR_XL_26HZ_26HZ (2 << LSM6DSL_CTRL1_XL_ODR_XL_SHIFT) @@ -313,14 +313,14 @@ functions (r/w). */ #define LSM6DSL_CTRL2_G_FS_125 (1 << 1) #define LSM6DSL_CTRL2_G_FS_G_SHIFT 2 #define LSM6DSL_CTRL2_G_FS_G_MASK (3 << LSM6DSL_CTRL2_G_FS_G_SHIFT) -#define LSM6DSL_CTRL2_G_FS_G_250DPS (0 << LSM6DSL_CTRL2_G_FS_G_SHIFT) -#define LSM6DSL_CTRL2_G_FS_G_500DPS (1 << LSM6DSL_CTRL2_G_FS_G_SHIFT) -#define LSM6DSL_CTRL2_G_FS_G_1000DPS (2 << LSM6DSL_CTRL2_G_FS_G_SHIFT) -#define LSM6DSL_CTRL2_G_FS_G_2000DPS (3 << LSM6DSL_CTRL2_G_FS_G_SHIFT) +#define LSM6DSL_CTRL2_G_FS_G_250DPS (0 << LSM6DSL_CTRL2_G_FS_G_SHIFT) +#define LSM6DSL_CTRL2_G_FS_G_500DPS (1 << LSM6DSL_CTRL2_G_FS_G_SHIFT) +#define LSM6DSL_CTRL2_G_FS_G_1000DPS (2 << LSM6DSL_CTRL2_G_FS_G_SHIFT) +#define LSM6DSL_CTRL2_G_FS_G_2000DPS (3 << LSM6DSL_CTRL2_G_FS_G_SHIFT) #define LSM6DSL_CTRL2_G_ODR_G_SHIFT 4 #define LSM6DSL_CTRL2_G_ODR_G_MASK (15 << LSM6DSL_CTRL2_G_ODR_G_SHIFT) -#define LSM6DSL_CTRL2_G_ODR_G_POWER_DOWN (0 << LSM6DSL_CTRL2_G_ODR_G_SHIFT) +#define LSM6DSL_CTRL2_G_ODR_G_POWER_DOWN (0 << LSM6DSL_CTRL2_G_ODR_G_SHIFT) #define LSM6DSL_CTRL2_G_ODR_G_1_6HZ_12_5HZ (11 << LSM6DSL_CTRL2_G_ODR_G_SHIFT) #define LSM6DSL_CTRL2_G_ODR_G_12_5HZ_12_5HZ (1 << LSM6DSL_CTRL2_G_ODR_G_SHIFT) #define LSM6DSL_CTRL2_G_ODR_G_26HZ_26HZ (2 << LSM6DSL_CTRL2_G_ODR_G_SHIFT) @@ -333,7 +333,7 @@ functions (r/w). */ #define LSM6DSL_CTRL2_G_ODR_G_3_3kHz_3_3kHZ (9 << LSM6DSL_CTRL2_G_ODR_G_SHIFT) #define LSM6DSL_CTRL2_G_ODR_G_6_6kHZ_6_6kHZ (10 << LSM6DSL_CTRL2_G_ODR_G_SHIFT) -#define LSM6DSL_CTRL3_C_SHIFT 0 +#define LSM6DSL_CTRL3_C_SHIFT 0 #define LSM6DSL_CTRL3_C_MASK (0 << LSM6DSL_CTRL3_C_SHIFT) #define LSM6DSL_CTRL3_C_SW_RESET (1 << 0) #define LSM6DSL_CTRL3_C_BLE (1 << 1) @@ -439,139 +439,139 @@ functions (r/w). */ #define LSM6DSL_CTRL5_C_SHIFT 0 #define LSM6DSL_CTRL5_C_ST_XL_MASK (3 << LSM6DSL_CTRL5_C_SHIFT) -#define LSM6DSL_OUT_TEMP_L_TEMP_SHIFT 0 +#define LSM6DSL_OUT_TEMP_L_TEMP_SHIFT 0 #define LSM6DSL_OUT_TEMP_L_TEMP_MASK (255 << LSM6DSL_OUT_TEMP_L_TEMP_SHIFT) #define LSM6DSL_OUT_TEMP_H_TEMP_SHIFT 0 #define LSM6DSL_OUT_TEMP_H_TEMP_MASK (255 << LSM6DSL_OUT_TEMP_H_TEMP_SHIFT) -#define LSM6DSL_OUTX_L_G_SHIFT 0 +#define LSM6DSL_OUTX_L_G_SHIFT 0 #define LSM6DSL_OUTX_L_G_MASK (255 << LSM6DSL_OUTX_L_G_SHIFT) -#define LSM6DSL_OUTX_H_G_SHIFT 0 +#define LSM6DSL_OUTX_H_G_SHIFT 0 #define LSM6DSL_OUTX_H_G_MASK (255 << LSM6DSL_OUTX_H_G_SHIFT) -#define LSM6DSL_OUTY_L_G_SHIFT 0 +#define LSM6DSL_OUTY_L_G_SHIFT 0 #define LSM6DSL_OUTY_L_G_MASK (255 << LSM6DSL_OUTY_L_G_SHIFT) -#define LSM6DSL_OUTY_H_G_SHIFT 0 +#define LSM6DSL_OUTY_H_G_SHIFT 0 #define LSM6DSL_OUTY_H_G_MASK (255 << LSM6DSL_OUTY_H_G_SHIFT) -#define LSM6DSL_OUTZ_L_G_SHIFT 0 +#define LSM6DSL_OUTZ_L_G_SHIFT 0 #define LSM6DSL_OUTZ_L_G_MASK (255 << LSM6DSL_OUTZ_L_G_SHIFT) -#define LSM6DSL_OUTZ_H_G_SHIFT 0 +#define LSM6DSL_OUTZ_H_G_SHIFT 0 #define LSM6DSL_OUTZ_H_G_MASK (255 << LSM6DSL_OUTZ_H_G_SHIFT) -#define LSM6DSL_OUTX_L_XL_SHIFT 0 +#define LSM6DSL_OUTX_L_XL_SHIFT 0 #define LSM6DSL_OUTX_L_XL_MASK (255 << LSM6DSL_OUTX_L_XL_SHIFT) -#define LSM6DSL_OUTX_H_XL_SHIFT 0 +#define LSM6DSL_OUTX_H_XL_SHIFT 0 #define LSM6DSL_OUTX_H_XL_MASK (255 << LSM6DSL_OUTX_H_XL_SHIFT) -#define LSM6DSL_OUTY_L_XL_SHIFT 0 +#define LSM6DSL_OUTY_L_XL_SHIFT 0 #define LSM6DSL_OUTY_L_XL_MASK (255 << LSM6DSL_OUTY_L_XL_SHIFT) -#define LSM6DSL_OUTY_H_XL_SHIFT 0 +#define LSM6DSL_OUTY_H_XL_SHIFT 0 #define LSM6DSL_OUTY_H_XL_MASK (255 << LSM6DSL_OUTY_H_XL_SHIFT) -#define LSM6DSL_OUTZ_L_XL_SHIFT 0 +#define LSM6DSL_OUTZ_L_XL_SHIFT 0 #define LSM6DSL_OUTZ_L_XL_MASK (255 << LSM6DSL_OUTZ_L_XL_SHIFT) -#define LSM6DSL_OUTZ_H_XL_SHIFT 0 +#define LSM6DSL_OUTZ_H_XL_SHIFT 0 #define LSM6DSL_OUTZ_H_XL_MASK (255 << LSM6DSL_OUTZ_H_XL_SHIFT) -#define LSM6DSL_SENSORHUB1_REG_SHIFT 0 +#define LSM6DSL_SENSORHUB1_REG_SHIFT 0 #define LSM6DSL_SENSORHUB1_REG_MASK (255 << LSM6DSL_SENSORHUB1_REG_SHIFT) -#define LSM6DSL_SENSORHUB2_REG_SHIFT 0 +#define LSM6DSL_SENSORHUB2_REG_SHIFT 0 #define LSM6DSL_SENSORHUB2_REG_MASK (255 << LSM6DSL_SENSORHUB2_REG_SHIFT) -#define LSM6DSL_SENSORHUB3_REG_SHIFT 0 +#define LSM6DSL_SENSORHUB3_REG_SHIFT 0 #define LSM6DSL_SENSORHUB3_REG_MASK (255 << LSM6DSL_SENSORHUB3_REG_SHIFT) -#define LSM6DSL_SENSORHUB4_REG_SHIFT 0 +#define LSM6DSL_SENSORHUB4_REG_SHIFT 0 #define LSM6DSL_SENSORHUB4_REG_MASK (255 << LSM6DSL_SENSORHUB4_REG_SHIFT) -#define LSM6DSL_SENSORHUB5_REG_SHIFT 0 +#define LSM6DSL_SENSORHUB5_REG_SHIFT 0 #define LSM6DSL_SENSORHUB5_REG_MASK (255 << LSM6DSL_SENSORHUB5_REG_SHIFT) -#define LSM6DSL_SENSORHUB6_REG_SHIFT 0 +#define LSM6DSL_SENSORHUB6_REG_SHIFT 0 #define LSM6DSL_SENSORHUB6_REG_MASK (255 << LSM6DSL_SENSORHUB6_REG_SHIFT) -#define LSM6DSL_SENSORHUB7_REG_SHIFT 0 +#define LSM6DSL_SENSORHUB7_REG_SHIFT 0 #define LSM6DSL_SENSORHUB7_REG_MASK (255 << LSM6DSL_SENSORHUB7_REG_SHIFT) -#define LSM6DSL_SENSORHUB8_REG_SHIFT 0 +#define LSM6DSL_SENSORHUB8_REG_SHIFT 0 #define LSM6DSL_SENSORHUB8_REG_MASK (255 << LSM6DSL_SENSORHUB8_REG_SHIFT) -#define LSM6DSL_SENSORHUB9_REG_SHIFT 0 +#define LSM6DSL_SENSORHUB9_REG_SHIFT 0 #define LSM6DSL_SENSORHUB9_REG_MASK (255 << LSM6DSL_SENSORHUB9_REG_SHIFT) -#define LSM6DSL_SENSORHUB10_REG_SHIFT 0 +#define LSM6DSL_SENSORHUB10_REG_SHIFT 0 #define LSM6DSL_SENSORHUB10_REG_MASK (255 << LSM6DSL_SENSORHUB10_REG_SHIFT) -#define LSM6DSL_SENSORHUB11_REG_SHIFT 0 +#define LSM6DSL_SENSORHUB11_REG_SHIFT 0 #define LSM6DSL_SENSORHUB11_REG_MASK (255 << LSM6DSL_SENSORHUB11_REG_SHIFT) -#define LSM6DSL_SENSORHUB12_REG_SHIFT 0 +#define LSM6DSL_SENSORHUB12_REG_SHIFT 0 #define LSM6DSL_SENSORHUB12_REG_MASK (255 << LSM6DSL_SENSORHUB12_REG_SHIFT) -#define LSM6DSL_FIFO_STATUS1_SHIFT 0 +#define LSM6DSL_FIFO_STATUS1_SHIFT 0 #define LSM6DSL_FIFO_STATUS1_MASK (255 << LSM6DSL_FIFO_STATUS1_SHIFT) -#define LSM6DSL_FIFO_STATUS2_DIFF_FIFO_SHIFT 0 +#define LSM6DSL_FIFO_STATUS2_DIFF_FIFO_SHIFT 0 #define LSM6DSL_FIFO_STATUS2_DIFF_FIFO_MASK (7 << LSM6DSL_FIFO_STATUS2_DIFF_FIFO_SHIFT) #define LSM6DSL_FIFO_STATUS2_FIFO_EMPTY (1 << 1) #define LSM6DSL_FIFO_STATUS2_FIFO_FULL_ART (1 << 1) #define LSM6DSL_FIFO_STATUS2_OVER_RUN (1 << 2) #define LSM6DSL_FIFO_STATUS2_WaterM (1 << 3) -#define LSM6DSL_FIFO_STATUS3_SHIFT 0 +#define LSM6DSL_FIFO_STATUS3_SHIFT 0 #define LSM6DSL_FIFO_STATUS3_MASK (255 << LSM6DSL_FIFO_STATUS3_SHIFT) -#define LSM6DSL_FIFO_STATUS4_SHIFT 0 +#define LSM6DSL_FIFO_STATUS4_SHIFT 0 #define LSM6DSL_FIFO_STATUS4_MASK (3 << LSM6DSL_FIFO_STATUS4_SHIFT) -#define LSM6DSL_FIFO_DATA_OUT_L_SHIFT 0 +#define LSM6DSL_FIFO_DATA_OUT_L_SHIFT 0 #define LSM6DSL_FIFO_DATA_OUT_L_MASK (255 << LSM6DSL_FIFO_DATA_OUT_L_SHIFT) -#define LSM6DSL_FIFO_DATA_OUT_H_SHIFT 0 +#define LSM6DSL_FIFO_DATA_OUT_H_SHIFT 0 #define LSM6DSL_FIFO_DATA_OUT_H_MASK (255 << LSM6DSL_FIFO_DATA_OUT_H_SHIFT) -#define LSM6DSL_TIMESTAMP0_REG_SHIFT 0 +#define LSM6DSL_TIMESTAMP0_REG_SHIFT 0 #define LSM6DSL_TIMESTAMP0_REG_MASK (255 << LSM6DSL_TIMESTAMP0_REG_SHIFT) -#define LSM6DSL_TIMESTAMP1_REG_SHIFT 0 +#define LSM6DSL_TIMESTAMP1_REG_SHIFT 0 #define LSM6DSL_TIMESTAMP1_REG_MASK (255 << LSM6DSL_TIMESTAMP1_REG_SHIFT) -#define LSM6DSL_TIMESTAMP2_REG_SHIFT 0 +#define LSM6DSL_TIMESTAMP2_REG_SHIFT 0 #define LSM6DSL_TIMESTAMP2_REG_MASK (255 << LSM6DSL_TIMESTAMP2_REG_SHIFT) -#define LSM6DSL_STEP_TIMESTAMP_L_SHIFT 0 +#define LSM6DSL_STEP_TIMESTAMP_L_SHIFT 0 #define LSM6DSL_STEP_TIMESTAMP_L_MASK (255 << LSM6DSL_STEP_TIMESTAMP_L_SHIFT) -#define LSM6DSL_STEP_TIMESTAMP_H_SHIFT 0 +#define LSM6DSL_STEP_TIMESTAMP_H_SHIFT 0 #define LSM6DSL_STEP_TIMESTAMP_H_MASK (255 << LSM6DSL_STEP_TIMESTAMP_H_SHIFT) -#define LSM6DSL_STEP_COUNTER_L_SHIFT 0 +#define LSM6DSL_STEP_COUNTER_L_SHIFT 0 #define LSM6DSL_STEP_COUNTER_L_MASK (255 << LSM6DSL_STEP_COUNTER_L_SHIFT) -#define LSM6DSL_SENSORHUB13_REG_SHIFT 0 +#define LSM6DSL_SENSORHUB13_REG_SHIFT 0 #define LSM6DSL_SENSORHUB13_REG_MASK (255 << LSM6DSL_SENSORHUB13_REG_SHIFT) -#define LSM6DSL_SENSORHUB14_REG_SHIFT 0 +#define LSM6DSL_SENSORHUB14_REG_SHIFT 0 #define LSM6DSL_SENSORHUB14_REG_MASK (255 << LSM6DSL_SENSORHUB14_REG_SHIFT) -#define LSM6DSL_SENSORHUB15_REG_SHIFT 0 +#define LSM6DSL_SENSORHUB15_REG_SHIFT 0 #define LSM6DSL_SENSORHUB15_REG_MASK (255 << LSM6DSL_SENSORHUB15_REG_SHIFT) -#define LSM6DSL_SENSORHUB16_REG_SHIFT 0 +#define LSM6DSL_SENSORHUB16_REG_SHIFT 0 #define LSM6DSL_SENSORHUB16_REG_MASK (255 << LSM6DSL_SENSORHUB16_REG_SHIFT) -#define LSM6DSL_SENSORHUB17_REG_SHIFT 0 +#define LSM6DSL_SENSORHUB17_REG_SHIFT 0 #define LSM6DSL_SENSORHUB17_REG_MASK (255 << LSM6DSL_SENSORHUB17_REG_SHIFT) -#define LSM6DSL_SENSORHUB18_REG_SHIFT 0 +#define LSM6DSL_SENSORHUB18_REG_SHIFT 0 #define LSM6DSL_SENSORHUB18_REG_MASK (255 << LSM6DSL_SENSORHUB18_REG_SHIFT) #define LSM6DSL_FUNC_SRC1_SENSORHUB_END_OP (1 << 0) @@ -589,7 +589,7 @@ functions (r/w). */ #define LSM6DSL_FUNC_SRC2_SLAVE2_NACK (1 << 5) #define LSM6DSL_FUNC_SRC2_SLAVE3_NACK (1 << 6) -#define LSM6DSL_WRIST_TILT_IA_SHIFT 2 +#define LSM6DSL_WRIST_TILT_IA_SHIFT 2 #define LSM6DSL_WRIST_TILT_IA_MASK (63 << LSM6DSL_WRIST_TILT_IA_SHIFT) #define LSM6DSL_TAP_CFG_LIR (1 << 0) @@ -597,13 +597,13 @@ functions (r/w). */ #define LSM6DSL_TAP_CFG_TAP_Y_EN (1 << 2) #define LSM6DSL_TAP_CFG_TAP_X_EN (1 << 3) #define LSM6DSL_TAP_CFG_SLOPE_FDS (1 << 4) -#define LSM6DSL_TAP_CFG_INACT_EN_SHIFT 2 +#define LSM6DSL_TAP_CFG_INACT_EN_SHIFT 2 #define LSM6DSL_TAP_CFG_INACT_EN_MASK (3 << LSM6DSL_TAP_CFG_INACT_EN_SHIFT) #define LSM6DSL_TAP_CFG_INTERRUPTS_ENABLE (1 << 7) -#define LSM6DSL_TAP_THS_6D_TAP_THS_SHIFT 0 +#define LSM6DSL_TAP_THS_6D_TAP_THS_SHIFT 0 #define LSM6DSL_TAP_THS_6D_TAP_THS_MASK (31 << LSM6DSL_TAP_THS_6D_TAP_THS_SHIFT) -#define LSM6DSL_TAP_THS_6D_SIXD_THS_SHIFT 5 +#define LSM6DSL_TAP_THS_6D_SIXD_THS_SHIFT 5 #define LSM6DSL_TAP_THS_6D_SIXD_THS_MASK (3 << LSM6DSL_TAP_THS_6D_SIXD_THS_SHIFT) #define LSM6DSL_TAP_THS_6D_SIXD_THS_80DEGR (0 << LSM6DSL_TAP_THS_6D_SIXD_THS_SHIFT) #define LSM6DSL_TAP_THS_6D_SIXD_THS_70DEGR (1 << LSM6DSL_TAP_THS_6D_SIXD_THS_SHIFT) @@ -611,27 +611,27 @@ functions (r/w). */ #define LSM6DSL_TAP_THS_6D_SIXD_THS_50DEGR (3 << LSM6DSL_TAP_THS_6D_SIXD_THS_SHIFT) #define LSM6DSL_TAP_THS_6D_D4D_EN (1 << 7) -#define LSM6DSL_INT_DUR2_SHOCK_SHIFT 0 +#define LSM6DSL_INT_DUR2_SHOCK_SHIFT 0 #define LSM6DSL_INT_DUR2_SHOCK_MASK (3 << LSM6DSL_INT_DUR2_SHOCK_SHIFT) -#define LSM6DSL_INT_DUR2_QUIET_SHIFT 2 +#define LSM6DSL_INT_DUR2_QUIET_SHIFT 2 #define LSM6DSL_INT_DUR2_QUIET_MASK (3 << LSM6DSL_INT_DUR2_QUIET_SHIFT) -#define LSM6DSL_INT_DUR2_DUR_SHIFT 4 +#define LSM6DSL_INT_DUR2_DUR_SHIFT 4 #define LSM6DSL_INT_DUR2_DUR_MASK (7 << LSM6DSL_INT_DUR2_QUIET_SHIFT) -#define LSM6DSL_WAKE_UP_THS_WK_THS_SHIFT 0 +#define LSM6DSL_WAKE_UP_THS_WK_THS_SHIFT 0 #define LSM6DSL_WAKE_UP_THS_WK_THS_MASK (31 << LSM6DSL_WAKE_UP_THS_WK_THS_SHIFT) #define LSM6DSL_WAKE_UP_THS_SINGLE_DOUBLE_TAP4D_EN (1 << 7) -#define LSM6DSL_WAKE_UP_DUR_SLEEP_DUR_SHIFT 0 +#define LSM6DSL_WAKE_UP_DUR_SLEEP_DUR_SHIFT 0 #define LSM6DSL_WAKE_UP_DUR_SLEEP_DUR_MASK (15 << LSM6DSL_WAKE_UP_DUR_SLEEP_DUR_SHIFT) #define LSM6DSL_WAKE_UP_DUR_TIMER_HR (1 << 4) -#define LSM6DSL_WAKE_UP_DUR_WAKE_DUR_SHIFT 5 +#define LSM6DSL_WAKE_UP_DUR_WAKE_DUR_SHIFT 5 #define LSM6DSL_WAKE_UP_DUR_WAKE_DUR_MASK (15 << LSM6DSL_WAKE_UP_DUR_WAKE_DUR_SHIFT) #define LSM6DSL_WAKE_UP_DUR_FF_DUR5 (1 << 7) -#define LSM6DSL_FREE_FALL_FF_THS_SHIFT 0 +#define LSM6DSL_FREE_FALL_FF_THS_SHIFT 0 #define LSM6DSL_FREE_FALL_FF_THS_MASK (7 << LSM6DSL_FREE_FALL_FF_THS_SHIFT) -#define LSM6DSL_FREE_FALL_FF_DUR_SHIFT 4 +#define LSM6DSL_FREE_FALL_FF_DUR_SHIFT 4 #define LSM6DSL_FREE_FALL_FF_DUR_MASK (31 << LSM6DSL_FREE_FALL_FF_DUR_SHIFT) #define LSM6DSL_MD1_CFG_INT1_TIMER (1 << 0) @@ -652,165 +652,165 @@ functions (r/w). */ #define LSM6DSL_MD2_CFG_INT1_SINGLE_TAP (1 << 6) #define LSM6DSL_MD2_CFG_INT1_INACT_STATE (1 << 7) -#define LSM6DSL_MASTER_CMD_CODE_SHIFT 0 +#define LSM6DSL_MASTER_CMD_CODE_SHIFT 0 #define LSM6DSL_MASTER_CMD_CODE_MASK (255 << LSM6DSL_MASTER_CMD_CODE_SHIFT) -#define LSM6DSL_SENS_SYNC_SPI_ERROR_CODE_SHIFT 0 +#define LSM6DSL_SENS_SYNC_SPI_ERROR_CODE_SHIFT 0 #define LSM6DSL_SENS_SYNC_SPI_ERROR_CODE_MASK (255 << LSM6DSL_SENS_SYNC_SPI_ERROR_CODE_SHIFT) -#define LSM6DSL_OUT_MAG_RAW_X_L_SHIFT 0 +#define LSM6DSL_OUT_MAG_RAW_X_L_SHIFT 0 #define LSM6DSL_OUT_MAG_RAW_X_L_MASK (255 << LSM6DSL_OUT_MAG_RAW_X_L_SHIFT) -#define LSM6DSL_OUT_MAG_RAW_X_H_SHIFT 0 +#define LSM6DSL_OUT_MAG_RAW_X_H_SHIFT 0 #define LSM6DSL_OUT_MAG_RAW_X_H_MASK (255 << LSM6DSL_OUT_MAG_RAW_X_H_SHIFT) -#define LSM6DSL_OUT_MAG_RAW_Y_L_SHIFT 0 +#define LSM6DSL_OUT_MAG_RAW_Y_L_SHIFT 0 #define LSM6DSL_OUT_MAG_RAW_Y_L_MASK (255 << LSM6DSL_OUT_MAG_RAW_Y_L_SHIFT) -#define LSM6DSL_OUT_MAG_RAW_Y_H_SHIFT 0 +#define LSM6DSL_OUT_MAG_RAW_Y_H_SHIFT 0 #define LSM6DSL_OUT_MAG_RAW_Y_H_MASK (255 << LSM6DSL_OUT_MAG_RAW_Y_H_SHIFT) -#define LSM6DSL_OUT_MAG_RAW_Z_L_SHIFT 0 +#define LSM6DSL_OUT_MAG_RAW_Z_L_SHIFT 0 #define LSM6DSL_OUT_MAG_RAW_Z_L_MASK (255 << LSM6DSL_OUT_MAG_RAW_Z_L_SHIFT) -#define LSM6DSL_OUT_MAG_RAW_Z_H_SHIFT 0 +#define LSM6DSL_OUT_MAG_RAW_Z_H_SHIFT 0 #define LSM6DSL_OUT_MAG_RAW_Z_H_MASK (255 << LSM6DSL_OUT_MAG_RAW_Z_H_SHIFT) -#define LSM6DSL_X_OFS_USR_SHIFT 0 +#define LSM6DSL_X_OFS_USR_SHIFT 0 #define LSM6DSL_X_OFS_USR_MASK (255 << LSM6DSL_X_OFS_USR_SHIFT) -#define LSM6DSL_Y_OFS_USR_SHIFT 0 +#define LSM6DSL_Y_OFS_USR_SHIFT 0 #define LSM6DSL_Y_OFS_USR_MASK (255 << LSM6DSL_Y_OFS_USR_SHIFT) -#define LSM6DSL_Z_OFS_USR_SHIFT 0 +#define LSM6DSL_Z_OFS_USR_SHIFT 0 #define LSM6DSL_Z_OFS_USR_MASK (255 << LSM6DSL_Z_OFS_USR_SHIFT) /* Embedded functions registers description - Bank A */ #define LSM6DSL_SLV0_ADD_rw_0 (1 << 0) -#define LSM6DSL_SLV0_ADD_Slave0_add_SHIFT 1 +#define LSM6DSL_SLV0_ADD_Slave0_add_SHIFT 1 #define LSM6DSL_SLV0_ADD_Slave0_add_MASK (127 << LSM6DSL_SLV0_ADD_Slave0_add_SHIFT) -#define LSM6DSL_SLV0_SUBADD_SHIFT 0 +#define LSM6DSL_SLV0_SUBADD_SHIFT 0 #define LSM6DSL_SLV0_SUBADD_MASK (255 << LSM6DSL_SLV0_SUBADD_SHIFT) -#define LSM6DSL_SLAVE0_CONFIG_Slave0_numop_SHIFT 0 +#define LSM6DSL_SLAVE0_CONFIG_Slave0_numop_SHIFT 0 #define LSM6DSL_SLAVE0_CONFIG_Slave0_numop_MASK (7 << LSM6DSL_SLAVE0_CONFIG_Slave0_numop_SHIFT) #define LSM6DSL_SLAVE0_CONFIG_Src_mode (1 << 3) -#define LSM6DSL_SLAVE0_CONFIG_Aux_sens_on_SHIFT 4 +#define LSM6DSL_SLAVE0_CONFIG_Aux_sens_on_SHIFT 4 #define LSM6DSL_SLAVE0_CONFIG_Aux_sens_on_MASK (3 << LSM6DSL_SLAVE0_CONFIG_Aux_sens_on_SHIFT) -#define LSM6DSL_SLAVE0_CONFIG_Slave0_rate_SHIFT 6 +#define LSM6DSL_SLAVE0_CONFIG_Slave0_rate_SHIFT 6 #define LSM6DSL_SLAVE0_CONFIG_Slave0_rate_MASK (3 << LSM6DSL_SLAVE0_CONFIG_Slave0_rate_SHIFT) #define LSM6DSL_SLV1_ADD_r_1 (1 << 0) -#define LSM6DSL_SLV1_ADD_Slave1_add_SHIFT 1 +#define LSM6DSL_SLV1_ADD_Slave1_add_SHIFT 1 #define LSM6DSL_SLV1_ADD_Slave1_add_MASK (127 << LSM6DSL_SLV1_ADD_Slave1_add_SHIFT) -#define LSM6DSL_SLV1_SUBADD_SHIFT 0 +#define LSM6DSL_SLV1_SUBADD_SHIFT 0 #define LSM6DSL_SLV1_SUBADD_MASK (255 << LSM6DSL_SLV1_SUBADD_SHIFT) -#define LSM6DSL_SLAVE1_CONFIG_Slave1_numop_SHIFT 0 +#define LSM6DSL_SLAVE1_CONFIG_Slave1_numop_SHIFT 0 #define LSM6DSL_SLAVE1_CONFIG_Slave1_numop_MASK (7 << LSM6DSL_SLAVE1_CONFIG_Slave1_numop_SHIFT) #define LSM6DSL_SLAVE1_CONFIG_write_once (1 << 5) -#define LSM6DSL_SLAVE1_CONFIG_Slave1_rate_SHIFT 6 +#define LSM6DSL_SLAVE1_CONFIG_Slave1_rate_SHIFT 6 #define LSM6DSL_SLAVE1_CONFIG_Slave1_rate_MASK (3 << LSM6DSL_SLAVE1_CONFIG_Slave1_rate_SHIFT) #define LSM6DSL_SLV2_ADD_r_2 (1 << 0) -#define LSM6DSL_SLV2_ADD_Slave2_add_SHIFT 1 +#define LSM6DSL_SLV2_ADD_Slave2_add_SHIFT 1 #define LSM6DSL_SLV2_ADD_Slave2_add_MASK (127 << LSM6DSL_SLV2_ADD_Slave2_add_SHIFT) -#define LSM6DSL_SLV2_SUBADD_SHIFT 0 +#define LSM6DSL_SLV2_SUBADD_SHIFT 0 #define LSM6DSL_SLV2_SUBADD_MASK (255 << LSM6DSL_SLV2_SUBADD_SHIFT) -#define LSM6DSL_SLAVE2_CONFIG_Slave2_numop_SHIFT 0 +#define LSM6DSL_SLAVE2_CONFIG_Slave2_numop_SHIFT 0 #define LSM6DSL_SLAVE2_CONFIG_Slave2_numop_MASK (7 << LSM6DSL_SLAVE1_CONFIG_Slave1_numop_SHIFT) -#define LSM6DSL_SLAVE2_CONFIG_Slave2_rate_SHIFT 6 +#define LSM6DSL_SLAVE2_CONFIG_Slave2_rate_SHIFT 6 #define LSM6DSL_SLAVE2_CONFIG_Slave2_rate_MASK (3 << LSM6DSL_SLAVE1_CONFIG_Slave1_rate_SHIFT) #define LSM6DSL_SLV3_ADD_r_3 (1 << 0) -#define LSM6DSL_SLV3_ADD_Slave3_add_SHIFT 1 +#define LSM6DSL_SLV3_ADD_Slave3_add_SHIFT 1 #define LSM6DSL_SLV3_ADD_Slave3_add_MASK (127 << LSM6DSL_SLV3_ADD_Slave3_add_SHIFT) -#define LSM6DSL_SLV3_SUBADD_SHIFT 0 +#define LSM6DSL_SLV3_SUBADD_SHIFT 0 #define LSM6DSL_SLV3_SUBADD_MASK (255 << LSM6DSL_SLV2_SUBADD_SHIFT) -#define LSM6DSL_SLAVE3_CONFIG_Slave3_numop_SHIFT 0 +#define LSM6DSL_SLAVE3_CONFIG_Slave3_numop_SHIFT 0 #define LSM6DSL_SLAVE3_CONFIG_Slave3_numop_MASK (7 << LSM6DSL_SLAVE1_CONFIG_Slave1_numop_SHIFT) -#define LSM6DSL_SLAVE3_CONFIG_Slave3_rate_SHIFT 6 +#define LSM6DSL_SLAVE3_CONFIG_Slave3_rate_SHIFT 6 #define LSM6DSL_SLAVE3_CONFIG_Slave3_rate_MASK (3 << LSM6DSL_SLAVE1_CONFIG_Slave1_rate_SHIFT) -#define LSM6DSL_DATAWRITE_SRC_MODE_SUB_SLV0_SHIFT 0 +#define LSM6DSL_DATAWRITE_SRC_MODE_SUB_SLV0_SHIFT 0 #define LSM6DSL_DATAWRITE_SRC_MODE_SUB_SLV0_MASK (255 << LSM6DSL_DATAWRITE_SRC_MODE_SUB_SLV0_SHIFT) -#define LSM6DSL_CONFIG_PEDO_THS_MIN_ths_min_SHIFT 0 +#define LSM6DSL_CONFIG_PEDO_THS_MIN_ths_min_SHIFT 0 #define LSM6DSL_CONFIG_PEDO_THS_MIN_ths_min_MASK (31 << LSM6DSL_CONFIG_PEDO_THS_MIN_ths_min_SHIFT) #define LSM6DSL_CONFIG_PEDO_THS_MIN_PEDO_FS (1 << 7> -#define LSM6DSL_SM_THS_SHIFT 0 +#define LSM6DSL_SM_THS_SHIFT 0 #define LSM6DSL_SM_THS_MASK (255 << LSM6DSL_SM_THS_SHIFT) -#define LSM6DSL_PEDO_DEB_REG_DEB_STEP_SHIFT 0 +#define LSM6DSL_PEDO_DEB_REG_DEB_STEP_SHIFT 0 #define LSM6DSL_PEDO_DEB_REG_DEB_STEP_MASK (7 << LSM6DSL_PEDO_DEB_REG_DEB_STEP_SHIFT) -#define LSM6DSL_PEDO_DEB_REG_DEB_TIME_SHIFT 3 +#define LSM6DSL_PEDO_DEB_REG_DEB_TIME_SHIFT 3 #define LSM6DSL_PEDO_DEB_REG_DEB_TIME_MASK (31 << LSM6DSL_PEDO_DEB_REG_DEB_TIME_SHIFT) -#define LSM6DSL_STEP_COUNT_DELTA_SHIFT 0 +#define LSM6DSL_STEP_COUNT_DELTA_SHIFT 0 #define LSM6DSL_STEP_COUNT_DELTA_MASK (255 << LSM6DSL_STEP_COUNT_DELTA_SHIFT) -#define LSM6DSL_MAG_SI_XX_SHIFT 0 +#define LSM6DSL_MAG_SI_XX_SHIFT 0 #define LSM6DSL_MAG_SI_XX_MASK (255 << LSM6DSL_MAG_SI_XX_SHIFT) -#define LSM6DSL_MAG_SI_XY_SHIFT 0 +#define LSM6DSL_MAG_SI_XY_SHIFT 0 #define LSM6DSL_MAG_SI_XY_MASK (255 << LSM6DSL_MAG_SI_XY_SHIFT) -#define LSM6DSL_MAG_SI_XZ_SHIFT 0 +#define LSM6DSL_MAG_SI_XZ_SHIFT 0 #define LSM6DSL_MAG_SI_XZ_MASK (255 << LSM6DSL_MAG_SI_XZ_SHIFT) -#define LSM6DSL_MAG_SI_YX_SHIFT 0 +#define LSM6DSL_MAG_SI_YX_SHIFT 0 #define LSM6DSL_MAG_SI_YX_MASK (255 << LSM6DSL_MAG_SI_YX_SHIFT) -#define LSM6DSL_MAG_SI_YY_SHIFT 0 +#define LSM6DSL_MAG_SI_YY_SHIFT 0 #define LSM6DSL_MAG_SI_YY_MASK (255 << LSM6DSL_MAG_SI_YY_SHIFT) -#define LSM6DSL_MAG_SI_YZ_SHIFT 0 +#define LSM6DSL_MAG_SI_YZ_SHIFT 0 #define LSM6DSL_MAG_SI_YZ_MASK (255 << LSM6DSL_MAG_SI_YZ_SHIFT) -#define LSM6DSL_MAG_SI_ZX_SHIFT 0 +#define LSM6DSL_MAG_SI_ZX_SHIFT 0 #define LSM6DSL_MAG_SI_ZX_MASK (255 << LSM6DSL_MAG_SI_ZX_SHIFT) -#define LSM6DSL_MAG_SI_ZY_SHIFT 0 +#define LSM6DSL_MAG_SI_ZY_SHIFT 0 #define LSM6DSL_MAG_SI_ZY_MASK (255 << LSM6DSL_MAG_SI_ZY_SHIFT) -#define LSM6DSL_MAG_SI_ZZ_SHIFT 0 +#define LSM6DSL_MAG_SI_ZZ_SHIFT 0 #define LSM6DSL_MAG_SI_ZZ_MASK (255 << LSM6DSL_MAG_SI_ZZ_SHIFT) -#define LSM6DSL_MAG_OFFX_L_SHIFT 0 +#define LSM6DSL_MAG_OFFX_L_SHIFT 0 #define LSM6DSL_MAG_OFFX_L_MASK (255 << LSM6DSL_MAG_OFFX_L_SHIFT) -#define LSM6DSL_MAG_OFFX_H_SHIFT 0 +#define LSM6DSL_MAG_OFFX_H_SHIFT 0 #define LSM6DSL_MAG_OFFX_H_MASK (255 << LSM6DSL_MAG_OFFX_H_SHIFT) -#define LSM6DSL_MAG_OFFY_L_SHIFT 0 +#define LSM6DSL_MAG_OFFY_L_SHIFT 0 #define LSM6DSL_MAG_OFFY_L_MASK (255 << LSM6DSL_MAG_OFFY_L_SHIFT) -#define LSM6DSL_MAG_OFFY_H_SHIFT 0 +#define LSM6DSL_MAG_OFFY_H_SHIFT 0 #define LSM6DSL_MAG_OFFY_H_MASK (255 << LSM6DSL_MAG_OFFY_H_SHIFT) -#define LSM6DSL_MAG_OFFZ_L_SHIFT 0 +#define LSM6DSL_MAG_OFFZ_L_SHIFT 0 #define LSM6DSL_MAG_OFFZ_L_MASK (255 << LSM6DSL_MAG_OFFZ_L_SHIFT) -#define LSM6DSL_MAG_OFFZ_H_SHIFT 0 +#define LSM6DSL_MAG_OFFZ_H_SHIFT 0 #define LSM6DSL_MAG_OFFZ_H_MASK (255 << LSM6DSL_MAG_OFFZ_H_SHIFT) /* Embedded functions registers description - Bank B */ -#define LSM6DSL_A_WRIST_TILT_LAT_SHIFT 0 +#define LSM6DSL_A_WRIST_TILT_LAT_SHIFT 0 #define LSM6DSL_A_WRIST_TILT_LAT_MASK (255 << LSM6DSL_A_WRIST_TILT_LAT_SHIFT) -#define LSM6DSL_A_WRIST_TILT_THS_SHIFT 0 +#define LSM6DSL_A_WRIST_TILT_THS_SHIFT 0 #define LSM6DSL_A_WRIST_TILT_THS_MASK (255 << LSM6DSL_A_WRIST_TILT_THS_SHIFT) -#define LSM6DSL_A_WRIST_TILT_Mask_SHIFT 2 +#define LSM6DSL_A_WRIST_TILT_Mask_SHIFT 2 #define LSM6DSL_A_WRIST_TILT_Mask_MASK (63 << LSM6DSL_A_WRIST_TILT_Mask_SHIFT) /****************************************************************************************************