В этом документе описывается структура объекта интерфейса поставщика (объект VINTF), который собирает соответствующую информацию об устройстве и делает эту информацию доступной через запрашиваемый API .
ВИНТФ объектный дизайн
Объект VINTF собирает часть необходимой ему информации непосредственно с устройства. Другие аспекты, такие как манифесты, описываются статически в XML.
Объектный дизайн VINTF обеспечивает следующее для компонентов устройства и фреймворка:
Для устройства | Для фреймворка |
---|---|
|
|
Объект VINTF должен быть надежным и предоставлять одинаковую полную информацию независимо от того, когда объект запрашивается (см. Предостережения ).
Манифесты и матрицы
Начиная с Android 8.0, API среды выполнения запрашивает, что находится на устройстве, и отправляет эту информацию на сервер обновлений по беспроводной сети (OTA) и другим заинтересованным сторонам (например, CTS DeviceInfo
). Часть информации извлекается во время выполнения, а часть определяется статически.
- Манифест устройства описывает статический компонент того, что устройство может предоставить платформе.
- Матрица совместимости платформы описывает, что платформа Android ожидает от данного устройства. Матрица представляет собой статическую сущность, состав которой определяется вручную при разработке следующего релиза Android-фреймворка.
- Манифест фреймворка описывает службы высокого уровня, которые фреймворк может предоставить устройству.
- Матрица совместимости устройств описывает службы, которые образ поставщика требует от платформы. Его состав определяется вручную при разработке устройства.
Эти две пары манифестов и матриц должны быть согласованы во время OTA, чтобы гарантировать, что устройство может получать обновления платформы, совместимые с возможностями устройства. Как правило, манифест описывает, что предоставляется, а матрица совместимости описывает, что требуется.
Этот раздел включает следующие сведения о манифестах и матрицах:
- Манифесты определяют манифест устройства, манифест платформы и схему файла манифеста.
- Матрицы совместимости определяет схему матрицы совместимости.
- Жизненный цикл FCM подробно описывает, как HIDL HAL устаревают и удаляются, а также как файлы FCM модифицируются, чтобы отразить состояние версии HAL.
- DM Development описывает, как поставщики могут определять и объявлять целевую версию FCM в манифесте устройства для новых устройств или внедрять новые версии HAL и увеличивать целевую версию FCM при обновлении образа поставщика для старых устройств.
- Правила сопоставления определяют правила для успешного сопоставления матрицы совместимости и манифеста.