
O Android oferece uma pilha Bluetooth padrão compatível com o Bluetooth clássico e o Bluetooth de baixa energia. Usando o Bluetooth, os dispositivos Android podem criar redes de área pessoal para enviar e receber dados com dispositivos Bluetooth próximos.
No Android 4.3 e versões mais recentes, a pilha Bluetooth do Android oferece a capacidade de implementar Bluetooth de baixa energia (BLE). Para usar totalmente as APIs BLE, siga os Requisitos de HCI do Bluetooth do Android. Dispositivos Android com um chipset qualificado podem implementar o Bluetooth clássico ou os dois. O BLE não é compatível com versões anteriores de chipsets Bluetooth.
No Android 8.0, a pilha Bluetooth é totalmente qualificada para Bluetooth 5. Para usar os recursos disponíveis do Bluetooth 5, o dispositivo precisa ter um chipset qualificado para Bluetooth 5.
Arquitetura do Android
Um app Bluetooth se comunica com o processo Bluetooth usando o Binder. O processo do Bluetooth usa JNI para se comunicar com a pilha do Bluetooth e oferece aos desenvolvedores acesso a vários perfis do Bluetooth. Este diagrama mostra a estrutura geral da pilha Bluetooth:
Figura 1. Arquitetura do Bluetooth do Android.
- framework de app
-
No nível do framework do app, há o código do app, que usa as
APIs
android.bluetooth
para interagir com o hardware Bluetooth. Internamente, esse código chama o processo Bluetooth pelo mecanismo Binder IPC. - App Bluetooth
-
O app Bluetooth, localizado em
packages/modules/Bluetooth/android/app
, é empacotado como um app Android e implementa os perfis Bluetooth na camada do framework Android. Esse app chama a pilha Bluetooth usando a JNI. - JNI
-
O código JNI associado a android.bluetooth está localizado em
packages/modules/Bluetooth/android/app/jni
. O código JNI chama a pilha Bluetooth quando determinadas operações Bluetooth ocorrem, como quando os dispositivos são descobertos. - Pilha Bluetooth
-
A pilha Bluetooth padrão é fornecida no AOSP e está localizada em
packages/modules/Bluetooth/system
. A pilha implementa a HAL genérica do Bluetooth e a personaliza com extensões e mudanças de configuração. - implementação do fornecedor
- Os dispositivos do fornecedor interagem com a pilha Bluetooth usando a linguagem de design de interface de hardware (HIDL, na sigla em inglês).
HIDL
O HIDL define a interface entre a
pilha Bluetooth e a implementação do fornecedor. Para gerar os arquivos HIDL do Bluetooth, transmita os arquivos de interface do Bluetooth para a ferramenta de geração do HIDL. Os arquivos de interface estão localizados em
hardware/interfaces/bluetooth
.
Desenvolvimento de pilha Bluetooth
A pilha Bluetooth do Android é totalmente qualificada. A lista de qualificação está no site da Bluetooth SIG em QDID 169365.
A pilha Bluetooth principal reside em
packages/modules/Bluetooth
. O desenvolvimento acontece no AOSP, e as contribuições são bem-vindas.
Arquitetura do Android 7.x e versões anteriores
Um serviço do sistema Bluetooth se comunica com a pilha Bluetooth usando JNI e com apps usando Binder IPC. O serviço do sistema oferece aos desenvolvedores acesso a vários perfis Bluetooth. Este diagrama mostra a estrutura geral da pilha Bluetooth:
Figura 2. Arquitetura Bluetooth do Android 7.x e versões anteriores.
- framework de app
-
No nível do framework do app, há o código do app, que usa as
APIs
android.bluetooth
para interagir com o hardware Bluetooth. Internamente, esse código chama o processo Bluetooth pelo mecanismo Binder IPC. - Serviço do sistema Bluetooth
-
O serviço do sistema Bluetooth, localizado em
packages/apps/Bluetooth
, é empacotado como um app Android e implementa o serviço e os perfis Bluetooth na camada do framework Android. Esse app chama a camada HAL usando a JNI. - JNI
-
O código JNI associado a
android.bluetooth
está localizado em
packages/apps/Bluetooth/jni
. O código JNI chama a camada HAL e recebe callbacks da HAL quando determinadas operações Bluetooth ocorrem, como quando dispositivos são descobertos. - HAL
-
A camada de abstração de hardware define a interface padrão que as APIs
android.bluetooth
e o processo do Bluetooth chamam e que você precisa implementar para que o hardware
Bluetooth funcione corretamente. O arquivo de cabeçalho para a HAL do Bluetooth é
hardware/libhardware/include/hardware/bluetooth.h
. Além disso, revise todos os arquivoshardware/libhardware/include/hardware/bt_*.h
. - Pilha Bluetooth
-
A pilha Bluetooth padrão é fornecida para você e está localizada em
system/bt
. A pilha implementa o HAL genérico do Bluetooth e o personaliza com extensões e mudanças de configuração. - extensões de fornecedor
- Para adicionar extensões personalizadas e uma camada de HCI para rastreamento, crie um módulo libbt-vendor e especifique esses componentes.
Implementar a HAL
O HAL do Bluetooth está localizado em
/hardware/libhardware/include/hardware/bluetooth.h
. O arquivo
bluetooth.h
contém a interface básica da pilha Bluetooth, e você
precisa implementar as funções dele.
Os arquivos específicos do perfil estão localizados no mesmo diretório. Para mais detalhes, consulte a referência do arquivo HAL.