aboutsummaryrefslogtreecommitdiff
path: root/vendor/827x_ble_remote/app_att.c
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/827x_ble_remote/app_att.c')
-rw-r--r--vendor/827x_ble_remote/app_att.c998
1 files changed, 998 insertions, 0 deletions
diff --git a/vendor/827x_ble_remote/app_att.c b/vendor/827x_ble_remote/app_att.c
new file mode 100644
index 0000000..4a5bdaf
--- /dev/null
+++ b/vendor/827x_ble_remote/app_att.c
@@ -0,0 +1,998 @@
+/******************************************************************************
+ * @file app_att.c
+ *
+ * @brief for TLSR chips
+ *
+ * @author public@telink-semi.com;
+ * @date Sep. 30, 2010
+ *
+ * @attention
+ *
+ * Copyright (C) 2019-2020 Telink Semiconductor (Shanghai) Co., Ltd.
+ * Copyright (C) Atmosic 2022
+ *
+ * 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.
+ *
+ *****************************************************************************/
+
+#ifdef CFG_ATM_SDK
+#include "refdesignrcu.h"
+#include "bridge_att.h"
+#include "bridge_audio.h"
+#include "ble_att.h"
+#include "app_att.h"
+#include "app_config.h"
+#include "app_ir.h"
+#include "stack/ble/ble_common.h"
+#include "stack/ble/ble_format.h"
+#include "stack/ble/host/attr/att.h"
+#include "stack/ble/service/uuid.h"
+#ifdef CFG_ATVRC_FIND_ME
+#include "./app_find_me/app_fms.h"
+#endif
+#else
+#include "tl_common.h"
+#include "application/audio/audio_config.h"
+#include "stack/ble/ble.h"
+#include "app_audio.h"
+#include "app_ui.h"
+#include "app_ota.h"
+#include "app_ir.h"
+#include "app_custom.h"
+#include "app_test.h"
+#include "./app_find_me/app_fms.h"
+#include "../../version.h"
+#endif
+
+typedef struct
+{
+ /** Minimum value for the connection event (interval. 0x0006 - 0x0C80 * 1.25 ms) */
+ u16 intervalMin;
+ /** Maximum value for the connection event (interval. 0x0006 - 0x0C80 * 1.25 ms) */
+ u16 intervalMax;
+ /** Number of LL latency connection events (0x0000 - 0x03e8) */
+ u16 latency;
+ /** Connection Timeout (0x000A - 0x0C80 * 10 ms) */
+ u16 timeout;
+} gap_periConnectParams_t;
+
+static const u16 clientCharacterCfgUUID = GATT_UUID_CLIENT_CHAR_CFG;
+
+static const u16 extReportRefUUID = GATT_UUID_EXT_REPORT_REF;
+
+static const u16 reportRefUUID = GATT_UUID_REPORT_REF;
+
+static const u16 characterPresentFormatUUID = GATT_UUID_CHAR_PRESENT_FORMAT;
+
+static const u16 userdesc_UUID = GATT_UUID_CHAR_USER_DESC;
+
+static const u16 serviceChangeUUID = GATT_UUID_SERVICE_CHANGE;
+
+static const u16 my_primaryServiceUUID = GATT_UUID_PRIMARY_SERVICE;
+
+static const u16 my_characterUUID = GATT_UUID_CHARACTER;
+
+#ifndef CFG_ATM_SDK
+static const u16 my_devServiceUUID = SERVICE_UUID_DEVICE_INFORMATION;
+
+static const u16 my_PnPUUID = CHARACTERISTIC_UUID_PNP_ID;
+
+static const u16 my_SysIDUUID = CHARACTERISTIC_UUID_SYSTEM_ID;
+
+static const u16 my_ModelNUMUUID = CHARACTERISTIC_UUID_MODEL_NUM_STRING;
+
+static const u16 my_SerialNUMUUID = CHARACTERISTIC_UUID_SERIAL_NUM_STRING;
+
+static const u16 my_FWRevUUID = CHARACTERISTIC_UUID_FW_REVISION_STRING;
+
+static const u16 my_HWRevUUID = CHARACTERISTIC_UUID_HW_REVISION_STRING;
+
+static const u16 my_SWRevUUID = CHARACTERISTIC_UUID_SW_REVISION_STRING;
+
+static const u16 my_ManuNameUUID = CHARACTERISTIC_UUID_MANU_NAME_STRING;
+
+static const u16 my_IEEE11073UUID = CHARACTERISTIC_UUID_IEEE_11073_CERT_LIST;
+
+
+static const u16 my_devNameUUID = GATT_UUID_DEVICE_NAME;
+
+static const u16 my_gapServiceUUID = SERVICE_UUID_GENERIC_ACCESS;
+
+static const u16 my_appearanceUIID = GATT_UUID_APPEARANCE;
+
+static const u16 my_periConnParamUUID = GATT_UUID_PERI_CONN_PARAM;
+
+static const u16 my_appearance = GAP_APPEARE_UNKNOWN;
+
+static const u16 my_gattServiceUUID = SERVICE_UUID_GENERIC_ATTRIBUTE;
+
+static u16 serviceChangeVal[2] = {0};
+
+static u8 serviceChangeCCC[2] = {0,0};
+
+static const gap_periConnectParams_t my_periConnParameters = {8, 11, 0, 1000};
+
+
+ _attribute_data_retention_ u8 my_FWRevtrs [] = {'V','1','.','1','1'};
+// _attribute_data_retention_ u8 my_SWRevtrs [] = {'V','1','.','0','2'};
+ static const u8 my_SWRevtrs [] = {'V', 0x30+((FW_VERSION>>8)&0x0f), '.', 0x30+((FW_VERSION>>4)&0x0f), 0x30+(FW_VERSION&0x0f)};
+
+ static const u8 my_HWRevtrs [] = {'V','1','.','0'};
+ static const u8 my_ManuNametrs [] = {'T','e','l','i','n','k'};
+
+//////////////////////// Battery /////////////////////////////////////////////////
+static const u16 my_batServiceUUID = SERVICE_UUID_BATTERY;
+static const u16 my_batCharUUID = CHARACTERISTIC_UUID_BATTERY_LEVEL;
+static u8 batteryValueInCCC[2];
+_attribute_data_retention_ u8 my_batVal[1] = {99};
+
+//////////////////////// HID /////////////////////////////////////////////////////
+
+static const u16 my_hidServiceUUID = SERVICE_UUID_HUMAN_INTERFACE_DEVICE;
+
+static const u16 hidServiceUUID = SERVICE_UUID_HUMAN_INTERFACE_DEVICE;
+static const u16 hidProtocolModeUUID = CHARACTERISTIC_UUID_HID_PROTOCOL_MODE;
+static const u16 hidReportUUID = CHARACTERISTIC_UUID_HID_REPORT;
+static const u16 hidReportMapUUID = CHARACTERISTIC_UUID_HID_REPORT_MAP;
+static const u16 hidbootKeyInReportUUID = CHARACTERISTIC_UUID_HID_BOOT_KEY_INPUT;
+static const u16 hidbootKeyOutReportUUID = CHARACTERISTIC_UUID_HID_BOOT_KEY_OUTPUT;
+static const u16 hidbootMouseInReportUUID = CHARACTERISTIC_UUID_HID_BOOT_MOUSE_INPUT;
+static const u16 hidinformationUUID = CHARACTERISTIC_UUID_HID_INFORMATION;
+static const u16 hidCtrlPointUUID = CHARACTERISTIC_UUID_HID_CONTROL_POINT;
+static const u16 hidIncludeUUID = GATT_UUID_INCLUDE;
+
+static const u8 protocolMode = DFLT_HID_PROTOCOL_MODE;
+
+// Key in Report characteristic variables
+static u8 reportKeyIn[8];
+static u8 reportKeyInCCC[2];
+// HID Report Reference characteristic descriptor, key input
+static const u8 reportRefKeyIn[2] =
+ { HID_REPORT_ID_KEYBOARD_INPUT, HID_REPORT_TYPE_INPUT };
+
+// Key out Report characteristic variables
+static u8 reportKeyOut[1];
+static const u8 reportRefKeyOut[2] =
+ { HID_REPORT_ID_KEYBOARD_INPUT, HID_REPORT_TYPE_OUTPUT };
+
+// Consumer Control input Report
+static u8 reportConsumerControlIn[2];
+static u8 reportConsumerControlInCCC[2];
+static const u8 reportRefConsumerControlIn[2] =
+ { HID_REPORT_ID_CONSUME_CONTROL_INPUT, HID_REPORT_TYPE_INPUT };
+
+// Boot Keyboard Input Report
+static u8 bootKeyInReport;
+static u8 bootKeyInReportCCC[2];
+
+// Boot Keyboard Output Report
+static u8 bootKeyOutReport;
+
+// HID Information characteristic
+static const u8 hidInformation[] =
+{
+ U16_LO(0x0111), U16_HI(0x0111), // bcdHID (USB HID version)
+ 0x00, // bCountryCode
+ 0x01 // Flags
+};
+
+// HID Control Point characteristic
+static u8 controlPoint;
+
+// HID Report Map characteristic
+// Keyboard report descriptor (using format for Boot interface descriptor)
+
+static const u8 reportMap[] =
+{
+ //keyboard report in
+ 0x05, 0x01, // Usage Pg (Generic Desktop)
+ 0x09, 0x06, // Usage (Keyboard)
+ 0xA1, 0x01, // Collection: (Application)
+ 0x85, HID_REPORT_ID_KEYBOARD_INPUT, // Report Id (keyboard)
+ //
+ 0x05, 0x07, // Usage Pg (Key Codes)
+ 0x19, 0xE0, // Usage Min (224) VK_CTRL:0xe0
+ 0x29, 0xE7, // Usage Max (231) VK_RWIN:0xe7
+ 0x15, 0x00, // Log Min (0)
+ 0x25, 0x01, // Log Max (1)
+ //
+ // Modifier byte
+ 0x75, 0x01, // Report Size (1) 1 bit * 8
+ 0x95, 0x08, // Report Count (8)
+ 0x81, 0x02, // Input: (Data, Variable, Absolute)
+ //
+ // Reserved byte
+ 0x95, 0x01, // Report Count (1)
+ 0x75, 0x08, // Report Size (8)
+ 0x81, 0x01, // Input: (static constant)
+
+ //keyboard output
+ //5 bit led ctrl: NumLock CapsLock ScrollLock Compose kana
+ 0x95, 0x05, //Report Count (5)
+ 0x75, 0x01, //Report Size (1)
+ 0x05, 0x08, //Usage Pg (LEDs )
+ 0x19, 0x01, //Usage Min
+ 0x29, 0x05, //Usage Max
+ 0x91, 0x02, //Output (Data, Variable, Absolute)
+ //3 bit reserved
+ 0x95, 0x01, //Report Count (1)
+ 0x75, 0x03, //Report Size (3)
+ 0x91, 0x01, //Output (static constant)
+
+ // Key arrays (6 bytes)
+ 0x95, 0x06, // Report Count (6)
+ 0x75, 0x08, // Report Size (8)
+ 0x15, 0x1e, // Log Min (0)
+ 0x25, 0xF1, // Log Max (241)
+ 0x05, 0x07, // Usage Pg (Key Codes)
+ 0x19, 0x1e, // Usage Min (0)
+ 0x29, 0xf1, // Usage Max (241)
+ 0x81, 0x00, // Input: (Data, Array)
+
+ 0xC0, // End Collection
+
+#if (TL_AUDIO_MODE & TL_AUDIO_MASK_HID_SERVICE_CHANNEL) //HID Service
+ //consumer report in
+ 0x05, 0x0C, // Usage Page (Consumer)
+ 0x09, 0x01, // Usage (Consumer Control)
+ 0xA1, 0x01, // Collection (Application)
+ 0x85, HID_REPORT_ID_CONSUME_CONTROL_INPUT, // Report Id
+ 0x75,0x10, //global, report size 16 bits
+ 0x95,0x0A, //global, report count 1
+ 0x15,0x01, //global, min 0x01
+ 0x26,0x8c,0x02, //global, max 0x28c
+ 0x19,0x01, //local, min 0x01
+ 0x2a,0x8c,0x02, //local, max 0x28c
+ 0x81,0x00, //main, input data variable, absolute
+ 0xc0, //main, end collection
+
+ //audio 3
+ 0x05, 0x0c,
+ 0x09, 0x01,
+ 0xA1, 0x01,
+ 0x85, HID_REPORT_ID_AUDIO_THIRD_INPUT,
+ 0x95, 0x14,
+ 0x75, 0x08,
+ 0x15, 0x00,
+ 0x26, 0xff, 0x00,
+ 0x81, 0x00,
+ 0xC0,
+ //audio 1
+ 0x05, 0x0c,
+ 0x09, 0x01,
+ 0xA1, 0x01,
+ 0x85, HID_REPORT_ID_AUDIO_FIRST_INPUT,
+ 0x95, 0x14,
+ 0x75, 0x08,
+ 0x15, 0x00,
+ 0x26, 0xff, 0x00,
+ 0x81, 0x00,
+ 0xC0,
+ //audio 2
+ 0x05, 0x0c,
+ 0x09, 0x01,
+ 0xA1, 0x01,
+ 0x85, HID_REPORT_ID_AUDIO_SECND_INPUT,
+ 0x95, 0x14,
+ 0x75, 0x08,
+ 0x15, 0x00,
+ 0x26, 0xff, 0x00,
+ 0x81, 0x00,
+ 0xC0,
+#else
+ //consumer report in
+ 0x05, 0x0C, // Usage Page (Consumer)
+ 0x09, 0x01, // Usage (Consumer Control)
+ 0xA1, 0x01, // Collection (Application)
+ 0x85, HID_REPORT_ID_CONSUME_CONTROL_INPUT, // Report Id
+ 0x75,0x10, //global, report size 16 bits
+ 0x95,0x02, //global, report count 2
+ 0x15,0x01, //global, min 0x01
+ 0x26,0x8c,0x02, //global, max 0x28c
+ 0x19,0x01, //local, min 0x01
+ 0x2a,0x8c,0x02, //local, max 0x28c
+ 0x81,0x00, //main, input data variable, absolute
+ 0xc0, //main, end collection
+#endif
+
+
+};
+
+// HID External Report Reference Descriptor for report map
+static u16 extServiceUUID;
+
+
+/////////////////////////////////////////////////////////
+
+static const u8 my_OtaUUID[16] = {TELINK_SPP_DATA_OTA};
+static const u8 my_OtaServiceUUID[16] = TELINK_OTA_UUID_SERVICE;
+
+static u8 my_OtaData = 0x00;
+_attribute_data_retention_ u16 my_Otaccc = 0;
+
+static const u8 my_OtaName[] = {'O', 'T', 'A'};
+
+#if (MP_TEST_MODE)
+static const u8 my_TestModeServiceUUID[16] = {TEST_MODE_SERVICE_UUID};
+static const u8 my_TestDataUUID[16] = {TEST_MODE_TEST_DATA_UUID};
+
+static u8 my_TestData = 0x00;
+static u8 my_TestDataCCC[2] = { 0x00, };
+#endif
+
+
+// Include attribute (Battery service)
+static const u16 include[3] = {BATT_PS_H, BATT_LEVEL_INPUT_CCB_H, SERVICE_UUID_BATTERY};
+
+
+//// GAP attribute values
+static const u8 my_devNameCharVal[5] = {
+ CHAR_PROP_READ | CHAR_PROP_NOTIFY,
+ U16_LO(GenericAccess_DeviceName_DP_H), U16_HI(GenericAccess_DeviceName_DP_H),
+ U16_LO(GATT_UUID_DEVICE_NAME), U16_HI(GATT_UUID_DEVICE_NAME)
+};
+static const u8 my_appearanceCharVal[5] = {
+ CHAR_PROP_READ,
+ U16_LO(GenericAccess_Appearance_DP_H), U16_HI(GenericAccess_Appearance_DP_H),
+ U16_LO(GATT_UUID_APPEARANCE), U16_HI(GATT_UUID_APPEARANCE)
+};
+static const u8 my_periConnParamCharVal[5] = {
+ CHAR_PROP_READ,
+ U16_LO(CONN_PARAM_DP_H), U16_HI(CONN_PARAM_DP_H),
+ U16_LO(GATT_UUID_PERI_CONN_PARAM), U16_HI(GATT_UUID_PERI_CONN_PARAM)
+};
+
+
+//// GATT attribute values
+static const u8 my_serviceChangeCharVal[5] = {
+ CHAR_PROP_INDICATE,
+ U16_LO(GenericAttribute_ServiceChanged_DP_H), U16_HI(GenericAttribute_ServiceChanged_DP_H),
+ U16_LO(GATT_UUID_SERVICE_CHANGE), U16_HI(GATT_UUID_SERVICE_CHANGE)
+};
+
+//// device Information attribute values
+static const u8 my_PnCharVal[5] = {
+ CHAR_PROP_READ,
+ U16_LO(DeviceInformation_pnpID_DP_H), U16_HI(DeviceInformation_pnpID_DP_H),
+ U16_LO(CHARACTERISTIC_UUID_PNP_ID), U16_HI(CHARACTERISTIC_UUID_PNP_ID)
+};
+
+static const u8 my_FWRevCharVal[5] = {
+ CHAR_PROP_READ,
+ U16_LO(DeviceInformation_firmwareRev_DP_H), U16_HI(DeviceInformation_firmwareRev_DP_H),
+ U16_LO(CHARACTERISTIC_UUID_FW_REVISION_STRING), U16_HI(CHARACTERISTIC_UUID_FW_REVISION_STRING)
+};
+
+
+static const u8 my_HWRevCharVal[5] = {
+ CHAR_PROP_READ,
+ U16_LO(DeviceInformation_hardwareRev_DP_H), U16_HI(DeviceInformation_hardwareRev_DP_H),
+ U16_LO(CHARACTERISTIC_UUID_HW_REVISION_STRING), U16_HI(CHARACTERISTIC_UUID_HW_REVISION_STRING)
+};
+
+static const u8 my_SWRevCharVal[5] = {
+ CHAR_PROP_READ,
+ U16_LO(DeviceInformation_softwareRev_DP_H), U16_HI(DeviceInformation_softwareRev_DP_H),
+ U16_LO(CHARACTERISTIC_UUID_SW_REVISION_STRING), U16_HI(CHARACTERISTIC_UUID_SW_REVISION_STRING)
+};
+
+
+
+//// HID attribute values
+static const u8 my_hidProtocolModeCharVal[5] = {
+ CHAR_PROP_READ | CHAR_PROP_WRITE_WITHOUT_RSP,
+ U16_LO(HID_PROTOCOL_MODE_DP_H), U16_HI(HID_PROTOCOL_MODE_DP_H),
+ U16_LO(CHARACTERISTIC_UUID_HID_PROTOCOL_MODE), U16_HI(CHARACTERISTIC_UUID_HID_PROTOCOL_MODE)
+};
+static const u8 my_hidbootKeyInReporCharVal[5] = {
+ CHAR_PROP_READ | CHAR_PROP_NOTIFY,
+ U16_LO(HID_BOOT_KB_REPORT_INPUT_DP_H), U16_HI(HID_BOOT_KB_REPORT_INPUT_DP_H),
+ U16_LO(CHARACTERISTIC_UUID_HID_BOOT_KEY_INPUT), U16_HI(CHARACTERISTIC_UUID_HID_BOOT_KEY_INPUT)
+};
+static const u8 my_hidbootKeyOutReporCharVal[5] = {
+ CHAR_PROP_READ | CHAR_PROP_WRITE | CHAR_PROP_WRITE_WITHOUT_RSP,
+ U16_LO(HID_BOOT_KB_REPORT_OUTPUT_DP_H), U16_HI(HID_BOOT_KB_REPORT_OUTPUT_DP_H),
+ U16_LO(CHARACTERISTIC_UUID_HID_BOOT_KEY_OUTPUT), U16_HI(CHARACTERISTIC_UUID_HID_BOOT_KEY_OUTPUT)
+};
+static const u8 my_hidReportCCinCharVal[5] = {
+ CHAR_PROP_READ | CHAR_PROP_NOTIFY,
+ U16_LO(HID_CONSUME_REPORT_INPUT_DP_H), U16_HI(HID_CONSUME_REPORT_INPUT_DP_H),
+ U16_LO(CHARACTERISTIC_UUID_HID_REPORT), U16_HI(CHARACTERISTIC_UUID_HID_REPORT)
+};
+static const u8 my_hidReportKEYinCharVal[5] = {
+ CHAR_PROP_READ | CHAR_PROP_NOTIFY,
+ U16_LO(HID_NORMAL_KB_REPORT_INPUT_DP_H), U16_HI(HID_NORMAL_KB_REPORT_INPUT_DP_H),
+ U16_LO(CHARACTERISTIC_UUID_HID_REPORT), U16_HI(CHARACTERISTIC_UUID_HID_REPORT)
+};
+static const u8 my_hidReportKEYoutCharVal[5] = {
+ CHAR_PROP_READ | CHAR_PROP_WRITE | CHAR_PROP_WRITE_WITHOUT_RSP,
+ U16_LO(HID_NORMAL_KB_REPORT_OUTPUT_DP_H), U16_HI(HID_NORMAL_KB_REPORT_OUTPUT_DP_H),
+ U16_LO(CHARACTERISTIC_UUID_HID_REPORT), U16_HI(CHARACTERISTIC_UUID_HID_REPORT)
+};
+static const u8 my_hidReportMapCharVal[5] = {
+ CHAR_PROP_READ,
+ U16_LO(HID_REPORT_MAP_DP_H), U16_HI(HID_REPORT_MAP_DP_H),
+ U16_LO(CHARACTERISTIC_UUID_HID_REPORT_MAP), U16_HI(CHARACTERISTIC_UUID_HID_REPORT_MAP)
+};
+static const u8 my_hidinformationCharVal[5] = {
+ CHAR_PROP_READ,
+ U16_LO(HID_INFORMATION_DP_H), U16_HI(HID_INFORMATION_DP_H),
+ U16_LO(CHARACTERISTIC_UUID_HID_INFORMATION), U16_HI(CHARACTERISTIC_UUID_HID_INFORMATION)
+};
+static const u8 my_hidCtrlPointCharVal[5] = {
+ CHAR_PROP_WRITE_WITHOUT_RSP,
+ U16_LO(HID_CONTROL_POINT_DP_H), U16_HI(HID_CONTROL_POINT_DP_H),
+ U16_LO(CHARACTERISTIC_UUID_HID_CONTROL_POINT), U16_HI(CHARACTERISTIC_UUID_HID_CONTROL_POINT)
+};
+
+
+//// Battery attribute values
+static const u8 my_batCharVal[5] = {
+ CHAR_PROP_READ | CHAR_PROP_NOTIFY,
+ U16_LO(BATT_LEVEL_INPUT_DP_H), U16_HI(BATT_LEVEL_INPUT_DP_H),
+ U16_LO(CHARACTERISTIC_UUID_BATTERY_LEVEL), U16_HI(CHARACTERISTIC_UUID_BATTERY_LEVEL)
+};
+
+
+//// OTA attribute values
+static const u8 my_OtaCharVal[19] = {
+// CHAR_PROP_READ | CHAR_PROP_WRITE_WITHOUT_RSP | CHAR_PROP_NOTIFY,
+
+ CHAR_PROP_READ | CHAR_PROP_NOTIFY | CHAR_PROP_WRITE_WITHOUT_RSP,
+ U16_LO(OTA_CMD_OUT_DP_H), U16_HI(OTA_CMD_OUT_DP_H),
+ TELINK_SPP_DATA_OTA,
+};
+
+#if (MP_TEST_MODE)
+/// Test Mode attribute values
+static const u8 my_TestCharVal[19] = {
+ CHAR_PROP_READ | CHAR_PROP_WRITE | CHAR_PROP_WRITE_WITHOUT_RSP | CHAR_PROP_NOTIFY,
+ U16_LO(TEST_MODE_DP_H), U16_HI(TEST_MODE_DP_H),
+ TEST_MODE_TEST_DATA_UUID,
+};
+#endif
+
+#endif // CFG_ATM_SDK
+
+#if APP_IR_OVER_BLE
+static const u8 my_IrUUID[16] = {TELINK_IR_UUID_SERVICE};
+static const u8 my_Ir_ProgControlUUID[16] = {TELINK_IR_PROG_CONTROL_UUID_SERVICE};
+static const u8 my_Ir_KeyIdUUID[16] = {TELINK_IR_KEY_ID_UUID_SERVICE};
+static const u8 my_Ir_CodeUUID[16] = {TELINK_IR_CODE_UUID_SERVICE};
+static const u8 my_Ir_SuppressUUID[16] = {TELINK_IR_SUPPRESS_UUID_SERVICE};
+static const u8 my_Ir_KeyEventUUID[16] = {TELINK_IR_KEY_EVENT_UUID_SERVICE};
+
+
+static const u8 my_Ir_ProgControl_CharVal[19] = {
+ CHAR_PROP_WRITE,
+ U16_LO(IR_PROG_OUT_CONTROL_H), U16_HI(IR_PROG_OUT_CONTROL_H),
+ TELINK_IR_PROG_CONTROL_UUID_SERVICE
+};
+static const u8 my_Ir_Key_Id_CharVal[19] = {
+ CHAR_PROP_WRITE,
+ U16_LO(IR_KEY_ID_H), U16_HI(IR_KEY_ID_H),
+ TELINK_IR_KEY_ID_UUID_SERVICE
+};
+static const u8 my_Ir_Code_CharVal[19] = {
+ CHAR_PROP_WRITE,
+ U16_LO(IR_CODE_H), U16_HI(IR_CODE_H),
+ TELINK_IR_CODE_UUID_SERVICE
+};
+static const u8 my_Ir_Suppress_CharVal[19] = {
+ CHAR_PROP_WRITE,
+ U16_LO(IR_SUPPRESS_H), U16_HI(IR_SUPPRESS_H),
+ TELINK_IR_SUPPRESS_UUID_SERVICE
+};
+static const u8 my_Ir_Key_Event_CharVal[19] = {
+ CHAR_PROP_NOTIFY,
+ U16_LO(IR_KEY_EVENT_H), U16_HI(IR_KEY_EVENT_H),
+ TELINK_IR_KEY_EVENT_UUID_SERVICE
+};
+u8 ir_data[1] = {0};
+#endif
+
+
+#if BLE_AUDIO_ENABLE
+//// Audio attribute values
+ #include "application/audio/gl_audio.h"
+
+ u8 atv_char_tx_data[20] = {0};
+ u8 atv_char_rx_data[1] = {0};
+ u8 atv_char_ctl_data[1] = {0};
+
+ static const u8 ATVV_Server_UUID[16] = AUDIO_GOOGLE_SERVICE_UUID;
+
+ static const u8 ATVV_Char_UUID_TX[16] = {AUDIO_GOOGL_TX_CHAR_UUID};
+ static const u8 ATVV_Char_UUID_RX[16] = {AUDIO_GOOGL_RX_CHAR_UUID};
+ static const u8 ATVV_Char_UUID_CTL[16] = {AUDIO_GOOGL_CTL_CHAR_UUID};
+
+ static const u8 my_MicCharTx[20] = {
+ CHAR_PROP_READ | CHAR_PROP_WRITE_WITHOUT_RSP | CHAR_PROP_NOTIFY,
+ U16_LO(AUDIO_GOOGLE_TX_DP_H), U16_HI(AUDIO_GOOGLE_TX_DP_H),
+ AUDIO_GOOGL_TX_CHAR_UUID,
+ };
+
+ static const u8 my_MicCharRx[20] = {
+ CHAR_PROP_READ | CHAR_PROP_NOTIFY,
+ U16_LO(AUDIO_GOOGLE_RX_DP_H), U16_HI(AUDIO_GOOGLE_RX_DP_H),
+ AUDIO_GOOGL_RX_CHAR_UUID,
+ };
+
+ static const u8 my_MicCharCtl[20] = {
+ CHAR_PROP_READ | CHAR_PROP_NOTIFY,
+ U16_LO(AUDIO_GOOGLE_CTL_DP_H), U16_HI(AUDIO_GOOGLE_CTL_DP_H),
+ AUDIO_GOOGL_CTL_CHAR_UUID,
+ };
+
+#endif
+
+#if FIND_ME_ENABLE
+
+static const u8 FMS_Server_UUID[16] = {GOOGLE_FMS_SERVfICE_UUID};
+static const u8 FMS_Char_UUID_CTL[16] = {GOOGLE_FMS_CTL_CHAR_UUID};
+static const u8 FMS_Char_UUID_DATA[16] = {GOOGLE_FMS_DATA_CHAR_UUID};
+
+_attribute_data_retention_ u16 my_fms_data_ccc = 0;
+
+static const u8 my_fms_CharCtlVal[19] = {
+ CHAR_PROP_READ | CHAR_PROP_WRITE_WITHOUT_RSP,
+ U16_LO(FMS_GOOGLE_CTL_DP_H), U16_HI(FMS_GOOGLE_CTL_DP_H),
+ GOOGLE_FMS_CTL_CHAR_UUID
+};
+
+static const u8 my_fms_CharDataVal[19] = {
+ CHAR_PROP_READ | CHAR_PROP_WRITE_WITHOUT_RSP | CHAR_PROP_NOTIFY,
+ U16_LO(FMS_GOOGLE_DATA_DP_H), U16_HI(FMS_GOOGLE_DATA_DP_H),
+ GOOGLE_FMS_DATA_CHAR_UUID
+};
+
+#endif
+
+extern void app_set_mtusize(void);
+extern void ir_fallback_process(u16 handle, u8* buf, u16 len);
+int app_ir_callback(void *p)
+{
+ u16 handle,len;
+ u16 printf_len;
+
+ rf_packet_att_data_t *pw = (rf_packet_att_data_t *)p;
+ handle = pw->handle;
+
+ //printf("handle = %x\r\n",handle);
+ //printf("pw->l2cap=%x\r\n",pw->l2cap-3);
+ //printf("dat=\r\n");
+
+ len = pw->l2cap-3;//pw->rf_len-7;
+ printf_len = len;
+ #if 0
+ if(printf_len > 6)
+ printf_len = 6;
+ for(u16 i=0;i<printf_len;i++)
+ printf(" %x",pw->dat[i]);
+ #endif
+ //printf("len=%x\r\n",len);
+#ifndef CFG_ATM_SDK
+ app_set_mtusize();
+#endif
+ ir_fallback_process(handle,pw->dat,len);
+
+ return 0;
+}
+
+
+int app_necir_or_dataupdate(void *p)
+{
+ u16 handle,len;
+ u16 printf_len;
+
+ rf_packet_att_data_t *pw = (rf_packet_att_data_t *)p;
+ handle = pw->handle;
+
+ //printf("handle = %x\r\n",handle);
+ //printf("pw->l2cap=%x\r\n",pw->l2cap-3);
+ //printf("app_nec_ir_table_callback handle=%x\r\n",handle);
+
+ len = pw->l2cap-3;//pw->rf_len-7;
+ printf_len = len;
+
+ #if 0
+ printf("len=%x\r\n",len);
+ for(u8 i=0;i<printf_len;i++)
+ printf(" %x",pw->dat[i]);
+ #endif
+
+#if APP_IR_OVER_BLE
+ ir_nec_ir_table_process(pw->dat,len);
+#endif
+
+#if APP_DATA_UPDATE_OVER_BLE
+ app_custom_data_update_process(pw->dat,len);
+#endif
+
+ return 0;
+}
+
+int app_ota_handle(void * p){
+
+ int result=0;
+
+ app_necir_or_dataupdate(p);
+
+ result = app_ota_write(p);
+
+ return result;
+}
+
+ static const attribute_t my_Attributes[] = {
+#if (MP_TEST_MODE)
+ {ATT_END_H - 1 - 4, 0,0,0,0,0}, // total num of attribute
+#else
+ {ATT_END_H - 1, 0,0,0,0,0}, // total num of attribute
+#endif
+#ifndef CFG_ATM_SDK
+ // 0001 - 0007 gap (1-7)
+ {7,ATT_PERMISSIONS_READ,2,2,(u8*)(&my_primaryServiceUUID), (u8*)(&my_gapServiceUUID), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_devNameCharVal),(u8*)(&my_characterUUID), (u8*)(my_devNameCharVal), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(_custom_data.device_name), (u8*)(&my_devNameUUID), (u8*)(_custom_data.device_name), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_appearanceCharVal),(u8*)(&my_characterUUID), (u8*)(my_appearanceCharVal), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof (my_appearance), (u8*)(&my_appearanceUIID), (u8*)(&my_appearance), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_periConnParamCharVal),(u8*)(&my_characterUUID), (u8*)(my_periConnParamCharVal), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof (my_periConnParameters),(u8*)(&my_periConnParamUUID), (u8*)(&my_periConnParameters), 0},
+
+
+ // 0008 - 000b gatt (8-11)
+ {4,ATT_PERMISSIONS_READ,2,2,(u8*)(&my_primaryServiceUUID), (u8*)(&my_gattServiceUUID), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_serviceChangeCharVal),(u8*)(&my_characterUUID), (u8*)(my_serviceChangeCharVal), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof (serviceChangeVal), (u8*)(&serviceChangeUUID), (u8*)(&serviceChangeVal), 0},
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof (serviceChangeCCC),(u8*)(&clientCharacterCfgUUID), (u8*)(serviceChangeCCC), 0},
+
+ // 000c - 000e device Information Service
+ //PnP ID (12-14)
+
+ {9,ATT_PERMISSIONS_READ,2,2,(u8*)(&my_primaryServiceUUID), (u8*)(&my_devServiceUUID), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_PnCharVal),(u8*)(&my_characterUUID), (u8*)(my_PnCharVal), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof (_custom_data.pnp_id),(u8*)(&my_PnPUUID), (u8*)(_custom_data.pnp_id), 0},
+
+ //firmware revision string (15-16)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_FWRevCharVal),(u8*)(&my_characterUUID), (u8*)(my_FWRevCharVal), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof (my_FWRevtrs),(u8*)(&my_FWRevUUID), (u8*)(my_FWRevtrs), 0},
+
+ //software revision string (17-18)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_SWRevCharVal),(u8*)(&my_characterUUID), (u8*)(my_SWRevCharVal), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof (my_SWRevtrs),(u8*)(&my_SWRevUUID), (u8*)(my_SWRevtrs), 0},
+
+ //hardware revision string (19-20)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_HWRevCharVal),(u8*)(&my_characterUUID), (u8*)(my_HWRevCharVal), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof (my_HWRevtrs),(u8*)(&my_HWRevUUID), (u8*)(my_HWRevtrs), 0},
+
+ /////////////////////////////////// 4. HID Service /////////////////////////////////////////////////////////
+ // 000f (21)
+ //{27, ATT_PERMISSIONS_READ,2,2,(u8*)(&my_primaryServiceUUID), (u8*)(&my_hidServiceUUID), 0},
+ {HID_CONTROL_POINT_DP_H - HID_PS_H + 1, ATT_PERMISSIONS_READ,2,2,(u8*)(&my_primaryServiceUUID), (u8*)(&my_hidServiceUUID), 0},
+
+ // 0010 include battery service (22)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(include),(u8*)(&hidIncludeUUID), (u8*)(include), 0},
+
+ // 0011 - 0012 protocol mode (23-24)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_hidProtocolModeCharVal),(u8*)(&my_characterUUID), (u8*)(my_hidProtocolModeCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_READ,2, sizeof(protocolMode),(u8*)(&hidProtocolModeUUID), (u8*)(&protocolMode), 0}, //value
+
+ // 0013 - 0015 boot keyboard input report (char-val-client) (25-27)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_hidbootKeyInReporCharVal),(u8*)(&my_characterUUID), (u8*)(my_hidbootKeyInReporCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_READ,2,sizeof(bootKeyInReport),(u8*)(&hidbootKeyInReportUUID), (u8*)(&bootKeyInReport), 0}, //value
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(bootKeyInReportCCC),(u8*)(&clientCharacterCfgUUID), (u8*)(bootKeyInReportCCC), 0}, //value
+
+ // 0016 - 0017 boot keyboard output report (char-val) (28-29)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_hidbootKeyOutReporCharVal),(u8*)(&my_characterUUID), (u8*)(my_hidbootKeyOutReporCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_RDWR,2, sizeof(bootKeyOutReport), (u8*)(&hidbootKeyOutReportUUID), (u8*)(&bootKeyOutReport), 0}, //value
+
+
+ // 0018 - 001b. consume report in: 4 (char-val-client-ref) (30-33)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_hidReportCCinCharVal),(u8*)(&my_characterUUID), (u8*)(my_hidReportCCinCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_READ,2, sizeof(reportConsumerControlIn),(u8*)(&hidReportUUID), (u8*)(reportConsumerControlIn), 0}, //value
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(reportConsumerControlInCCC),(u8*)(&clientCharacterCfgUUID), (u8*)(reportConsumerControlInCCC), 0}, //value
+ {0,ATT_PERMISSIONS_READ,2,sizeof(reportRefConsumerControlIn),(u8*)(&reportRefUUID), (u8*)(reportRefConsumerControlIn), 0}, //value
+
+ // 001c - 001f . keyboard report in : 4 (char-val-client-ref) (34-37)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_hidReportKEYinCharVal),(u8*)(&my_characterUUID), (u8*)(my_hidReportKEYinCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_READ,2, sizeof(reportKeyIn),(u8*)(&hidReportUUID), (u8*)(reportKeyIn), 0}, //value
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(reportKeyInCCC),(u8*)(&clientCharacterCfgUUID), (u8*)(reportKeyInCCC), 0}, //value
+ {0,ATT_PERMISSIONS_READ,2,sizeof(reportRefKeyIn),(u8*)(&reportRefUUID), (u8*)(reportRefKeyIn), 0}, //value
+
+ // 0020 - 0022 . keyboard report out: 3 (char-val-ref) (38-40)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_hidReportKEYoutCharVal),(u8*)(&my_characterUUID), (u8*)(my_hidReportKEYoutCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(reportKeyOut),(u8*)(&hidReportUUID), (u8*)(reportKeyOut), 0}, //value
+ {0,ATT_PERMISSIONS_READ,2,sizeof(reportRefKeyOut),(u8*)(&reportRefUUID), (u8*)(reportRefKeyOut), 0}, //value
+
+ // 0023 - 0025 . report map: 3 (41-43)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_hidReportMapCharVal),(u8*)(&my_characterUUID), (u8*)(my_hidReportMapCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_READ,2,sizeof(reportMap),(u8*)(&hidReportMapUUID), (u8*)(reportMap), 0}, //value
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(extServiceUUID),(u8*)(&extReportRefUUID), (u8*)(&extServiceUUID), 0}, //value
+
+ // 0026 - 0027 . hid information: 2 (44-45)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_hidinformationCharVal),(u8*)(&my_characterUUID), (u8*)(my_hidinformationCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_READ,2, sizeof(hidInformation),(u8*)(&hidinformationUUID), (u8*)(hidInformation), 0}, //value
+
+ // 0028 - 0029 . control point: 2 (46-47)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_hidCtrlPointCharVal),(u8*)(&my_characterUUID), (u8*)(my_hidCtrlPointCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_WRITE,2, sizeof(controlPoint),(u8*)(&hidCtrlPointUUID), (u8*)(&controlPoint), 0}, //value
+
+
+ ////////////////////////////////////// Battery Service /////////////////////////////////////////////////////
+ // 002a - 002d (48-51)
+ {4,ATT_PERMISSIONS_READ,2,2,(u8*)(&my_primaryServiceUUID), (u8*)(&my_batServiceUUID), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_batCharVal),(u8*)(&my_characterUUID), (u8*)(my_batCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_batVal),(u8*)(&my_batCharUUID), (u8*)(my_batVal), 0}, //value
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(batteryValueInCCC),(u8*)(&clientCharacterCfgUUID), (u8*)(batteryValueInCCC), 0}, //value
+
+ ////////////////////////////////////// OTA /////////////////////////////////////////////////////
+ // 002e - 0031 (52-56)
+ {5,ATT_PERMISSIONS_READ, 2,16,(u8*)(&my_primaryServiceUUID), (u8*)(&my_OtaServiceUUID), 0},
+ {0,ATT_PERMISSIONS_READ, 2, sizeof(my_OtaCharVal),(u8*)(&my_characterUUID), (u8*)(my_OtaCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_RDWR,16,sizeof(my_OtaData),(u8*)(&my_OtaUUID), (&my_OtaData), &app_ota_handle, 0},//&otaRead}, //value
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(my_Otaccc),(u8*)(&clientCharacterCfgUUID),(u8*)(&my_Otaccc), &att_ccc_control},
+ {0,ATT_PERMISSIONS_READ, 2,sizeof (my_OtaName),(u8*)(&userdesc_UUID), (u8*)(my_OtaName), 0},
+#endif // CFG_ATM_SDK
+
+ ////////////////////////////////////// Audio /////////////////////////////////////////////////////
+ /********************************************************************************************
+ * GOOGLE AUDIO service
+ ********************************************************************************************/
+#if BLE_AUDIO_ENABLE
+ //0032 (57-65)
+ {9,ATT_PERMISSIONS_READ,2,16, (u8*)(&my_primaryServiceUUID), (u8*)(&ATVV_Server_UUID), 0},
+ //TX 0033-0034
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(my_MicCharTx),(u8*)(&my_characterUUID),(u8*)(my_MicCharTx), 0},
+ {0,ATT_PERMISSIONS_RDWR,16,sizeof(atv_char_tx_data),(u8*)(&ATVV_Char_UUID_TX),(u8*)(&atv_char_tx_data), &app_auido_google_callback}, //value
+ //RX 0035 - 0037
+#ifdef CFG_ATM_SDK
+ {0,ATT_PERMISSIONS_READ,2,256,(u8*)(&my_characterUUID),(u8*)(my_MicCharRx), 0},
+#else
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_MicCharRx),(u8*)(&my_characterUUID),(u8*)(my_MicCharRx), 0},
+#endif
+ {0,ATT_PERMISSIONS_READ,16,sizeof(atv_char_rx_data),(u8*)(&ATVV_Char_UUID_RX),(u8*)(&atv_char_rx_data), 0},
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(atv_char_rx_ccc),(u8*)(&clientCharacterCfgUUID),(u8*)(&atv_char_rx_ccc), &att_ccc_control},
+// {0,ATT_PERMISSIONS_RDWR,2,sizeof(atv_char_rx_ccc),(u8*)(&clientCharacterCfgUUID),(u8*)(&atv_char_rx_ccc), 0},
+
+ //CTRL 0038 -003A
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_MicCharCtl),(u8*)(&my_characterUUID),(u8*)(my_MicCharCtl), 0},
+ {0,ATT_PERMISSIONS_READ,16,sizeof(atv_char_ctl_data),(u8*)(&ATVV_Char_UUID_CTL),(u8*)(&atv_char_ctl_data), 0},
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(atv_char_ctl_ccc),(u8*)(&clientCharacterCfgUUID),(u8*)(&atv_char_ctl_ccc), &att_ccc_control},
+// {0,ATT_PERMISSIONS_RDWR,2,sizeof(atv_char_ctl_ccc),(u8*)(&clientCharacterCfgUUID),(u8*)(&atv_char_ctl_ccc), 0},
+#endif
+
+ ////////////////////////////////////// IR /////////////////////////////////////////////////////
+#if APP_IR_OVER_BLE
+ //IR 003C (66-77)
+ {12,ATT_PERMISSIONS_READ,2,16,(u8*)(&my_primaryServiceUUID), (u8*)(&my_IrUUID), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_Ir_ProgControl_CharVal),(u8*)(&my_characterUUID), (u8*)(my_Ir_ProgControl_CharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_RDWR,16,sizeof(ir_data),(u8*)(&my_Ir_ProgControlUUID), (u8*)(ir_data), &app_ir_callback},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_Ir_Key_Id_CharVal),(u8*)(&my_characterUUID), (u8*)(my_Ir_Key_Id_CharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_RDWR,16,sizeof(ir_data),(u8*)(&my_Ir_KeyIdUUID), (u8*)(ir_data), &app_ir_callback},
+#ifdef CFG_ATM_SDK
+ // Fix incorrect attribute data size
+ {0,ATT_PERMISSIONS_READ,2,256,(u8*)(&my_characterUUID), (u8*)(my_Ir_Code_CharVal), 0}, //prop
+#else
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_Ir_Code_CharVal),(u8*)(&my_characterUUID), (u8*)(my_Ir_Code_CharVal), 0}, //prop
+#endif
+ {0,ATT_PERMISSIONS_RDWR,16,sizeof(ir_data),(u8*)(&my_Ir_CodeUUID), (u8*)(ir_data),&app_ir_callback},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_Ir_Suppress_CharVal),(u8*)(&my_characterUUID), (u8*)(my_Ir_Suppress_CharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_RDWR,16,sizeof(ir_data),(u8*)(&my_Ir_SuppressUUID), (u8*)(ir_data), &app_ir_callback},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_Ir_Key_Event_CharVal),(u8*)(&my_characterUUID), (u8*)(my_Ir_Key_Event_CharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_RDWR,16,sizeof(ir_data),(u8*)(&my_Ir_KeyEventUUID), (u8*)(ir_data), 0},
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(ir_data),(u8*)(&clientCharacterCfgUUID), (u8*)(ir_data), &app_ir_callback},
+#endif
+
+#if FIND_ME_ENABLE
+ {6,ATT_PERMISSIONS_READ,2,16,(u8*)(&my_primaryServiceUUID), (u8*)(&FMS_Server_UUID), 0},
+
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_fms_CharCtlVal),(u8*)(&my_characterUUID), (u8*)(my_fms_CharCtlVal), 0},
+ {0,ATT_PERMISSIONS_RDWR,16,2,(u8*)(&FMS_Char_UUID_CTL),(u8 *) g_p_app_fms_ctrl_val, &app_fms_att_ctl_cb},
+
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_fms_CharDataVal),(u8*)(&my_characterUUID),(u8*)(my_fms_CharDataVal), 0},
+ {0,ATT_PERMISSIONS_RDWR,16,2,(u8*)(&FMS_Char_UUID_DATA),(u8 *)g_p_app_fms_data_val, &app_fms_att_data_cb},
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(my_fms_data_ccc),(u8*)(&clientCharacterCfgUUID),(u8*)(&my_fms_data_ccc), &att_ccc_control},
+
+#endif
+
+ };
+
+#if (MP_TEST_MODE)
+ static const attribute_t my_test_dome_Attributes[] = {
+
+ {ATT_END_H - 1, 0,0,0,0,0}, // total num of attribute
+
+
+ /////////////////////////////////// 1. Gap /////////////////////////////////////////////////////////
+ // 0001 - 0007 (1-7)
+ {7,ATT_PERMISSIONS_READ,2,2,(u8*)(&my_primaryServiceUUID), (u8*)(&my_gapServiceUUID), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_devNameCharVal),(u8*)(&my_characterUUID), (u8*)(my_devNameCharVal), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(_custom_data.device_name), (u8*)(&my_devNameUUID), (u8*)(_custom_data.device_name), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_appearanceCharVal),(u8*)(&my_characterUUID), (u8*)(my_appearanceCharVal), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof (my_appearance), (u8*)(&my_appearanceUIID), (u8*)(&my_appearance), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_periConnParamCharVal),(u8*)(&my_characterUUID), (u8*)(my_periConnParamCharVal), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof (my_periConnParameters),(u8*)(&my_periConnParamUUID), (u8*)(&my_periConnParameters), 0},
+
+
+ /////////////////////////////////// 2. Gatt ////////////////////////////////////////////////////////
+ // 0008 - 000b (8-11)
+ {4,ATT_PERMISSIONS_READ,2,2,(u8*)(&my_primaryServiceUUID), (u8*)(&my_gattServiceUUID), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_serviceChangeCharVal),(u8*)(&my_characterUUID), (u8*)(my_serviceChangeCharVal), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof (serviceChangeVal), (u8*)(&serviceChangeUUID), (u8*)(&serviceChangeVal), 0},
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof (serviceChangeCCC),(u8*)(&clientCharacterCfgUUID), (u8*)(serviceChangeCCC), 0},
+
+
+ /////////////////////////////////// 3. Device Information Service //////////////////////////////////
+ // 000c - 0014
+ // PnP ID (12-14)
+ {9,ATT_PERMISSIONS_READ,2,2,(u8*)(&my_primaryServiceUUID), (u8*)(&my_devServiceUUID), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_PnCharVal),(u8*)(&my_characterUUID), (u8*)(my_PnCharVal), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof (_custom_data.pnp_id),(u8*)(&my_PnPUUID), (u8*)(_custom_data.pnp_id), 0},
+
+ // firmware revision string (15-16)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_FWRevCharVal),(u8*)(&my_characterUUID), (u8*)(my_FWRevCharVal), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof (my_FWRevtrs),(u8*)(&my_FWRevUUID), (u8*)(my_FWRevtrs), 0},
+
+ // software revision string (17-18)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_SWRevCharVal),(u8*)(&my_characterUUID), (u8*)(my_SWRevCharVal), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof (my_SWRevtrs),(u8*)(&my_SWRevUUID), (u8*)(my_SWRevtrs), 0},
+
+ // hardware revision string (19-20)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_HWRevCharVal),(u8*)(&my_characterUUID), (u8*)(my_HWRevCharVal), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof (my_HWRevtrs),(u8*)(&my_HWRevUUID), (u8*)(my_HWRevtrs), 0},
+
+
+ /////////////////////////////////// 4. HID Service /////////////////////////////////////////////////
+ // 0015 - 002F
+ // primary (21)
+ {HID_CONTROL_POINT_DP_H - HID_PS_H + 1, ATT_PERMISSIONS_READ,2,2,(u8*)(&my_primaryServiceUUID), (u8*)(&my_hidServiceUUID), 0},
+
+ // include battery service (22)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(include),(u8*)(&hidIncludeUUID), (u8*)(include), 0},
+
+ // protocol mode (23-24)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_hidProtocolModeCharVal),(u8*)(&my_characterUUID), (u8*)(my_hidProtocolModeCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_RDWR,2, sizeof(protocolMode),(u8*)(&hidProtocolModeUUID), (u8*)(&protocolMode), 0}, //value
+
+ // boot keyboard input report (char-val-client) (25-27)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_hidbootKeyInReporCharVal),(u8*)(&my_characterUUID), (u8*)(my_hidbootKeyInReporCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_READ,2,sizeof(bootKeyInReport),(u8*)(&hidbootKeyInReportUUID), (u8*)(&bootKeyInReport), 0}, //value
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(bootKeyInReportCCC),(u8*)(&clientCharacterCfgUUID), (u8*)(bootKeyInReportCCC), 0}, //value
+
+ // boot keyboard output report (char-val) (28-29)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_hidbootKeyOutReporCharVal),(u8*)(&my_characterUUID), (u8*)(my_hidbootKeyOutReporCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_RDWR,2, sizeof(bootKeyOutReport), (u8*)(&hidbootKeyOutReportUUID), (u8*)(&bootKeyOutReport), 0}, //value
+
+ // consume report in: 4 (char-val-client-ref) (30-33)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_hidReportCCinCharVal),(u8*)(&my_characterUUID), (u8*)(my_hidReportCCinCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_READ,2, sizeof(reportConsumerControlIn),(u8*)(&hidReportUUID), (u8*)(reportConsumerControlIn), 0}, //value
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(reportConsumerControlInCCC),(u8*)(&clientCharacterCfgUUID), (u8*)(reportConsumerControlInCCC), 0}, //value
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(reportRefConsumerControlIn),(u8*)(&reportRefUUID), (u8*)(reportRefConsumerControlIn), 0}, //value
+
+ // keyboard report in : 4 (char-val-client-ref) (34-37)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_hidReportKEYinCharVal),(u8*)(&my_characterUUID), (u8*)(my_hidReportKEYinCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_READ,2, sizeof(reportKeyIn),(u8*)(&hidReportUUID), (u8*)(reportKeyIn), 0}, //value
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(reportKeyInCCC),(u8*)(&clientCharacterCfgUUID), (u8*)(reportKeyInCCC), 0}, //value
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(reportRefKeyIn),(u8*)(&reportRefUUID), (u8*)(reportRefKeyIn), 0}, //value
+
+ // keyboard report out: 3 (char-val-ref) (38-40)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_hidReportKEYoutCharVal),(u8*)(&my_characterUUID), (u8*)(my_hidReportKEYoutCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(reportKeyOut),(u8*)(&hidReportUUID), (u8*)(reportKeyOut), 0}, //value
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(reportRefKeyOut),(u8*)(&reportRefUUID), (u8*)(reportRefKeyOut), 0}, //value
+
+ // report map: 3 (41-43)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_hidReportMapCharVal),(u8*)(&my_characterUUID), (u8*)(my_hidReportMapCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_READ,2,sizeof(reportMap),(u8*)(&hidReportMapUUID), (u8*)(reportMap), 0}, //value
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(extServiceUUID),(u8*)(&extReportRefUUID), (u8*)(&extServiceUUID), 0}, //value
+
+ // hid information: 2 (44-45)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_hidinformationCharVal),(u8*)(&my_characterUUID), (u8*)(my_hidinformationCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_READ,2, sizeof(hidInformation),(u8*)(&hidinformationUUID), (u8*)(hidInformation), 0}, //value
+
+ // control point: 2 (46-47)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_hidCtrlPointCharVal),(u8*)(&my_characterUUID), (u8*)(my_hidCtrlPointCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_WRITE,2, sizeof(controlPoint),(u8*)(&hidCtrlPointUUID), (u8*)(&controlPoint), 0}, //value
+
+
+ /////////////////////////////////// 5. Battery Service /////////////////////////////////////////////
+ // 0030 - 0033 (48-51)
+ {4,ATT_PERMISSIONS_READ,2,2,(u8*)(&my_primaryServiceUUID), (u8*)(&my_batServiceUUID), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_batCharVal),(u8*)(&my_characterUUID), (u8*)(my_batCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_batVal),(u8*)(&my_batCharUUID), (u8*)(my_batVal), 0}, //value
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(batteryValueInCCC),(u8*)(&clientCharacterCfgUUID), (u8*)(batteryValueInCCC), 0}, //value
+
+
+ /////////////////////////////////// 6. OTA /////////////////////////////////////////////////////////
+ // 0034 - 0038 (52-56)
+ {5,ATT_PERMISSIONS_READ, 2,16,(u8*)(&my_primaryServiceUUID), (u8*)(&my_OtaServiceUUID), 0},
+ {0,ATT_PERMISSIONS_READ, 2, sizeof(my_OtaCharVal),(u8*)(&my_characterUUID), (u8*)(my_OtaCharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_RDWR,16,sizeof(my_OtaData),(u8*)(&my_OtaUUID), (&my_OtaData), &app_ota_write, 0},//&otaRead}, //value
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(my_Otaccc),(u8*)(&clientCharacterCfgUUID),(u8*)(&my_Otaccc), &att_ccc_control},
+ {0,ATT_PERMISSIONS_READ, 2,sizeof (my_OtaName),(u8*)(&userdesc_UUID), (u8*)(my_OtaName), 0},
+
+
+ /////////////////////////////////// 7. Audio ///////////////////////////////////////////////////////
+ /********************************************************************************************
+ * GOOGLE AUDIO service
+ ********************************************************************************************/
+ // 0039 - 0041
+ // primary (57)
+#if BLE_AUDIO_ENABLE
+ {9,ATT_PERMISSIONS_READ,2,16, (u8*)(&my_primaryServiceUUID), (u8*)(&ATVV_Server_UUID), 0},
+
+ // TX (58-59)
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(my_MicCharTx),(u8*)(&my_characterUUID),(u8*)(my_MicCharTx), 0},
+ {0,ATT_PERMISSIONS_RDWR,16,sizeof(atv_char_tx_data),(u8*)(&ATVV_Char_UUID_TX),(u8*)(&atv_char_tx_data), &app_auido_google_callback}, //value
+
+ // RX (60-62)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_MicCharRx),(u8*)(&my_characterUUID),(u8*)(my_MicCharRx), 0},
+ {0,ATT_PERMISSIONS_READ,16,sizeof(atv_char_rx_data),(u8*)(&ATVV_Char_UUID_RX),(u8*)(&atv_char_rx_data), 0},
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(atv_char_rx_ccc),(u8*)(&clientCharacterCfgUUID),(u8*)(&atv_char_rx_ccc), &att_ccc_control},
+
+ // CTRL (63-65)
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_MicCharCtl),(u8*)(&my_characterUUID),(u8*)(my_MicCharCtl), 0},
+ {0,ATT_PERMISSIONS_READ,16,sizeof(atv_char_ctl_data),(u8*)(&ATVV_Char_UUID_CTL),(u8*)(&atv_char_ctl_data), 0},
+ {0,ATT_PERMISSIONS_RDWR,2,sizeof(atv_char_ctl_ccc),(u8*)(&clientCharacterCfgUUID),(u8*)(&atv_char_ctl_ccc), &att_ccc_control},
+#endif
+
+ /////////////////////////////////// 8. IR //////////////////////////////////////////////////////////
+ // 0042 - 004D (66-77)
+#if APP_IR_OVER_BLE
+ {12,ATT_PERMISSIONS_READ,2,16,(u8*)(&my_primaryServiceUUID), (u8*)(&my_IrUUID), 0},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_Ir_ProgControl_CharVal),(u8*)(&my_characterUUID), (u8*)(my_Ir_ProgControl_CharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_RDWR,16,0,(u8*)(&my_Ir_ProgControlUUID), 0, &app_ir_callback},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_Ir_Key_Id_CharVal),(u8*)(&my_characterUUID), (u8*)(my_Ir_Key_Id_CharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_RDWR,16,0,(u8*)(&my_Ir_KeyIdUUID), 0, &app_ir_callback},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_Ir_Code_CharVal),(u8*)(&my_characterUUID), (u8*)(my_Ir_Code_CharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_RDWR,16,0,(u8*)(&my_Ir_CodeUUID), 0,&app_ir_callback},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_Ir_Suppress_CharVal),(u8*)(&my_characterUUID), (u8*)(my_Ir_Suppress_CharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_RDWR,16,0,(u8*)(&my_Ir_SuppressUUID), 0, &app_ir_callback},
+ {0,ATT_PERMISSIONS_READ,2,sizeof(my_Ir_Key_Event_CharVal),(u8*)(&my_characterUUID), (u8*)(my_Ir_Key_Event_CharVal), 0}, //prop
+ {0,ATT_PERMISSIONS_RDWR,16,0,(u8*)(&my_Ir_KeyEventUUID), 0, 0},
+ {0,ATT_PERMISSIONS_RDWR,2,0,(u8*)(&clientCharacterCfgUUID), 0, &app_ir_callback},
+#endif
+
+ /////////////////////////////////// 9. TEST MODE ///////////////////////////////////////////////////
+ // 004E - 0051 (78-81)
+ {4, ATT_PERMISSIONS_READ, 2, 16, (u8*)(&my_primaryServiceUUID), (u8*)(&my_TestModeServiceUUID), 0},
+ {0, ATT_PERMISSIONS_READ, 2, sizeof(my_TestCharVal), (u8*)(&my_characterUUID), (u8*)(my_TestCharVal), 0}, //prop
+ {0, ATT_PERMISSIONS_WRITE, 16, sizeof(my_TestData), (u8*)(&my_TestDataUUID), (&my_TestData), &test_write_cb, 0}, //value
+ {0, ATT_PERMISSIONS_RDWR, 2, sizeof(my_TestDataCCC), (u8*)(&clientCharacterCfgUUID), (u8*)(my_TestDataCCC), 0},
+
+ };
+#endif
+
+
+void my_att_init (void)
+{
+#if (MP_TEST_MODE)
+ if (test_get_mode() == MODE_TEST) bls_att_setAttributeTable((u8 *)my_test_dome_Attributes);
+ else
+#endif
+ bls_att_setAttributeTable ((u8 *)my_Attributes);
+}
+
+#ifndef CFG_ATM_SDK
+void init_device_info (void)
+{
+ //u8 my_FWRevtrs [] = {'V','1','.','1','.','1'};
+ //u8 my_SWRevtrs [] = {'V','1','.','0','2'};
+ my_FWRevtrs[1] = ((FW_VERSION>>28)&0x0f) + 48;
+ //my_FWRevtrs[3] = ((FW_VERSION>>24)&0x0f) + 48;
+ //my_FWRevtrs[5] = ((FW_VERSION>>20)&0x0f) + 48;
+
+// my_SWRevtrs[1] = ((FW_VERSION>>8)&0x0f) + 48;
+// my_SWRevtrs[3] = ((FW_VERSION>>4)&0x0f) + 48;
+// my_SWRevtrs[4] = (FW_VERSION&0x0f) + 48;
+}
+#endif