From 160e81e901ecf2505c2af1c863d8d7974b434660 Mon Sep 17 00:00:00 2001 From: Tian Hao Date: Thu, 24 Nov 2016 20:20:59 +0800 Subject: [PATCH] example : cleanup the order --- examples/06_bluedroid_demos/README.rst | 6 - .../app_client_profiles/battery_c/battery_c.c | 200 ------ .../bluedroid_demos/app_core/bt_app_core.c | 420 ------------- .../app_WX_airsync/app_airsync_md5.c | 131 ---- .../app_WX_airsync/app_airsync_prf.c | 161 ----- .../app_profiles/app_WX_airsync/epb.c | 414 ------------- .../app_profiles/app_WX_airsync/epb_mmbp.c | 565 ----------------- .../app_profiles/app_WX_airsync/mpbledemo2.c | 586 ------------------ .../app_profiles/app_WX_airsync/wechar_crc.c | 51 -- .../app_profiles/app_WX_airsync/wechat_aes.c | 450 -------------- .../app_sample_button/app_button.c | 339 ---------- .../app_project/SampleClientProject.c | 393 ------------ .../app_project/SampleServerProject.c | 381 ------------ .../components/bluedroid_demos/component.mk | 22 - .../bluedroid_demos/include/app_airsync_md5.h | 39 -- .../bluedroid_demos/include/app_airsync_prf.h | 35 -- .../bluedroid_demos/include/app_button.h | 51 -- .../bluedroid_demos/include/app_button_int.h | 116 ---- .../bluedroid_demos/include/app_wechat_util.h | 85 --- .../bluedroid_demos/include/bt_app_common.h | 31 - .../components/bluedroid_demos/include/epb.h | 117 ---- .../bluedroid_demos/include/epb_mmbp.h | 248 -------- .../bluedroid_demos/include/gattc_profile.h | 46 -- .../bluedroid_demos/include/mpbledemo2.h | 140 ----- .../bluedroid_demos/include/wechar_crc.h | 29 - .../bluedroid_demos/include/wechat_aes.h | 73 --- examples/06_bluedroid_demos/main/demo_main.c | 42 -- examples/08_bt_sdp/Makefile | 11 - examples/09_gatt_server/main/component.mk | 10 - examples/{07_blufi => 12_blufi}/Makefile | 0 examples/{07_blufi => 12_blufi}/README.rst | 0 .../components/blufi/blufi.c | 0 .../components/blufi/blufi_task.c | 0 .../components/blufi/component.mk | 0 .../components/blufi/include/blufi.h | 0 .../main/component.mk | 0 .../{07_blufi => 12_blufi}/main/demo_main.c | 0 .../Makefile | 0 examples/{08_bt_sdp => 13_bt_sdp}/README.rst | 0 .../bluedroid_demos/app_core/bt_app_core.c | 0 .../bluedroid_demos/app_project/SampleBtSdp.c | 0 .../bluedroid_demos/btif/btif_core.c | 0 .../components/bluedroid_demos/btif/btif_dm.c | 0 .../bluedroid_demos/btif/btif_sdp.c | 0 .../bluedroid_demos/btif/btif_sdp_server.c | 0 .../bluedroid_demos/btif/btif_util.c | 0 .../bluedroid_demos/btif/stack_manager.c | 0 .../components/bluedroid_demos/component.mk | 0 .../bluedroid_demos/include/bt_app_common.h | 0 .../bluedroid_demos/include/btif_api.h | 0 .../bluedroid_demos/include/btif_common.h | 0 .../bluedroid_demos/include/btif_dm.h | 0 .../bluedroid_demos/include/btif_sdp.h | 0 .../include/btif_stack_manager.h | 0 .../bluedroid_demos/include/btif_util.h | 0 .../bluedroid_demos/include/stack_manager.h | 0 .../{07_blufi => 13_bt_sdp}/main/component.mk | 0 .../{08_bt_sdp => 13_bt_sdp}/main/demo_main.c | 0 .../Makefile | 0 .../README.rst | 0 .../main/component.mk | 0 .../main/gatts_demo.c | 0 .../Makefile | 0 .../README.rst | 0 .../main/component.mk | 0 .../main/gattc_demo.c | 0 66 files changed, 5192 deletions(-) delete mode 100644 examples/06_bluedroid_demos/README.rst delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/app_client_profiles/battery_c/battery_c.c delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/app_core/bt_app_core.c delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/app_airsync_md5.c delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/app_airsync_prf.c delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/epb.c delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/epb_mmbp.c delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/mpbledemo2.c delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/wechar_crc.c delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/wechat_aes.c delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_sample_button/app_button.c delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/app_project/SampleClientProject.c delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/app_project/SampleServerProject.c delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/component.mk delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/include/app_airsync_md5.h delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/include/app_airsync_prf.h delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/include/app_button.h delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/include/app_button_int.h delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/include/app_wechat_util.h delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/include/bt_app_common.h delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/include/epb.h delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/include/epb_mmbp.h delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/include/gattc_profile.h delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/include/mpbledemo2.h delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/include/wechar_crc.h delete mode 100644 examples/06_bluedroid_demos/components/bluedroid_demos/include/wechat_aes.h delete mode 100644 examples/06_bluedroid_demos/main/demo_main.c delete mode 100755 examples/08_bt_sdp/Makefile delete mode 100644 examples/09_gatt_server/main/component.mk rename examples/{07_blufi => 12_blufi}/Makefile (100%) rename examples/{07_blufi => 12_blufi}/README.rst (100%) rename examples/{07_blufi => 12_blufi}/components/blufi/blufi.c (100%) rename examples/{07_blufi => 12_blufi}/components/blufi/blufi_task.c (100%) rename examples/{07_blufi => 12_blufi}/components/blufi/component.mk (100%) rename examples/{07_blufi => 12_blufi}/components/blufi/include/blufi.h (100%) rename examples/{06_bluedroid_demos => 12_blufi}/main/component.mk (100%) rename examples/{07_blufi => 12_blufi}/main/demo_main.c (100%) rename examples/{06_bluedroid_demos => 13_bt_sdp}/Makefile (100%) mode change 100644 => 100755 rename examples/{08_bt_sdp => 13_bt_sdp}/README.rst (100%) rename examples/{08_bt_sdp => 13_bt_sdp}/components/bluedroid_demos/app_core/bt_app_core.c (100%) rename examples/{08_bt_sdp => 13_bt_sdp}/components/bluedroid_demos/app_project/SampleBtSdp.c (100%) rename examples/{08_bt_sdp => 13_bt_sdp}/components/bluedroid_demos/btif/btif_core.c (100%) rename examples/{08_bt_sdp => 13_bt_sdp}/components/bluedroid_demos/btif/btif_dm.c (100%) rename examples/{08_bt_sdp => 13_bt_sdp}/components/bluedroid_demos/btif/btif_sdp.c (100%) rename examples/{08_bt_sdp => 13_bt_sdp}/components/bluedroid_demos/btif/btif_sdp_server.c (100%) rename examples/{08_bt_sdp => 13_bt_sdp}/components/bluedroid_demos/btif/btif_util.c (100%) rename examples/{08_bt_sdp => 13_bt_sdp}/components/bluedroid_demos/btif/stack_manager.c (100%) rename examples/{08_bt_sdp => 13_bt_sdp}/components/bluedroid_demos/component.mk (100%) rename examples/{08_bt_sdp => 13_bt_sdp}/components/bluedroid_demos/include/bt_app_common.h (100%) rename examples/{08_bt_sdp => 13_bt_sdp}/components/bluedroid_demos/include/btif_api.h (100%) rename examples/{08_bt_sdp => 13_bt_sdp}/components/bluedroid_demos/include/btif_common.h (100%) rename examples/{08_bt_sdp => 13_bt_sdp}/components/bluedroid_demos/include/btif_dm.h (100%) rename examples/{08_bt_sdp => 13_bt_sdp}/components/bluedroid_demos/include/btif_sdp.h (100%) rename examples/{08_bt_sdp => 13_bt_sdp}/components/bluedroid_demos/include/btif_stack_manager.h (100%) rename examples/{08_bt_sdp => 13_bt_sdp}/components/bluedroid_demos/include/btif_util.h (100%) rename examples/{08_bt_sdp => 13_bt_sdp}/components/bluedroid_demos/include/stack_manager.h (100%) rename examples/{07_blufi => 13_bt_sdp}/main/component.mk (100%) mode change 100644 => 100755 rename examples/{08_bt_sdp => 13_bt_sdp}/main/demo_main.c (100%) rename examples/{09_gatt_server => 14_gatt_server}/Makefile (100%) rename examples/{09_gatt_server => 14_gatt_server}/README.rst (100%) rename examples/{08_bt_sdp => 14_gatt_server}/main/component.mk (100%) mode change 100755 => 100644 rename examples/{09_gatt_server => 14_gatt_server}/main/gatts_demo.c (100%) rename examples/{10_gatt_client => 15_gatt_client}/Makefile (100%) rename examples/{10_gatt_client => 15_gatt_client}/README.rst (100%) rename examples/{10_gatt_client => 15_gatt_client}/main/component.mk (100%) rename examples/{10_gatt_client => 15_gatt_client}/main/gattc_demo.c (100%) diff --git a/examples/06_bluedroid_demos/README.rst b/examples/06_bluedroid_demos/README.rst deleted file mode 100644 index 4861adcf45..0000000000 --- a/examples/06_bluedroid_demos/README.rst +++ /dev/null @@ -1,6 +0,0 @@ -ESP-IDF Bluedroid Demos -======================= - -Some demos integration for bluedroid - - diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/app_client_profiles/battery_c/battery_c.c b/examples/06_bluedroid_demos/components/bluedroid_demos/app_client_profiles/battery_c/battery_c.c deleted file mode 100644 index 2f146e967e..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/app_client_profiles/battery_c/battery_c.c +++ /dev/null @@ -1,200 +0,0 @@ -// Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD -// -// 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. - -/*************************************************************** -* * -* * This file is for client to execute battery-related operation -* * -***************************************************************/ -#include -#include -#include -#include - -#include "bta_api.h" -#include "bta_gatt_api.h" -#include "controller.h" - -#include "gatt_int.h" -#include "bt_trace.h" -#include "btm_api.h" -#include "bt_types.h" -#include "gattc_profile.h" -#include "esp_gatts_api.h" - -#define BT_BD_ADDR_STR "%02x:%02x:%02x:%02x:%02x:%02x" -#define BT_BD_ADDR_HEX(addr) addr[0], addr[1], addr[2], addr[3], addr[4], addr[5] -esp_gattc_if_t client_if; - -esp_bt_uuid_t bas_uuid = {LEN_UUID_16, {UUID_SERVCLASS_BATTERY}}; - -uint16_t get_uuid16(esp_bt_uuid_t* p_uuid) -{ - if(p_uuid->len == LEN_UUID_16) - { - return p_uuid->uu.uuid16; - } - else if(p_uuid->len == LEN_UUID_128) - { - UINT16 u16; - UINT8 *p = &p_uuid->uu.uuid128[LEN_UUID_128 - 4]; - STREAM_TO_UINT16(u16, p); - return u16; - } - else - { - return (UINT16)p_uuid->uu.uuid32; - } -} - -/*fill a GATT ID structure*/ -void bta_le_fill_16bits_gatt_id(UINT8 inst_id, UINT16 uuid, tBTA_GATT_ID* p_output) -{ - p_output->inst_id = inst_id; - p_output->uuid.len = LEN_UUID_16; - p_output->uuid.uu.uuid16 = uuid; -} - -/*fill a service ID structure with a 16 bits service UUID*/ -void bta_le_fill_16bits_srvc_id(bool is_pri, UINT8 inst_id, UINT16 srvc_uuid, esp_gatt_srvc_id_t* p_output) -{ - memset((void *)p_output, 0, sizeof(esp_gatt_srvc_id_t)); - p_output->is_primary = is_pri; - bta_le_fill_16bits_gatt_id(inst_id, srvc_uuid, &p_output->id); -} - -/*fill a char ID structure with a 16 bits char UUID*/ -void bta_le_fill_16bits_char_id(UINT8 inst_id, UINT16 char_uuid, esp_gatt_id_t* p_output) -{ - memset((void *)p_output, 0, sizeof(esp_gatt_id_t)); - bta_le_fill_16bits_gatt_id(inst_id, char_uuid, p_output); -} - -/****************************************************************************** -** Function bas_gattc_callback -** -** Description battery service register callback function -*******************************************************************************/ -static void bas_gattc_callback(esp_gattc_evt_t event, esp_gattc_t* p_data) -{ - switch (event) - { - case ESP_GATTC_REG_EVT: - { - esp_gatt_status_t status = p_data->reg_oper.status; - client_if = p_data->reg_oper.client_if; - LOG_ERROR("BAS register completed: event=%d, status=%d, client_if=%d\n", - event, status, client_if); - - } - break; - - /*connect callback*/ - case ESP_GATTC_OPEN_EVT: - { - - LOG_ERROR("\n%s:device is connected "BT_BD_ADDR_STR", client_if=%d, status=%d, connect_id=%d\n", - __FUNCTION__, BT_BD_ADDR_HEX(p_data->open.remote_bda), p_data->open.client_if, - p_data->open.status, p_data->open.conn_id); - /*return whether the remote device is currently connected*/ - int is_connected = BTA_DmGetConnectionState(p_data->open.remote_bda); - LOG_ERROR("is_connected=%d\n",is_connected); - /*get the energy info of the controller*/ - - /*read battery level*/ - int conn_id = p_data->open.conn_id; - - /*discover service*/ - esp_ble_gattc_svc_search_req(conn_id, NULL); - - } - break; - - case ESP_GATTC_SEARCH_RES_EVT: - { - // tBTA_GATTC_SRVC_RES service_result; - LOG_ERROR("find the service,uuid=0x%x, is_primary=%d\n", - get_uuid16(&p_data->srvc_res.service_uuid.id.uuid), - p_data->srvc_res.service_uuid.is_primary); - } - break; - - case ESP_GATTC_SEARCH_CMPL_EVT: - { - LOG_ERROR("search service complete, conn_id=%d,status=%d\n", p_data->search_cmpl.conn_id, - p_data->search_cmpl.status); - - /*get first characteristic of battey service*/ - LOG_ERROR("get first characteristic of battery service\n"); - tBTA_GATT_STATUS status; - tBTA_GATT_SRVC_ID battery_srvc_id; - tBTA_GATTC_CHAR_ID out_char_id; - tGATT_CHAR_PROP out_char_prop; - bta_le_fill_16bits_srvc_id(TRUE, 0, UUID_SERVCLASS_BATTERY, &battery_srvc_id); - status = esp_ble_gattc_get_first_char(p_data->search_cmpl.conn_id, &battery_srvc_id, NULL, - &out_char_id, &out_char_prop); - if(status == 0) - { - LOG_ERROR("the first char:srvc_id=0x%x,char_id=0x%x, property = %d\n", - get_uuid16(&out_char_id.srvc_id.id.uuid), get_uuid16(&out_char_id.char_id.uuid), - out_char_prop); - /*read battery level*/ - tBTA_GATTC_CHAR_ID battery_char_id; - bta_le_fill_16bits_srvc_id(TRUE, 0, UUID_SERVCLASS_BATTERY, &battery_char_id.srvc_id); - bta_le_fill_16bits_char_id(0, GATT_UUID_BATTERY_LEVEL, &battery_char_id.char_id); - - esp_ble_gattc_read_char(p_data->search_cmpl.conn_id, &battery_char_id, - BTA_GATT_AUTH_REQ_NONE); - } - } - break; - - case ESP_GATTC_READ_CHAR_EVT: - { - - LOG_ERROR("\nread characteristic:connect_id=%d, status=%d\n", - p_data->read.conn_id, p_data->read.status); - LOG_ERROR("srvc_id=0x%x,char_id=0x%x,descr_type=0x%x\n", - get_uuid16(&p_data->read.srvc_id.id.uuid), - get_uuid16(&p_data->read.char_id.uuid), - get_uuid16(&p_data->read.descr_type.uuid)); - if(get_uuid16(&p_data->read.descr_type.uuid) != GATT_UUID_CHAR_AGG_FORMAT - && p_data->read.p_value->unformat.len > 0 - && p_data->read.p_value->unformat.p_value != NULL) - { - LOG_ERROR("read the value: len=%d, value=%d\n", p_data->read.p_value->unformat.len, - *(p_data->read.p_value->unformat.p_value)); - } - } - break; - - default: - LOG_ERROR("unsettled event: %d\n", event); - } - -} - -/*************************************************************** -** -** Function bac_register -** -** Description register app for battery service -** -****************************************************************/ -void bac_register(void) -{ - esp_ble_gattc_app_register(&bas_uuid, bas_gattc_callback); - -} - diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/app_core/bt_app_core.c b/examples/06_bluedroid_demos/components/bluedroid_demos/app_core/bt_app_core.c deleted file mode 100644 index 931e146a0f..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/app_core/bt_app_core.c +++ /dev/null @@ -1,420 +0,0 @@ -// Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD -// -// 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 -#include -#include - -#include "fixed_queue.h" -#include "gki.h" -#include "bt_defs.h" -#include "bt_trace.h" -#include "bt_types.h" -#include "allocator.h" - -#include "bta_api.h" -#include "bta_gatt_api.h" -#include "bt_app_common.h" - -#include "controller.h" -//#include "prf_defs.h" -#include "hash_map.h" -#include "hash_functions.h" -#include "alarm.h" -//#include "app_button.h" -#if (BUT_PROFILE_CFG) -#include "button_pro.h" -#endif ///BUT_PROFILE_CFG -#include "thread.h" -#include "bt_app_common.h" -#include "dis_api.h" -#include "gattc_profile.h" -#include "smp_int.h" -#include "smp_api.h" - -static fixed_queue_t *bta_app_msg_queue; -fixed_queue_t *bt_app_general_alarm_queue; -hash_map_t *bt_app_general_alarm_hash_map; -pthread_mutex_t bt_app_general_alarm_lock; -static const size_t BT_APP_GENERAL_ALARM_HASH_MAP_SIZE = 10; - -xQueueHandle xBtaApp1Queue; -xTaskHandle xBtaApp1TaskHandle; - -#define BT_APP_TTYPE_MAIN_ENTRY (1) -static TIMER_LIST_ENT main_boot_tle; - -tSMP_CB smp_cmd; - -static void bt_app_context_switched(void *p_msg); -static void bt_app_send_msg(void *p_msg); -static void bt_app_task_handler(void *arg); -static void bta_app_msg_ready(fixed_queue_t *queue); -static void bt_app_task_shut_down(void); - -static void bt_app_general_alarm_ready(fixed_queue_t *queue); -static void bt_app_general_alarm_process(TIMER_LIST_ENT *p_tle); -void bt_app_start_timer(TIMER_LIST_ENT *p_tle, UINT16 type, UINT32 timeout_sec); - -//extern void ble_test_conn(void); -//extern void bt_test_start_inquiry(void); -extern void ble_server_test(void); - -static void bt_app_task_handler(void *arg) -{ - BtTaskEvt_t e; - UINT8 button_msg[2] = {0x01,0x00}; - for (;;) { - if (pdTRUE == xQueueReceive(xBtaApp1Queue, &e, (portTickType)portMAX_DELAY)) { - if (e.sig == 0xff) { - fixed_queue_process(bta_app_msg_queue); - fixed_queue_process(bt_app_general_alarm_queue); - } -#if (BUT_PROFILE_CFG) - // else if(e.sig == BUTTON_PRESS_EVT){ - // LOG_ERROR("button_press_event come in,button_value=%x\n",e.par); - // button_msg[1] = e.par; - // button_msg_notify(2,button_msg); - - - //} -#endif ///BUT_PROFILE_CFG - - } - } -} - -static void bt_app_task_post(void) -{ - BtTaskEvt_t evt; - - evt.sig = 0xff; - evt.par = 0; - - if (xQueueSend(xBtaApp1Queue, &evt, 10/portTICK_RATE_MS) != pdTRUE) { - ets_printf("btdm_post failed\n"); - } - -} - - -static void bta_app_msg_ready(fixed_queue_t *queue) { - BT_HDR *p_msg; - while (!fixed_queue_is_empty(queue)) { - p_msg = (BT_HDR *)fixed_queue_dequeue(queue); - LOG_ERROR("bta_app_msg_ready, evt: %d\n", p_msg->event); - switch (p_msg->event) { - case BT_EVT_APP_CONTEXT_SWITCH: - bt_app_context_switched(p_msg); - break; - default: - LOG_ERROR("unhandled BT_APP event (%d)\n", p_msg->event & BT_EVT_MASK); - break; - } - GKI_freebuf(p_msg); - } -} - -static void bt_app_context_switched(void *p_msg) -{ - tBTAPP_CONTEXT_SWITCH_CBACK *p = (tBTAPP_CONTEXT_SWITCH_CBACK *) p_msg; - - if (p->p_cb) - p->p_cb(p->event, p->p_param); -} - -static void bt_app_send_msg(void *p_msg) -{ - if (bta_app_msg_queue) { - fixed_queue_enqueue(bta_app_msg_queue, p_msg); - //ke_event_set(KE_EVENT_BT_APP_TASK); - bt_app_task_post(); - } -} - -bt_status_t bt_app_transfer_context (tBTAPP_CBACK *p_cback, UINT16 event, char* p_params, int param_len, tBTAPP_COPY_CBACK *p_copy_cback) -{ - tBTAPP_CONTEXT_SWITCH_CBACK *p_msg; - - LOG_ERROR("btapp_transfer_context evt %d, len %d", event, param_len); - - /* allocate and send message that will be executed in btif context */ - if ((p_msg = (tBTAPP_CONTEXT_SWITCH_CBACK *) GKI_getbuf(sizeof(tBTAPP_CONTEXT_SWITCH_CBACK) + param_len)) != NULL) - { - p_msg->hdr.event = BT_EVT_APP_CONTEXT_SWITCH; /* internal event */ - p_msg->p_cb = p_cback; - - p_msg->event = event; /* callback event */ - - /* check if caller has provided a copy callback to do the deep copy */ - if (p_copy_cback) - { - p_copy_cback(event, p_msg->p_param, p_params); - } - else if (p_params) - { - memcpy(p_msg->p_param, p_params, param_len); /* callback parameter data */ - } - - bt_app_send_msg(p_msg); - return BT_STATUS_SUCCESS; - } - else - { - /* let caller deal with a failed allocation */ - return BT_STATUS_NOMEM; - } -} - -void bt_app_task_start_up(void) -{ - bta_app_msg_queue = fixed_queue_new(SIZE_MAX); - if (bta_app_msg_queue == NULL) - goto error_exit; - //ke_event_callback_set(KE_EVENT_BT_APP_TASK, &bt_app_task_handler); - - xBtaApp1Queue = xQueueCreate(3, sizeof(BtTaskEvt_t)); - xTaskCreate(bt_app_task_handler, "BtaApp1T", 8192, NULL, configMAX_PRIORITIES - 3, xBtaApp1TaskHandle); - - fixed_queue_register_dequeue(bta_app_msg_queue, bta_app_msg_ready); - - bt_app_general_alarm_hash_map = hash_map_new(BT_APP_GENERAL_ALARM_HASH_MAP_SIZE, - hash_function_pointer, NULL, (data_free_fn)osi_alarm_free, NULL); - if (bt_app_general_alarm_hash_map == NULL) - goto error_exit; - - pthread_mutex_init(&bt_app_general_alarm_lock, NULL); - - bt_app_general_alarm_queue = fixed_queue_new(SIZE_MAX); - if (bt_app_general_alarm_queue == NULL) - goto error_exit; - fixed_queue_register_dequeue(bt_app_general_alarm_queue, bt_app_general_alarm_ready); - - memset(&main_boot_tle, 0, sizeof(TIMER_LIST_ENT)); - return; - -error_exit: - LOG_ERROR("%s Unable to allocate resources for bt_app\n", __func__); - bt_app_task_shut_down(); -} - -static void bt_app_task_shut_down(void) -{ - fixed_queue_unregister_dequeue(bta_app_msg_queue); - fixed_queue_free(bta_app_msg_queue, NULL); - bta_app_msg_queue = NULL; - - // todo: hash map, pthread_mutex... - fixed_queue_unregister_dequeue(bt_app_general_alarm_queue); - - vTaskDelete(xBtaApp1TaskHandle); - vQueueDelete(xBtaApp1Queue); -} - - -static void bt_app_dm_data_copy(uint16_t event, char *dst, char *src) -{ - tBTA_DM_SEC *dst_dm_sec = (tBTA_DM_SEC*)dst; - tBTA_DM_SEC *src_dm_sec = (tBTA_DM_SEC*)src; - - if (!src_dm_sec) - return; - - assert(dst_dm_sec); - memcpy(dst_dm_sec, src_dm_sec, sizeof(tBTA_DM_SEC)); - - if (event == BTA_DM_BLE_KEY_EVT) - { - dst_dm_sec->ble_key.p_key_value = osi_malloc(sizeof(tBTM_LE_KEY_VALUE)); - assert(src_dm_sec->ble_key.p_key_value); - assert(dst_dm_sec->ble_key.p_key_value); - memcpy(dst_dm_sec->ble_key.p_key_value, src_dm_sec->ble_key.p_key_value, sizeof(tBTM_LE_KEY_VALUE)); - } -} - -static void bt_app_dm_data_free(uint16_t event, tBTA_DM_SEC *dm_sec) -{ - if (event == BTA_DM_BLE_KEY_EVT) - osi_free(dm_sec->ble_key.p_key_value); -} - -static void bt_app_dm_upstreams_evt(UINT16 event, char *p_param) -{ - tBTA_DM_SEC *p_data = (tBTA_DM_SEC*)p_param; - switch (event) { - case BTA_DM_ENABLE_EVT: { - -// BTA_DmSetDeviceName("ijiazu"); - - - - - /*set connectable,discoverable, pairable and paired only modes of local device*/ - tBTA_DM_DISC disc_mode = BTA_DM_BLE_GENERAL_DISCOVERABLE; - tBTA_DM_CONN conn_mode = BTA_DM_BLE_CONNECTABLE; - //BTA_DmSetVisibility(disc_mode, conn_mode, (UINT8)BTA_DM_NON_PAIRABLE, (UINT8)BTA_DM_CONN_ALL); - -#if (defined(BLE_INCLUDED) && (BLE_INCLUDED == TRUE)) - /* Enable local privacy */ - //BTA_DmBleConfigLocalPrivacy(BLE_LOCAL_PRIVACY_ENABLED); - do { - const controller_t *controller = controller_get_interface(); - char bdstr[18]; - bdaddr_to_string(controller->get_address(), bdstr, sizeof(bdstr)); - LOG_ERROR("BDA is: %s\n", bdstr); - } while (0); -#endif - } - break; - case BTA_DM_BLE_SEC_REQ_EVT: - - smp_cb.local_io_capability = 0x03; //no input no output - smp_cb.loc_oob_flag = 0x00; //oob data not present - smp_cb.loc_auth_req = 0x01; - smp_cb.loc_enc_size = 0x10; - smp_cb.local_i_key = 0x01; - smp_cb.local_r_key = 0x01; //1101 - - //memcpy(smp_cb.pairing_bda,p_data->ble_req.bd_addr,0x06); - - smp_sm_event(&smp_cb,SMP_PAIRING_REQ_EVT,NULL); - //smp_send_cmd(SMP_OPCODE_PAIRING_RSP,&smp_cb); - //smp_generate_srand_mrand_confirm(&smp_cb,NULL); - //smp_set_state(SMP_STATE_PAIR_REQ_RSP,SMP_BR_PAIRING_REQ_EVT); - //BTA_DmConfirm(p_data->ble_req.bd_addr,true); - break; - case BTA_DM_BLE_KEY_EVT: - if(p_data->ble_key.key_type == BTM_LE_KEY_PENC) - { - smp_set_state(SMP_STATE_IDLE); - } - break; - default: - break; - } - - bt_app_dm_data_free(event, p_data); -} - -static void bte_dm_evt(tBTA_DM_SEC_EVT event, tBTA_DM_SEC* p_data) -{ - LOG_ERROR("bte_dm_evt: %d\n", (uint16_t)event); - bt_app_transfer_context(bt_app_dm_upstreams_evt, (uint16_t)event, - (void *)p_data, sizeof(tBTA_DM_SEC), bt_app_dm_data_copy); -} - -void bt_app_init_ok(UNUSED_ATTR uint16_t event, UNUSED_ATTR char *p_param) -{ - BTA_EnableBluetooth(bte_dm_evt); - vTaskDelay(1000 / portTICK_PERIOD_MS); - bt_app_start_timer(&main_boot_tle, BT_APP_TTYPE_MAIN_ENTRY, 8); -} - -/* Alarm timer */ -static void bt_app_general_alarm_cb(void *data) { - assert(data != NULL); - TIMER_LIST_ENT *p_tle = (TIMER_LIST_ENT *)data; - - fixed_queue_enqueue(bt_app_general_alarm_queue, p_tle); - //ke_event_set(KE_EVENT_BT_APP_TASK); - bt_app_task_post(); -} - -void bt_app_start_timer(TIMER_LIST_ENT *p_tle, UINT16 type, UINT32 timeout_sec) { - osi_alarm_t *alarm = NULL; - - assert(p_tle != NULL); - - // Get the alarm for the timer list entry. - pthread_mutex_lock(&bt_app_general_alarm_lock); - if (!hash_map_has_key(bt_app_general_alarm_hash_map, p_tle)) { - alarm = osi_alarm_new("bt_app", bt_app_general_alarm_cb, (void *)p_tle, 0); - hash_map_set(bt_app_general_alarm_hash_map, p_tle, alarm); - } - pthread_mutex_unlock(&bt_app_general_alarm_lock); - - pthread_mutex_lock(&bt_app_general_alarm_lock); - alarm = hash_map_get(bt_app_general_alarm_hash_map, p_tle); - pthread_mutex_unlock(&bt_app_general_alarm_lock); - if (alarm == NULL) { - LOG_ERROR("%s Unable to create alarm\n", __func__); - - return; - } - - osi_alarm_cancel(alarm); - - p_tle->event = type; - // NOTE: This value is in seconds but stored in a ticks field. - p_tle->ticks = timeout_sec; - p_tle->in_use = TRUE; - osi_alarm_set(alarm, (period_ms_t)(timeout_sec * 1000)); -} - -void bt_app_stop_timer(TIMER_LIST_ENT *p_tle) -{ - assert(p_tle != NULL); - - if (p_tle->in_use == FALSE) - return; - p_tle->in_use = FALSE; - - // Get the alarm for the timer list entry. - osi_alarm_t *alarm = hash_map_get(bt_app_general_alarm_hash_map, p_tle); - if (alarm == NULL) { - LOG_WARN("%s Unable to find expected alarm in hashmap\n", __func__); - return; - } - osi_alarm_cancel(alarm); -} - -static void bt_app_general_alarm_process(TIMER_LIST_ENT *p_tle) -{ - assert(p_tle != NULL); - LOG_ERROR("general_alarm_process\n"); - switch (p_tle->event) { - case BT_APP_TTYPE_MAIN_ENTRY: - LOG_ERROR("BT_APP main boot**********\n"); - - // ble_test_conn(); - // ble_server_test(); - - - // bt_test_start_inquiry(); - /*set connectable,discoverable, pairable and paired only modes of local device*/ - // tBTA_DM_DISC disc_mode = BTA_DM_BLE_GENERAL_DISCOVERABLE; - // tBTA_DM_CONN conn_mode = BTA_DM_BLE_CONNECTABLE; - // BTA_DmSetVisibility(disc_mode, conn_mode, (UINT8)BTA_DM_NON_PAIRABLE, (UINT8)BTA_DM_CONN_ALL); - - gatts_server_test(); - //gattc_client_test(); - break; - } - -} - -static void bt_app_general_alarm_ready(fixed_queue_t *queue) -{ - TIMER_LIST_ENT *p_tle; - - while (!fixed_queue_is_empty(queue)) { - p_tle = (TIMER_LIST_ENT *)fixed_queue_dequeue(queue); - bt_app_general_alarm_process(p_tle); - } -} - -void bt_app_core_start(void) { - bt_app_transfer_context(bt_app_init_ok, 0, NULL, 0, NULL); -} - diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/app_airsync_md5.c b/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/app_airsync_md5.c deleted file mode 100644 index d8ecda9b3d..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/app_airsync_md5.c +++ /dev/null @@ -1,131 +0,0 @@ -// Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD -// -// 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 "prf_defs.h" -#if (WX_AIRSYNC_CFG) - - -#include -#include -#include -#include "gki.h" -#include "app_airsync_md5.h" - -const uint32_t X[4][2] = {{0, 1}, {1, 5}, {5, 3}, {0, 7}}; -const uint32_t S[4][4] = {{ 7, 12, 17, 22 },{ 5, 9 , 14, 20 },{ 4, 11, 16, 23 },{ 6, 10, 15, 21 }}; -uint32_t F( uint32_t X, uint32_t Y, uint32_t Z ) -{ - return ( X & Y ) | ( ~X & Z ); -} -uint32_t G( uint32_t X, uint32_t Y, uint32_t Z ) - { - return ( X & Z ) | ( Y & ~Z ); - } -uint32_t H( uint32_t X, uint32_t Y, uint32_t Z ) -{ - return X ^ Y ^ Z; -} -uint32_t I( uint32_t X, uint32_t Y, uint32_t Z ) -{ - return Y ^ ( X | ~Z ); -} - // rotates x left s bits. -uint32_t rotate_left( uint32_t x, uint32_t s ) -{ - return ( x << s ) | ( x >> ( 32 - s ) ); -} - - // Pre-processin -uint32_t count_padding_bits ( uint32_t length ) -{ -// uint32_t div = length * BITS / BLOCK_SIZE; - uint32_t mod = length * BITS % BLOCK_SIZE; - uint32_t c_bits; - if ( mod == 0 ) - { - c_bits = MOD_SIZE; - } - else - { - c_bits = ( MOD_SIZE + BLOCK_SIZE - mod ) % BLOCK_SIZE; - } - return c_bits / BITS; -} - -MD5String append_padding_bits ( char * argv ) -{ - uint32_t msg_length = strlen ( argv ); - uint32_t bit_length = count_padding_bits ( msg_length ); - uint64_t app_length = msg_length * BITS; - MD5String string; - string.str = (char *)GKI_getbuf(msg_length + bit_length + APP_SIZE / BITS); - strncpy ( string.str, argv, msg_length ); - memset ( string.str + msg_length, 0, bit_length ); - string.str [ msg_length ] = SINGLE_ONE_BIT; - memmove ( string.str + msg_length + bit_length, (char *)&app_length, sizeof( uint64_t ) ); - string.len = msg_length + bit_length + sizeof( uint64_t ); - return string; -} - -int32_t wechat_md5 (char *argv, uint8_t *md5_32) -{ - MD5String string; - uint32_t w[16]; - uint32_t chain[4]; - uint32_t state[4]; - - uint32_t ( *auxi[ 4 ])( uint32_t, uint32_t, uint32_t ) = { F, G, H, I }; - int sIdx; - int wIdx; - string = append_padding_bits ( argv ); - chain[0] = A; - chain[1] = B; - chain[2] = C; - chain[3] = D; - for (uint32_t j = 0; j < string.len; j += BLOCK_SIZE / BITS) - { - memmove ( (char *)w, string.str + j, BLOCK_SIZE / BITS ); - memmove ( state, chain, sizeof(chain) ); - for ( uint8_t roundIdx = 0; roundIdx < 4; roundIdx++ ) - { - wIdx = X[ roundIdx ][ 0 ]; - sIdx = 0; - for (uint8_t i = 0; i < 16; i++ ) - { - state[sIdx] = state [(sIdx + 1)%4] + rotate_left( state[sIdx] +(*auxi[ roundIdx])( state[(sIdx+1) % 4], - state[(sIdx+2) % 4], - state[(sIdx+3) % 4]) + w[ wIdx ] + (uint32_t)floor((1ULL << 32) * fabs(sin( roundIdx * 16 + i + 1 )) ), - S[ roundIdx ][ i % 4 ]); - sIdx = ( sIdx + 3 ) % 4; - wIdx = ( wIdx + X[ roundIdx ][ 1 ] ) & 0xF; - } - } - chain[ 0 ] += state[ 0 ]; - chain[ 1 ] += state[ 1 ]; - chain[ 2 ] += state[ 2 ]; - chain[ 3 ] += state[ 3 ]; - } - memmove ( md5_32 + 0, (char *)&chain[0], sizeof(uint32_t) ); - memmove ( md5_32 + 4, (char *)&chain[1], sizeof(uint32_t) ); - memmove ( md5_32 + 8, (char *)&chain[2], sizeof(uint32_t) ); - memmove ( md5_32 + 12, (char *)&chain[3], sizeof(uint32_t) ); - free(string.str); - string.str = NULL; - return EXIT_SUCCESS; - -} - - -#endif ///WX_AIRSYNC_CFG - diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/app_airsync_prf.c b/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/app_airsync_prf.c deleted file mode 100644 index 893c71dbeb..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/app_airsync_prf.c +++ /dev/null @@ -1,161 +0,0 @@ -// Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD -// -// 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 "prf_defs.h" -#if (WX_AIRSYNC_CFG) - -#include "app_airsync_prf.h" -#include "wx_airsync_prf.h" -#include "app_wechat_util.h" -#include "gki.h" -#include "mpbledemo2.h" - -/***************************************************************************** -* data handle -*****************************************************************************/ -data_info g_send_data; - -static data_info g_rcv_data; -data_handler *pDataHandler; - - -static void airsync_process_msgreceive_cb(UINT8 app_id, - UINT8 conn_id,uint8_t *pData, uint16_t length); - -///function for register all products -static void register_all_products(void) -{ - REGISTER(mpbledemo2); - // could register more products if defined -} - -void app_wechat_init(void) -{ - register_all_products(); - - data_handler_init(&m_mpbledemo2_handler,PRODUCT_TYPE_MPBLEDEMO2); - m_mpbledemo2_handler->m_data_init_func(); - m_mpbledemo2_handler->m_data_init_peripheral_func(); - - app_wechat_SetDatahandler(m_mpbledemo2_handler); -} - -int ble_wechat_indicate_data_chunk(void) -{ - uint16_t chunk_len = 0; - chunk_len = g_send_data.len - g_send_data.offset; - chunk_len = chunk_len > BLE_WECHAT_MAX_DATA_LEN?BLE_WECHAT_MAX_DATA_LEN:chunk_len; - - if(chunk_len == 0) - { - app_wechat_datahandler()->m_data_free_func(g_send_data.data,g_send_data.len); - g_send_data.data = NULL; - g_send_data.len = 0; - g_send_data.offset = 0; - return 0; - } - - g_send_data.offset += chunk_len; - return 1; -} - - - /******************************************************************************* -** -** Function airsync_msgreceive_cb -** -** Description the callback function after the airsync profile have been -** receive the data from the peer device -** parms appid:the appid have been register to the gatt database -** conn_id:the current connection index -** msg_val:the airsync value receive from peer device -** Returns NULL -** -*******************************************************************************/ -static void airsync_process_msgreceive_cb(UINT8 app_id, - UINT8 conn_id,uint8_t *pData, uint16_t length) -{ - int error_code; - int chunk_size = 0; - if(length <= BLE_WECHAT_MAX_DATA_LEN) - { - if(g_rcv_data.len == 0) - { - BpFixHead *fix_head = (BpFixHead *)pData; - g_rcv_data.len = ntohs(fix_head->nLength); - g_rcv_data.offset = 0; - g_rcv_data.data = (uint8_t *)GKI_getbuf(g_rcv_data.len); - } - - chunk_size = g_rcv_data.len - g_rcv_data.offset; - chunk_size = chunk_size < length ? chunk_size : length; - memcpy(g_rcv_data.data + g_rcv_data.offset, pData, chunk_size); - g_rcv_data.offset += chunk_size; - - if (g_rcv_data.len <= g_rcv_data.offset) - { - error_code = app_wechat_datahandler()->m_data_consume_func(g_rcv_data.data, g_rcv_data.len); - app_wechat_datahandler()->m_data_free_func(g_rcv_data.data,g_rcv_data.len); - wechat_error_chack(app_wechat_datahandler(), error_code); - g_rcv_data.len = 0; - g_rcv_data.offset = 0; - - app_wechat_datahandler()->m_data_main_process_func(); - } - - - } - - -} - - void app_wechat_SetDatahandler(data_handler* pHandler) -{ - pDataHandler = pHandler; -} - -bool ble_wechat_is_last_data_sent_out(void) -{ - return (g_send_data.len == 0 && g_send_data.offset == 0 ) || \ - (g_send_data.len != 0 && g_send_data.len == g_send_data.offset); -} - -//device sent data on the indicate characteristic -int ble_wechat_indicate_data(uint8_t *data, int len) -{ - if(data == NULL || len == 0) - { - return 0; - } - - if(!ble_wechat_is_last_data_sent_out()) - { - return 0; - } - - g_send_data.data = data; - g_send_data.len = len; - g_send_data.offset = 0; - - return (ble_wechat_indicate_data_chunk()); -} - -data_handler *app_wechat_datahandler(void) -{ - return pDataHandler; -} - - -#endif ///WX_AIRSYNC_CFG - diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/epb.c b/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/epb.c deleted file mode 100644 index 3a830b064b..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/epb.c +++ /dev/null @@ -1,414 +0,0 @@ -// epb.c -// WeChat Embedded Proto Buffer -// -// Created by harlliu@tencent.com on 14-02-15. -// Copyright 2014 Tencent. All rights reserved. -// - -// Version : 1.0.2 - -#include "prf_defs.h" -#if (WX_AIRSYNC_CFG) - - -#include -#include "epb.h" - - -#define __LITTLE_ENDIAN__ 1 //Need Test - -typedef enum { - WIRETYPE_VARINT = 0, - WIRETYPE_FIXED64 = 1, - WIRETYPE_LENGTH_DELIMITED = 2, - WIRETYPE_FIXED32 = 5 -} WireType; - -#define CONTINUOUS_MASK 0x80 -#define WIRETYPE_MASK 0x07 - -static int epb_get_varint32_bits(const uint8_t *data, int len, uint32_t *value); - -inline static int sizeof_tag(uint16_t tag) -{ - return ((tag&0xff00) == 0) ? 1 : 2; //TODO:Tag more then two bytes -} - -static uint16_t epb_get_wire_type(uint16_t tag) { - uint16_t wire_type = tag & WIRETYPE_MASK; - if ((tag>>8) != 0) - wire_type = (tag>>8) & WIRETYPE_MASK; - - return wire_type; -} - -static int epb_get_value_length(const uint8_t *data, int len, uint32_t wire_type) -{ - int offset = 0; - switch(wire_type) { - case WIRETYPE_VARINT: - while ((data[offset++]&CONTINUOUS_MASK)!=0 && offset= len) - return -1; - - if (offset >= 5) - break; - - p_value |= ((uint32_t)data[offset]&0x7F) << (offset*7); - ++offset; - } - *value = p_value; - return offset; -} - -static uint32_t epb_get_fixed32_bits(const uint8_t *data, int len) -{ - if(len < 4) - return 0; - - uint32_t value = 0; -#ifdef __LITTLE_ENDIAN__ - memcpy(&value, data, sizeof(uint32_t)); -#else - value = (data[3]<<24)|(data[2]<<16)|(data[1]<<8)|data[0]; -#endif - return value; -} - -void epb_unpack_init(Epb *e, const uint8_t *buf, int len) -{ - e->unpack_buf = buf; - e->buf_len = len; -} - -bool epb_has_tag(Epb *e, uint16_t tag) -{ - int offset = epb_get_tag_value_offset(e->unpack_buf, e->buf_len, tag); - if (offset < 0) - return false; - else - return true; -} - -uint32_t epb_get_uint32(Epb *e, uint16_t tag) -{ - int offset = epb_get_tag_value_offset(e->unpack_buf, e->buf_len, tag); - if (offset < 0) - return 0; - - uint32_t value = 0; - epb_get_varint32_bits(e->unpack_buf+offset, e->buf_len-offset, &value); - return value; -} - -int32_t epb_get_int32(Epb *e, uint16_t tag) -{ - return epb_get_uint32(e, tag); -} - -int32_t epb_get_sint32(Epb *e, uint16_t tag) -{ - uint32_t value = epb_get_uint32(e, tag); - if (value&1) - return -(value>>1) - 1; - else - return value>>1; -} - -bool epb_get_bool(Epb *e, uint16_t tag) -{ - return epb_get_uint32(e, tag); -} - -int epb_get_enum(Epb *e, uint16_t tag) -{ - return epb_get_uint32(e, tag); -} - -const uint8_t *epb_get_bytes(Epb *e, uint16_t tag, int *len) -{ - int offset = epb_get_tag_value_offset(e->unpack_buf, e->buf_len, tag); - if (offset < 0) - return NULL; - - uint32_t l; - offset += epb_get_varint32_bits(e->unpack_buf+offset, e->buf_len-offset, &l); - *len = (int)l; - - return e->unpack_buf+offset; -} - -const char *epb_get_string(Epb *e, uint16_t tag, int *len) -{ - return (char *)epb_get_bytes(e, tag, len); -} - -const Message *epb_get_message(Epb *e, uint16_t tag, int *len) -{ - return (Message *)epb_get_bytes(e, tag, len); -} - -uint32_t epb_get_fixed32(Epb *e, uint16_t tag) -{ - int offset = epb_get_tag_value_offset(e->unpack_buf, e->buf_len, tag); - if (offset < 0) - return 0; - - return epb_get_fixed32_bits(e->unpack_buf+offset, e->buf_len-offset); -} - -int32_t epb_get_sfixed32(Epb *e, uint16_t tag) -{ - return epb_get_fixed32(e, tag); -} - -float epb_get_float(Epb *e, uint16_t tag) -{ - uint32_t bits = epb_get_fixed32(e, tag); - return *(float *)&bits; -} - -/* - epb pack functions -*/ - -inline static int epb_pack_buf_remain(Epb *e) -{ - return e->buf_len - e->buf_offset; -} - -static int epb_pack_tag(Epb *e, uint16_t tag) -{ - int tag_len = sizeof_tag(tag); - if (epb_pack_buf_remain(e) >= tag_len) { - uint8_t *buf = e->pack_buf + e->buf_offset; - if (tag_len == 2) //TODO - *(buf++) = 0xff&(tag>>8); - *buf = 0xff&tag; - e->buf_offset += tag_len; - return tag_len; - } - return -1; -} - -static int epb_pack_varint32_bits(Epb *e, uint32_t value) -{ - uint8_t buf[5] = {0}; - int i = 0; - do { - buf[i] = value&0x7f; - if (i-1 >= 0) - buf[i-1] |= 0x80; - value = value >> 7; - ++i; - } while (value!=0 && i<5); - if (epb_pack_buf_remain(e) >= i) { - memcpy(e->pack_buf+e->buf_offset, buf, i); - e->buf_offset += i; - return i; - } - return -1; -} - -void epb_pack_init(Epb *e, uint8_t *buf, int len) -{ - e->pack_buf = buf; - e->buf_len = len; - e->buf_offset = 0; -} - -int epb_get_packed_size(Epb *e) -{ - return e->buf_offset; -} - -int epb_set_uint32(Epb *e, uint16_t tag, uint32_t value) -{ - int len = 0; - int ret = epb_pack_tag(e, tag); - if (ret < 0) return ret; - len += ret; - - ret = epb_pack_varint32_bits(e, value); - if (ret < 0) return ret; - len += ret; - - return len; -} - -int epb_set_int32(Epb *e, uint16_t tag, int32_t value) -{ - return epb_set_uint32(e, tag, value); -} - -int epb_set_sint32(Epb *e, uint16_t tag, int32_t value) -{ - uint32_t v = (value << 1) ^ (value >> 31); - return epb_set_uint32(e, tag, v); -} - -int epb_set_bool(Epb *e, uint16_t tag, bool value) -{ - return epb_set_uint32(e, tag, value); -} - -int epb_set_enum(Epb *e, uint16_t tag, int value) -{ - return epb_set_uint32(e, tag, value); -} - -static int epb_set_fixed32_bits(Epb *e, uint32_t value) -{ - if (epb_pack_buf_remain(e) >= 4) { -#ifdef __LITTLE_ENDIAN__ - memcpy(e->pack_buf+e->buf_offset, &value, 4); -#else - uint8_t *data = (uint8_t *)&value; - for (int i=0; i<4; i++) { - *(e->pack_buf+e->buf_offset+i) = data[4-i]; - } -#endif - e->buf_offset += 4; - return 4; - } - return -1; -} - -static int epb_pack_length_delimited(Epb *e, const uint8_t *data, int len) -{ - if (epb_pack_buf_remain(e) >= len) { - memcpy(e->pack_buf + e->buf_offset, data, len); - e->buf_offset += len; - return len; - } - return -1; -} - -int epb_set_bytes(Epb *e, uint16_t tag, const uint8_t *data, int length) -{ - int len = 0; - int ret = epb_pack_tag(e, tag); - if (ret < 0) return ret; - len += ret; - - ret = epb_pack_varint32_bits(e, length); - if (ret < 0) return ret; - len += ret; - - ret = epb_pack_length_delimited(e, data, length); - if (ret < 0) return ret; - len += ret; - - return len; -} - -int epb_set_string(Epb *e, uint16_t tag, const char *data, int len) -{ - return epb_set_bytes(e, tag, (const uint8_t *)data, len); -} - -int epb_set_message(Epb *e, uint16_t tag, const Message *data, int len) -{ - return epb_set_bytes(e, tag, data, len); -} - -int epb_set_fixed32(Epb *e, uint16_t tag, uint32_t value) -{ - int len = 0; - int ret = epb_pack_tag(e, tag); - if (ret < 0) return ret; - len += ret; - - ret = epb_set_fixed32_bits(e, value); - if (ret < 0) return ret; - len += ret; - - return len; -} - -int epb_set_sfixed32(Epb *e, uint16_t tag, int32_t value) -{ - return epb_set_fixed32(e, tag, value); -} - -int epb_set_float(Epb *e, uint16_t tag, float value) -{ - uint32_t v = *(uint32_t *)&value; - return epb_set_fixed32(e, tag, v); -} - -int epb_varint32_pack_size(uint16_t tag, uint32_t value, bool is_signed) -{ - if (is_signed) - value = (value << 1) ^ (value >> 31); - - int i = 0; - do { - value = value >> 7; - ++i; - } while (value!=0 && i<5); - - return sizeof_tag(tag) + i; -} - -int epb_fixed32_pack_size(uint16_t tag) -{ - return sizeof_tag(tag) + 4; -} - -int epb_length_delimited_pack_size(uint16_t tag, int len) -{ - return epb_varint32_pack_size(tag, len, false) + len; -} - - -#endif ///WX_AIRSYNC_CFG \ No newline at end of file diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/epb_mmbp.c b/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/epb_mmbp.c deleted file mode 100644 index 48f9f7b937..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/epb_mmbp.c +++ /dev/null @@ -1,565 +0,0 @@ -// epb_MmBp.c -// WeChat Embedded Proto Buffer -// -// Generated by harlliu@tencent.com on 14-11-26. -// Copyright 2014 Tencent. All rights reserved. -// - -// Version : 1.0.4 - -#include "prf_defs.h" -#if (WX_AIRSYNC_CFG) - - -#include -#include -#include -#include "epb_MmBp.h" -#include "gki.h" - -#define TAG_BaseResponse_ErrCode 0x08 -#define TAG_BaseResponse_ErrMsg 0x12 - -#define TAG_AuthRequest_BaseRequest 0x0a -#define TAG_AuthRequest_Md5DeviceTypeAndDeviceId 0x12 -#define TAG_AuthRequest_ProtoVersion 0x18 -#define TAG_AuthRequest_AuthProto 0x20 -#define TAG_AuthRequest_AuthMethod 0x28 -#define TAG_AuthRequest_AesSign 0x32 -#define TAG_AuthRequest_MacAddress 0x3a -#define TAG_AuthRequest_TimeZone 0x52 -#define TAG_AuthRequest_Language 0x5a -#define TAG_AuthRequest_DeviceName 0x62 - -#define TAG_AuthResponse_BaseResponse 0x0a -#define TAG_AuthResponse_AesSessionKey 0x12 - -#define TAG_InitRequest_BaseRequest 0x0a -#define TAG_InitRequest_RespFieldFilter 0x12 -#define TAG_InitRequest_Challenge 0x1a - -#define TAG_InitResponse_BaseResponse 0x0a -#define TAG_InitResponse_UserIdHigh 0x10 -#define TAG_InitResponse_UserIdLow 0x18 -#define TAG_InitResponse_ChalleangeAnswer 0x20 -#define TAG_InitResponse_InitScence 0x28 -#define TAG_InitResponse_AutoSyncMaxDurationSecond 0x30 -#define TAG_InitResponse_UserNickName 0x5a -#define TAG_InitResponse_PlatformType 0x60 -#define TAG_InitResponse_Model 0x6a -#define TAG_InitResponse_Os 0x72 -#define TAG_InitResponse_Time 0x78 -#define TAG_InitResponse_TimeZone 0x8001 -#define TAG_InitResponse_TimeString 0x8a01 - -#define TAG_SendDataRequest_BaseRequest 0x0a -#define TAG_SendDataRequest_Data 0x12 -#define TAG_SendDataRequest_Type 0x18 - -#define TAG_SendDataResponse_BaseResponse 0x0a -#define TAG_SendDataResponse_Data 0x12 - -#define TAG_RecvDataPush_BasePush 0x0a -#define TAG_RecvDataPush_Data 0x12 -#define TAG_RecvDataPush_Type 0x18 - -#define TAG_SwitchViewPush_BasePush 0x0a -#define TAG_SwitchViewPush_SwitchViewOp 0x10 -#define TAG_SwitchViewPush_ViewId 0x18 - -#define TAG_SwitchBackgroudPush_BasePush 0x0a -#define TAG_SwitchBackgroudPush_SwitchBackgroundOp 0x10 - - -int epb_base_request_pack_size(BaseRequest *request) -{ - int pack_size = 0; - - return pack_size; -} - -int epb_pack_base_request(BaseRequest *request, uint8_t *buf, int buf_len) -{ - Epb epb; - epb_pack_init(&epb, buf, buf_len); - - return epb_get_packed_size(&epb); -} - -BaseResponse *epb_unpack_base_response(const uint8_t *buf, int buf_len) -{ - Epb epb; - epb_unpack_init(&epb, buf, buf_len); - - if (!epb_has_tag(&epb, TAG_BaseResponse_ErrCode)) { - return NULL; - } - - BaseResponse *response = (BaseResponse *)GKI_getbuf(sizeof(BaseResponse)); - memset(response, 0, sizeof(BaseResponse)); - response->err_code = epb_get_int32(&epb, TAG_BaseResponse_ErrCode); - if (epb_has_tag(&epb, TAG_BaseResponse_ErrMsg)) { - response->err_msg.str = epb_get_string(&epb, TAG_BaseResponse_ErrMsg, &response->err_msg.len); - response->has_err_msg = true; - } - - return response; -} - -void epb_unpack_base_response_free(BaseResponse *response) -{ - GKI_freebuf(response); -} - -BasePush *epb_unpack_base_push(const uint8_t *buf, int buf_len) -{ - Epb epb; - epb_unpack_init(&epb, buf, buf_len); - - BasePush *push = (BasePush *)GKI_getbuf(sizeof(BasePush)); - memset(push, 0, sizeof(BasePush)); - - return push; -} - -void epb_unpack_base_push_free(BasePush *push) -{ - GKI_freebuf(push); -} - -int epb_auth_request_pack_size(AuthRequest *request) -{ - int pack_size = 0; - int len = 0; - - len = epb_base_request_pack_size(request->base_request); - pack_size += epb_length_delimited_pack_size(TAG_AuthRequest_BaseRequest, len); - if (request->has_md5_device_type_and_device_id) { - pack_size += epb_length_delimited_pack_size(TAG_AuthRequest_Md5DeviceTypeAndDeviceId, request->md5_device_type_and_device_id.len); - } - pack_size += epb_varint32_pack_size(TAG_AuthRequest_ProtoVersion, request->proto_version, false); - pack_size += epb_varint32_pack_size(TAG_AuthRequest_AuthProto, request->auth_proto, false); - pack_size += epb_varint32_pack_size(TAG_AuthRequest_AuthMethod, request->auth_method, false); - if (request->has_aes_sign) { - pack_size += epb_length_delimited_pack_size(TAG_AuthRequest_AesSign, request->aes_sign.len); - } - if (request->has_mac_address) { - pack_size += epb_length_delimited_pack_size(TAG_AuthRequest_MacAddress, request->mac_address.len); - } - if (request->has_time_zone) { - pack_size += epb_length_delimited_pack_size(TAG_AuthRequest_TimeZone, request->time_zone.len); - } - if (request->has_language) { - pack_size += epb_length_delimited_pack_size(TAG_AuthRequest_Language, request->language.len); - } - if (request->has_device_name) { - pack_size += epb_length_delimited_pack_size(TAG_AuthRequest_DeviceName, request->device_name.len); - } - - return pack_size; -} - -int epb_pack_auth_request(AuthRequest *request, uint8_t *buf, int buf_len) -{ - Epb epb; - epb_pack_init(&epb, buf, buf_len); - - int ret; - int tmp_len; - uint8_t *tmp; - - tmp_len = epb_base_request_pack_size(request->base_request); - tmp = (uint8_t *)GKI_getbuf(tmp_len); - ret = epb_pack_base_request(request->base_request, tmp, tmp_len); - if (ret < 0) { - GKI_freebuf(tmp); - return ret; - } - ret = epb_set_message(&epb, TAG_AuthRequest_BaseRequest, tmp, tmp_len); - GKI_freebuf(tmp); - if (ret < 0) return ret; - if (request->has_md5_device_type_and_device_id) { - ret = epb_set_bytes(&epb, TAG_AuthRequest_Md5DeviceTypeAndDeviceId, request->md5_device_type_and_device_id.data, request->md5_device_type_and_device_id.len); - if (ret < 0) return ret; - } - ret = epb_set_int32(&epb, TAG_AuthRequest_ProtoVersion, request->proto_version); - if (ret < 0) return ret; - ret = epb_set_int32(&epb, TAG_AuthRequest_AuthProto, request->auth_proto); - if (ret < 0) return ret; - ret = epb_set_enum(&epb, TAG_AuthRequest_AuthMethod, request->auth_method); - if (ret < 0) return ret; - if (request->has_aes_sign) { - ret = epb_set_bytes(&epb, TAG_AuthRequest_AesSign, request->aes_sign.data, request->aes_sign.len); - if (ret < 0) return ret; - } - if (request->has_mac_address) { - ret = epb_set_bytes(&epb, TAG_AuthRequest_MacAddress, request->mac_address.data, request->mac_address.len); - if (ret < 0) return ret; - } - if (request->has_time_zone) { - ret = epb_set_string(&epb, TAG_AuthRequest_TimeZone, request->time_zone.str, request->time_zone.len); - if (ret < 0) return ret; - } - if (request->has_language) { - ret = epb_set_string(&epb, TAG_AuthRequest_Language, request->language.str, request->language.len); - if (ret < 0) return ret; - } - if (request->has_device_name) { - ret = epb_set_string(&epb, TAG_AuthRequest_DeviceName, request->device_name.str, request->device_name.len); - if (ret < 0) return ret; - } - - return epb_get_packed_size(&epb); -} - -AuthResponse *epb_unpack_auth_response(const uint8_t *buf, int buf_len) -{ - Epb epb; - epb_unpack_init(&epb, buf, buf_len); - - const uint8_t *tmp; - int tmp_len; - - if (!epb_has_tag(&epb, TAG_AuthResponse_BaseResponse)) { - return NULL; - } - if (!epb_has_tag(&epb, TAG_AuthResponse_AesSessionKey)) { - return NULL; - } - - AuthResponse *response = (AuthResponse *)GKI_getbuf(sizeof(AuthResponse)); - memset(response, 0, sizeof(AuthResponse)); - tmp = epb_get_message(&epb, TAG_AuthResponse_BaseResponse, &tmp_len); - response->base_response = epb_unpack_base_response(tmp, tmp_len); - if (response->base_response == NULL) { - GKI_freebuf(response); - return NULL; - } - response->aes_session_key.data = epb_get_bytes(&epb, TAG_AuthResponse_AesSessionKey, &response->aes_session_key.len); - - return response; -} - -void epb_unpack_auth_response_free(AuthResponse *response) -{ - epb_unpack_base_response_free(response->base_response); - GKI_freebuf(response); -} - -int epb_init_request_pack_size(InitRequest *request) -{ - int pack_size = 0; - int len = 0; - - len = epb_base_request_pack_size(request->base_request); - pack_size += epb_length_delimited_pack_size(TAG_InitRequest_BaseRequest, len); - if (request->has_resp_field_filter) { - pack_size += epb_length_delimited_pack_size(TAG_InitRequest_RespFieldFilter, request->resp_field_filter.len); - } - if (request->has_challenge) { - pack_size += epb_length_delimited_pack_size(TAG_InitRequest_Challenge, request->challenge.len); - } - - return pack_size; -} - -int epb_pack_init_request(InitRequest *request, uint8_t *buf, int buf_len) -{ - Epb epb; - epb_pack_init(&epb, buf, buf_len); - - int ret; - int tmp_len; - uint8_t *tmp; - - tmp_len = epb_base_request_pack_size(request->base_request); - tmp = (uint8_t *)GKI_getbuf(tmp_len); - ret = epb_pack_base_request(request->base_request, tmp, tmp_len); - if (ret < 0) { - GKI_freebuf(tmp); - return ret; - } - ret = epb_set_message(&epb, TAG_InitRequest_BaseRequest, tmp, tmp_len); - GKI_freebuf(tmp); - if (ret < 0) return ret; - if (request->has_resp_field_filter) { - ret = epb_set_bytes(&epb, TAG_InitRequest_RespFieldFilter, request->resp_field_filter.data, request->resp_field_filter.len); - if (ret < 0) return ret; - } - if (request->has_challenge) { - ret = epb_set_bytes(&epb, TAG_InitRequest_Challenge, request->challenge.data, request->challenge.len); - if (ret < 0) return ret; - } - - return epb_get_packed_size(&epb); -} - -InitResponse *epb_unpack_init_response(const uint8_t *buf, int buf_len) -{ - Epb epb; - epb_unpack_init(&epb, buf, buf_len); - - const uint8_t *tmp; - int tmp_len; - - if (!epb_has_tag(&epb, TAG_InitResponse_BaseResponse)) { - return NULL; - } - if (!epb_has_tag(&epb, TAG_InitResponse_UserIdHigh)) { - return NULL; - } - if (!epb_has_tag(&epb, TAG_InitResponse_UserIdLow)) { - return NULL; - } - - InitResponse *response = (InitResponse *)GKI_getbuf(sizeof(InitResponse)); - memset(response, 0, sizeof(InitResponse)); - tmp = epb_get_message(&epb, TAG_InitResponse_BaseResponse, &tmp_len); - response->base_response = epb_unpack_base_response(tmp, tmp_len); - if (response->base_response == NULL) { - GKI_freebuf(response); - return NULL; - } - response->user_id_high = epb_get_uint32(&epb, TAG_InitResponse_UserIdHigh); - response->user_id_low = epb_get_uint32(&epb, TAG_InitResponse_UserIdLow); - if (epb_has_tag(&epb, TAG_InitResponse_ChalleangeAnswer)) { - response->challeange_answer = epb_get_uint32(&epb, TAG_InitResponse_ChalleangeAnswer); - response->has_challeange_answer = true; - } - if (epb_has_tag(&epb, TAG_InitResponse_InitScence)) { - response->init_scence = (EmInitScence)epb_get_enum(&epb, TAG_InitResponse_InitScence); - response->has_init_scence = true; - } - if (epb_has_tag(&epb, TAG_InitResponse_AutoSyncMaxDurationSecond)) { - response->auto_sync_max_duration_second = epb_get_uint32(&epb, TAG_InitResponse_AutoSyncMaxDurationSecond); - response->has_auto_sync_max_duration_second = true; - } - if (epb_has_tag(&epb, TAG_InitResponse_UserNickName)) { - response->user_nick_name.str = epb_get_string(&epb, TAG_InitResponse_UserNickName, &response->user_nick_name.len); - response->has_user_nick_name = true; - } - if (epb_has_tag(&epb, TAG_InitResponse_PlatformType)) { - response->platform_type = (EmPlatformType)epb_get_enum(&epb, TAG_InitResponse_PlatformType); - response->has_platform_type = true; - } - if (epb_has_tag(&epb, TAG_InitResponse_Model)) { - response->model.str = epb_get_string(&epb, TAG_InitResponse_Model, &response->model.len); - response->has_model = true; - } - if (epb_has_tag(&epb, TAG_InitResponse_Os)) { - response->os.str = epb_get_string(&epb, TAG_InitResponse_Os, &response->os.len); - response->has_os = true; - } - if (epb_has_tag(&epb, TAG_InitResponse_Time)) { - response->time = epb_get_int32(&epb, TAG_InitResponse_Time); - response->has_time = true; - } - if (epb_has_tag(&epb, TAG_InitResponse_TimeZone)) { - response->time_zone = epb_get_int32(&epb, TAG_InitResponse_TimeZone); - response->has_time_zone = true; - } - if (epb_has_tag(&epb, TAG_InitResponse_TimeString)) { - response->time_string.str = epb_get_string(&epb, TAG_InitResponse_TimeString, &response->time_string.len); - response->has_time_string = true; - } - - return response; -} - -void epb_unpack_init_response_free(InitResponse *response) -{ - epb_unpack_base_response_free(response->base_response); - GKI_freebuf((void *)response); -} - -int epb_send_data_request_pack_size(SendDataRequest *request) -{ - int pack_size = 0; - int len = 0; - - len = epb_base_request_pack_size(request->base_request); - pack_size += epb_length_delimited_pack_size(TAG_SendDataRequest_BaseRequest, len); - pack_size += epb_length_delimited_pack_size(TAG_SendDataRequest_Data, request->data.len); - if (request->has_type) { - pack_size += epb_varint32_pack_size(TAG_SendDataRequest_Type, request->type, false); - } - - return pack_size; -} - -int epb_pack_send_data_request(SendDataRequest *request, uint8_t *buf, int buf_len) -{ - Epb epb; - epb_pack_init(&epb, buf, buf_len); - - int ret; - int tmp_len; - uint8_t *tmp; - - tmp_len = epb_base_request_pack_size(request->base_request); - tmp = (uint8_t *)GKI_getbuf(tmp_len); - ret = epb_pack_base_request(request->base_request, tmp, tmp_len); - if (ret < 0) { - GKI_freebuf(tmp); - return ret; - } - ret = epb_set_message(&epb, TAG_SendDataRequest_BaseRequest, tmp, tmp_len); - GKI_freebuf(tmp); - if (ret < 0) return ret; - ret = epb_set_bytes(&epb, TAG_SendDataRequest_Data, request->data.data, request->data.len); - if (ret < 0) return ret; - if (request->has_type) { - ret = epb_set_enum(&epb, TAG_SendDataRequest_Type, request->type); - if (ret < 0) return ret; - } - - return epb_get_packed_size(&epb); -} - -SendDataResponse *epb_unpack_send_data_response(const uint8_t *buf, int buf_len) -{ - Epb epb; - epb_unpack_init(&epb, buf, buf_len); - - const uint8_t *tmp; - int tmp_len; - - if (!epb_has_tag(&epb, TAG_SendDataResponse_BaseResponse)) { - return NULL; - } - - SendDataResponse *response = (SendDataResponse *)GKI_getbuf(sizeof(SendDataResponse)); - memset(response, 0, sizeof(SendDataResponse)); - tmp = epb_get_message(&epb, TAG_SendDataResponse_BaseResponse, &tmp_len); - response->base_response = epb_unpack_base_response(tmp, tmp_len); - if (response->base_response == NULL) { - GKI_freebuf(response); - return NULL; - } - if (epb_has_tag(&epb, TAG_SendDataResponse_Data)) { - response->data.data = epb_get_bytes(&epb, TAG_SendDataResponse_Data, &response->data.len); - response->has_data = true; - } - - return response; -} - -void epb_unpack_send_data_response_free(SendDataResponse *response) -{ - epb_unpack_base_response_free(response->base_response); - GKI_freebuf(response); -} - -RecvDataPush *epb_unpack_recv_data_push(const uint8_t *buf, int buf_len) -{ - Epb epb; - epb_unpack_init(&epb, buf, buf_len); - - const uint8_t *tmp; - int tmp_len; - - if (!epb_has_tag(&epb, TAG_RecvDataPush_BasePush)) { - return NULL; - } - if (!epb_has_tag(&epb, TAG_RecvDataPush_Data)) { - return NULL; - } - - RecvDataPush *push = (RecvDataPush *)GKI_getbuf(sizeof(RecvDataPush)); - memset(push, 0, sizeof(RecvDataPush)); - tmp = epb_get_message(&epb, TAG_RecvDataPush_BasePush, &tmp_len); - push->base_push = epb_unpack_base_push(tmp, tmp_len); - if (push->base_push == NULL) { - GKI_freebuf(push); - return NULL; - } - push->data.data = epb_get_bytes(&epb, TAG_RecvDataPush_Data, &push->data.len); - if (epb_has_tag(&epb, TAG_RecvDataPush_Type)) { - push->type = (EmDeviceDataType)epb_get_enum(&epb, TAG_RecvDataPush_Type); - push->has_type = true; - } - - return push; -} - -void epb_unpack_recv_data_push_free(RecvDataPush *push) -{ - epb_unpack_base_push_free(push->base_push); - push->base_push = NULL; - GKI_freebuf(push); -} - -SwitchViewPush *epb_unpack_switch_view_push(const uint8_t *buf, int buf_len) -{ - Epb epb; - epb_unpack_init(&epb, buf, buf_len); - - const uint8_t *tmp; - int tmp_len; - - if (!epb_has_tag(&epb, TAG_SwitchViewPush_BasePush)) { - return NULL; - } - if (!epb_has_tag(&epb, TAG_SwitchViewPush_SwitchViewOp)) { - return NULL; - } - if (!epb_has_tag(&epb, TAG_SwitchViewPush_ViewId)) { - return NULL; - } - - SwitchViewPush *push = (SwitchViewPush *)GKI_getbuf(sizeof(SwitchViewPush)); - memset(push, 0, sizeof(SwitchViewPush)); - tmp = epb_get_message(&epb, TAG_SwitchViewPush_BasePush, &tmp_len); - push->base_push = epb_unpack_base_push(tmp, tmp_len); - if (push->base_push == NULL) { - GKI_freebuf(push); - return NULL; - } - push->switch_view_op = (EmSwitchViewOp)epb_get_enum(&epb, TAG_SwitchViewPush_SwitchViewOp); - push->view_id = (EmViewId)epb_get_enum(&epb, TAG_SwitchViewPush_ViewId); - - return push; -} - -void epb_unpack_switch_view_push_free(SwitchViewPush *push) -{ - epb_unpack_base_push_free(push->base_push); - GKI_freebuf(push); -} - -SwitchBackgroudPush *epb_unpack_switch_backgroud_push(const uint8_t *buf, int buf_len) -{ - Epb epb; - epb_unpack_init(&epb, buf, buf_len); - - const uint8_t *tmp; - int tmp_len; - - if (!epb_has_tag(&epb, TAG_SwitchBackgroudPush_BasePush)) { - return NULL; - } - if (!epb_has_tag(&epb, TAG_SwitchBackgroudPush_SwitchBackgroundOp)) { - return NULL; - } - - SwitchBackgroudPush *push = (SwitchBackgroudPush *)GKI_getbuf(sizeof(SwitchBackgroudPush)); - memset(push, 0, sizeof(SwitchBackgroudPush)); - tmp = epb_get_message(&epb, TAG_SwitchBackgroudPush_BasePush, &tmp_len); - push->base_push = epb_unpack_base_push(tmp, tmp_len); - if (push->base_push == NULL) { - GKI_freebuf(push); - return NULL; - } - push->switch_background_op = (EmSwitchBackgroundOp)epb_get_enum(&epb, TAG_SwitchBackgroudPush_SwitchBackgroundOp); - - return push; -} - -void epb_unpack_switch_backgroud_push_free(SwitchBackgroudPush *push) -{ - epb_unpack_base_push_free(push->base_push); - GKI_freebuf(push); -} - -#endif ///WX_AIRSYNC_CFG - diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/mpbledemo2.c b/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/mpbledemo2.c deleted file mode 100644 index 68fd24d791..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/mpbledemo2.c +++ /dev/null @@ -1,586 +0,0 @@ -/* -* WeChat mpbledemo2 -* -* author by anqiren 2014/12/02 V1.0bat -* -**/ - -#include "prf_defs.h" - -#if (WX_AIRSYNC_CFG) - -#include -#include -#include -#include -#include "app_airsync_prf.h" -#include "wechat_aes.h" -#include "epb_MmBp.h" -#include "wechar_crc.h" -#include "app_wechat_util.h" -#include "app_airsync_md5.h" -#include "mpbledemo2.h" -#include "gki.h" - - -mpbledemo2_info m_info = {CMD_NULL, {NULL, 0}}; - -#if defined EAM_md5AndNoEnrypt || EAM_md5AndAesEnrypt - uint8_t md5_type_and_id[16]; -#endif - -uint8_t challeange[CHALLENAGE_LENGTH] = {0x11,0x22,0x33,0x44}; //为了方便这里填了一组确定的数组,使用过程中请自行生成随机数 - -mpbledemo2_state mpbledemo2Sta = {false, false, false, false, false, false,0,0,0}; -const uint8_t key[16] = DEVICE_KEY; -uint8_t session_key[32] = {0}; -data_handler *m_mpbledemo2_handler = NULL; -uint8_t isLightOn; -/**** NOTIFICATION BITS ***********/ -uint8_t FirstNotificationBit ; -uint8_t SecondNotificationBit; - - -//static void mpbledemo2_handleCmdFromServer(BleDemo2CmdID cmd, uint8_t *ptrData, uint32_t lengthInByte); - -/**@brief Function for the light initialization. - * - * @details Initializes all lights used by this application. - */ - -int32_t mpbledemo2_get_md5(void) -{ - int32_t error_code = 0; -#if defined EAM_md5AndNoEnrypt || EAM_md5AndAesEnrypt - char device_type[] = DEVICE_TYPE; - char device_id[] = DEVICE_ID; - char argv[sizeof(DEVICE_TYPE) + sizeof(DEVICE_ID) - 1]; - memcpy(argv,device_type,sizeof(DEVICE_TYPE)); -/*when add the DEVICE_ID to DEVICE_TYPE, the offset shuld -1 to overwrite '\0' at the end of DEVICE_TYPE */ - memcpy(argv + sizeof(DEVICE_TYPE)-1,device_id,sizeof(DEVICE_ID)); - - error_code = wechat_md5(argv, md5_type_and_id); - -#endif - return error_code; -} - -void mpbledemo2_reset() -{ - mpbledemo2Sta.auth_send = false; - mpbledemo2Sta.auth_state = false; - mpbledemo2Sta.indication_state = false; - mpbledemo2Sta.init_send = false; - mpbledemo2Sta.init_state = false; - mpbledemo2Sta.send_data_seq = 0; - mpbledemo2Sta.push_data_seq = 0; - mpbledemo2Sta.seq = 0; -} - -int32_t mpbledemo2_init(void) -{ - mpbledemo2_reset(); - return (mpbledemo2_get_md5()); -} - - -void mpbledemo2_indication_state(bool isEnable) -{ - mpbledemo2Sta.indication_state = isEnable; - if (false == isEnable) - { - mpbledemo2Sta.auth_send = false; - } -} - -int32_t device_auth() -{ - if (m_mpbledemo2_handler == NULL) { - m_mpbledemo2_handler = get_handler_by_type(PRODUCT_TYPE_MPBLEDEMO2); - } - uint8_t *data = NULL; - uint32_t len = 0; - - ARGS_ITEM_SET(mpbledemo2_info, m_mpbledemo2_handler->m_data_produce_args, cmd, CMD_AUTH); - m_mpbledemo2_handler->m_data_produce_func(m_mpbledemo2_handler->m_data_produce_args, &data, &len); - if(data == NULL) - { - return errorCodeProduce; - } - - //sent data - ble_wechat_indicate_data(data, len); - return 0; - } - - -int32_t device_init() - { - uint8_t *data = NULL; - uint32_t len = 0; - ARGS_ITEM_SET(mpbledemo2_info, m_mpbledemo2_handler->m_data_produce_args, cmd, CMD_INIT); - m_mpbledemo2_handler->m_data_produce_func(m_mpbledemo2_handler->m_data_produce_args, &data, &len); - if(data == NULL) - { - return errorCodeProduce; - } - - //sent data - ble_wechat_indicate_data(data, len); - - return 0; -} - -void mpbledemo2_main_process() -{ - int error_code = 0; - if((mpbledemo2Sta.indication_state) && (!mpbledemo2Sta.auth_state) && (!mpbledemo2Sta.auth_send) ) - { - error_code = device_auth(); - if (0 == error_code) - { - mpbledemo2Sta.auth_send = true; - } - } - if((mpbledemo2Sta.auth_state) && (!mpbledemo2Sta.init_state) && (!mpbledemo2Sta.init_send)) - { - error_code = device_init(); - if (0 == error_code) - { - mpbledemo2Sta.init_send = true; - } - } -} - -void mpbledemo2_data_free_func(uint8_t *data, uint32_t len) -{ - if(data) - { - GKI_freebuf(data); - data = NULL; - } -} - -void mpbledemo2_data_produce_func(void *args, uint8_t **r_data, uint32_t *r_len) -{ - static uint16_t bleDemoHeadLen = sizeof(BlueDemoHead); - mpbledemo2_info *info = (mpbledemo2_info *)args; - BaseRequest basReq = {NULL}; - static uint8_t fix_head_len = sizeof(BpFixHead); - BpFixHead fix_head = {0xFE, 1, 0, htons(ECI_req_auth), 0}; - mpbledemo2Sta.seq++; - switch (info->cmd) - { - case CMD_AUTH: - { - #if defined EAM_md5AndAesEnrypt - uint8_t deviceid[] = DEVICE_ID; - static uint32_t seq = 0x00000001; // - uint32_t ran = 0x11223344; //为了方便起见这里放了一个固定值做为随机数,在使用时请自行生成随机数。 - ran = t_htonl(ran); - seq = t_htonl(seq); - uint8_t id_len = strlen(DEVICE_ID); - uint8_t* data = GKI_getbuf(id_len+8); - if(!data){return;} - memcpy(data,deviceid,id_len); - memcpy(data+id_len,(uint8_t*)&ran,4); - memcpy(data+id_len+4,(uint8_t*)&seq,4); - uint32_t crc = crc32(0, data, id_len+8); - crc = t_htonl(crc); - memset(data,0x00,id_len+8); - memcpy(data,(uint8_t*)&ran,4); - memcpy(data+4,(uint8_t*)&seq,4); - memcpy(data+8,(uint8_t*)&crc,4); - uint8_t CipherText[16]; - AES_Init(key); - AES_Encrypt_PKCS7 (data, CipherText, 12, key); - if(data){GKI_freebuf(data);data = NULL;} - AuthRequest authReq = {&basReq, true,{md5_type_and_id, MD5_TYPE_AND_ID_LENGTH}, - PROTO_VERSION, AUTH_PROTO, (EmAuthMethod)AUTH_METHOD, true , - {CipherText, CIPHER_TEXT_LENGTH}, false, {NULL, 0}, false, {NULL, 0}, false, - {NULL, 0},true,{DEVICE_ID,sizeof(DEVICE_ID)}}; - seq++; - #endif - - #if defined EAM_macNoEncrypt - static uint8_t mac_address[MAC_ADDRESS_LENGTH]; - //get_mac_addr(mac_address); - AuthRequest authReq = {&basReq, false,{NULL, 0}, PROTO_VERSION, AUTH_PROTO, (EmAuthMethod)AUTH_METHOD, false,{NULL, 0}, true, {mac_address, MAC_ADDRESS_LENGTH}, false, {NULL, 0}, false, {NULL, 0},true,{DEVICE_ID,sizeof(DEVICE_ID)}}; - #endif - - #if defined EAM_md5AndNoEnrypt - AuthRequest authReq = {&basReq, true,{md5_type_and_id, MD5_TYPE_AND_ID_LENGTH}, PROTO_VERSION, (EmAuthMethod)AUTH_PROTO, (EmAuthMethod)AUTH_METHOD, false ,{NULL, 0}, false, {NULL, 0}, false, {NULL, 0}, false, {NULL, 0},true,{DEVICE_ID,sizeof(DEVICE_ID)}}; - #endif - *r_len = epb_auth_request_pack_size(&authReq) + fix_head_len; - *r_data = (uint8_t *)GKI_getbuf(*r_len); - if(!(*r_data)){return;} - if(epb_pack_auth_request(&authReq, *r_data+fix_head_len, *r_len-fix_head_len)<0) - { - *r_data = NULL; - return; - } - fix_head.nCmdId = htons(ECI_req_auth); - fix_head.nLength = htons(*r_len); - fix_head.nSeq = htons(mpbledemo2Sta.seq); - memcpy(*r_data, &fix_head, fix_head_len); - return ; - } - case CMD_INIT: - { - //has challeange - InitRequest initReq = {&basReq,false, {NULL, 0},true, {challeange, CHALLENAGE_LENGTH}}; - *r_len = epb_init_request_pack_size(&initReq) + fix_head_len; - #if defined EAM_md5AndAesEnrypt - uint8_t length = *r_len; - uint8_t *p = GKI_getbuf(AES_get_length( *r_len-fix_head_len)); - if(!p){return;} - *r_len = AES_get_length( *r_len-fix_head_len)+fix_head_len; - #endif - //pack data - *r_data = (uint8_t *)GKI_getbuf(*r_len); - if(!(*r_data)){return;} - if(epb_pack_init_request(&initReq, *r_data+fix_head_len, *r_len-fix_head_len)<0) - {*r_data = NULL;return;} - //encrypt body - #if defined EAM_md5AndAesEnrypt - AES_Init(session_key); - AES_Encrypt_PKCS7(*r_data+fix_head_len,p,length-fix_head_len,session_key);//原始数据长度 - memcpy(*r_data + fix_head_len, p, *r_len-fix_head_len); - if(p)GKI_freebuf(p); - #endif - fix_head.nCmdId = htons(ECI_req_init); - fix_head.nLength = htons(*r_len); - fix_head.nSeq = htons(mpbledemo2Sta.seq); - memcpy(*r_data, &fix_head, fix_head_len); - return ; - } - case CMD_SENDDAT: - { - - BlueDemoHead *bleDemoHead = (BlueDemoHead*)GKI_getbuf(bleDemoHeadLen+info->send_msg.len); - if (!bleDemoHead) - { - return; - } - - // header of sent data - bleDemoHead->m_magicCode[0] = MPBLEDEMO2_MAGICCODE_H; - bleDemoHead->m_magicCode[1] = MPBLEDEMO2_MAGICCODE_L; - bleDemoHead->m_version = htons(MPBLEDEMO2_VERSION); - bleDemoHead->m_totalLength = htons(bleDemoHeadLen + info->send_msg.len); - bleDemoHead->m_cmdid = htons(sendTextReq); - bleDemoHead->m_seq = htons(mpbledemo2Sta.seq); - bleDemoHead->m_errorCode = 0; - - /*connect body and head.*/ - /*turn to uint8_t* befort offset.*/ - memcpy((uint8_t*)bleDemoHead + bleDemoHeadLen, info->send_msg.str, info->send_msg.len); - - SendDataRequest sendDatReq = - { - &basReq, - { (uint8_t*) bleDemoHead, (bleDemoHeadLen + info->send_msg.len)}, // define the data content wrapped in epb - false, // no type, the data is directly sent to vendor server - (EmDeviceDataType)NULL - }; - *r_len = epb_send_data_request_pack_size(&sendDatReq) + fix_head_len; - - #if defined EAM_md5AndAesEnrypt - uint16_t length = *r_len; - uint8_t *p = GKI_getbuf(AES_get_length( *r_len-fix_head_len)); - if(!p){return;} - *r_len = AES_get_length( *r_len-fix_head_len)+fix_head_len; - #endif - - *r_data = (uint8_t *)GKI_getbuf(*r_len); - if(!(*r_data)){return;} - if(epb_pack_send_data_request(&sendDatReq, *r_data+fix_head_len, *r_len-fix_head_len)<0) - { - *r_data = NULL; - #if defined EAM_md5AndAesEnrypt - if(p){GKI_freebuf(p); - p = NULL;} - #endif - return; - } - - #if defined EAM_md5AndAesEnrypt - //encrypt body - AES_Init(session_key); - AES_Encrypt_PKCS7(*r_data+fix_head_len,p,length-fix_head_len,session_key);//原始数据长度 - memcpy(*r_data + fix_head_len, p, *r_len-fix_head_len); - if(p){GKI_freebuf(p); p = NULL;} - #endif - - // header of epb - fix_head.nCmdId = htons(ECI_req_sendData); - fix_head.nLength = htons(*r_len); - fix_head.nSeq = htons(mpbledemo2Sta.seq); - - memcpy(*r_data, &fix_head, fix_head_len); - if(bleDemoHead){GKI_freebuf(bleDemoHead);bleDemoHead = NULL;} - - // increase sequence by 1 - mpbledemo2Sta.send_data_seq++; - return ; - } - } -} - -int mpbledemo2_data_consume_func(uint8_t *data, uint32_t len) -{ - BpFixHead *fix_head = (BpFixHead *)data; - uint8_t fix_head_len = sizeof(BpFixHead); - switch(ntohs(fix_head->nCmdId)) - { - case ECI_none: - { - - - } - break; - case ECI_resp_auth: - { - AuthResponse* authResp; - authResp = epb_unpack_auth_response(data+fix_head_len,len-fix_head_len); - if(authResp->base_response) - { - if(authResp->base_response->err_code == 0) - { - mpbledemo2Sta.auth_state = true; - } - else - { - int32_t returnedErrCode = authResp->base_response->err_code; - epb_unpack_auth_response_free(authResp); - return returnedErrCode; - } - } - #if defined EAM_md5AndAesEnrypt // get sessionkey - if(authResp->aes_session_key.len) - { - AES_Init(key); - AES_Decrypt(session_key,authResp->aes_session_key.data,authResp->aes_session_key.len,key); - } - #endif - epb_unpack_auth_response_free(authResp); - } - break; - case ECI_resp_sendData: - { - - #if defined EAM_md5AndAesEnrypt - uint32_t length = len- fix_head_len;//加密后数据长度 - uint8_t *p = GKI_getbuf (length); - if(!p){ if(data)GKI_freebuf(data);data = NULL; return 0;} - AES_Init(session_key); - //解密数据 - AES_Decrypt(p,data+fix_head_len,len- fix_head_len,session_key); - - uint8_t temp; - temp = p[length - 1];//算出填充长度 - len = len - temp;//取加密前数据总长度 - memcpy(data + fix_head_len, p ,length -temp);//把明文放回 - if(p){GKI_freebuf(p);p = NULL;} - #endif - SendDataResponse *sendDataResp; - sendDataResp = epb_unpack_send_data_response(data+fix_head_len,len-fix_head_len); - if (!sendDataResp) - { - return errorCodeUnpackSendDataResp; - } - - if(sendDataResp->base_response->err_code) - { - epb_unpack_send_data_response_free(sendDataResp); - return sendDataResp->base_response->err_code; - } - epb_unpack_send_data_response_free(sendDataResp); - } - break; - case ECI_resp_init: - { - FirstNotificationBit = 0; - SecondNotificationBit = 0; - - #if defined EAM_md5AndAesEnrypt - uint32_t length = len- fix_head_len; //加密后数据长度 - uint8_t *p = GKI_getbuf (length); - if(!p){if(data)GKI_freebuf(data);data = NULL; return 0;} - AES_Init(session_key); - //解密数据 - AES_Decrypt(p,data+fix_head_len,len- fix_head_len,session_key); - - uint8_t temp; - temp = p[length - 1]; //算出填充长度 - len = len - temp; //取加密前数据总长度 - memcpy(data + fix_head_len, p ,length -temp); //把明文放回 - if(p){GKI_freebuf(p);p = NULL;} - #endif - InitResponse *initResp = epb_unpack_init_response(data+fix_head_len, len-fix_head_len); - if(!initResp) - { - return errorCodeUnpackInitResp; - } - - if(initResp->base_response) - { - if(initResp->base_response->err_code == 0) - { - if(initResp->has_challeange_answer) - { - if(crc32(0,challeange,CHALLENAGE_LENGTH) == initResp->challeange_answer) - { - mpbledemo2Sta.init_state = true; - } - } - else mpbledemo2Sta.init_state = true; - mpbledemo2Sta.wechats_switch_state = true; - } - else - { - epb_unpack_init_response_free(initResp); - return initResp->base_response->err_code; - } - } - epb_unpack_init_response_free(initResp); - } - break; - case ECI_push_recvData: - { - #if defined EAM_md5AndAesEnrypt - uint32_t length = len- fix_head_len;//加密后数据长度 - uint8_t *p = GKI_getbuf (length); - if(!p){if(data)GKI_freebuf(data); data =NULL; return 0;} - AES_Init(session_key); - //解密数据 - AES_Decrypt(p,data+fix_head_len,len- fix_head_len,session_key); - - uint8_t temp; - temp = p[length - 1];//算出填充长度 - len = len - temp;//取加密前数据总长度 - memcpy(data + fix_head_len, p ,length -temp);//把明文放回 - if(p){GKI_freebuf(p);p = NULL;} - #endif - RecvDataPush *recvDatPush; - recvDatPush = epb_unpack_recv_data_push(data+fix_head_len, len-fix_head_len); - - if(!recvDatPush) - { - return errorCodeUnpackRecvDataPush; - } - - BlueDemoHead *bledemohead = (BlueDemoHead*)recvDatPush->data.data; - - - // ble demo command handle - - epb_unpack_recv_data_push_free(recvDatPush); - mpbledemo2Sta.push_data_seq++; - } - break; - case ECI_push_switchView: - { - - mpbledemo2Sta.wechats_switch_state = !mpbledemo2Sta.wechats_switch_state; - - #if defined EAM_md5AndAesEnrypt - uint32_t length = len- fix_head_len;//加密后数据长度 - uint8_t *p = GKI_getbuf (length); - if(!p){if(data)GKI_freebuf(data);data = NULL; return 0;} - AES_Init(session_key); - //解密数据 - AES_Decrypt(p,data+fix_head_len,len- fix_head_len,session_key); - - uint8_t temp; - temp = p[length - 1];//算出填充长度 - len = len - temp;//取加密前数据总长度 - memcpy(data + fix_head_len, p ,length -temp);//把明文放回 - if(p){GKI_freebuf(p);p = NULL;} - #endif - SwitchViewPush *swichViewPush; - swichViewPush = epb_unpack_switch_view_push(data+fix_head_len,len-fix_head_len); - if(!swichViewPush) - { - return errorCodeUnpackSwitchViewPush; - } - epb_unpack_switch_view_push_free(swichViewPush); - } - break; - case ECI_push_switchBackgroud: - { - - #if defined EAM_md5AndAesEnrypt - uint32_t length = len- fix_head_len;//加密后数据长度 - uint8_t *p = GKI_getbuf (length); - if(!p){if(data)GKI_freebuf(data);data = NULL; return 0;} - AES_Init(session_key); - //解密数据 - AES_Decrypt(p,data+fix_head_len,len- fix_head_len,session_key); - uint8_t temp; - temp = p[length - 1];//算出填充长度 - len = len - temp;//取加密前数据总长度 - memcpy(data + fix_head_len, p ,length -temp);//把明文放回 - if(data){GKI_freebuf(p);p = NULL;} - #endif - SwitchBackgroudPush *switchBackgroundPush = epb_unpack_switch_backgroud_push(data+fix_head_len,len-fix_head_len); - if(! switchBackgroundPush) - { - return errorCodeUnpackSwitchBackgroundPush; - } - epb_unpack_switch_backgroud_push_free(switchBackgroundPush); - } - break; - case ECI_err_decode: - break; - default: - { - - } - break; - } - return 0; -} -void mpbledemo2_data_error_func(int error_code) -{ - if(error_code) - { - - //NVIC_SystemReset(); - } -} - -data_handler mpbledemo2_data_handler = { - .m_product_type = PRODUCT_TYPE_MPBLEDEMO2, - .m_data_produce_func = &mpbledemo2_data_produce_func, - .m_data_free_func = &mpbledemo2_data_free_func, - .m_data_consume_func = &mpbledemo2_data_consume_func, - .m_data_error_func = &mpbledemo2_data_error_func, - .m_data_init_peripheral_func = NULL, - .m_data_init_func = &mpbledemo2_init, - .m_data_main_process_func = &mpbledemo2_main_process, - .m_data_button_handler_func = NULL, - .m_data_produce_args = &m_info, - .next = NULL -}; - -// send data to wechat server -int32_t mpbledemo2_sendData(uint8_t* ptrData, uint32_t lengthInByte) -{ - uint8_t *data = NULL; - uint32_t len = 0; - ARGS_ITEM_SET(mpbledemo2_info, m_mpbledemo2_handler->m_data_produce_args, cmd, CMD_SENDDAT); - ARGS_ITEM_SET(mpbledemo2_info, m_mpbledemo2_handler->m_data_produce_args, send_msg.len, lengthInByte); - ARGS_ITEM_SET(mpbledemo2_info, m_mpbledemo2_handler->m_data_produce_args, send_msg.str, (const char *)ptrData); - - m_mpbledemo2_handler->m_data_produce_func(m_mpbledemo2_handler->m_data_produce_args, &data, &len); - if(data == NULL) - { - return errorCodeProduce; - } - ble_wechat_indicate_data(data, len); - return 0; -} - -#endif ///WX_AIRSYNC_CFG - diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/wechar_crc.c b/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/wechar_crc.c deleted file mode 100644 index 2239a75ca4..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/wechar_crc.c +++ /dev/null @@ -1,51 +0,0 @@ -// crc32.c -// WeChat Embedded -// -// Created by harlliu on 14-03-03. -// Copyright 2014 Tencent. All rights reserved. -// - - -#include "prf_defs.h" -#if (WX_AIRSYNC_CFG) - -#include -#include "wechar_crc.h" - -#define DO1(buf) crc = crc_table(((int)crc ^ (*buf++)) & 0xff) ^ (crc >> 8); -#define DO2(buf) DO1(buf); DO1(buf); -#define DO4(buf) DO2(buf); DO2(buf); -#define DO8(buf) DO4(buf); DO4(buf); - - -static uint32_t crc_table(uint32_t index) -{ - uint32_t c = index; - uint32_t poly = 0xedb88320L; - int k; - - for (k = 0; k < 8; k++) - c = c & 1 ? poly ^ (c >> 1) : c >> 1; - - return c; -} - -uint32_t crc32(uint32_t crc, const uint8_t *buf, int len) -{ - if (buf == NULL) return 0L; - - crc = crc ^ 0xffffffffL; - while (len >= 8) - { - DO8(buf); - len -= 8; - } - if (len) do { - DO1(buf); - } while (--len); - return crc ^ 0xffffffffL; -} - - -#endif ///WX_AIRSYNC_CFG - diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/wechat_aes.c b/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/wechat_aes.c deleted file mode 100644 index 9841f49117..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_WX_airsync/wechat_aes.c +++ /dev/null @@ -1,450 +0,0 @@ -/////////////////////////////////////////////////////////////////////////////// -// 文 件 名:wechat_aes.c -// 描 述:AES加密算法 -// 创 建 人:Liangbofu -// 创建日期:2009-07-17 -/////////////////////////////////////////////////////////////////////////////// - -#include "prf_defs.h" -#if (WX_AIRSYNC_CFG) - -#include "wechat_aes.h" -#include -#include -#include -#include - -// 为了能针对C51进行优化,并且又使代码可用于ARM和PC等环境, -// 在非C51环境(没有定义__C51__)下需要把C51特定的关键字定义为空 -#ifndef __C51__ - #define code - #define data - #define idata - #define xdata - #define pdata - typedef unsigned char BOOL; -#else - typedef bit BOOL; -#endif - - -#define Nk (AES_KEY_LENGTH / 32) // 以“字”(4字节)为单位的密钥长度 -#define Nb 4 // 以“字”(4字节)为单位的加解密数据块大小,固定为4 - -// Nr:加密的轮数 -#if AES_KEY_LENGTH == 128 - #define Nr 10 -#elif AES_KEY_LENGTH == 192 - #define Nr 12 -#elif AES_KEY_LENGTH == 256 - #define Nr 14 -#else - #error AES_KEY_LENGTH must be 128, 192 or 256 BOOLs! -#endif - -// GF(28) 多项式 -#define BPOLY 0x1B // Lower 8 BOOLs of (x^8 + x^4 + x^3 + x + 1), ie. (x^4 + x^3 + x + 1). - -// AES子密钥表,当密钥长度为128位时,占用176字节空间 -static xdata unsigned char g_roundKeyTable[4*Nb*(Nr+1)]; - -// 加密用的SBox -static code const unsigned char SBox[256] = -{ - 0x63, 0x7c, 0x77, 0x7b, 0xf2, 0x6b, 0x6f, 0xc5, 0x30, 0x01, 0x67, 0x2b, 0xfe, 0xd7, 0xab, 0x76, - 0xca, 0x82, 0xc9, 0x7d, 0xfa, 0x59, 0x47, 0xf0, 0xad, 0xd4, 0xa2, 0xaf, 0x9c, 0xa4, 0x72, 0xc0, - 0xb7, 0xfd, 0x93, 0x26, 0x36, 0x3f, 0xf7, 0xcc, 0x34, 0xa5, 0xe5, 0xf1, 0x71, 0xd8, 0x31, 0x15, - 0x04, 0xc7, 0x23, 0xc3, 0x18, 0x96, 0x05, 0x9a, 0x07, 0x12, 0x80, 0xe2, 0xeb, 0x27, 0xb2, 0x75, - 0x09, 0x83, 0x2c, 0x1a, 0x1b, 0x6e, 0x5a, 0xa0, 0x52, 0x3b, 0xd6, 0xb3, 0x29, 0xe3, 0x2f, 0x84, - 0x53, 0xd1, 0x00, 0xed, 0x20, 0xfc, 0xb1, 0x5b, 0x6a, 0xcb, 0xbe, 0x39, 0x4a, 0x4c, 0x58, 0xcf, - 0xd0, 0xef, 0xaa, 0xfb, 0x43, 0x4d, 0x33, 0x85, 0x45, 0xf9, 0x02, 0x7f, 0x50, 0x3c, 0x9f, 0xa8, - 0x51, 0xa3, 0x40, 0x8f, 0x92, 0x9d, 0x38, 0xf5, 0xbc, 0xb6, 0xda, 0x21, 0x10, 0xff, 0xf3, 0xd2, - 0xcd, 0x0c, 0x13, 0xec, 0x5f, 0x97, 0x44, 0x17, 0xc4, 0xa7, 0x7e, 0x3d, 0x64, 0x5d, 0x19, 0x73, - 0x60, 0x81, 0x4f, 0xdc, 0x22, 0x2a, 0x90, 0x88, 0x46, 0xee, 0xb8, 0x14, 0xde, 0x5e, 0x0b, 0xdb, - 0xe0, 0x32, 0x3a, 0x0a, 0x49, 0x06, 0x24, 0x5c, 0xc2, 0xd3, 0xac, 0x62, 0x91, 0x95, 0xe4, 0x79, - 0xe7, 0xc8, 0x37, 0x6d, 0x8d, 0xd5, 0x4e, 0xa9, 0x6c, 0x56, 0xf4, 0xea, 0x65, 0x7a, 0xae, 0x08, - 0xba, 0x78, 0x25, 0x2e, 0x1c, 0xa6, 0xb4, 0xc6, 0xe8, 0xdd, 0x74, 0x1f, 0x4b, 0xbd, 0x8b, 0x8a, - 0x70, 0x3e, 0xb5, 0x66, 0x48, 0x03, 0xf6, 0x0e, 0x61, 0x35, 0x57, 0xb9, 0x86, 0xc1, 0x1d, 0x9e, - 0xe1, 0xf8, 0x98, 0x11, 0x69, 0xd9, 0x8e, 0x94, 0x9b, 0x1e, 0x87, 0xe9, 0xce, 0x55, 0x28, 0xdf, - 0x8c, 0xa1, 0x89, 0x0d, 0xbf, 0xe6, 0x42, 0x68, 0x41, 0x99, 0x2d, 0x0f, 0xb0, 0x54, 0xbb, 0x16 -}; - -// 解密用的SBox -static code const unsigned char InvSBox[256] = -{ - 0x52, 0x09, 0x6a, 0xd5, 0x30, 0x36, 0xa5, 0x38, 0xbf, 0x40, 0xa3, 0x9e, 0x81, 0xf3, 0xd7, 0xfb, - 0x7c, 0xe3, 0x39, 0x82, 0x9b, 0x2f, 0xff, 0x87, 0x34, 0x8e, 0x43, 0x44, 0xc4, 0xde, 0xe9, 0xcb, - 0x54, 0x7b, 0x94, 0x32, 0xa6, 0xc2, 0x23, 0x3d, 0xee, 0x4c, 0x95, 0x0b, 0x42, 0xfa, 0xc3, 0x4e, - 0x08, 0x2e, 0xa1, 0x66, 0x28, 0xd9, 0x24, 0xb2, 0x76, 0x5b, 0xa2, 0x49, 0x6d, 0x8b, 0xd1, 0x25, - 0x72, 0xf8, 0xf6, 0x64, 0x86, 0x68, 0x98, 0x16, 0xd4, 0xa4, 0x5c, 0xcc, 0x5d, 0x65, 0xb6, 0x92, - 0x6c, 0x70, 0x48, 0x50, 0xfd, 0xed, 0xb9, 0xda, 0x5e, 0x15, 0x46, 0x57, 0xa7, 0x8d, 0x9d, 0x84, - 0x90, 0xd8, 0xab, 0x00, 0x8c, 0xbc, 0xd3, 0x0a, 0xf7, 0xe4, 0x58, 0x05, 0xb8, 0xb3, 0x45, 0x06, - 0xd0, 0x2c, 0x1e, 0x8f, 0xca, 0x3f, 0x0f, 0x02, 0xc1, 0xaf, 0xbd, 0x03, 0x01, 0x13, 0x8a, 0x6b, - 0x3a, 0x91, 0x11, 0x41, 0x4f, 0x67, 0xdc, 0xea, 0x97, 0xf2, 0xcf, 0xce, 0xf0, 0xb4, 0xe6, 0x73, - 0x96, 0xac, 0x74, 0x22, 0xe7, 0xad, 0x35, 0x85, 0xe2, 0xf9, 0x37, 0xe8, 0x1c, 0x75, 0xdf, 0x6e, - 0x47, 0xf1, 0x1a, 0x71, 0x1d, 0x29, 0xc5, 0x89, 0x6f, 0xb7, 0x62, 0x0e, 0xaa, 0x18, 0xbe, 0x1b, - 0xfc, 0x56, 0x3e, 0x4b, 0xc6, 0xd2, 0x79, 0x20, 0x9a, 0xdb, 0xc0, 0xfe, 0x78, 0xcd, 0x5a, 0xf4, - 0x1f, 0xdd, 0xa8, 0x33, 0x88, 0x07, 0xc7, 0x31, 0xb1, 0x12, 0x10, 0x59, 0x27, 0x80, 0xec, 0x5f, - 0x60, 0x51, 0x7f, 0xa9, 0x19, 0xb5, 0x4a, 0x0d, 0x2d, 0xe5, 0x7a, 0x9f, 0x93, 0xc9, 0x9c, 0xef, - 0xa0, 0xe0, 0x3b, 0x4d, 0xae, 0x2a, 0xf5, 0xb0, 0xc8, 0xeb, 0xbb, 0x3c, 0x83, 0x53, 0x99, 0x61, - 0x17, 0x2b, 0x04, 0x7e, 0xba, 0x77, 0xd6, 0x26, 0xe1, 0x69, 0x14, 0x63, 0x55, 0x21, 0x0c, 0x7d -}; - - -/////////////////////////////////////////////////////////////////////////////// -// 函数名: RotationWord -// 描述: 对一个“字”数据进行循环右移。 -// 输入参数: pWord -- 要右移的4字节数据。 -// 输出参数: pWord -- 右移后的4字节数据。 -// 返回值: 无。 -/////////////////////////////////////////////////////////////////////////////// -static void RotationWord(unsigned char *pWord) -{ - unsigned char temp = pWord[0]; - pWord[0] = pWord[1]; - pWord[1] = pWord[2]; - pWord[2] = pWord[3]; - pWord[3] = temp; -} - -/////////////////////////////////////////////////////////////////////////////// -// 函数名: XorBytes -// 描述: 批量异或两组数据。 -// 输入参数: pData1 -- 要异或的第一组数据。 -// pData1 -- 要异或的第二组数据。 -// nCount -- 要异或的数据长度。 -// 输出参数: pData1 -- 异或后的结果。 -// 返回值: 无。 -/////////////////////////////////////////////////////////////////////////////// -static void XorBytes(unsigned char *pData1, const unsigned char *pData2, unsigned char nCount) -{ - unsigned char i; - - for (i = 0; i < nCount; i++) - { - pData1[i] ^= pData2[i]; - } -} - -/////////////////////////////////////////////////////////////////////////////// -// 函数名: AddRoundKey -// 描述: 把 中间状态数据 加上(异或)子密钥,数据长度为16字节。 -// 输入参数: pState -- 状态数据。 -// pRoundKey -- 子密钥数据。 -// 输出参数: pState -- 加上子密钥后的状态数据。 -// 返回值: 无。 -/////////////////////////////////////////////////////////////////////////////// -// static void AddRoundKey(unsigned char *pState, const unsigned char *pRoundKey) -// { -// XorBytes(pState, pRoundKey, 4*Nb); -// } - -// AddRoundKey的宏形式,比函数形式可以节省4字节的data数据 -#define AddRoundKey(pState, pRoundKey) \ - XorBytes((pState), (pRoundKey), 4*Nb) - - -/////////////////////////////////////////////////////////////////////////////// -// 函数名: SubBytes -// 描述: 通过S盒子置换状态数据。 -// 输入参数: pState -- 状态数据。 -// nCount -- 状态数据长度。 -// bInvert -- 是否使用反向S盒子(解密时使用)。 -// 输出参数: pState -- 置换后的状态数据。 -// 返回值: 无。 -/////////////////////////////////////////////////////////////////////////////// -static void SubBytes(unsigned char *pState, unsigned char nCount, BOOL bInvert) -{ - unsigned char i; - const unsigned char code *pSBox = bInvert ? InvSBox : SBox; - - for (i = 0; i < nCount; i++) - { - pState[i] = pSBox[pState[i]]; - } -} - -/////////////////////////////////////////////////////////////////////////////// -// 函数名: ShiftRows -// 描述: 把状态数据移行。 -// 输入参数: pState -- 状态数据。 -// bInvert -- 是否反向移行(解密时使用)。 -// 输出参数: pState -- 移行后的状态数据。 -// 返回值: 无。 -/////////////////////////////////////////////////////////////////////////////// -static void ShiftRows(unsigned char *pState, BOOL bInvert) -{ - // 注意:状态数据以列形式存放! - - unsigned char r; // row, 行 - unsigned char c; // column,列 - unsigned char temp; - unsigned char rowData[4]; - - for (r = 1; r < 4; r++) - { - // 备份一行数据 - for (c = 0; c < 4; c++) - { - rowData[c] = pState[r + 4*c]; - } - - temp = bInvert ? (4 - r) : r; - for (c = 0; c < 4; c++) - { - pState[r + 4*c] = rowData[(c + temp) % 4]; - } - } -} - -/////////////////////////////////////////////////////////////////////////////// -// 函数名: GfMultBy02 -// 描述: 在GF(28)域的 乘2 运算。 -// 输入参数: num -- 乘数。 -// 输出参数: 无。 -// 返回值: num乘以2的结果。 -/////////////////////////////////////////////////////////////////////////////// -static unsigned char GfMultBy02(unsigned char num) -{ - if ((num & 0x80) == 0) - { - num = num << 1; - } - else - { - num = (num << 1) ^ BPOLY; - } - - return num; -} - -/////////////////////////////////////////////////////////////////////////////// -// 函数名: MixColumns -// 描述: 混合状态各列数据。 -// 输入参数: pState -- 状态数据。 -// bInvert -- 是否反向混合(解密时使用)。 -// 输出参数: pState -- 混合列后的状态数据。 -// 返回值: 无。 -/////////////////////////////////////////////////////////////////////////////// -static void MixColumns(unsigned char *pState, BOOL bInvert) -{ - unsigned char i; - unsigned char temp; - unsigned char a0Pa2_M4; // 4(a0 + a2) - unsigned char a1Pa3_M4; // 4(a1 + a3) - unsigned char result[4]; - - for (i = 0; i < 4; i++, pState += 4) - { - // b0 = 2a0 + 3a1 + a2 + a3 - // = (a0 + a1 + a2 + a3) + 2(a0 + a1) + a0 - - temp = pState[0] ^ pState[1] ^ pState[2] ^ pState[3]; - result[0] = temp ^ pState[0] ^ GfMultBy02((unsigned char) (pState[0] ^ pState[1])); - result[1] = temp ^ pState[1] ^ GfMultBy02((unsigned char) (pState[1] ^ pState[2])); - result[2] = temp ^ pState[2] ^ GfMultBy02((unsigned char) (pState[2] ^ pState[3])); - result[3] = temp ^ pState[3] ^ GfMultBy02((unsigned char) (pState[3] ^ pState[0])); - - if (bInvert) - { - // b0' = 14a0 + 11a1 + 13a2 + 9a3 - // = (a0 + a1 + a2 + a3) + 2(a0 + a1) + a0 (这部分为b0) - // + 2(4(a0 + a2) + 4(a1 + a3)) - // + 4(a0 + a2) - - a0Pa2_M4 = GfMultBy02(GfMultBy02((unsigned char) (pState[0] ^ pState[2]))); - a1Pa3_M4 = GfMultBy02(GfMultBy02((unsigned char) (pState[1] ^ pState[3]))); - temp = GfMultBy02((unsigned char) (a0Pa2_M4 ^ a1Pa3_M4)); - result[0] ^= temp ^ a0Pa2_M4; - result[1] ^= temp ^ a1Pa3_M4; - result[2] ^= temp ^ a0Pa2_M4; - result[3] ^= temp ^ a1Pa3_M4; - } - - memcpy(pState, result, 4); - } -} - -/////////////////////////////////////////////////////////////////////////////// -// 函数名: BlockEncrypt -// 描述: 对单块数据加密。 -// 输入参数: pState -- 状态数据。 -// 输出参数: pState -- 加密后的状态数据。 -// 返回值: 无。 -/////////////////////////////////////////////////////////////////////////////// -static void BlockEncrypt(unsigned char *pState) -{ - unsigned char i; - - AddRoundKey(pState, g_roundKeyTable); - - for (i = 1; i <= Nr; i++) // i = [1, Nr] - { - SubBytes(pState, 4*Nb, 0); - ShiftRows(pState, 0); - - if (i != Nr) - { - MixColumns(pState, 0); - } - - AddRoundKey(pState, &g_roundKeyTable[4*Nb*i]); - } - -// 为了节省代码,合并到循化执行 -// SubBytes(pState, 4*Nb); -// ShiftRows(pState, 0); -// AddRoundKey(pState, &g_roundKeyTable[4*Nb*Nr]); -} - -/////////////////////////////////////////////////////////////////////////////// -// 函数名: BlockDecrypt -// 描述: 对单块数据解密。 -// 输入参数: pState -- 状态数据。 -// 输出参数: pState -- 解密后的状态数据。 -// 返回值: 无。 -/////////////////////////////////////////////////////////////////////////////// -static void BlockDecrypt(unsigned char *pState) -{ - unsigned char i; - - AddRoundKey(pState, &g_roundKeyTable[4*Nb*Nr]); - - for (i = Nr; i > 0; i--) // i = [Nr, 1] - { - ShiftRows(pState, 1); - SubBytes(pState, 4*Nb, 1); - AddRoundKey(pState, &g_roundKeyTable[4*Nb*(i-1)]); - - if (i != 1) - { - MixColumns(pState, 1); - } - } -} - - -/////////////////////////////////////////////////////////////////////////////// -// 函数名: AES_Init -// 描述: 初始化,在此执行扩展密钥操作。 -// 输入参数: pKey -- 原始密钥,其长度必须为 AES_KEY_LENGTH/8 字节。 -// 输出参数: 无。 -// 返回值: 无。 -/////////////////////////////////////////////////////////////////////////////// -void AES_Init(const void *pKey) -{ - // 扩展密钥 - unsigned char i; - unsigned char *pRoundKey; - unsigned char Rcon[4] = {0x01, 0x00, 0x00, 0x00}; - - memcpy(g_roundKeyTable, pKey, 4*Nk); - - pRoundKey = &g_roundKeyTable[4*Nk]; - - for (i = Nk; i < Nb*(Nr+1); pRoundKey += 4, i++) - { - memcpy(pRoundKey, pRoundKey - 4, 4); - - if (i % Nk == 0) - { - RotationWord(pRoundKey); - SubBytes(pRoundKey, 4, 0); - XorBytes(pRoundKey, Rcon, 4); - - Rcon[0] = GfMultBy02(Rcon[0]); - } - else if (Nk > 6 && i % Nk == Nb) - { - SubBytes(pRoundKey, 4, 0); - } - - XorBytes(pRoundKey, pRoundKey - 4*Nk, 4); - } -} - -unsigned int AES_get_length(unsigned int length) -{ - return ((length>>4) + 1)<<4; -} -////////////////////////////////////////////////////////////////////////// -// 函数名: AES_Encrypt -// 描述: 加密数据 -// 输入参数: pPlainText -- 明文,即需加密的数据,其长度为nDataLen字节。 -// nDataLen -- 数据长度,以字节为单位 -// pIV -- 初始化向量,如果使用ECB模式,可设为NULL。 -// 输出参数: pCipherText -- 密文,即由明文加密后的数据,可以与pPlainText相同。 -// 返回值: 无。 -////////////////////////////////////////////////////////////////////////// -unsigned int AES_Encrypt_PKCS7(const unsigned char *pPlainText, unsigned char *pCipherText, - unsigned int nDataLen, const unsigned char *pIV) -{ - unsigned int i; - //长度调整 - unsigned int length = nDataLen; - nDataLen = ((nDataLen>>4) + 1)<<4; - uint8_t p=(Nb<<2)-(length%(Nb<<2)); - if (pPlainText != pCipherText){memcpy(pCipherText,pPlainText,length);} - //填充 - unsigned char temp[16]; - memset(temp,p,16); - if(length 0 ; i--, pCipherText += 4*Nb) - { - #if AES_MODE == AES_MODE_CBC - XorBytes(pCipherText, pIV, 4*Nb); - #endif - BlockEncrypt(pCipherText); - pIV = pCipherText; - } - return(nDataLen); -} -////////////////////////////////////////////////////////////////////////// -// 函数名: AES_Decrypt -// 描述: 解密数据 -// 输入参数: pCipherText -- 密文,即需解密的数据,其长度为nDataLen字节。 -// nDataLen -- 数据长度,以字节为单位,必须为AES_KEY_LENGTH/8的整倍数。 -// pIV -- 初始化向量,如果使用ECB模式,可设为NULL。 -// 输出参数: pPlainText -- 明文,即由密文解密后的数据,可以与pCipherText相同。 -// 返回值: 无。 -////////////////////////////////////////////////////////////////////////// -void AES_Decrypt(unsigned char *pPlainText, const unsigned char *pCipherText, - unsigned int nDataLen, const unsigned char *pIV) -{ - unsigned int i; - - if (pPlainText != pCipherText) - { - memcpy(pPlainText, pCipherText, nDataLen); - } - - // 从最后一块数据开始解密,这样不用开辟空间来保存IV - pPlainText += nDataLen - 4*Nb; - for (i = nDataLen/(4*Nb); i > 0 ; i--, pPlainText -= 4*Nb) - { - BlockDecrypt(pPlainText); - - #if AES_MODE == AES_MODE_CBC - if (i == 1) - {// 最后一块数据 - XorBytes(pPlainText, pIV, 4*Nb); - } - else - { - XorBytes(pPlainText, pPlainText - 4*Nb, 4*Nb); - } - #endif - } -} - - -#endif ///WX_AIRSYNC_CFG - diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_sample_button/app_button.c b/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_sample_button/app_button.c deleted file mode 100644 index fc67351796..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/app_profiles/app_sample_button/app_button.c +++ /dev/null @@ -1,339 +0,0 @@ -// Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD -// -// 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 "prf_defs.h" - -#if (BUT_PROFILE_CFG) - - -#include -#include -#include -#include - - -#include "rom/gpio.h" -#include "app_button.h" -#include "bt_trace.h" -#include "freertos/FreeRTOS.h" -#include "freertos/timers.h" -#include "freertos/task.h" -#include "freertos/xtensa_api.h" -#include "thread.h" - -#include "allocator.h" -#include "button_pro.h" -#include "app_button_int.h" - -static const tBT_PRF_SYS_REG but_prf_reg = -{ - ble_but_prf_hdl_event, - ble_but_prf_disable -}; - - - -/******************************************************************************* -** -** Function ble_but_prf_hdl_event -** -** Description button profile main event handling function. -** -** -** Returns BOOLEAN -** -*******************************************************************************/ -BOOLEAN ble_but_prf_hdl_event(prf_hdr_evt_t *msg_data) -{ - LOG_ERROR("###################ble_but_prf_hdl_event#####################################\n"); - - UINT16 connid = 0; - switch(msg_data->event) - { - case BLE_BUT_CREATE_DB_REQ_EVT: - Button_CreateService(); - break; - case BLE_BUT_VAL_SEND_CFM_EVT: - break; - case BLE_BUT_SET_CHAR_VAL_REQ_EVT: - button_msg_notify(msg_data->len,msg_data->data); - break; - case BLE_BUT_ENABLE_REQ_EVT: - button_init(NULL); - break; - case BLE_BUT_DISABLE_IND_EVT: - button_disable(connid); - break; - case BLE_BUT_CHAR_WRITE_IND_EVT: - - break; - case BLE_BUT_ERROR_IND_EVT: - break; - default: - break; - } -} - - -/******************************************************************************* -** -** Function ble_but_prf_disable -** -** Description This function is called to disable the button profile modlue -** -** Parameters None. -** -** Returns None -** -*******************************************************************************/ -void ble_but_prf_disable(void) -{ - prf_hdr_evt_t *p_buf; - LOG_ERROR("ble_but_prf_disable\n"); - - if (bt_prf_sys_is_register(PRF_ID_BUT_LE) == FALSE) - { - APPL_TRACE_WARNING("button profile Module not enabled/already disabled\n"); - return; - } - - if ((p_buf = (prf_hdr_evt_t *) GKI_getbuf(sizeof(prf_hdr_evt_t))) != NULL) - { - p_buf->event = BLE_BUT_DISABLE_IND_EVT; - bta_sys_sendmsg(p_buf); - } - bta_sys_deregister(PRF_ID_BUT_LE); - -} - -void ble_but_prf_enable(void) -{ - bt_prf_sys_register(PRF_ID_BUT_LE,&but_prf_reg); -} - -void ble_but_create_svc(void) -{ - prf_hdr_evt_t *p_msg; - - LOG_ERROR("ble_but_create_svc\n"); //todo - if ((p_msg = (prf_hdr_evt_t *) GKI_getbuf(sizeof(prf_hdr_evt_t))) != NULL) - { - memset(p_msg, 0, sizeof(prf_hdr_evt_t)); - - p_msg->event = BLE_BUT_ENABLE_REQ_EVT; - - bt_prf_sys_sendmsg(p_msg); - } -} - - - - - - -#endif ///BUT_PROFILE_CFG - -#if 0 - -#define GPIO_INUM 8 -#define TABLE_ELEMENT_CNT(table) ((sizeof(table))/(sizeof(table[0]))); -app_key_env key_press; - -uint8_t gpio_test_table[]={0,2,4,5,12,13,14,15,16,17,18,19,20,21,22,23,25,26,27,33,34,35,36,37,38,39}; - -struct gpio_test_info{ - uint8_t *gpio_test_table; - uint8_t gpio_test_num; - void *time_s; -}; - -static void gpio_irq_init(uint64_t gpio_num); - -void gpio_check_register(enum_gpio_num_t gpio_num) -{ - if(gpio_num>=GPIO_PIN_COUNT||0==GPIO_PIN_MUX_REG[gpio_num]){ - ets_printf("io_num=%d not exits\n",gpio_num); - return; - } - LOG_ERROR("---------gpio_num %d reg----------\n",gpio_num); -LOG_ERROR("GPIO_IOMUX_%d=0x%08x\n",gpio_num,READ_PERI_REG(GPIO_PIN_MUX_REG[gpio_num])); - LOG_ERROR("GPIO_PIN%d_ADDR=0x%08x\n",gpio_num,READ_PERI_REG(GPIO_PIN_ADDR(gpio_num))); - LOG_ERROR("GPIO_OUT_REG=0x%08x\n",READ_PERI_REG(GPIO_OUT_REG)); - LOG_ERROR("GPIO_OUT1_REG=0x%08x\n",READ_PERI_REG(GPIO_OUT1_REG)); - LOG_ERROR("GPIO_ENABLE_REG=0x%08x\n",READ_PERI_REG(GPIO_ENABLE_REG)); - LOG_ERROR("GPIO_ENABLE1_REG=0x%08x\n",READ_PERI_REG(GPIO_ENABLE1_REG)); - LOG_ERROR("GPIO_IN_REG=0x%08x\n",READ_PERI_REG(GPIO_IN_REG)); - LOG_ERROR("GPIO_IN1_REG=0x%08x\n",READ_PERI_REG(GPIO_IN1_REG)); - LOG_ERROR("GPIO_STATUS_REG=0x%08x\n",READ_PERI_REG(GPIO_STATUS_REG)); - LOG_ERROR("GPIO_STATUS1_REG=0x%08x\n",READ_PERI_REG(GPIO_STATUS1_REG)); -} - -void t1_callback(void *arg) -{ - static uint8_t level=0; - static uint8_t cnt=0; - uint8_t err_flag=0; - struct gpio_test_info *gpio_test=(struct gpio_test_info*)(arg); - uint8_t i=0; - while(1){ - gpio_check_register(35); - vTaskDelay(2*1000); - /* - level=~level; - LOG_ERROR("Test cnt %u, level %u\n",cnt+1,level&0x01); - for(i=0;igpio_test_num;i++){ - gpio_set_output_level(gpio_test->gpio_test_table[i],level&0x01); - if(gpio_get_input_level(gpio_test->gpio_test_table[i])!=(level&0x01)) - { - err_flag=1; - LOG_ERROR("[ERR] GPIO%u set_level %u get_level %u\n",gpio_test->gpio_test_table[i],level&0x01,gpio_get_input_level(gpio_test->gpio_test_table[i])); - } - else{ - LOG_ERROR("GPIO%u OK\n",gpio_test->gpio_test_table[i]); - } - } - cnt++; - if(err_flag==0){ - LOG_ERROR("cnt %u test ok\n",cnt); - } - err_flag=0; - if(cnt>=10){ - LOG_ERROR("Gpio input and output test end\n"); - vTaskDelete(NULL);*/ - // } - - //vTaskDelay(2*1000); - - } -} - - void app_button_init(void) -{ - uint64_t gpio_num = GPIO_Pin_27|GPIO_Pin_35|GPIO_Pin_34|GPIO_Pin_36|GPIO_Pin_39; - // Reset environment - memset(&key_press, 0, sizeof(key_press)); - gpio_irq_init(gpio_num); - static struct gpio_test_info gpio_test_infor; - LOG_ERROR("app_button_init."); -/* TimerHandle_t t1=NULL; - t1=xTimerCreate("t1_time",(1000/portTICK_PERIOD_MS),pdTRUE,&gpio_test_infor,t1_callback); - do{ - gpio_test_infor.gpio_test_table=gpio_test_table; - gpio_test_infor.gpio_test_num=TABLE_ELEMENT_CNT(gpio_test_table); - gpio_test_infor.time_s=t1; - }while(0);*/ - - // xTaskCreate(t1_callback,"t1_callback",1024,&gpio_test_infor,30,NULL); - LOG_ERROR("gpio_input_output_demo\n"); - return; -} - -static void gpio_irq_init(uint64_t gpio_num) -{ - gpio_config_t gpio_config_prot; - memset(&gpio_config_prot,0,sizeof(gpio_config_prot)); - gpio_config_prot.GPIO_Pin= gpio_num; - - gpio_config_prot.GPIO_Mode=GPIO_Mode_Input; - gpio_config_prot.GPIO_IntrType=GPIO_PIN_INTR_NEGEDGE; - gpio_config_prot.GPIO_Pullup=GPIO_PullUp_EN; - gpio_config_prot.GPIO_Pulldown=GPIO_PullDown_DIS; - gpio_config(&gpio_config_prot); - //Register gpio handler - gpio_intr_handler_register(GPIO_isr_callback,NULL); - //Enable gpio intr - xt_ints_on(1<par = Button_Voice; - break; - case GPIO_NUM_34: - evt->par = Button_OK; - break; - case GPIO_NUM_39: - evt->par = Button_Down; - break; - case GPIO_NUM_36: - evt->par = Button_Up; - break; - default: - evt->par = Button_Back; - break; - } - evt->sig = BUTTON_PRESS_EVT; - if(xQueueSend(xBtaApp1Queue,&evt,10/portTICK_RATE_MS)!=pdTRUE){ - LOG_ERROR("btdm_post_failed\n"); - } - //enable the interrupt - xt_ints_on(1< -#include -#include -#include - -#include "bta_api.h" -#include "bta_gatt_api.h" -#include "controller.h" - -#include "bt_trace.h" -#include "btm_api.h" -#include "bt_types.h" -#include "gattc_profile.h" - -#define BT_BD_ADDR_STR "%02x:%02x:%02x:%02x:%02x:%02x" -#define BT_BD_ADDR_HEX(addr) addr[0], addr[1], addr[2], addr[3], addr[4], addr[5] - -tBTA_GATTC_IF client_if; -BD_ADDR obj_addr; -static unsigned char BASE_UUID[16] = { - 0xfb, 0x34, 0x9b, 0x5f, 0x80, 0x00, 0x00, 0x80, - 0x00, 0x10, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 - }; - -int uuidType(unsigned char* p_uuid) -{ - int i = 0; - int match = 0; - int all_zero = 1; - - for(i = 0; i != 16; ++i) - { - if (i == 12 || i == 13) - continue; - - if (p_uuid[i] == BASE_UUID[i]) - ++match; - - if (p_uuid[i] != 0) - all_zero = 0; - } - if (all_zero) - return 0; - if (match == 12) - return LEN_UUID_32; - if (match == 14) - return LEN_UUID_16; - return LEN_UUID_128; -} - -static void btif_to_bta_uuid(tBT_UUID *p_dest, bt_uuid_t *p_src) -{ - char *p_byte = (char*)p_src; - - int i = 0; - - p_dest->len = uuidType(p_src->uu); - - switch (p_dest->len) - { - case LEN_UUID_16: - p_dest->uu.uuid16 = (p_src->uu[13] << 8) + p_src->uu[12]; - break; - - case LEN_UUID_32: - p_dest->uu.uuid32 = (p_src->uu[13] << 8) + p_src->uu[12]; - p_dest->uu.uuid32 += (p_src->uu[15] << 24) + (p_src->uu[14] << 16); - break; - - case LEN_UUID_128: - for(i = 0; i != 16; ++i) - p_dest->uu.uuid128[i] = p_byte[i]; - break; - - default: - LOG_ERROR("%s: Unknown UUID length %d!", __FUNCTION__, p_dest->len); - break; - } -} -/* -uint16_t get_uuid16(tBT_UUID* p_uuid) -{ - if(p_uuid->len == LEN_UUID_16) - { - return p_uuid->uu.uuid16; - } - else if(p_uuid->len == LEN_UUID_128) - { - UINT16 u16; - UINT8 *p = &p_uuid->uu.uuid128[LEN_UUID_128 - 4]; - STREAM_TO_UINT16(u16, p); - return u16; - } - else - { - return (UINT16)p_uuid->uu.uuid32; - } -} - -//fill a GATT ID structure -void bta_le_fill_16bits_gatt_id(UINT8 inst_id, UINT16 uuid, tBTA_GATT_ID* p_output) -{ - p_output->inst_id = inst_id; - p_output->uuid.len = LEN_UUID_16; - p_output->uuid.uu.uuid16 = uuid; -} - -//fill a service ID structure with a 16 bits service UUID -void bta_le_fill_16bits_srvc_id(bool is_pri, UINT8 inst_id, UINT16 srvc_uuid, tBTA_GATT_SRVC_ID* p_output) -{ - memset((void *)p_output, 0, sizeof(tBTA_GATT_SRVC_ID)); - p_output->is_primary = is_pri; - bta_le_fill_16bits_gatt_id(inst_id, srvc_uuid, &p_output->id); -} - -//fill a char ID structure with a 16 bits char UUID -void bta_le_fill_16bits_char_id(UINT8 inst_id, UINT16 char_uuid, tBTA_GATT_ID* p_output) -{ - memset((void *)p_output, 0, sizeof(tBTA_GATT_ID)); - bta_le_fill_16bits_gatt_id(inst_id, char_uuid, p_output); -} -*/ -/*get remote name*/ -static bool check_remote_name(tBTA_DM_INQ_RES* result, uint8_t* rmt_name, uint8_t* rmt_name_len) -{ - uint8_t *p_rmt_name = NULL; - uint8_t remote_name_len = 0; - - if (result->p_eir) { - p_rmt_name = BTM_CheckEirData(result->p_eir, - BTM_EIR_COMPLETE_LOCAL_NAME_TYPE, - &remote_name_len); - if (!p_rmt_name) - p_rmt_name = BTM_CheckEirData(result->p_eir, - BTM_EIR_SHORTENED_LOCAL_NAME_TYPE, - &remote_name_len); - if (p_rmt_name) { - if (remote_name_len > BD_NAME_LEN) - remote_name_len = BD_NAME_LEN; - if (rmt_name && rmt_name_len) { - memcpy(rmt_name, p_rmt_name, remote_name_len); - *(rmt_name + remote_name_len) = 0; - *rmt_name_len = remote_name_len; - } - return true; - } - } - return false; -} - -/************************************************************************************ -* * Function bta_scan_recult_callback -* * -* * Description scan result.it will be called when device scaned a peer device -* * -* * Return NULL -**************************************************************************************/ -static void bta_scan_result_callback(tBTA_DM_SEARCH_EVT event, tBTA_DM_SEARCH* p_data) -{ - uint8_t len; - BD_ADDR bd_addr; - char dev_name[32]; - tBTA_GATT_TRANSPORT transport = BTA_GATT_TRANSPORT_LE; - //char obj_name[] = "Find Me"; - char obj_name[] = "SimpleBLEClient"; - uint8_t dev_name_len; - - switch (event) - { - case BTA_DM_INQ_RES_EVT: - { - LOG_ERROR("scan result: event=%d, "BT_BD_ADDR_STR", device_type=%d\n", - event, BT_BD_ADDR_HEX(p_data->inq_res.bd_addr), p_data->inq_res.device_type); - - bdcpy(bd_addr, p_data->inq_res.bd_addr); - if (p_data->inq_res.p_eir) - { - if (BTM_CheckEirData(p_data->inq_res.p_eir, BTM_EIR_COMPLETE_LOCAL_NAME_TYPE, &len)) - { - p_data->inq_res.remt_name_not_required = TRUE; - } - } - - if(check_remote_name(&(p_data->inq_res), dev_name, &dev_name_len)) - { - LOG_ERROR("scan device name len=%d, name = %s\n", dev_name_len, dev_name); - } - - if(strcmp(dev_name, obj_name) == 0) - { - bdcpy(obj_addr, bd_addr); - LOG_ERROR("find the device, obj_addr="BT_BD_ADDR_STR"\n", BT_BD_ADDR_HEX(obj_addr)); -// BTA_GATTC_Open(client_if, obj_addr, true, transport); - } - } - break; - - case BTA_DM_INQ_CMPL_EVT: - { - LOG_ERROR("%s-BLE observe complete. Num Resp %d\n", __FUNCTION__, p_data->inq_cmpl.num_resps); - - LOG_ERROR("connect the device "BT_BD_ADDR_STR", client_if=%d\n", - BT_BD_ADDR_HEX(obj_addr), client_if); - - /* scan complete, start connect*/ - BTA_GATTC_Open(client_if, obj_addr, true, transport); - } - break; - - default: - LOG_ERROR("%s : unknown event 0x%x", __FUNCTION__, event); - } -} - -/************************************************************************************ -* * Function bta_scan_param_setup_cback -* * -* * Description set scan param callback.it will be called after setting scan parameter -* * -* * Return NULL -**************************************************************************************/ -static void bta_scan_param_setup_cback(tGATT_IF c_client_if, tBTM_STATUS status) -{ - client_if = c_client_if; - LOG_ERROR("\nset scan params complete: status=%d, client_if=%d\n", status, client_if); - /*start scan*/ - BTA_DmBleObserve(true, 8, bta_scan_result_callback); -} - -/************************************************************************************ -* * Function bta_gattc_callback -* * -* * Description app register callback -* * -* * Return NULL -**************************************************************************************/ -static void bta_gattc_callback(tBTA_GATTC_EVT event, tBTA_GATTC* p_data) -{ - switch (event) - { - case BTA_GATTC_REG_EVT: - { - tBTA_GATT_STATUS status = p_data->reg_oper.status; - client_if = p_data->reg_oper.client_if; - LOG_ERROR("%s:register complete: event=%d, status=%d, client_if=%d\n", __FUNCTION__, event, status, client_if); - UINT8 scan_interval = 0x50; - UINT8 scan_window = 0x30; - tBLE_SCAN_MODE scan_mode = BTM_BLE_SCAN_MODE_ACTI; - - bac_register(); - /*register complete,set scan parameter*/ - BTA_DmSetBleScanParams(client_if, scan_interval, scan_window, scan_mode, - bta_scan_param_setup_cback); - - } - break; - - /*connect callback*/ - case BTA_GATTC_OPEN_EVT: - { - - LOG_ERROR("\n%s:device is connected "BT_BD_ADDR_STR", client_if=%d, status=%d, connect_id=%d\n", - __FUNCTION__, BT_BD_ADDR_HEX(p_data->open.remote_bda), p_data->open.client_if, - p_data->open.status, p_data->open.conn_id); - /*return whether the remote device is currently connected*/ - int is_connected = BTA_DmGetConnectionState(p_data->open.remote_bda); - LOG_ERROR("is_connected=%d\n",is_connected); - /*get the energy info of the controller*/ - - /*read battery level*/ - int conn_id = p_data->open.conn_id; - - /*discover service*/ - // BTA_GATTC_ServiceSearchRequest(conn_id, NULL); - - } - break; -/* - case BTA_GATTC_SEARCH_RES_EVT: - { - // tBTA_GATTC_SRVC_RES service_result; - LOG_ERROR("find the service,uuid=0x%x, is_primary=%d\n", - get_uuid16(&p_data->srvc_res.service_uuid.id.uuid), - p_data->srvc_res.service_uuid.is_primary); - } - break; - - case BTA_GATTC_SEARCH_CMPL_EVT: - { - LOG_ERROR("search service complete, conn_id=%d,status=%d\n", p_data->search_cmpl.conn_id, - p_data->search_cmpl.status); - - //get first characteristic of battey service - LOG_ERROR("get first characteristic of battery service\n"); - tBTA_GATT_STATUS status; - tBTA_GATT_SRVC_ID battery_srvc_id; - tBTA_GATTC_CHAR_ID out_char_id; - tGATT_CHAR_PROP out_char_prop; - bta_le_fill_16bits_srvc_id(TRUE, 0, UUID_SERVCLASS_BATTERY, &battery_srvc_id); - status = BTA_GATTC_GetFirstChar(p_data->search_cmpl.conn_id, &battery_srvc_id, NULL, - &out_char_id, &out_char_prop); - if(status == 0) - { - LOG_ERROR("the first char:srvc_id=0x%x,char_id=0x%x, property = %d\n", - get_uuid16(&out_char_id.srvc_id.id.uuid), get_uuid16(&out_char_id.char_id.uuid), - out_char_prop); - //read battery level - tBTA_GATTC_CHAR_ID battery_char_id; - bta_le_fill_16bits_srvc_id(TRUE, 0, UUID_SERVCLASS_BATTERY, &battery_char_id.srvc_id); - bta_le_fill_16bits_char_id(0, GATT_UUID_BATTERY_LEVEL, &battery_char_id.char_id); - - BTA_GATTC_ReadCharacteristic(p_data->search_cmpl.conn_id, &battery_char_id, - BTA_GATT_AUTH_REQ_NONE); - } - } - break; - - case BTA_GATTC_READ_CHAR_EVT: - { - - LOG_ERROR("\nread characteristic:connect_id=%d, status=%d\n", - p_data->read.conn_id, p_data->read.status); - LOG_ERROR("srvc_id=0x%x,char_id=0x%x,descr_type=0x%x\n", - get_uuid16(&p_data->read.srvc_id.id.uuid), - get_uuid16(&p_data->read.char_id.uuid), - get_uuid16(&p_data->read.descr_type.uuid)); - if(get_uuid16(&p_data->read.descr_type.uuid) != GATT_UUID_CHAR_AGG_FORMAT - && p_data->read.p_value->unformat.len > 0 - && p_data->read.p_value->unformat.p_value != NULL) - { - LOG_ERROR("read the value: len=%d, value=%d\n", p_data->read.p_value->unformat.len, - *(p_data->read.p_value->unformat.p_value)); - } - } - break; -*/ - default: - LOG_ERROR("%s:unknown event: %d\n", __FUNCTION__, event); - } - -} - -/************************************************************************************ -* * Function ble_client_appRegister -* * -* * Description app register function -* * -* * Return NULL -**************************************************************************************/ -void ble_client_appRegister(void) -{ - - bt_uuid_t uuid; - tBT_UUID t_uuid; - memcpy(&uuid, BASE_UUID, sizeof(bt_uuid_t)); - btif_to_bta_uuid(&t_uuid, &uuid); - - LOG_ERROR("register application\n"); - BTA_GATTC_AppRegister(&t_uuid, bta_gattc_callback); - - /*battery service register*/ -// bac_register(); - -} - -void gattc_client_test(void) -{ - BTM_SetTraceLevel(BT_TRACE_LEVEL_DEBUG); - - ble_client_appRegister(); -} diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/app_project/SampleServerProject.c b/examples/06_bluedroid_demos/components/bluedroid_demos/app_project/SampleServerProject.c deleted file mode 100644 index e87f337837..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/app_project/SampleServerProject.c +++ /dev/null @@ -1,381 +0,0 @@ -// Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD -// -// 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. - -/*************************************************************** -* -* This file is for gatt server device. It instantiates BATTERY -* sevice. It can be scanned and connected by central device, -* and the client will get the BAS value. It calls the API bta -* layer provides. -* -****************************************************************/ - -#include -#include -#include -#include - -#include "prf_defs.h" - -#include "bta_api.h" -#include "bta_gatt_api.h" -#include "controller.h" - -#include "gatt_int.h" -#include "bt_trace.h" -#include "btm_api.h" -#include "bt_types.h" -#include "dis_api.h" -#include "bt_app_common.h" - -//#include "prf_defs.h" - -#include "wx_airsync_prf.h" - -#include "button_pro.h" -#include "app_button.h" -#include "hid_le_prf.h" - -#include "esp_gatt_api.h" - -// - -#include "hcimsgs.h" -#include "esp_bt_defs.h" - - -#define BT_BD_ADDR_STR "%02x:%02x:%02x:%02x:%02x:%02x" -#define BT_BD_ADDR_HEX(addr) addr[0], addr[1], addr[2], addr[3], addr[4], addr[5] -tBTA_GATTS_IF server_if; - -static unsigned char DIS_UUID[16] = { - 0xfb, 0x34, 0x9b, 0x5f, 0x80, 0x00, 0x00, 0x80, - 0x00, 0x10, 0x00, 0x00, 0x0a, 0x18, 0x00, 0x00 - }; -static unsigned char BASE_UUID[16] = { - 0xfb, 0x34, 0x9b, 0x5f, 0x80, 0x00, 0x00, 0x80, - 0x00, 0x10, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 - }; - -UINT16 ijiazu_uuid = 0xffff; -UINT16 wechat_uuid = 0xfee7; -tBTA_BLE_SERVICE ijiazu_service = { - 0x01, //only one service in the ijiazu button profile - false, - &ijiazu_uuid - }; /* 16 bits services */ - -tBTA_BLE_SERVICE wechat_service = { - 0x01, //only one service in the ijiazu button profile - false, - &wechat_uuid - }; /* 16 bits services */ - - - -UINT8 beacon_manu[25] = {0x4c, 0x00,0x02, 0x15, 0xfd, 0xa5, 0x06, 0x93, 0xa4, 0xe2, - 0x4f, 0xb1, 0xaf, 0xcf, 0xc6, 0xeb, 0x07, 0x64, 0x78, 0x25, - 0x27, 0x32, 0xe6, 0x08, 0xc5}; - -//UINT8 ijiazu_manu[17] = {0xff,0x20,0x14,0x07,0x22,0x00,0x02,0x5B,0x00,0x33,0x49,0x31,0x30,0x4a,0x30,0x30,0x31}; -UINT8 ijiazu_manu[17] = {0xff,0x20,0x14,0x07,0x22,0x00,0x02,0x5B,0x00,0x33,0x49,0x31,0x30,0x4a,0x30,0x30,0x31}; -UINT8 wechat_manu[] = {0x00,0x00,0x18,0xfe,0x34,0x6a,0x86,0x2e}; -tBTA_BLE_MANU p_ijiazu_manu = {sizeof(ijiazu_manu),ijiazu_manu}; /* manufacturer data */ -tBTA_BLE_MANU p_wechat_manu = {sizeof(wechat_manu),wechat_manu}; - - -tBLE_BD_ADDR p_peer_bda = { - .type = API_PUBLIC_ADDR, - .bda = {0} -}; - -esp_ble_adv_params_all_t adv_params = -{ - .adv_int_min = BTM_BLE_ADV_INT_MIN + 0x100, - .adv_int_max = BTM_BLE_ADV_INT_MIN + 0x100, - .adv_type = API_NON_DISCOVERABLE, - .addr_type_own = API_PUBLIC_ADDR, - .channel_map = ESP_BLE_ADV_CHNL_MAP, - .adv_filter_policy = ADV_ALLOW_SCAN_ANY_CON_ANY, - .p_dir_bda = &p_peer_bda -}; - - - - - -BD_ADDR rand_ijiazu_addr = {0x00,0x02,0x5B,0x00,0x32,0x55}; - -esp_ble_adv_data_cfg_t ijiazu_adv_data[ADV_SCAN_IDX_MAX] = -{ - [BLE_ADV_DATA_IDX] = { - .adv_name = "Espressif_007", - { - {0,0}, - NULL, //no manufature data to be setting in the ijiazu adervetisiing datas - &ijiazu_service, - NULL, //the 128 bits service uuid set to null(not used) - NULL, //the 32 bits Service UUID set to null(not used) - NULL, //16 bits services Solicitation UUIDs set to null(not used) - NULL, //List of 32 bit Service Solicitation UUIDs set to null(not used) - NULL, //List of 128 bit Service Solicitation UUIDs set to null(not used) - NULL, //proprietary data set to null(not used) - NULL, //service data set not null(no service data to be sent) - 0x0200, //device type : generic display - BTA_DM_GENERAL_DISC, // General discoverable. - 0xFE //the tx power value,defult value is 0 - }, - - }, - [BLE_SCAN_RSP_DATA_IDX] = { - .adv_name = NULL, - { - {0,0}, - &p_ijiazu_manu, - NULL, - NULL, //the 128 bits service uuid set to null(not used) - NULL, //the 32 bits Service UUID set to null(not used) - NULL, //16 bits services Solicitation UUIDs set to null(not used) - NULL, //List of 32 bit Service Solicitation UUIDs set to null(not used) - NULL, //List of 128 bit Service Solicitation UUIDs set to null(not used) - NULL, //proprietary data set to null(not used) - NULL, //service data set not null(no service data to be sent) - 0x0000, //device type : generic display - 0x00, // General discoverable. - 0x00}, //the tx power value,defult value is 0 - - } -}; - -esp_ble_adv_data_cfg_t wechat_adv_data[ADV_SCAN_IDX_MAX] = -{ - [BLE_ADV_DATA_IDX] = { - .adv_name = NULL, - { - {0,0}, - NULL, //no manufature data to be setting in the ijiazu adervetisiing datas - &wechat_service, - NULL, //the 128 bits service uuid set to null(not used) - NULL, //the 32 bits Service UUID set to null(not used) - NULL, //16 bits services Solicitation UUIDs set to null(not used) - NULL, //List of 32 bit Service Solicitation UUIDs set to null(not used) - NULL, //List of 128 bit Service Solicitation UUIDs set to null(not used) - NULL, //proprietary data set to null(not used) - NULL, //service data set not null(no service data to be sent) - 0x0200, //device type : generic display - BTA_DM_GENERAL_DISC, // General discoverable. - 0xFE //the tx power value,defult value is 0 - }, - - }, - [BLE_SCAN_RSP_DATA_IDX] = { - .adv_name = "wechat_demo", - { - {0,0}, - &p_wechat_manu, - NULL, - NULL, //the 128 bits service uuid set to null(not used) - NULL, //the 32 bits Service UUID set to null(not used) - NULL, //16 bits services Solicitation UUIDs set to null(not used) - NULL, //List of 32 bit Service Solicitation UUIDs set to null(not used) - NULL, //List of 128 bit Service Solicitation UUIDs set to null(not used) - NULL, //proprietary data set to null(not used) - NULL, //service data set not null(no service data to be sent) - 0x0000, //device type : generic display - 0x00, // General discoverable. - 0x00}, //the tx power value,defult value is 0 - - } -}; - -#if (BUT_PROFILE_CFG) -static void SimpleDataCallBack(uint8_t app_id, uint8_t event, uint16_t len, uint8_t *p_data); -#endif - -int uuidType(unsigned char* p_uuid) -{ - int i = 0; - int match = 0; - int all_zero = 1; - - for(i = 0; i != 16; ++i) - { - if (i == 12 || i == 13) - continue; - - if (p_uuid[i] == BASE_UUID[i]) - ++match; - - if (p_uuid[i] != 0) - all_zero = 0; - } - if (all_zero) - return 0; - if (match == 12) - return LEN_UUID_32; - if (match == 14) - return LEN_UUID_16; - return LEN_UUID_128; -} - -/*16-bits uuid to the structure of holding any type of UUID*/ -void btif_to_bta_uuid(tBT_UUID *p_dest, bt_uuid_t *p_src) -{ - char *p_byte = (char*)p_src; - - int i = 0; - - p_dest->len = uuidType(p_src->uu); - - switch (p_dest->len) - { - case LEN_UUID_16: - p_dest->uu.uuid16 = (p_src->uu[13] << 8) + p_src->uu[12]; - break; - - case LEN_UUID_32: - p_dest->uu.uuid32 = (p_src->uu[13] << 8) + p_src->uu[12]; - p_dest->uu.uuid32 += (p_src->uu[15] << 24) + (p_src->uu[14] << 16); - break; - - case LEN_UUID_128: - for(i = 0; i != 16; ++i) - p_dest->uu.uuid128[i] = p_byte[i]; - break; - - default: - LOG_ERROR("%s: Unknown UUID length %d!", __FUNCTION__, p_dest->len); - break; - } -} - - -/*set advertising config callback*/ -static void bta_gatts_set_adv_data_cback(tBTA_STATUS call_status) -{ - LOG_ERROR("set advertising config:status=%d\n", call_status); - /*dis init*/ -/* tDIS_ATTR_MASK dis_attr_mask; - dis_attr_mask = DIS_ATTR_SYS_ID_BIT | DIS_ATTR_MODEL_NUM_BIT | DIS_ATTR_SERIAL_NUM_BIT | - DIS_ATTR_FW_NUM_BIT | DIS_ATTR_HW_NUM_BIT | DIS_ATTR_SW_NUM_BIT | DIS_ATTR_MANU_NAME_BIT | - DIS_ATTR_IEEE_DATA_BIT | DIS_ATTR_PNP_ID_BIT; - DIS_SrInit(dis_attr_mask); -*/ - //ble_but_create_svc(); - /*instantiate a battery service*/ - bas_register(); - /*instantiate the driver for button profile*/ - //app_button_init(); -#if (BUT_PROFILE_CFG) - /*instantiate a button service*/ - //button_init(SimpleDataCallBack); -#endif ///BUT_PROFILE_CFG - -#if (HIDD_LE_PROFILE_CFG) - /*instantiate a hid device service*/ - hidd_le_init(); -#endif ///HIDD_LE_PROFILE_CFG - -#if (WX_AIRSYNC_CFG) - AirSync_Init(NULL); -#endif ///WX_AIRSYNC_CFG - esp_ble_start_advertising(&adv_params); - //API_Ble_AppStartAdvertising(&adv_params); - /*start advetising*/ -// BTA_GATTS_Listen(server_if, true, NULL); -} - -/*register callback*/ -void bta_gatts_callback(tBTA_GATTS_EVT event, tBTA_GATTS* p_data) -{ - switch (event) - { - case BTA_GATTS_REG_EVT: - { - tBTA_GATT_STATUS status = p_data->reg_oper.status; - server_if = p_data->reg_oper.server_if; - LOG_ERROR("register complete: event=%d, status=%d, server_if=%d\n", - event, status, server_if); - - LOG_ERROR("set advertising parameters\n"); - //set the advertising data to the btm layer - esp_ble_config_adv_data(&wechat_adv_data[BLE_ADV_DATA_IDX], - bta_gatts_set_adv_data_cback); - - } - break; - /*connect callback*/ - case BTA_GATTS_CONNECT_EVT: - { - ///Stop the advertising when the connection is establish - esp_ble_stop_advertising(); - LOG_ERROR("\ndevice is connected "BT_BD_ADDR_STR", server_if=%d,reason=0x%x,connect_id=%d\n", - BT_BD_ADDR_HEX(p_data->conn.remote_bda), p_data->conn.server_if, - p_data->conn.reason, p_data->conn.conn_id); - /*return whether the remote device is currently connected*/ - int is_connected = BTA_DmGetConnectionState(p_data->conn.remote_bda); - LOG_ERROR("is_connected=%d\n",is_connected); - } - break; - - case BTA_GATTS_DISCONNECT_EVT: - ///start the advertising again when lose the connection - esp_ble_start_advertising(&adv_params); - break; - default: - LOG_ERROR("unsettled event: %d\n", event); - } - -} - -#if (BUT_PROFILE_CFG) -static void SimpleDataCallBack(uint8_t app_id, uint8_t event, uint16_t len, uint8_t *p_data) -{ - LOG_ERROR("the event value is:%x\n",event); - switch(event) - { - case RECEIVE_NET_PASSWD_EVT: - LOG_ERROR("Received the network passwork"); - break; - case RECEIVE_NET_SSD_EVT: - LOG_ERROR("Received the network SSID"); - break; - default: - break; - } -} -#endif ///BUT_PROFILE_CFG - - -static void ble_server_appRegister(void) -{ - bt_uuid_t uuid; - tBT_UUID t_uuid; - memcpy(&uuid, BASE_UUID, sizeof(bt_uuid_t)); - //memcpy(&uuid, DIS_UUID, sizeof(bt_uuid_t)); - btif_to_bta_uuid(&t_uuid, &uuid); - - LOG_ERROR("register gatts application\n"); - esp_ble_gatts_app_register(&t_uuid, bta_gatts_callback); - - bt_prf_sys_init(); - ble_but_prf_enable(); -} - -void gatts_server_test(void) -{ - BTM_SetTraceLevel(BT_TRACE_LEVEL_DEBUG); - - ble_server_appRegister(); -} diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/component.mk b/examples/06_bluedroid_demos/components/bluedroid_demos/component.mk deleted file mode 100644 index d8ee3a878b..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/component.mk +++ /dev/null @@ -1,22 +0,0 @@ -# -# Main Makefile. This is basically the same as a component makefile. -# -# This Makefile should, at the very least, just include $(SDK_PATH)/make/component_common.mk. By default, -# this will take the sources in the src/ directory, compile them and link them into -# lib(subdirectory_name).a in the build directory. This behaviour is entirely configurable, -# please read the ESP-IDF documents if you need to do this. -# - -COMPONENT_SRCDIRS := \ - app_core \ - app_client_profiles/battery_c \ - app_client_profiles \ - app_profiles/app_sample_button \ - app_profiles/app_WX_airsync \ - app_profiles \ - app_project - -CFLAGS += -Wno-error=unused-label -Wno-error=return-type -Wno-error=missing-braces -Wno-error=pointer-sign -Wno-error=parentheses -I./include - - -include $(IDF_PATH)/make/component_common.mk diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/include/app_airsync_md5.h b/examples/06_bluedroid_demos/components/bluedroid_demos/include/app_airsync_md5.h deleted file mode 100644 index 6a1e709144..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/include/app_airsync_md5.h +++ /dev/null @@ -1,39 +0,0 @@ -#ifndef __APP_AIRSYNC_MD5__ -#define __APP_AIRSYNC_MD5__ - -#include "prf_defs.h" -#if (WX_AIRSYNC_CFG) - - -#include -#include -#include -#include - -#define SINGLE_ONE_BIT 0x80 -#define BLOCK_SIZE 512 -#define MOD_SIZE 448 -#define APP_SIZE 64 -#define BITS 8 - -// MD5 Chaining Variable -#define A 0x67452301UL -#define B 0xEFCDAB89UL -#define C 0x98BADCFEUL -#define D 0x10325476UL - -typedef struct -{ - char *str; - uint32_t len; -}MD5String; - - -int32_t wechat_md5 ( char *argv, uint8_t *md5_32); - - -#endif ///WX_AIRSYNC_CFG - -#endif /// __APP_AIRSYNC_MD5__ - - diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/include/app_airsync_prf.h b/examples/06_bluedroid_demos/components/bluedroid_demos/include/app_airsync_prf.h deleted file mode 100644 index 39d1913ddd..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/include/app_airsync_prf.h +++ /dev/null @@ -1,35 +0,0 @@ -#ifndef _APP_AIRSYNC_PRF_H__ -#define _APP_AIRSYNC_PRF_H__ - -#include "prf_defs.h" -#if (WX_AIRSYNC_CFG) - - -#include "app_wechat_util.h" -#include -#include - -#define MAGIC_NUMBER 0xFE - -/** - **************************************************************************************** - * @brief Create Wechat Database - * - **************************************************************************************** - */ -void app_wechat_create_db(void); - -void app_wechat_SetDatahandler(data_handler* pHandler); -int ble_wechat_indicate_data(uint8_t *data, int len); -int ble_wechat_indicate_data_chunk(void); -void ble_wechat_process_received_data(uint8_t* pData, uint32_t length); -data_handler* app_wechat_datahandler(void); -bool ble_wechat_is_last_data_sent_out(void); - - -#endif ///WX_AIRSYNC_CFG - -#endif ///_APP_AIRSYNC_PRF_H__ - - - diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/include/app_button.h b/examples/06_bluedroid_demos/components/bluedroid_demos/include/app_button.h deleted file mode 100644 index dfebee0c3a..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/include/app_button.h +++ /dev/null @@ -1,51 +0,0 @@ - /* - * DEFINES - **************************************************************************************** - */ -#define BUTTON_HEAD (0x01) -#define BUTTON_PRESS_EVT (0x10) - -//the key value enum -enum -{ - Button_Up = 0x01, - Button_Voice = 0x02, - Button_OK = 0x04, - Button_Down = 0x08, - Button_Back = 0x10, -}; - - -typedef struct { - uint8_t key_val; //button val - uint8_t head; //the head of the frame -}key_frame; - - -typedef struct -{ - bool button_press; - key_frame key_msg; -}app_key_env; - - - -extern app_key_env key_press; - -/* - * FUNCTIONS DECLARATION - **************************************************************************************** - */ - - void app_button_init(void); - - void GPIO_isr_callback(void* arg); - - uint8_t check_sum(uint8_t *check_array,uint8_t len); - - void ble_but_prf_enable(void); - - void ble_but_create_svc(void); - - - diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/include/app_button_int.h b/examples/06_bluedroid_demos/components/bluedroid_demos/include/app_button_int.h deleted file mode 100644 index 616497bd99..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/include/app_button_int.h +++ /dev/null @@ -1,116 +0,0 @@ -#include "prf_defs.h" -#include "bt_prf_sys.h" -#include "bt_types.h" - -#if (BUT_PROFILE_CFG) - -/// Messages for Device Information Service Server -enum -{ - ///Add a BUTTON instance into the database - BLE_BUT_CREATE_DB_REQ_EVT = BT_PRF_SYS_EVT_START(PRF_ID_BUT_LE), - ///Send key value confirm to APP so stable values can be erased - ///if correctly sent. - BLE_BUT_VAL_SEND_CFM_EVT, - ///Set the value of an attribute - BLE_BUT_SET_CHAR_VAL_REQ_EVT, - - ///Start the button notify Service Task - at connection - BLE_BUT_ENABLE_REQ_EVT, - - /// Inform the application that the profile service role task has been disabled after a disconnection - BLE_BUT_DISABLE_IND_EVT, - /// Inform the application that the profile service has been reiceivd the charateristic write commamd from Client - BLE_BUT_CHAR_WRITE_IND_EVT, - ///Error indication to Host - BLE_BUT_ERROR_IND_EVT, -}; - -/// Parameters of the @ref KEY_CREATE_DB_REQ message -typedef struct -{ - ///Database configuration - uint16_t features; -}tBUT_CRT_DB_REQ; - -/// Parameters of the @ref KEY_CREATE_DB_CFM message -typedef struct -{ - ///Status - uint8_t status; -}tBUT_CRT_DB_CFM; - -///Parameters of the @ref key_CFG_INDNTF_IND message -typedef struct -{ - ///Connection handle - uint16_t conhdl; - ///Stop/notify/indicate value to configure into the peer characteristic - uint16_t cfg_val; - /// characteristics - uint8_t char_code; -}tBUT_CFG_NTF_IND; - - -/// Parameters of the @ref KEY_SET_CHAR_VAL_REQ message - shall be dynamically allocated -typedef struct -{ - /// Characteristic Code - //uint8_t char_code; - uint8_t conhdl; - uint8_t key_val_len; - uint8_t key_val[2]; -}tBUT_SND_CHAR_VAL_REQ; - -/// Parameters of the @ref KEY_ENABLE_REQ message -typedef struct -{ - ///Connection handle - uint16_t conhdl; - /// security level: b0= nothing, b1=unauthenticated, b2=authenticated, b3=authorized; b1 or b2 and b3 can go together - uint8_t sec_lvl; - ///Type of connection - uint8_t con_type; -}tBUT_ENABLE_REQ; - -///Parameters of the @ref KEY_VAL_SEND_CFM message -typedef struct -{ - ///Connection handle - uint16_t conhdl; - ///Status - uint8_t status; -}tBUT_VAL_SND_CFM; - - -/// Parameters of the @ref KEY_DISABLE_IND message -typedef struct -{ - ///Connection handle - uint16_t conhdl; -}tBUT_DISABLE_IND; - -typedef union -{ - uint16_t conhdl; - tBUT_CRT_DB_REQ but_crt_db_req; - tBUT_CRT_DB_CFM but_crt_db_cfm; - tBUT_CFG_NTF_IND but_cfg_ntf_ind; - tBUT_SND_CHAR_VAL_REQ but_snd_char_val_req; - tBUT_ENABLE_REQ but_enable_req; - tBUT_VAL_SND_CFM but_val_snd_cfm; - tBUT_DISABLE_IND but_disable_ind; -}tBUT_PRF_MSG; - - - -BOOLEAN ble_but_prf_hdl_event(prf_hdr_evt_t *msg_data); - -void ble_but_prf_disable(void); - - - -#endif ///BUT_PROFILE_CFG - - - diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/include/app_wechat_util.h b/examples/06_bluedroid_demos/components/bluedroid_demos/include/app_wechat_util.h deleted file mode 100644 index 3b048c3f1e..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/include/app_wechat_util.h +++ /dev/null @@ -1,85 +0,0 @@ -#ifndef __APP_WECHAT_UTIL_H__ -#define __APP_WECHAT_UTIL_H__ - -#include "prf_defs.h" -#if (WX_AIRSYNC_CFG) -#include -#include - -#define PRODUCT_TYPE_UNKNOWN 0 -#define PRODUCT_TYPE_MPBLEDEMO2 1 - -typedef void (*data_produce_func)(void *args, uint8_t **r_data, uint32_t *r_len); -typedef void (*data_free_func)(uint8_t *data, uint32_t len); -typedef int (*data_consume_func)(uint8_t *data, uint32_t len); -typedef void (*data_error_func)(int error_code); - -typedef int32_t (*data_button_handler_func)(uint8_t pin_no); -typedef void (*data_main_process_func)(void); -typedef int32_t (*data_init_func)(void); -typedef int32_t (*data_init_peripheral_func)(void); - -typedef struct data_handler{ - int m_product_type; - data_produce_func m_data_produce_func; - data_free_func m_data_free_func; - data_consume_func m_data_consume_func; - data_error_func m_data_error_func; - data_init_peripheral_func m_data_init_peripheral_func; - data_init_func m_data_init_func; - data_main_process_func m_data_main_process_func; - data_button_handler_func m_data_button_handler_func; - void *m_data_produce_args; - struct data_handler *next; -} data_handler; - -extern data_handler first_handler; - -#define REGISTER(NAME) \ - do { \ - data_handler *tmp = &NAME##_data_handler; \ - tmp->next = first_handler.next; \ - first_handler.next = tmp; \ - } while(0) - -#define ARGS_ITEM_SET(ARGS_TYPE, ARGS_POINTER, ITEM_NAME, ITEM_VALUE) \ - do { \ - ARGS_TYPE *tmp = (ARGS_TYPE *)(ARGS_POINTER); \ - tmp->ITEM_NAME = (ITEM_VALUE); \ - } while(0) - - -typedef struct -{ - unsigned char bMagicNumber; - unsigned char bVer; - unsigned short nLength; - unsigned short nCmdId; - unsigned short nSeq; -} BpFixHead; - -/* - * TYPE DEFINITIONS - **************************************************************************************** - */ - -typedef struct -{ - uint8_t *data; - uint16_t len; - uint16_t offset; -} data_info; - -data_handler* get_handler_by_type(int type); -unsigned short htons(unsigned short val); -unsigned short ntohs(unsigned short val); -unsigned long t_htonl(unsigned long h); -unsigned long t_ntohl(unsigned long n); - -void wechat_error_chack(data_handler *p_data_handler, int error_code); -void data_handler_init(data_handler** p_data_handler, uint8_t product_type); - -#endif ///WX_AIRSYNC_CFG - -#endif ///__APP_WECHAT_UTIL_H__ - diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/include/bt_app_common.h b/examples/06_bluedroid_demos/components/bluedroid_demos/include/bt_app_common.h deleted file mode 100644 index d0eb314bb1..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/include/bt_app_common.h +++ /dev/null @@ -1,31 +0,0 @@ -#ifndef __BT_APP_COMMON_H__ -#define __BT_APP_COMMON_H__ - -#include -#include "osi.h" -#include "bt_common_types.h" -#include "bt_defs.h" - -/* BT APP Events */ -#define BT_EVT_APP (0xB000) -#define BT_EVT_APP_CONTEXT_SWITCH (0x0001 | BT_EVT_APP) - -typedef void (tBTAPP_CBACK) (uint16_t event, char *p_param); -typedef void (tBTAPP_COPY_CBACK) (uint16_t event, char *p_dest, char *p_src); - -typedef struct -{ - BT_HDR hdr; - tBTAPP_CBACK* p_cb; /* context switch callback */ - - /* parameters passed to callback */ - UINT16 event; /* message event id */ - char p_param[0]; /* parameter area needs to be last */ -} tBTAPP_CONTEXT_SWITCH_CBACK; - -bt_status_t bt_app_transfer_context (tBTAPP_CBACK *p_cback, UINT16 event, char* p_params, int param_len, tBTAPP_COPY_CBACK *p_copy_cback); - -void bt_app_init_ok(UNUSED_ATTR uint16_t event, UNUSED_ATTR char *p_param); - -void bt_app_task_start_up(void); -#endif /* __BT_APP_COMMON_H__ */ diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/include/epb.h b/examples/06_bluedroid_demos/components/bluedroid_demos/include/epb.h deleted file mode 100644 index b9d031d39f..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/include/epb.h +++ /dev/null @@ -1,117 +0,0 @@ -// epb.h -// MicroMessenger -// -// Created by harlliu@tencent.com on 14-02-15. -// Copyright 2014 Tencent. All rights reserved. -// - -// Version : 1.0.2 - -#ifndef __EPB_H__ -#define __EPB_H__ - -#include "prf_defs.h" -#if (WX_AIRSYNC_CFG) - - -#include -#include - -typedef struct -{ - uint8_t *data; - int len; -} Bytes; - -typedef struct -{ - const uint8_t *data; - int len; -} CBytes; - -typedef struct -{ - char *str; - int len; -} String; - -typedef struct -{ - const char *str; - int len; -} CString; - -typedef uint8_t Message; - -typedef struct -{ - const uint8_t *unpack_buf; - uint8_t *pack_buf; - int buf_len; - int buf_offset; -} Epb; - -/* - * embeded protobuf unpack functions - */ - -void epb_unpack_init(Epb *e, const uint8_t *buf, int len); -bool epb_has_tag(Epb *e, uint16_t tag); - -//Varint -int32_t epb_get_int32(Epb *e, uint16_t tag); -uint32_t epb_get_uint32(Epb *e, uint16_t tag); -int32_t epb_get_sint32(Epb *e, uint16_t tag); -bool epb_get_bool(Epb *e, uint16_t tag); -int epb_get_enum(Epb *e, uint16_t tag); - -//Length Delimited -const char *epb_get_string(Epb *e, uint16_t tag, int *len); -const uint8_t *epb_get_bytes(Epb *e, uint16_t tag, int *len); -const Message *epb_get_message(Epb *e, uint16_t tag, int *len); - -//Length Delimited Packed Repeadted Field -//TODO - -//Fixed32 -uint32_t epb_get_fixed32(Epb *e, uint16_t tag); -int32_t epb_get_sfixed32(Epb *e, uint16_t tag); -float epb_get_float(Epb *e, uint16_t tag); - -/* - * embeded protobuf pack functions - */ - -void epb_pack_init(Epb *e, uint8_t *buf, int len); -int epb_get_packed_size(Epb *e); - -//Varint -int epb_set_int32(Epb *e, uint16_t tag, int32_t value); -int epb_set_uint32(Epb *e, uint16_t tag, uint32_t value); -int epb_set_sint32(Epb *e, uint16_t tag, int32_t value); -int epb_set_bool(Epb *e, uint16_t tag, bool value); -int epb_set_enum(Epb *e, uint16_t tag, int value); - -//Length Delimited -int epb_set_string(Epb *e, uint16_t tag, const char *data, int len); -int epb_set_bytes(Epb *e, uint16_t tag, const uint8_t *data, int len); -int epb_set_message(Epb *e, uint16_t tag, const Message *data, int len); - -//Length Delimited Packed Repeadted Field -//TODO - -//Fixed32 -int epb_set_fixed32(Epb *e, uint16_t tag, uint32_t value); -int epb_set_sfixed32(Epb *e, uint16_t tag, int32_t value); -int epb_set_float(Epb *e, uint16_t tag, float value); - -//Pack size -int epb_varint32_pack_size(uint16_t tag, uint32_t value, bool is_signed); -int epb_fixed32_pack_size(uint16_t tag); -int epb_length_delimited_pack_size(uint16_t tag, int len); - - -#endif ///WX_AIRSYNC_CFG - -#endif ///__EPB_H__ - diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/include/epb_mmbp.h b/examples/06_bluedroid_demos/components/bluedroid_demos/include/epb_mmbp.h deleted file mode 100644 index 293b951836..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/include/epb_mmbp.h +++ /dev/null @@ -1,248 +0,0 @@ -// epb_MmBp.h -// WeChat Embedded Proto Buffer -// -// Generated by harlliu@tencent.com on 14-11-26. -// Copyright 2014 Tencent. All rights reserved. -// - -// Version : 1.0.4 - -#ifndef __EPB_MMBP_H__ -#define __EPB_MMBP_H__ - -#include "prf_defs.h" -#if (WX_AIRSYNC_CFG) - - -#include "epb.h" - -typedef enum -{ - ECI_none = 0, - ECI_req_auth = 10001, - ECI_req_sendData = 10002, - ECI_req_init = 10003, - ECI_resp_auth = 20001, - ECI_resp_sendData = 20002, - ECI_resp_init = 20003, - ECI_push_recvData = 30001, - ECI_push_switchView = 30002, - ECI_push_switchBackgroud = 30003, - ECI_err_decode = 29999 -} EmCmdId; - -typedef enum -{ - EEC_system = -1, - EEC_needAuth = -2, - EEC_sessionTimeout = -3, - EEC_decode = -4, - EEC_deviceIsBlock = -5, - EEC_serviceUnAvalibleInBackground = -6, - EEC_deviceProtoVersionNeedUpdate = -7, - EEC_phoneProtoVersionNeedUpdate = -8, - EEC_maxReqInQueue = -9, - EEC_userExitWxAccount = -10 -} EmErrorCode; - -typedef enum -{ - EAM_md5 = 1, - EAM_macNoEncrypt = 2 -} EmAuthMethod; - -typedef enum -{ - EIRFF_userNickName = 0x1, - EIRFF_platformType = 0x2, - EIRFF_model = 0x4, - EIRFF_os = 0x8, - EIRFF_time = 0x10, - EIRFF_timeZone = 0x20, - EIRFF_timeString = 0x40 -} EmInitRespFieldFilter; - -typedef enum -{ - EIS_deviceChat = 1, - EIS_autoSync = 2 -} EmInitScence; - -typedef enum -{ - EPT_ios = 1, - EPT_andriod = 2, - EPT_wp = 3, - EPT_s60v3 = 4, - EPT_s60v5 = 5, - EPT_s40 = 6, - EPT_bb = 7 -} EmPlatformType; - -typedef enum -{ - EDDT_manufatureSvr = 0, - EDDT_wxWristBand = 1, - EDDT_wxDeviceHtmlChatView = 10001 -} EmDeviceDataType; - -typedef enum -{ - ESVO_enter = 1, - ESVO_exit = 2 -} EmSwitchViewOp; - -typedef enum -{ - EVI_deviceChatView = 1, - EVI_deviceChatHtmlView = 2 -} EmViewId; - -typedef enum -{ - ESBO_enterBackground = 1, - ESBO_enterForground = 2, - ESBO_sleep = 3 -} EmSwitchBackgroundOp; - -typedef struct -{ - void *none; -} BaseRequest; - -typedef struct -{ - int32_t err_code; - bool has_err_msg; - CString err_msg; -} BaseResponse; - -typedef struct -{ - void *none; -} BasePush; - -typedef struct -{ - BaseRequest *base_request; - bool has_md5_device_type_and_device_id; - Bytes md5_device_type_and_device_id; - int32_t proto_version; - int32_t auth_proto; - EmAuthMethod auth_method; - bool has_aes_sign; - Bytes aes_sign; - bool has_mac_address; - Bytes mac_address; - bool has_time_zone; - String time_zone; - bool has_language; - String language; - bool has_device_name; - String device_name; -} AuthRequest; - -typedef struct -{ - BaseResponse *base_response; - CBytes aes_session_key; -} AuthResponse; - -typedef struct -{ - BaseRequest *base_request; - bool has_resp_field_filter; - Bytes resp_field_filter; - bool has_challenge; - Bytes challenge; -} InitRequest; - -typedef struct -{ - BaseResponse *base_response; - uint32_t user_id_high; - uint32_t user_id_low; - bool has_challeange_answer; - uint32_t challeange_answer; - bool has_init_scence; - EmInitScence init_scence; - bool has_auto_sync_max_duration_second; - uint32_t auto_sync_max_duration_second; - bool has_user_nick_name; - CString user_nick_name; - bool has_platform_type; - EmPlatformType platform_type; - bool has_model; - CString model; - bool has_os; - CString os; - bool has_time; - int32_t time; - bool has_time_zone; - int32_t time_zone; - bool has_time_string; - CString time_string; -} InitResponse; - -typedef struct -{ - BaseRequest *base_request; - Bytes data; - bool has_type; - EmDeviceDataType type; -} SendDataRequest; - -typedef struct -{ - BaseResponse *base_response; - bool has_data; - CBytes data; -} SendDataResponse; - -typedef struct -{ - BasePush *base_push; - CBytes data; - bool has_type; - EmDeviceDataType type; -} RecvDataPush; - -typedef struct -{ - BasePush *base_push; - EmSwitchViewOp switch_view_op; - EmViewId view_id; -} SwitchViewPush; - -typedef struct -{ - BasePush *base_push; - EmSwitchBackgroundOp switch_background_op; -} SwitchBackgroudPush; - -BaseResponse *epb_unpack_base_response(const uint8_t *buf, int buf_len); -void epb_unpack_base_response_free(BaseResponse *response); -int epb_auth_request_pack_size(AuthRequest *request); -int epb_pack_auth_request(AuthRequest *request, uint8_t *buf, int buf_len); -AuthResponse *epb_unpack_auth_response(const uint8_t *buf, int buf_len); -void epb_unpack_auth_response_free(AuthResponse *response); -int epb_init_request_pack_size(InitRequest *request); -int epb_pack_init_request(InitRequest *request, uint8_t *buf, int buf_len); -InitResponse *epb_unpack_init_response(const uint8_t *buf, int buf_len); -void epb_unpack_init_response_free(InitResponse *response); -int epb_send_data_request_pack_size(SendDataRequest *request); -int epb_pack_send_data_request(SendDataRequest *request, uint8_t *buf, int buf_len); -SendDataResponse *epb_unpack_send_data_response(const uint8_t *buf, int buf_len); -void epb_unpack_send_data_response_free(SendDataResponse *response); -RecvDataPush *epb_unpack_recv_data_push(const uint8_t *buf, int buf_len); -void epb_unpack_recv_data_push_free(RecvDataPush *push); -SwitchViewPush *epb_unpack_switch_view_push(const uint8_t *buf, int buf_len); -void epb_unpack_switch_view_push_free(SwitchViewPush *push); -SwitchBackgroudPush *epb_unpack_switch_backgroud_push(const uint8_t *buf, int buf_len); -void epb_unpack_switch_backgroud_push_free(SwitchBackgroudPush *push); - - -#endif ///WX_AIRSYNC_CFG - -#endif ///__EPB_MMBP_H__ - diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/include/gattc_profile.h b/examples/06_bluedroid_demos/components/bluedroid_demos/include/gattc_profile.h deleted file mode 100644 index 95b82c909d..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/include/gattc_profile.h +++ /dev/null @@ -1,46 +0,0 @@ -/****************************************************************************** - * - * Copyright (C) 1999-2013 Broadcom Corporation - * - * 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. - * - ******************************************************************************/ - -/******************************************************************************* -** -** Header file for gatt client. -** -********************************************************************************/ - -#include "bt_target.h" -#include "gatt_api.h" -#include "gattdefs.h" - -/******************************************************************************* -** BATTERY CLIENT API -*******************************************************************************/ -/*************************************************************** -** -** Function bac_register -** -** Description register app for battery service -** -****************************************************************/ -extern void bac_register(void); - -extern void gattc_client_test(void); -#ifdef __cplusplus - -} -#endif - diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/include/mpbledemo2.h b/examples/06_bluedroid_demos/components/bluedroid_demos/include/mpbledemo2.h deleted file mode 100644 index 0a48058d40..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/include/mpbledemo2.h +++ /dev/null @@ -1,140 +0,0 @@ - -#ifndef __MPBLEDEMO2_H__ -#define __MPBLEDEMO2_H__ - -#include "prf_defs.h" - -#if (WX_AIRSYNC_CFG) - - -#include -#include -#include -#include -#include -#include "epb_MmBp.h" -#include "app_airsync_prf.h" - -#define CMD_NULL 0 -#define CMD_AUTH 1 -#define CMD_INIT 2 -#define CMD_SENDDAT 3 - -#define DEVICE_TYPE "gh_b57f1be552dd" -#define DEVICE_ID "gh_b57f1be552dd_8ecc3b117f8c05112638289b0952c797" //"wechat_dialog" -#define PROTO_VERSION 0x010004 -#define AUTH_PROTO 1 - -#define MAC_ADDRESS_LENGTH 6 - -//#define EAM_md5AndNoEnrypt 1 -#define EAM_md5AndAesEnrypt 1 -//#define EAM_macNoEncrypt 2 - -#define DEVICE_KEY {0x00,0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,0x09,0x0a,0x0b,0x0c,0x0d,0x0e,0x0f}; - -#ifdef EAM_macNoEncrypt - #define AUTH_METHOD EAM_macNoEncrypt - #define MD5_TYPE_AND_ID_LENGTH 0 - #define CIPHER_TEXT_LENGTH 0 -#endif - -#ifdef EAM_md5AndAesEnrypt - #define AUTH_METHOD EAM_md5AndAesEnrypt - #define MD5_TYPE_AND_ID_LENGTH 16 - #define CIPHER_TEXT_LENGTH 16 -#endif -#ifdef EAM_md5AndNoEnrypt - #define AUTH_METHOD EAM_md5AndNoEnrypt - #define MD5_TYPE_AND_ID_LENGTH 16 - #define CIPHER_TEXT_LENGTH 0 -#endif - -#define CHALLENAGE_LENGTH 4 - -#define MPBLEDEMO2_MAGICCODE_H 0xfe -#define MPBLEDEMO2_MAGICCODE_L 0xcf -#define MPBLEDEMO2_VERSION 0x01 -#define SEND_HELLO_WECHAT "Hello, WeChat!" - -/* Hardware Resources define */ -#define MPBLEDEMO2_LIGHT 19 -#define MPBLEDEMO2_BUTTON_1 17 - -typedef enum -{ - errorCodeUnpackAuthResp = 0x9990, - errorCodeUnpackInitResp = 0x9991, - errorCodeUnpackSendDataResp = 0x9992, - errorCodeUnpackCtlCmdResp = 0x9993, - errorCodeUnpackRecvDataPush = 0x9994, - errorCodeUnpackSwitchViewPush = 0x9995, - errorCodeUnpackSwitchBackgroundPush = 0x9996, - errorCodeUnpackErrorDecode = 0x9997, -} mpbledemo2UnpackErrorCode; - -typedef enum -{ - errorCodeProduce = 0x9980, -} mpbledemo2PackErrorCode; - - -// command ID between device and vendor server -typedef enum -{ - sendTextReq = 0x01, - - sendTextResp = 0x1001, - openLightPush = 0x2001, - closeLightPush = 0x2002, -} BleDemo2CmdID; - -typedef struct -{ - uint8_t m_magicCode[2]; - uint16_t m_version; - uint16_t m_totalLength; - uint16_t m_cmdid; - uint16_t m_seq; - uint16_t m_errorCode; -} BlueDemoHead; - -typedef struct -{ - int cmd; - CString send_msg; -} mpbledemo2_info; - - typedef struct -{ - bool wechats_switch_state; //公众账号切换到前台的状态 - bool indication_state; - bool auth_state; - bool init_state; - bool auth_send; - bool init_send; - unsigned short send_data_seq; - unsigned short push_data_seq; - unsigned short seq; -}mpbledemo2_state; - -typedef void (*mpbledemo2_handler_func)(uint8_t *ptrData, uint32_t lengthInByte); - -typedef struct -{ - BleDemo2CmdID commandCode; - mpbledemo2_handler_func handler; -} MPBLEDEMO2_RECEIVED_CMD_HANDLER_T; - -extern data_handler mpbledemo2_data_handler; -extern data_handler *m_mpbledemo2_handler; - -extern void mpbledemo2_reset(void); -extern void mpbledemo2_indication_state(bool isEnable); -extern int32_t mpbledemo2_sendData(uint8_t* ptrData, uint32_t lengthInByte); - - -#endif ///WX_AIRSYNC_CFG - -#endif ///__MPBLEDEMO2_H__ - diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/include/wechar_crc.h b/examples/06_bluedroid_demos/components/bluedroid_demos/include/wechar_crc.h deleted file mode 100644 index 9dbe222417..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/include/wechar_crc.h +++ /dev/null @@ -1,29 +0,0 @@ -// crc32.h -// WeChat Embedded -// -// Created by harlliu on 14-03-03. -// Copyright 2014 Tencent. All rights reserved. -// - -#ifndef __CRC32_H__ -#define __CRC32_H__ - - -#include "prf_defs.h" -#if (WX_AIRSYNC_CFG) - -#include - -#ifdef __cplusplus -extern "C" { -#endif -uint32_t crc32(uint32_t crc, const uint8_t *buf, int len); - -#ifdef __cplusplus -} -#endif ///__cplusplus - -#endif ///WX_AIRSYNC_CFG - -#endif ///__CRC32_H__ - diff --git a/examples/06_bluedroid_demos/components/bluedroid_demos/include/wechat_aes.h b/examples/06_bluedroid_demos/components/bluedroid_demos/include/wechat_aes.h deleted file mode 100644 index c663b326c6..0000000000 --- a/examples/06_bluedroid_demos/components/bluedroid_demos/include/wechat_aes.h +++ /dev/null @@ -1,73 +0,0 @@ -/////////////////////////////////////////////////////////////////////////////// -// 文 件 名:AES.h -// 描 述:AES加密算法 -// 创 建 人:Liangbofu -// 创建日期:2009-07-17 -/////////////////////////////////////////////////////////////////////////////// -#ifndef __WECHAT_AES_H -#define __WECHAT_AES_H - -#include "prf_defs.h" -#if (WX_AIRSYNC_CFG) - -#ifdef __cplusplus - extern "C" { -#endif - -// 以bit为单位的密钥长度,只能为 128,192 和 256 三种 -#define AES_KEY_LENGTH 128 - -// 加解密模式 -#define AES_MODE_ECB 0 // 电子密码本模式(一般模式) -#define AES_MODE_CBC 1 // 密码分组链接模式 -#define AES_MODE AES_MODE_CBC - - -/////////////////////////////////////////////////////////////////////////////// -// 函数名: AES_Init -// 描述: 初始化,在此执行扩展密钥操作。 -// 输入参数: pKey -- 原始密钥,其长度必须为 AES_KEY_LENGTH/8 字节。 -// 输出参数: 无。 -// 返回值: 无。 -/////////////////////////////////////////////////////////////////////////////// -void AES_Init(const void *pKey); - -////////////////////////////////////////////////////////////////////////// -// 函数名: AES_Encrypt -// 描述: 加密数据 -// 输入参数: pPlainText -- 明文,即需加密的数据,其长度为nDataLen字节。 -// nDataLen -- 数据长度,以字节为单位,必须为AES_KEY_LENGTH/8的整倍数。 -// pIV -- 初始化向量,如果使用ECB模式,可设为NULL。 -// 输出参数: pCipherText -- 密文,即由明文加密后的数据,可以与pPlainText相同。 -// 返回值: 无。 -////////////////////////////////////////////////////////////////////////// -void AES_Encrypt(const unsigned char *pPlainText, unsigned char *pCipherText, - unsigned int nDataLen, const unsigned char *pIV); - -////////////////////////////////////////////////////////////////////////// -// 函数名: AES_Decrypt -// 描述: 解密数据 -// 输入参数: pCipherText -- 密文,即需解密的数据,其长度为nDataLen字节。 -// nDataLen -- 数据长度,以字节为单位,必须为AES_KEY_LENGTH/8的整倍数。 -// pIV -- 初始化向量,如果使用ECB模式,可设为NULL。 -// 输出参数: pPlainText -- 明文,即由密文解密后的数据,可以与pCipherText相同。 -// 返回值: 无。 -////////////////////////////////////////////////////////////////////////// -void AES_Decrypt(unsigned char *pPlainText, const unsigned char *pCipherText, - unsigned int nDataLen, const unsigned char *pIV); - -//对数据进行解密操作,成功返回1,失败返回0 -unsigned char app_data_encode_aes(char *input, char *output, unsigned short *slen); -unsigned char app_data_decode_aes(unsigned char *input, char *output, unsigned short *slen); -unsigned int AES_Encrypt_PKCS7(const unsigned char *pPlainText, unsigned char *pCipherText, - unsigned int nDataLen, const unsigned char *pIV); -unsigned int AES_get_length(unsigned int length); -void AES_free(unsigned char* p); -#ifdef __cplusplus - } -#endif ///__cplusplus - -#endif ///WX_AIRSYNC_CFG - -#endif // __WECHAT_AES_H - diff --git a/examples/06_bluedroid_demos/main/demo_main.c b/examples/06_bluedroid_demos/main/demo_main.c deleted file mode 100644 index 7ea523c0e9..0000000000 --- a/examples/06_bluedroid_demos/main/demo_main.c +++ /dev/null @@ -1,42 +0,0 @@ -// Copyright 2015-2016 Espressif Systems (Shanghai) PTE LTD -// -// 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 -#include -#include -#include "bt.h" -#include "freertos/FreeRTOS.h" -#include "freertos/task.h" -#include "string.h" - - -extern void bte_main_boot_entry(void *); -extern void bt_app_task_start_up(void); -extern void bt_app_core_start(void); - -void pingTask(void *pvParameters) -{ - while (1) { - vTaskDelay(1000 / portTICK_PERIOD_MS); - //printf("ping\n"); - } -} - -void app_main() -{ - bt_controller_init(); - xTaskCreatePinnedToCore(&pingTask, "pingTask", 2048, NULL, 5, NULL, 0); - bt_app_task_start_up(); - bte_main_boot_entry(bt_app_core_start); -} diff --git a/examples/08_bt_sdp/Makefile b/examples/08_bt_sdp/Makefile deleted file mode 100755 index 1e91bbb891..0000000000 --- a/examples/08_bt_sdp/Makefile +++ /dev/null @@ -1,11 +0,0 @@ -# -# This is a project Makefile. It is assumed the directory this Makefile resides in is a -# project subdirectory. -# - -PROJECT_NAME := bluedroid_demos - -COMPONENT_ADD_INCLUDEDIRS := components/include - -include $(IDF_PATH)/make/project.mk - diff --git a/examples/09_gatt_server/main/component.mk b/examples/09_gatt_server/main/component.mk deleted file mode 100644 index 24356f23ed..0000000000 --- a/examples/09_gatt_server/main/component.mk +++ /dev/null @@ -1,10 +0,0 @@ -# -# Main Makefile. This is basically the same as a component makefile. -# -# This Makefile should, at the very least, just include $(SDK_PATH)/make/component_common.mk. By default, -# this will take the sources in the src/ directory, compile them and link them into -# lib(subdirectory_name).a in the build directory. This behaviour is entirely configurable, -# please read the ESP-IDF documents if you need to do this. -# - -include $(IDF_PATH)/make/component_common.mk diff --git a/examples/07_blufi/Makefile b/examples/12_blufi/Makefile similarity index 100% rename from examples/07_blufi/Makefile rename to examples/12_blufi/Makefile diff --git a/examples/07_blufi/README.rst b/examples/12_blufi/README.rst similarity index 100% rename from examples/07_blufi/README.rst rename to examples/12_blufi/README.rst diff --git a/examples/07_blufi/components/blufi/blufi.c b/examples/12_blufi/components/blufi/blufi.c similarity index 100% rename from examples/07_blufi/components/blufi/blufi.c rename to examples/12_blufi/components/blufi/blufi.c diff --git a/examples/07_blufi/components/blufi/blufi_task.c b/examples/12_blufi/components/blufi/blufi_task.c similarity index 100% rename from examples/07_blufi/components/blufi/blufi_task.c rename to examples/12_blufi/components/blufi/blufi_task.c diff --git a/examples/07_blufi/components/blufi/component.mk b/examples/12_blufi/components/blufi/component.mk similarity index 100% rename from examples/07_blufi/components/blufi/component.mk rename to examples/12_blufi/components/blufi/component.mk diff --git a/examples/07_blufi/components/blufi/include/blufi.h b/examples/12_blufi/components/blufi/include/blufi.h similarity index 100% rename from examples/07_blufi/components/blufi/include/blufi.h rename to examples/12_blufi/components/blufi/include/blufi.h diff --git a/examples/06_bluedroid_demos/main/component.mk b/examples/12_blufi/main/component.mk similarity index 100% rename from examples/06_bluedroid_demos/main/component.mk rename to examples/12_blufi/main/component.mk diff --git a/examples/07_blufi/main/demo_main.c b/examples/12_blufi/main/demo_main.c similarity index 100% rename from examples/07_blufi/main/demo_main.c rename to examples/12_blufi/main/demo_main.c diff --git a/examples/06_bluedroid_demos/Makefile b/examples/13_bt_sdp/Makefile old mode 100644 new mode 100755 similarity index 100% rename from examples/06_bluedroid_demos/Makefile rename to examples/13_bt_sdp/Makefile diff --git a/examples/08_bt_sdp/README.rst b/examples/13_bt_sdp/README.rst similarity index 100% rename from examples/08_bt_sdp/README.rst rename to examples/13_bt_sdp/README.rst diff --git a/examples/08_bt_sdp/components/bluedroid_demos/app_core/bt_app_core.c b/examples/13_bt_sdp/components/bluedroid_demos/app_core/bt_app_core.c similarity index 100% rename from examples/08_bt_sdp/components/bluedroid_demos/app_core/bt_app_core.c rename to examples/13_bt_sdp/components/bluedroid_demos/app_core/bt_app_core.c diff --git a/examples/08_bt_sdp/components/bluedroid_demos/app_project/SampleBtSdp.c b/examples/13_bt_sdp/components/bluedroid_demos/app_project/SampleBtSdp.c similarity index 100% rename from examples/08_bt_sdp/components/bluedroid_demos/app_project/SampleBtSdp.c rename to examples/13_bt_sdp/components/bluedroid_demos/app_project/SampleBtSdp.c diff --git a/examples/08_bt_sdp/components/bluedroid_demos/btif/btif_core.c b/examples/13_bt_sdp/components/bluedroid_demos/btif/btif_core.c similarity index 100% rename from examples/08_bt_sdp/components/bluedroid_demos/btif/btif_core.c rename to examples/13_bt_sdp/components/bluedroid_demos/btif/btif_core.c diff --git a/examples/08_bt_sdp/components/bluedroid_demos/btif/btif_dm.c b/examples/13_bt_sdp/components/bluedroid_demos/btif/btif_dm.c similarity index 100% rename from examples/08_bt_sdp/components/bluedroid_demos/btif/btif_dm.c rename to examples/13_bt_sdp/components/bluedroid_demos/btif/btif_dm.c diff --git a/examples/08_bt_sdp/components/bluedroid_demos/btif/btif_sdp.c b/examples/13_bt_sdp/components/bluedroid_demos/btif/btif_sdp.c similarity index 100% rename from examples/08_bt_sdp/components/bluedroid_demos/btif/btif_sdp.c rename to examples/13_bt_sdp/components/bluedroid_demos/btif/btif_sdp.c diff --git a/examples/08_bt_sdp/components/bluedroid_demos/btif/btif_sdp_server.c b/examples/13_bt_sdp/components/bluedroid_demos/btif/btif_sdp_server.c similarity index 100% rename from examples/08_bt_sdp/components/bluedroid_demos/btif/btif_sdp_server.c rename to examples/13_bt_sdp/components/bluedroid_demos/btif/btif_sdp_server.c diff --git a/examples/08_bt_sdp/components/bluedroid_demos/btif/btif_util.c b/examples/13_bt_sdp/components/bluedroid_demos/btif/btif_util.c similarity index 100% rename from examples/08_bt_sdp/components/bluedroid_demos/btif/btif_util.c rename to examples/13_bt_sdp/components/bluedroid_demos/btif/btif_util.c diff --git a/examples/08_bt_sdp/components/bluedroid_demos/btif/stack_manager.c b/examples/13_bt_sdp/components/bluedroid_demos/btif/stack_manager.c similarity index 100% rename from examples/08_bt_sdp/components/bluedroid_demos/btif/stack_manager.c rename to examples/13_bt_sdp/components/bluedroid_demos/btif/stack_manager.c diff --git a/examples/08_bt_sdp/components/bluedroid_demos/component.mk b/examples/13_bt_sdp/components/bluedroid_demos/component.mk similarity index 100% rename from examples/08_bt_sdp/components/bluedroid_demos/component.mk rename to examples/13_bt_sdp/components/bluedroid_demos/component.mk diff --git a/examples/08_bt_sdp/components/bluedroid_demos/include/bt_app_common.h b/examples/13_bt_sdp/components/bluedroid_demos/include/bt_app_common.h similarity index 100% rename from examples/08_bt_sdp/components/bluedroid_demos/include/bt_app_common.h rename to examples/13_bt_sdp/components/bluedroid_demos/include/bt_app_common.h diff --git a/examples/08_bt_sdp/components/bluedroid_demos/include/btif_api.h b/examples/13_bt_sdp/components/bluedroid_demos/include/btif_api.h similarity index 100% rename from examples/08_bt_sdp/components/bluedroid_demos/include/btif_api.h rename to examples/13_bt_sdp/components/bluedroid_demos/include/btif_api.h diff --git a/examples/08_bt_sdp/components/bluedroid_demos/include/btif_common.h b/examples/13_bt_sdp/components/bluedroid_demos/include/btif_common.h similarity index 100% rename from examples/08_bt_sdp/components/bluedroid_demos/include/btif_common.h rename to examples/13_bt_sdp/components/bluedroid_demos/include/btif_common.h diff --git a/examples/08_bt_sdp/components/bluedroid_demos/include/btif_dm.h b/examples/13_bt_sdp/components/bluedroid_demos/include/btif_dm.h similarity index 100% rename from examples/08_bt_sdp/components/bluedroid_demos/include/btif_dm.h rename to examples/13_bt_sdp/components/bluedroid_demos/include/btif_dm.h diff --git a/examples/08_bt_sdp/components/bluedroid_demos/include/btif_sdp.h b/examples/13_bt_sdp/components/bluedroid_demos/include/btif_sdp.h similarity index 100% rename from examples/08_bt_sdp/components/bluedroid_demos/include/btif_sdp.h rename to examples/13_bt_sdp/components/bluedroid_demos/include/btif_sdp.h diff --git a/examples/08_bt_sdp/components/bluedroid_demos/include/btif_stack_manager.h b/examples/13_bt_sdp/components/bluedroid_demos/include/btif_stack_manager.h similarity index 100% rename from examples/08_bt_sdp/components/bluedroid_demos/include/btif_stack_manager.h rename to examples/13_bt_sdp/components/bluedroid_demos/include/btif_stack_manager.h diff --git a/examples/08_bt_sdp/components/bluedroid_demos/include/btif_util.h b/examples/13_bt_sdp/components/bluedroid_demos/include/btif_util.h similarity index 100% rename from examples/08_bt_sdp/components/bluedroid_demos/include/btif_util.h rename to examples/13_bt_sdp/components/bluedroid_demos/include/btif_util.h diff --git a/examples/08_bt_sdp/components/bluedroid_demos/include/stack_manager.h b/examples/13_bt_sdp/components/bluedroid_demos/include/stack_manager.h similarity index 100% rename from examples/08_bt_sdp/components/bluedroid_demos/include/stack_manager.h rename to examples/13_bt_sdp/components/bluedroid_demos/include/stack_manager.h diff --git a/examples/07_blufi/main/component.mk b/examples/13_bt_sdp/main/component.mk old mode 100644 new mode 100755 similarity index 100% rename from examples/07_blufi/main/component.mk rename to examples/13_bt_sdp/main/component.mk diff --git a/examples/08_bt_sdp/main/demo_main.c b/examples/13_bt_sdp/main/demo_main.c similarity index 100% rename from examples/08_bt_sdp/main/demo_main.c rename to examples/13_bt_sdp/main/demo_main.c diff --git a/examples/09_gatt_server/Makefile b/examples/14_gatt_server/Makefile similarity index 100% rename from examples/09_gatt_server/Makefile rename to examples/14_gatt_server/Makefile diff --git a/examples/09_gatt_server/README.rst b/examples/14_gatt_server/README.rst similarity index 100% rename from examples/09_gatt_server/README.rst rename to examples/14_gatt_server/README.rst diff --git a/examples/08_bt_sdp/main/component.mk b/examples/14_gatt_server/main/component.mk old mode 100755 new mode 100644 similarity index 100% rename from examples/08_bt_sdp/main/component.mk rename to examples/14_gatt_server/main/component.mk diff --git a/examples/09_gatt_server/main/gatts_demo.c b/examples/14_gatt_server/main/gatts_demo.c similarity index 100% rename from examples/09_gatt_server/main/gatts_demo.c rename to examples/14_gatt_server/main/gatts_demo.c diff --git a/examples/10_gatt_client/Makefile b/examples/15_gatt_client/Makefile similarity index 100% rename from examples/10_gatt_client/Makefile rename to examples/15_gatt_client/Makefile diff --git a/examples/10_gatt_client/README.rst b/examples/15_gatt_client/README.rst similarity index 100% rename from examples/10_gatt_client/README.rst rename to examples/15_gatt_client/README.rst diff --git a/examples/10_gatt_client/main/component.mk b/examples/15_gatt_client/main/component.mk similarity index 100% rename from examples/10_gatt_client/main/component.mk rename to examples/15_gatt_client/main/component.mk diff --git a/examples/10_gatt_client/main/gattc_demo.c b/examples/15_gatt_client/main/gattc_demo.c similarity index 100% rename from examples/10_gatt_client/main/gattc_demo.c rename to examples/15_gatt_client/main/gattc_demo.c