HCI — это аббревиатура интерфейса хост-контроллера, который является мостом между хостом и контроллером в четвертой части базовой спецификации Bluetooth 5.3.
HCI Command packet
Команда HCI — это команда, отправляемая стеком протокола Bluetooth на чип Bluetooth. Она имеет двухбайтовый код операции, из которых OCF занимает 10 бит, OGF — 6 бит, а длина параметра — один байт. длина параметра использует один байт. Это означает, что максимальное количество последующих параметров равно 255, а максимальная длина всей команды — 258.
Каждая команда имеет свой собственный код операции для выполнения. Этот код операции уникален и OCF является одной из групп. В каталоге КОМАНДЫ И СОБЫТИЯ HCI каждый субтитр имеет OGF, и каждый субтитр в нем имеет свой OGF. команда имеет свой собственный OCF (есть также 0x3F, который зарезервирован для производителей, чтобы определить их самостоятельно)
Например, на этом снимке экрана OGF LINK CONTROL — 0x01, а OCF Inquiry — 0x0001. Комбинированный код операции этих двух представляет HCI_Inquiry. Остальные принципы команды такие же.
Далее открываем лог hci и смотрим hci_reset. Wireshark нам его разобрал и OGF, и OCF — 3, и тоже понятно, как они складываются, смещаются на два места влево и затем объединяются. с ОКФ.
Выполните поиск по OGF и OCF, а также найдете его в базовой спецификации.
Найдите другой с параметрами и посмотрите формат.
Позиционирование в основных спецификациях позиционирования согласно OGF и OCF
Всего параметров два, один — BD_ADDR (адрес Bluetooth), длина — 6 байт, другой — Role (роль), длина — 1 байт.
HCI Event packet
Событие HCI — это событие, сообщаемое чипом Bluetooth в стек протоколов Bluetooth. По сравнению с командой формат данных события относительно прост. Для обнаружения события можно напрямую использовать код события.
Например, код события HCI_Command_Status — 0xf.
Стандартный процесс инициализации SIG
Далее давайте рассмотрим стандартный процесс инициализации Bluetooth через журнал HCI.
Первый выпуск HCI Reset,Эквивалент мягкого сброса чипа,OGF да 0x03,OCF 也да 0x0003, у него нет параметров
Чип ответит Command Полный, его event code да 0x0e, есть три параметра, Num_HCI_Command_Packets, 1 байт, соответствующие Number of Allowed Command Packets Указывает количество пакетов данных, которые можно отправить.
Command Opcode Да command из opcode,Return_Parameters переписываться Status: Success (0x00) указывает на статус
Read Local Version Information Читать версию чипа, переписыватьсяиз OGF да 0x04,OCF да 0x01, он возвращает больше параметров
Главное да вернул чип Bluetooth из информации о версии
Эти издания переписываютсяиз нумеруются:
https://www.bluetooth.com/specifications/assigned-numbers/
Определение на стр. 7, HCI Version Дапротокол Bluetoothиз Версия
Read Buffer Size,Размер буфера чтения OGF до 0x04,OCF да 0x05,нет параметров,Размер буфера для управления потоком, используемый из
Read BD ADDR Получить адрес Bluetooth, OGF да 0x04,OCF да 0x09, возвращает статус и адрес Bluetooth.
Write Class of Device настраивать Class of Device,OGF да 0x03,OCF да 0x024 используется для идентификации типа устройства.,При сопряжении мобильного телефона с устройством Bluetooth перед телефоном отображаются типы значков гарнитуры и клавиатуры. cod Чтобы отметить из, смотрите подробности:
https://blog.csdn.net/XiaoXiaoPengBo/article/details/108366776
Write Local NameнастраиватьBluetooth-устройствоизимя,OGFда0x03,OCFда0x013,Есть параметр имя устройства
Write Page Timeout Роль дана. controller настройки Тайм-аут, в течение которого controller Если по истечении этого времени вы по-прежнему не можете подключиться к одноранговому устройству, дайте host Отчет
Set Event Mask да host Рассказывать controller Какие события вы хотите принять, а какие нет, контролер Просто отчет host Хотите получать изиз событий
Write Simple Pairing Mode данастраивать SSP метод сопряжения, если Simple Pairing Mode да disable изразговаривать Да PINCODE метод, вам необходимо вручную ввести код сопряжения, если обе стороны; Simple Pairing Mode enable изразговаривать,Появится небольшое окно с кодом сопряжения.,Нажмите на форму сопряжения
Write Inquiry Mode настройки режим поиска Предусмотрено три режима поиска.
В первом режиме каждое устройство предоставляет стандартную информацию только один раз, включая адрес Bluetooth и код. Подождите, как бы не менялся уровень сигнала, только один раз Отчет Второй режим добавит мощность сигнала на основе стандартной информации Bluetooth. RSSI, повторит отчет Третий режим принесет EIR Принесет имя Bluetooth, поддержку из UUID Как и пользовательская информация, Отчет будет повторяться.
этот пакет Да Рассказывать Рассказывать Чипу нужен третий режим,Информация, поддерживаемая партнером, должна быть получена с помощью результата запроса в формате RSSI или расширенного формата результата запроса.
Write Scan Enable настраивать scan режим, есть два режима, один да Inquiry Scan своего рода Page Сканировать, только если оно включено Inquiry Scan можно искать только если он включен Page Scan Для того, чтобы подключиться, здесь все включено, то есть можно искать и подключаться.
Write LE Host Supported Этот шаг эквивалентен включению да LE
Write LE Host Supported настраивать EIR Информация, подробнее узнайте позже
На этом инициализация заканчивается.,дальше вниз Да Одноранговое устройствоиз Запрошено соединение
Если только да хочет, чтобы его искали, HCI Сброс одно, один Записать локальное имя, Включить сканирование достаточно