This is an example of BLE GATT Client, which receives broadcast data from BLE_Server_BME280 ( a GATT server) , then transfers values up to mbed Device Connector (cloud).
Please refer details about BLEClient_mbedDevConn below. https://github.com/soramame21/BLEClient_mbedDevConn
The location of required BLE GATT server, BLE_Server_BME280, is at here. https://developer.mbed.org/users/edamame22/code/BLE_Server_BME280/
mbed-client/source/m2mblockmessage.cpp
- Committer:
- Ren Boting
- Date:
- 2017-09-05
- Revision:
- 2:b894b3508057
- Parent:
- 0:29983394c6b6
File content as of revision 2:b894b3508057:
/* * Copyright (c) 2015 ARM Limited. All rights reserved. * SPDX-License-Identifier: Apache-2.0 * Licensed under the Apache License, Version 2.0 (the License); you may * not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an AS IS BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include "mbed-client/m2mblockmessage.h" #include "mbed-client/m2mconfig.h" #include <stdlib.h> #include <string.h> M2MBlockMessage::M2MBlockMessage() : _block_data_ptr(NULL), _total_message_size(0), _block_data_len(0), _block_number(0), _error_code(M2MBlockMessage::ErrorNone), _is_last_block(false), _is_block_message(false) { } M2MBlockMessage::~M2MBlockMessage() { free(_block_data_ptr); _block_data_ptr = NULL; } void M2MBlockMessage::set_message_info(sn_coap_hdr_s *coap_header) { _is_block_message = (coap_header && coap_header->options_list_ptr && coap_header->options_list_ptr->block1 != -1) ? true : false; if (coap_header && coap_header->options_list_ptr) { // Check total size if (coap_header->options_list_ptr->use_size1) { _total_message_size = coap_header->options_list_ptr->size1; } // Default value in coap library is 65kb uint32_t max_size = SN_COAP_MAX_INCOMING_MESSAGE_SIZE; if (_total_message_size > max_size) { _error_code = M2MBlockMessage::EntityTooLarge; } else { _error_code = M2MBlockMessage::ErrorNone; } if (M2MBlockMessage::ErrorNone == _error_code) { // Is last block if (coap_header->options_list_ptr->block1 != -1) { // if (!(*(coap_header->options_list_ptr->block1_ptr + (coap_header->options_list_ptr->block1_len - 1)) & 0x08)) { if (!((coap_header->options_list_ptr->block1) & 0x08)) { _is_last_block = true; } else { _is_last_block = false; } } _block_number = coap_header->options_list_ptr->block1 >> 4; // Block number // if (coap_header->options_list_ptr->block1_len == 3) { // _block_number = *(coap_header->options_list_ptr->block1_ptr) << 12; // _block_number |= *(coap_header->options_list_ptr->block1_ptr + 1) << 4; // _block_number |= (*(coap_header->options_list_ptr->block1_ptr + 2)) >> 4; // } // else if (coap_header->options_list_ptr->block1_len == 2) { // _block_number = *(coap_header->options_list_ptr->block1_ptr) << 4; // _block_number |= (*(coap_header->options_list_ptr->block1_ptr + 1)) >> 4; // } // else if (coap_header->options_list_ptr->block1_len == 1) { // _block_number = (*coap_header->options_list_ptr->block1_ptr) >> 4; // } // else { // _block_number = 0; // } // Payload free(_block_data_ptr); _block_data_ptr = NULL; _block_data_len = coap_header->payload_len; if(_block_data_len > 0) { _block_data_ptr = (uint8_t *)malloc(_block_data_len); if (_block_data_ptr) { memcpy(_block_data_ptr, coap_header->payload_ptr, _block_data_len); } } } } } void M2MBlockMessage::clear_values() { free(_block_data_ptr); _block_data_ptr = NULL; _block_data_len = 0; _block_number = 0; _total_message_size = 0; _is_last_block = false; _error_code = M2MBlockMessage::ErrorNone; } bool M2MBlockMessage::is_block_message() const { return _is_block_message; } uint16_t M2MBlockMessage::block_number() const { return _block_number; } uint32_t M2MBlockMessage::total_message_size() const { return _total_message_size; } bool M2MBlockMessage::is_last_block() const { return _is_last_block; } uint8_t* M2MBlockMessage::block_data() const { return _block_data_ptr; } uint32_t M2MBlockMessage::block_data_len() const { return _block_data_len; } M2MBlockMessage::Error M2MBlockMessage::error_code() const { return _error_code; }