mirror of
				https://github.com/esphome/esphome.git
				synced 2025-10-31 07:03:55 +00:00 
			
		
		
		
	Merge branch 'ble_services_opt' into integration
This commit is contained in:
		| @@ -13,16 +13,17 @@ namespace bluetooth_proxy { | ||||
|  | ||||
| static const char *const TAG = "bluetooth_proxy.connection"; | ||||
|  | ||||
| static std::vector<uint64_t> get_128bit_uuid_vec(esp_bt_uuid_t uuid_source) { | ||||
| static void set_128bit_uuid_vec(std::vector<uint64_t> &out, esp_bt_uuid_t uuid_source) { | ||||
|   esp_bt_uuid_t uuid = espbt::ESPBTUUID::from_uuid(uuid_source).as_128bit().get_uuid(); | ||||
|   return std::vector<uint64_t>{((uint64_t) uuid.uuid.uuid128[15] << 56) | ((uint64_t) uuid.uuid.uuid128[14] << 48) | | ||||
|                                    ((uint64_t) uuid.uuid.uuid128[13] << 40) | ((uint64_t) uuid.uuid.uuid128[12] << 32) | | ||||
|                                    ((uint64_t) uuid.uuid.uuid128[11] << 24) | ((uint64_t) uuid.uuid.uuid128[10] << 16) | | ||||
|                                    ((uint64_t) uuid.uuid.uuid128[9] << 8) | ((uint64_t) uuid.uuid.uuid128[8]), | ||||
|                                ((uint64_t) uuid.uuid.uuid128[7] << 56) | ((uint64_t) uuid.uuid.uuid128[6] << 48) | | ||||
|                                    ((uint64_t) uuid.uuid.uuid128[5] << 40) | ((uint64_t) uuid.uuid.uuid128[4] << 32) | | ||||
|                                    ((uint64_t) uuid.uuid.uuid128[3] << 24) | ((uint64_t) uuid.uuid.uuid128[2] << 16) | | ||||
|                                    ((uint64_t) uuid.uuid.uuid128[1] << 8) | ((uint64_t) uuid.uuid.uuid128[0])}; | ||||
|   out.reserve(2); | ||||
|   out.emplace_back(((uint64_t) uuid.uuid.uuid128[15] << 56) | ((uint64_t) uuid.uuid.uuid128[14] << 48) | | ||||
|                    ((uint64_t) uuid.uuid.uuid128[13] << 40) | ((uint64_t) uuid.uuid.uuid128[12] << 32) | | ||||
|                    ((uint64_t) uuid.uuid.uuid128[11] << 24) | ((uint64_t) uuid.uuid.uuid128[10] << 16) | | ||||
|                    ((uint64_t) uuid.uuid.uuid128[9] << 8) | ((uint64_t) uuid.uuid.uuid128[8])); | ||||
|   out.emplace_back(((uint64_t) uuid.uuid.uuid128[7] << 56) | ((uint64_t) uuid.uuid.uuid128[6] << 48) | | ||||
|                    ((uint64_t) uuid.uuid.uuid128[5] << 40) | ((uint64_t) uuid.uuid.uuid128[4] << 32) | | ||||
|                    ((uint64_t) uuid.uuid.uuid128[3] << 24) | ((uint64_t) uuid.uuid.uuid128[2] << 16) | | ||||
|                    ((uint64_t) uuid.uuid.uuid128[1] << 8) | ((uint64_t) uuid.uuid.uuid128[0])); | ||||
| } | ||||
|  | ||||
| void BluetoothConnection::dump_config() { | ||||
| @@ -97,7 +98,7 @@ void BluetoothConnection::send_service_for_discovery_() { | ||||
|   resp.address = this->address_; | ||||
|   resp.services.emplace_back(); | ||||
|   auto &service_resp = resp.services.back(); | ||||
|   service_resp.uuid = get_128bit_uuid_vec(service_result.uuid); | ||||
|   set_128bit_uuid_vec(service_resp.uuid, service_result.uuid); | ||||
|   service_resp.handle = service_result.start_handle; | ||||
|  | ||||
|   // Get the number of characteristics directly with one call | ||||
| @@ -136,7 +137,7 @@ void BluetoothConnection::send_service_for_discovery_() { | ||||
|  | ||||
|     service_resp.characteristics.emplace_back(); | ||||
|     auto &characteristic_resp = service_resp.characteristics.back(); | ||||
|     characteristic_resp.uuid = get_128bit_uuid_vec(char_result.uuid); | ||||
|     set_128bit_uuid_vec(characteristic_resp.uuid, char_result.uuid); | ||||
|     characteristic_resp.handle = char_result.char_handle; | ||||
|     characteristic_resp.properties = char_result.properties; | ||||
|     char_offset++; | ||||
| @@ -176,7 +177,7 @@ void BluetoothConnection::send_service_for_discovery_() { | ||||
|  | ||||
|       characteristic_resp.descriptors.emplace_back(); | ||||
|       auto &descriptor_resp = characteristic_resp.descriptors.back(); | ||||
|       descriptor_resp.uuid = get_128bit_uuid_vec(desc_result.uuid); | ||||
|       set_128bit_uuid_vec(descriptor_resp.uuid, desc_result.uuid); | ||||
|       descriptor_resp.handle = desc_result.handle; | ||||
|       desc_offset++; | ||||
|     } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user