Generic Pelion Device Management example for various U-blox-based boards.

Dependencies:   ublox-at-cellular-interface ublox-cellular-base

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 great on the following platforms:

For Odin-W2 please go to Repository link

Follow the Quick-Start instructions: https://cloud.mbed.com/quick-start

UBLOX_C030_U201

UBLOX_C030_R412M

Example functionality

This example showcases the following device functionality:

  • 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.
  • (currently disabled) Read ADC temperature and ADC vref, and report 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/ublox/code/pelion-example-common

cd pelion-example-common

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 <TARGET_BOARD>

(supported toolchains : GCC_ARM / ARM / IAR)

Committer:
screamer
Date:
Mon Dec 10 21:58:43 2018 +0000
Revision:
0:a076a1bbe630
Initial revision

Who changed what in which revision?

UserRevisionLine numberNew contents of line
screamer 0:a076a1bbe630 1 // ----------------------------------------------------------------------------
screamer 0:a076a1bbe630 2 // Copyright 2016-2017 ARM Ltd.
screamer 0:a076a1bbe630 3 //
screamer 0:a076a1bbe630 4 // SPDX-License-Identifier: Apache-2.0
screamer 0:a076a1bbe630 5 //
screamer 0:a076a1bbe630 6 // Licensed under the Apache License, Version 2.0 (the "License");
screamer 0:a076a1bbe630 7 // you may not use this file except in compliance with the License.
screamer 0:a076a1bbe630 8 // You may obtain a copy of the License at
screamer 0:a076a1bbe630 9 //
screamer 0:a076a1bbe630 10 // http://www.apache.org/licenses/LICENSE-2.0
screamer 0:a076a1bbe630 11 //
screamer 0:a076a1bbe630 12 // Unless required by applicable law or agreed to in writing, software
screamer 0:a076a1bbe630 13 // distributed under the License is distributed on an "AS IS" BASIS,
screamer 0:a076a1bbe630 14 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
screamer 0:a076a1bbe630 15 // See the License for the specific language governing permissions and
screamer 0:a076a1bbe630 16 // limitations under the License.
screamer 0:a076a1bbe630 17 // ----------------------------------------------------------------------------
screamer 0:a076a1bbe630 18
screamer 0:a076a1bbe630 19 // This file is a template and it's intented to be copied to the application
screamer 0:a076a1bbe630 20 // Enable this configuration
screamer 0:a076a1bbe630 21
screamer 0:a076a1bbe630 22 #ifndef MBED_CLOUD_CLIENT_USER_CONFIG_H
screamer 0:a076a1bbe630 23 #define MBED_CLOUD_CLIENT_USER_CONFIG_H
screamer 0:a076a1bbe630 24
screamer 0:a076a1bbe630 25 #ifdef MBED_CONF_APP_ENDPOINT_TYPE
screamer 0:a076a1bbe630 26 #define MBED_CLOUD_CLIENT_ENDPOINT_TYPE MBED_CONF_APP_ENDPOINT_TYPE
screamer 0:a076a1bbe630 27 #else
screamer 0:a076a1bbe630 28 #define MBED_CLOUD_CLIENT_ENDPOINT_TYPE "default"
screamer 0:a076a1bbe630 29 #endif
screamer 0:a076a1bbe630 30
screamer 0:a076a1bbe630 31 // Enable either TCP or UDP, but no both
screamer 0:a076a1bbe630 32 #define MBED_CLOUD_CLIENT_TRANSPORT_MODE_TCP
screamer 0:a076a1bbe630 33 // MBED_CLOUD_CLIENT_TRANSPORT_MODE_UDP
screamer 0:a076a1bbe630 34
screamer 0:a076a1bbe630 35 #define MBED_CLOUD_CLIENT_LIFETIME 3600
screamer 0:a076a1bbe630 36
screamer 0:a076a1bbe630 37 #define MBED_CLOUD_CLIENT_SUPPORT_UPDATE
screamer 0:a076a1bbe630 38 #define SN_COAP_MAX_BLOCKWISE_PAYLOAD_SIZE 1024
screamer 0:a076a1bbe630 39
screamer 0:a076a1bbe630 40 // set flag to enable update support in mbed Cloud client
screamer 0:a076a1bbe630 41 #define MBED_CLOUD_CLIENT_SUPPORT_UPDATE
screamer 0:a076a1bbe630 42
screamer 0:a076a1bbe630 43 // set download buffer size in bytes (min. 1024 bytes)
screamer 0:a076a1bbe630 44
screamer 0:a076a1bbe630 45 // Use larger buffers in Linux //
screamer 0:a076a1bbe630 46 #ifdef __linux__
screamer 0:a076a1bbe630 47 #define MBED_CLOUD_CLIENT_UPDATE_BUFFER (2 * 1024 * 1024)
screamer 0:a076a1bbe630 48 #else
screamer 0:a076a1bbe630 49 #define MBED_CLOUD_CLIENT_UPDATE_BUFFER 2048
screamer 0:a076a1bbe630 50 #endif
screamer 0:a076a1bbe630 51
screamer 0:a076a1bbe630 52 // Developer flags for Update feature
screamer 0:a076a1bbe630 53 #if MBED_CONF_APP_DEVELOPER_MODE == 1
screamer 0:a076a1bbe630 54 #define MBED_CLOUD_DEV_UPDATE_CERT
screamer 0:a076a1bbe630 55 #define MBED_CLOUD_DEV_UPDATE_ID
screamer 0:a076a1bbe630 56 #endif // MBED_CONF_APP_DEVELOPER_MODE
screamer 0:a076a1bbe630 57
screamer 0:a076a1bbe630 58 #endif // MBED_CLOUD_CLIENT_USER_CONFIG_H
screamer 0:a076a1bbe630 59