mirror of
				https://github.com/esphome/esphome.git
				synced 2025-10-26 12:43:48 +00:00 
			
		
		
		
	[bluetooth_proxy] Optimize UUID transmission with efficient short_uuid field (#9995)
This commit is contained in:
		| @@ -24,6 +24,24 @@ static void fill_128bit_uuid_array(std::array<uint64_t, 2> &out, esp_bt_uuid_t u | ||||
|            ((uint64_t) uuid.uuid.uuid128[1] << 8) | ((uint64_t) uuid.uuid.uuid128[0]); | ||||
| } | ||||
|  | ||||
| // Helper to fill UUID in the appropriate format based on client support and UUID type | ||||
| static void fill_gatt_uuid(std::array<uint64_t, 2> &uuid_128, uint32_t &short_uuid, const esp_bt_uuid_t &uuid, | ||||
|                            bool use_efficient_uuids) { | ||||
|   if (!use_efficient_uuids || uuid.len == ESP_UUID_LEN_128) { | ||||
|     // Use 128-bit format for old clients or when UUID is already 128-bit | ||||
|     fill_128bit_uuid_array(uuid_128, uuid); | ||||
|   } else if (uuid.len == ESP_UUID_LEN_16) { | ||||
|     short_uuid = uuid.uuid.uuid16; | ||||
|   } else if (uuid.len == ESP_UUID_LEN_32) { | ||||
|     short_uuid = uuid.uuid.uuid32; | ||||
|   } | ||||
| } | ||||
|  | ||||
| bool BluetoothConnection::supports_efficient_uuids_() const { | ||||
|   auto *api_conn = this->proxy_->get_api_connection(); | ||||
|   return api_conn && api_conn->client_supports_api_version(1, 12); | ||||
| } | ||||
|  | ||||
| void BluetoothConnection::dump_config() { | ||||
|   ESP_LOGCONFIG(TAG, "BLE Connection:"); | ||||
|   BLEClientBase::dump_config(); | ||||
| @@ -74,6 +92,9 @@ void BluetoothConnection::send_service_for_discovery_() { | ||||
|     return; | ||||
|   } | ||||
|  | ||||
|   // Check if client supports efficient UUIDs | ||||
|   bool use_efficient_uuids = this->supports_efficient_uuids_(); | ||||
|  | ||||
|   // Prepare response for up to 3 services | ||||
|   api::BluetoothGATTGetServicesResponse resp; | ||||
|   resp.address = this->address_; | ||||
| @@ -100,7 +121,9 @@ void BluetoothConnection::send_service_for_discovery_() { | ||||
|     this->send_service_++; | ||||
|     resp.services.emplace_back(); | ||||
|     auto &service_resp = resp.services.back(); | ||||
|     fill_128bit_uuid_array(service_resp.uuid, service_result.uuid); | ||||
|  | ||||
|     fill_gatt_uuid(service_resp.uuid, service_resp.short_uuid, service_result.uuid, use_efficient_uuids); | ||||
|  | ||||
|     service_resp.handle = service_result.start_handle; | ||||
|  | ||||
|     // Get the number of characteristics directly with one call | ||||
| @@ -145,7 +168,9 @@ void BluetoothConnection::send_service_for_discovery_() { | ||||
|  | ||||
|       service_resp.characteristics.emplace_back(); | ||||
|       auto &characteristic_resp = service_resp.characteristics.back(); | ||||
|       fill_128bit_uuid_array(characteristic_resp.uuid, char_result.uuid); | ||||
|  | ||||
|       fill_gatt_uuid(characteristic_resp.uuid, characteristic_resp.short_uuid, char_result.uuid, use_efficient_uuids); | ||||
|  | ||||
|       characteristic_resp.handle = char_result.char_handle; | ||||
|       characteristic_resp.properties = char_result.properties; | ||||
|       char_offset++; | ||||
| @@ -189,7 +214,9 @@ void BluetoothConnection::send_service_for_discovery_() { | ||||
|  | ||||
|         characteristic_resp.descriptors.emplace_back(); | ||||
|         auto &descriptor_resp = characteristic_resp.descriptors.back(); | ||||
|         fill_128bit_uuid_array(descriptor_resp.uuid, desc_result.uuid); | ||||
|  | ||||
|         fill_gatt_uuid(descriptor_resp.uuid, descriptor_resp.short_uuid, desc_result.uuid, use_efficient_uuids); | ||||
|  | ||||
|         descriptor_resp.handle = desc_result.handle; | ||||
|         desc_offset++; | ||||
|       } | ||||
|   | ||||
| @@ -27,6 +27,7 @@ class BluetoothConnection : public esp32_ble_client::BLEClientBase { | ||||
|  protected: | ||||
|   friend class BluetoothProxy; | ||||
|  | ||||
|   bool supports_efficient_uuids_() const; | ||||
|   void send_service_for_discovery_(); | ||||
|   void reset_connection_(esp_err_t reason); | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user