
Mbed OS and Pelion Device Management example over WIFI for DISCO_L475VG_IOT01 board
Dependencies: X_NUCLEO_COMMON ST_INTERFACES
DEPRECATED
This example application is not maintained and not recommended. It uses an old version of Mbed OS, Pelion DM and Arm toolchain. It doesn't work with Mbed Studio.
Please use: https://os.mbed.com/teams/mbed-os-examples/code/mbed-os-example-pelion/
This example is known to work on the following platforms:
- DISCO_L475E_IOT01A over WiFI and using onboard QSPI flash.
Follow the Quick-Start instructions: https://cloud.mbed.com/quick-start
Example functionality
This example showcases the following device functionality:
- Read onboard temperature and humidity sensors, and report them as Pelion LWM2M resources (see image below).
- On user button click, increment Pelion LWM2M button resource.
- Allow the user to change the state of the board LED from Pelion LWM2M led_state resource and PUT request.
- Uses all onboard sensors and reports them as Pelion LWM2M resources.
Use this example with Mbed CLI
1. Import the application into your desktop:
mbed import https://os.mbed.com/teams/ST/code/pelion-example-disco-iot01 cd pelion-example-disco-iot01
2. Install the CLOUD_SDK_API_KEY
mbed config -G CLOUD_SDK_API_KEY <PELION_DM_API_KEY>
For instructions on how to generate your API key, please see the documentation.
3. Initialize firmware credentials (done once per repository). You can use the following command:
mbed dm init -d "<your company name in Pelion DM>" --model-name "<product model identifier>" -q --force
If above command do not work for your Mbed CLI, please consider upgrading Mbed CLI to version 1.8.x or above.
4. Compile and program:
mbed compile -t <toolchain> -m DISCO_L475VG_IOT01A
(supported toolchains : GCC_ARM / ARM / IAR)
5. You can connect on a virtual terminal/COM port to the platform using:
mbed sterm -b 115200
This should give you an output similar to:
[BOOT] Mbed Bootloader [BOOT] ARM: 00000000000000000000 [BOOT] OEM: 00000000000000000000 [BOOT] Layout: 0 80096F4 [BOOT] Active firmware integrity check: [BOOT] SHA256: 0660E360D432225D5251461998FD8617B017098C5F1F90D5FB607BF8C27ED530 [BOOT] Version: 1553615309 [BOOT] Slot 0 is empty [BOOT] Active firmware up-to-date [BOOT] Application's start address: 0x8010400 [BOOT] Application's jump address: 0x8011041 [BOOT] Application's stack address: 0x20018000 [BOOT] Forwarding to application... Starting Simple Pelion Device Management Client example You can hold the user button during boot to format the storage and change the device identity. Sensors configuration: Invalid new address! HTS221 humidity & temperature = 0xBC LPS22HB pressure & temperature = 0xB1 LIS3MDL magnetometer = 0x3D LSM6DSL accelerometer & gyroscope = 0x6A Connecting to the network using Wifi... Connected to the network successfully. IP address: 192.168.1.3 Initializing Pelion Device Management Client... Initialized Pelion Client. Registering... Registered to Pelion Device Management. Endpoint Name: 0169********************001002d5 ADC temp: 23.0037 C, vref: 0.3661 V HTS221 temp: 28.700 C, humidity: 31.90 % LPS22HB temp: 29.600 C, pressure: 1032.01 mbar LIS3MDL mag: 0.217 x, -0.284 y, -0.053 z [gauss] LSM6DSL acc: 0.005 x, -0.014 y, 1.029 z [g] LSM6DSL gyro: 0.910 x, -0.910 y, 1.120 z [dps] VL53L0X dist: 1855 mm
sensors/HTS221/HTS221Sensor.cpp
- Committer:
- chris
- Date:
- 2020-03-13
- Revision:
- 36:aaf44d2a6c33
- Parent:
- 18:a15bfe7aaebd
File content as of revision 36:aaf44d2a6c33:
/** ****************************************************************************** * @file HTS221Sensor.cpp * @author CLab * @version V1.0.0 * @date 5 August 2016 * @brief Implementation of an HTS221 Humidity and Temperature sensor. ****************************************************************************** * @attention * * <h2><center>© COPYRIGHT(c) 2016 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. * ****************************************************************************** */ /* Includes ------------------------------------------------------------------*/ #include "HTS221Sensor.h" /* Class Implementation ------------------------------------------------------*/ HTS221Sensor::HTS221Sensor(SPI *spi, PinName cs_pin, PinName drdy_pin) : _dev_spi(spi), _cs_pin(cs_pin), _drdy_pin(drdy_pin) // SPI3W ONLY { assert(spi); _dev_i2c = NULL; }; /** Constructor * @param i2c object of an helper class which handles the I2C peripheral * @param address the address of the component's instance */ HTS221Sensor::HTS221Sensor(DevI2C *i2c, uint8_t address, PinName drdy_pin) : _dev_i2c(i2c), _address(address), _cs_pin(NC), _drdy_pin(drdy_pin) { assert(i2c); _dev_spi = NULL; }; /** * @brief Initializing the component. * @param[in] init pointer to device specific initalization structure. * @retval "0" in case of success, an error code otherwise. */ int HTS221Sensor::init(void *init) { /* Power down the device */ if ( HTS221_DeActivate( (void *)this ) == HTS221_ERROR ) { return 1; } /* Enable BDU */ if ( HTS221_Set_BduMode( (void *)this, HTS221_ENABLE ) == HTS221_ERROR ) { return 1; } if(set_odr(1.0f) == 1) { return 1; } return 0; } /** * @brief Enable HTS221 * @retval 0 in case of success, an error code otherwise */ int HTS221Sensor::enable(void) { /* Power up the device */ if ( HTS221_Activate( (void *)this ) == HTS221_ERROR ) { return 1; } return 0; } /** * @brief Disable HTS221 * @retval 0 in case of success, an error code otherwise */ int HTS221Sensor::disable(void) { /* Power up the device */ if ( HTS221_DeActivate( (void *)this ) == HTS221_ERROR ) { return 1; } return 0; } /** * @brief Read ID address of HTS221 * @param id the pointer where the ID of the device is stored * @retval 0 in case of success, an error code otherwise */ int HTS221Sensor::read_id(uint8_t *id) { if(!id) { return 1; } /* Read WHO AM I register */ if ( HTS221_Get_DeviceID( (void *)this, id ) == HTS221_ERROR ) { return 1; } return 0; } /** * @brief Reboot memory content of HTS221 * @param None * @retval 0 in case of success, an error code otherwise */ int HTS221Sensor::reset(void) { uint8_t tmpreg; /* Read CTRL_REG2 register */ if (read_reg(HTS221_CTRL_REG2, &tmpreg) != 0) { return 1; } /* Enable or Disable the reboot memory */ tmpreg |= (0x01 << HTS221_BOOT_BIT); /* Write value to MEMS CTRL_REG2 regsister */ if (write_reg(HTS221_CTRL_REG2, tmpreg) != 0) { return 1; } return 0; } /** * @brief Read HTS221 output register, and calculate the humidity * @param pfData the pointer to data output * @retval 0 in case of success, an error code otherwise */ int HTS221Sensor::get_humidity(float* pfData) { uint16_t uint16data = 0; /* Read data from HTS221. */ if ( HTS221_Get_Humidity( (void *)this, &uint16data ) == HTS221_ERROR ) { return 1; } *pfData = ( float )uint16data / 10.0f; return 0; } /** * @brief Read HTS221 output register, and calculate the temperature * @param pfData the pointer to data output * @retval 0 in case of success, an error code otherwise */ int HTS221Sensor::get_temperature(float* pfData) { int16_t int16data = 0; /* Read data from HTS221. */ if ( HTS221_Get_Temperature( (void *)this, &int16data ) == HTS221_ERROR ) { return 1; } *pfData = ( float )int16data / 10.0f; return 0; } /** * @brief Read HTS221 output register, and calculate the humidity * @param odr the pointer to the output data rate * @retval 0 in case of success, an error code otherwise */ int HTS221Sensor::get_odr(float* odr) { HTS221_Odr_et odr_low_level; if ( HTS221_Get_Odr( (void *)this, &odr_low_level ) == HTS221_ERROR ) { return 1; } switch( odr_low_level ) { case HTS221_ODR_ONE_SHOT: *odr = 0.0f; break; case HTS221_ODR_1HZ : *odr = 1.0f; break; case HTS221_ODR_7HZ : *odr = 7.0f; break; case HTS221_ODR_12_5HZ : *odr = 12.5f; break; default : *odr = -1.0f; return 1; } return 0; } /** * @brief Set ODR * @param odr the output data rate to be set * @retval 0 in case of success, an error code otherwise */ int HTS221Sensor::set_odr(float odr) { HTS221_Odr_et new_odr; new_odr = ( odr <= 1.0f ) ? HTS221_ODR_1HZ : ( odr <= 7.0f ) ? HTS221_ODR_7HZ : HTS221_ODR_12_5HZ; if ( HTS221_Set_Odr( (void *)this, new_odr ) == HTS221_ERROR ) { return 1; } return 0; } /** * @brief Read the data from register * @param reg register address * @param data register data * @retval 0 in case of success * @retval 1 in case of failure */ int HTS221Sensor::read_reg( uint8_t reg, uint8_t *data ) { if ( HTS221_read_reg( (void *)this, reg, 1, data ) == HTS221_ERROR ) { return 1; } return 0; } /** * @brief Write the data to register * @param reg register address * @param data register data * @retval 0 in case of success * @retval 1 in case of failure */ int HTS221Sensor::write_reg( uint8_t reg, uint8_t data ) { if ( HTS221_write_reg( (void *)this, reg, 1, &data ) == HTS221_ERROR ) { return 1; } return 0; } uint8_t HTS221_io_write( void *handle, uint8_t WriteAddr, uint8_t *pBuffer, uint16_t nBytesToWrite ) { return ((HTS221Sensor *)handle)->io_write(pBuffer, WriteAddr, nBytesToWrite); } uint8_t HTS221_io_read( void *handle, uint8_t ReadAddr, uint8_t *pBuffer, uint16_t nBytesToRead ) { return ((HTS221Sensor *)handle)->io_read(pBuffer, ReadAddr, nBytesToRead); }