Android 10 ou version ultérieure inclut plusieurs composants multimédias pouvant être mis à jour qui permettent de mettre à jour les composants du framework via l'infrastructure du Google Play Store ou via un mécanisme OTA (Over-the-Air) fourni par un partenaire. Les composants multimédias sont empaquetés dans des modules qui permettent de fournir des mises à jour de sécurité et de fonctionnalités sans nécessiter de mise à jour complète de l'image système.
Les composants multimédias pouvant être mis à jour se trouvent dans les modules suivants.
Media. Ce module inclut des extracteurs multimédias, des API
MediaSession2
et des APIMediaParser
.Codecs multimédias Ce module inclut des composants logiciels Codec2 pouvant être mis à jour.
MediaProvider Ce module optimise les métadonnées indexées (audio, vidéo et images provenant de cartes SD et d'appareils USB) et met ces données à la disposition des applications via les API publiques MediaStore.
Pour en savoir plus sur l'ajout d'extracteurs et de décodeurs personnalisés, consultez la section Personnaliser les composants multimédias.
Extracteurs multimédias
Sous Android 9 ou version antérieure, les extracteurs sont compilés dans un seul fichier libstagefright.so
. Sous Android 10 ou version ultérieure, les extracteurs multimédias sont des composants distincts. Chaque extracteur possède son propre fichier .so
avec un point d'entrée qui fournit une fonction sniffer pour déterminer si l'extracteur peut gérer le fichier multimédia donné, ainsi qu'une fonction factory qui crée une instance de l'extracteur pour le fichier multimédia donné. Chaque extracteur est nommé (pour faciliter le débogage) et numéroté pour indiquer lequel est le plus récent.
Le framework multimédia charge automatiquement tous les fichiers .so
d'extracteur disponibles. Vous pouvez donc créer vos propres extracteurs en ajoutant un fichier .so
sans avoir à modifier libstagefright
ni d'autres bibliothèques du framework multimédia. Vous pouvez également vous assurer qu'un extracteur personnalisé est préféré à l'extracteur fourni par Google.
API MediaSession2
L'API MediaSession2 permet aux applications multimédias d'exposer leurs commandes de transport et leurs informations de lecture à d'autres processus tels que le framework Android et d'autres applications. Ce composant ne peut pas être personnalisé.
API MediaParser
L'API MediaParser permet à ExoPlayer d'utiliser efficacement les analyseurs de conteneurs multimédias du framework pour extraire des échantillons multimédias à partir de conteneurs multimédias. MediaParser inclut les modifications suivantes apportées aux limites du code source:
frameworks/base/apex/media/framework/java/android/media/MediaParser.java
. API et implémentation de couches minces.external/exoplayer/
: sources verbatim Exoplayer sur lesquelles MediaParser est compilé.
L'API MediaParser ne peut pas être personnalisée. Pour tester MediaParser, utilisez les tests de cts/tests/tests/mediaparser/
.
Codecs multimédias
Le module des codecs multimédias inclut des composants de codec 2 logiciels pouvant être mis à jour. La compatibilité avec la personnalisation diffère selon les versions:
Sous Android 11 ou version ultérieure (en particulier la mise à jour du système Google Play v292100200), vous pouvez personnaliser les paramètres d'allocation de mémoire ION (voir ci-dessous pour en savoir plus).
Sous Android 9 ou version antérieure, l'API de codec OMX n'est pas actualisable, mais vous pouvez toujours l'utiliser dans la partition du fournisseur.
Allocation de mémoire ION
Sous Android 11 ou version ultérieure et mise à jour du système Google Play v292100200 ou version ultérieure, vous pouvez personnaliser les paramètres suivants pour l'allocation de mémoire ION.
Paramètre | Valeur par défaut | Description |
---|---|---|
heapMask |
0xFFFFFFFF |
Tous les types de tas sont autorisés. |
allocFlags |
0 |
Aucune option définie. |
minAlignment |
0 |
Aucun alignement. |
Pour remplacer les paramètres:
Enregistrez un service
android.hardware.media.c2
par défaut et fournissez des paramètres d'utilisation ION personnalisés.Pour créer un service, copiez le fichier frameworks/av/media/codec2/hidl/services/vendor.cpp dans votre dépôt, puis modifiez
StoreImpl::Interface::SetIonUsage()
si nécessaire.Pour réutiliser le processus
media.codec
(OMX), copiez et enregistrez la classeStoreImpl
de frameworks/av/media/codec2/hidl/services/vendor.cpp dans le fichiermediacodec
existant (frameworks/av/services/mediacodec/main_codecservice.cpp).
Ajoutez le code suivant à l'appareil
manifest.xml
.<hal format="hidl"> <name>android.hardware.media.c2</name> <transport>hwbinder</transport> <version>1.0</version> <interface> <name>IComponentStore</name> <instance>default</instance> </interface> </hal>
Format et dépendances
Le module Media (com.android.media
) et le module Media Codec (com.android.media.swcodec
) sont au format APEX. Les composants multimédias inclus ne s'appuient que sur les API du NDK.
Mises à jour
Lors d'une mise à jour, les composants du framework sur l'appareil chargent un package APEX contenant du code Java et natif.
Figure 1 : Flux de mise à jour du composant multimédia
Une fois que le framework a installé le package APEX, l'appareil redémarre et monte l'image disque. Les processus du système multimédia (media.extractor
et media.codec
) chargent les modules mis à jour à partir du point d'installation.