Bluetooth

Symbol für Android Bluetooth HAL

Android bietet einen standardmäßigen Bluetooth-Stack, der sowohl Classic Bluetooth als auch Bluetooth Low Energy (BLE) unterstützt. Über Bluetooth können Android-Geräte Personal Area Networks erstellen, um Daten mit Bluetooth-Geräten in der Nähe zu senden und zu empfangen.

In Android 4.3 und höher bietet der Android-Bluetooth-Stack die Möglichkeit, BLE zu implementieren. Wenn Sie die BLE-APIs vollständig nutzen möchten, müssen Sie die Android Bluetooth HCI Requirements (Anforderungen an die Bluetooth-HCI-Schnittstelle von Android) einhalten. Auf Android-Geräten mit einem geeigneten Chipsatz kann entweder Classic Bluetooth oder sowohl Classic Bluetooth als auch BLE implementiert werden. BLE ist nicht mit älteren Bluetooth-Chipsätzen abwärtskompatibel.

In Android 8.0 ist der Bluetooth-Stack vollständig für Bluetooth 5 qualifiziert. Damit die verfügbaren Bluetooth 5-Funktionen genutzt werden können, muss das Gerät einen Bluetooth 5-kompatiblen Chipsatz haben.

Android-Architektur

Eine Bluetooth-App kommuniziert über Binder mit dem Bluetooth-Prozess. Der Bluetooth-Prozess verwendet Java Native Interface (JNI), um mit dem Bluetooth-Stack zu kommunizieren, und bietet Entwicklern Zugriff auf verschiedene Bluetooth-Profile. Dieses Diagramm zeigt die allgemeine Struktur des Bluetooth-Stacks:

Diagramm mit den Ebenen des Android-Bluetooth-Stacks.

Abbildung 1: Android-Bluetooth-Architektur.

App-Framework
Auf der Ebene des App-Frameworks befindet sich der App-Code, der die android.bluetooth APIs verwendet, um mit der Bluetooth-Hardware zu interagieren. Intern wird mit diesem Code der Bluetooth-Prozess über den Binder-IPC-Mechanismus aufgerufen.
Bluetooth-App
Die Bluetooth-App, die sich unter packages/modules/Bluetooth/android/app befindet, ist als Android-App verpackt und implementiert die Bluetooth-Profile auf der Android-Framework-Ebene. Diese App ruft den Bluetooth-Stack über JNI auf.
JNI
Der mit android.bluetooth verknüpfte JNI-Code befindet sich unter packages/modules/Bluetooth/android/app/jni. Der JNI-Code ruft den Bluetooth-Stack auf, wenn bestimmte Bluetooth-Vorgänge ausgeführt werden, z. B. wenn Geräte gefunden werden.
Bluetooth-Stack
Der Standard-Bluetooth-Stack ist in AOSP enthalten und befindet sich unter packages/modules/Bluetooth/system. Der Stack implementiert die generische Bluetooth-HAL und passt sie mit Erweiterungen und Konfigurationsänderungen an.
Anbieterimplementierung
Anbietergeräte interagieren über die HAL-Schnittstellendefinitionssprache (HIDL) mit dem Bluetooth-Stack.

HIDL

HIDL definiert die Schnittstelle zwischen dem Bluetooth-Stack und der Anbieterimplementierung. Um die Bluetooth-HIDL-Dateien zu generieren, übergeben Sie die Bluetooth-Schnittstellendateien an das HIDL-Generierungstool. Die Schnittstellendateien befinden sich in hardware/interfaces/bluetooth.

Entwicklung des Bluetooth-Stacks

Der Android-Bluetooth-Stack ist ein vollständig qualifizierter Bluetooth-Stack. Die Qualifizierungsliste finden Sie auf der Bluetooth SIG-Website (Anmeldung erforderlich) unter QDID 169365.

Der Bluetooth-Kern-Stack befindet sich in packages/modules/Bluetooth. Die Entwicklung erfolgt in AOSP und Beiträge sind willkommen.