Processus de publication d'une image de noyau générique (GKI)

Cette page décrit la manière dont GKI est publié, y compris de manière hebdomadaire, mensuelle et des sorties d'urgence de bracelet. Ce document vise à fournir aux OEM la procédure à suivre pour récupérer le GKI, solutions d'urgence. Les OEM peuvent également utiliser les GKI développement pour en savoir plus sur la façon dont ils peuvent collaborer avec l'équipe du noyau Android pour optimiser le noyau GKI pour leurs produits.

Cadence des lancements GKI

GKI est publié à un rythme mensuel après le blocage de KMI.

Version GKI d'Android 13, 14 et 15

Le tableau suivant ne s'applique qu'aux android13-5.10 android13-5.15 et android14-5.15:

Builds certifiés GKI mensuels Date limite d'arrivée Date de préchargement GKI Confirmé ?
Octobre 14 octobre 2022 31 octobre 2022 Oui
Novembre 14 novembre 2022 30 novembre 2022 Oui
Décembre 9 décembre 2022 21 décembre 2022 Oui
Janvier 17 janvier 2023 31 janvier 2023 Oui
Février 15 février 2023 28 février 2023 Oui
Mars 15 mars 2023 31 mars 2023 Oui
Avril 13 avril 2023 28 avril 2023 Oui
Mai 17 mai 2023 31 mai 2023 Oui
Juin 15 juin 2023 30 juin 2023 Oui
Juillet 18 juillet 2023 31 juillet 2023 Oui
Août 16 août 2023 31 août 2023 Oui
Septembre 14 septembre 2023 29 septembre 2023 Oui
Novembre 10 novembre 2023 30 novembre 2023 Oui
Janvier 16 janvier 2024 31 janvier 2024 Oui
Mars 13 mars 2024 29 mars 2024 Oui
Mai 14 mai 2024 31 mai 2024 Oui
Juillet 16 juillet 2024 31 juillet 2024 Oui
Septembre 17 septembre 2024 30 septembre 2024 Oui
Novembre 11 novembre 2024 3 décembre 2024 Oui
Janvier 17 janvier 2025 31 janvier 2025 Oui
Février 14 février 2025 28 février 2025 Oui

Le tableau suivant ne s'applique qu'aux android14-6.1 et android15-6.6:

Builds certifiés GKI mensuels Date limite d'arrivée Date de préchargement GKI Confirmé ?
Janvier 16 janvier 2024 31 janvier 2024 Oui
Février 13 février 2024 29 février 2024 Oui
Mars 4 mars 2024 15 mars 2024 Oui
Avril 1er avril 2024 17 avril 2024 Oui
Mai 1er mai 2024 17 mai 2024 Oui
Juin 3 juin 2024 31 juin 2024 Oui
Juillet 1er juillet 2024 15 juillet 2024 Oui
Août 1er août 2024 31 août 2024 Oui
Septembre 2 septembre 2024 16 septembre 2024 Oui
Octobre 1er octobre 2024 14 octobre 2024 Oui
Novembre 1er novembre 2024 15 novembre 2024 Oui
Décembre 2 décembre 2024 16 décembre 2024 Oui
Janvier 6 janvier 2025 22 janvier 2025 Oui

Version GKI d'Android 12

Après mai 2024, les versions GKI de android12-5.10 seront publiées tous les trimestres et publiées en milieu de mois. Le tableau suivant ne s'applique qu'aux android12-5.10

Builds certifiés GKI mensuels Date limite d'arrivée Date de préchargement GKI Confirmé ?
Juillet 3 juillet 2023 14 juillet 2023 Oui
Septembre 1er septembre 2023 15 septembre 2023 Oui
Novembre 3 novembre 2023 17 novembre 2023 Oui
Janvier 5 janvier 2024 19 janvier 2024 Oui
Mars 4 mars 2024 15 mars 2024 Oui
Mai 1er mai 2024 17 mai 2024 Oui
Août 1er août 2024 16 août 2024 Oui
Novembre 1er novembre 2024 15 novembre 2024 Oui
Février 3 février 2025 17 février 2025 Oui

Validité du build GKI pour les OEM

Les OEM peuvent utiliser une version GKI récente d'Android. Les OEM peuvent lancer les builds certifiés GKI, à condition qu'ils soient conformes aux exigences LTS du Bulletin de sécurité Android (ASB)

Versions de développement hebdomadaires

Les versions sont testées avec Cuttlefish pour vous assurer qu'elles répondent à un seuil de qualité minimal.

Les binaires GKI sont disponibles en libre-service sur Android intégration continue lors de la fusion des modifications. Les builds hebdomadaires ne sont pas certifiés, mais peuvent être utilisés une référence pour le développement et les tests. Les builds hebdomadaires ne peuvent pas être utilisés pour les builds d'appareil de production pour les utilisateurs finaux.

Versions certifiées mensuelles

Les versions mensuelles de GKI contiennent un fichier boot.img testé qui inclut un objet inséré un certificat pour attester que les binaires ont été créés à partir d'une source connue du code de référence.

Chaque mois, une version GKI mensuelle (non certifiée) est sélectionnée. après la date limite d'arrivée, qui correspond généralement à la deuxième compilation hebdomadaire de ce mois-là. Une fois la version mensuelle candidate sélectionnée, les nouveaux les modifications ne seront pas acceptées dans la version du mois en cours. Pendant la fenêtre de fermeture uniquement pour les bugs qui provoquent l'échec du test. La la version finale fait l'objet d'un contrôle qualité, tel que décrit dans la GKI qualification, pour vous assurer que les tests de conformité sont concluants Compiler GSI+GKI avec un appareil de référence ainsi qu'une seiche.

Chronologie des lancements de GKI Figure 1 : Calendrier de lancement de GKI

Processus de renvoi d'urgence

Une respin désigne un processus de fusion, de reconstruction, de retest et recertifier un binaire après Une version publique du noyau GKI. Vous pouvez demander la résolution d'un binaire certifié pour l'un des éléments suivants : circonstances:

  • Pour mettre à jour une liste de symboles.
  • Pour appliquer un correctif à un bug, y compris pour les bugs détectés lors de l'approbation de l'atelier du transporteur.
  • Pour ajouter une accroche de fournisseur, procédez comme suit :
  • Pour appliquer un correctif à une fonctionnalité existante.
  • Pour appliquer un correctif de sécurité (après six mois).

Les correctifs de sécurité sont automatiquement fusionnés dans une branche de publication pendant une durée maximale Six mois après la sortie de la branche Passé ce délai, vous devez : demander un renvoi pour appliquer des correctifs de sécurité à une branche.

Consignes concernant les demandes de renvoi

Avant de demander un nouvel examen, tenez compte des consignes suivantes:

  • Les respins ne sont autorisés que sur les branches de publication après une version publique initiale d'une compilation mensuelle a été lancé.

  • Les demandes de relance ne sont acceptées que pour une branche de publication donnée pour un maximum six mois après la sortie publique initiale. Après six mois, branches ne peuvent faire l'objet d'une nouvelle analyse que pour les correctifs de sécurité cités dans un bulletin sur la sécurité d'Android.

  • Lorsque les exigences LTS , défini par le bulletin de sécurité Android (ASB) entraîner la non-conformité de la branche, celle-ci est obsolète. Renvoyer les requêtes ne sont pas acceptés pour les branches obsolètes. La date d'abandon d'un GKI donné la branche de publication est incluse dans les notes de version mensuelles de GKI sous Versions : Pour la planification future, les exigences LTS sont mises à jour en mai et en novembre une fois par an. Par exemple, android12-5.10-2023-07 (5.10.177) n'est plus compatible avec les respins après le 1er mai 2024, car android12-5.10-2023-07 branche (5.10.177) n'est pas conforme aux exigences LTS de l'ASB-2024-05.

  • Les résolutions ne s'appliquent qu'aux corrections de bugs urgentes, aux mises à jour de la liste des symboles ou afin d'appliquer un correctif pour corriger une caractéristique existante.

  • Tous les correctifs destinés à la branche de version mensuelle doivent déjà être fusionnés dans la branche principale du développement GKI. Par exemple, si un correctif est nécessaire pour une retour de android12-5.10-2022-09, il doit déjà être fusionné avec android12-5.10

  • Vous devez sélectionner les correctifs de la branche principale de développement GKI et importez le correctif dans la branche de publication mensuelle.

  • Dans la requête de renvoi, vous devez lui attribuer un niveau de priorité (urgence). Cette priorité permet à l'équipe GKI de mieux aider les partenaires en temps opportun. Pour les requêtes critiques ou urgentes, définissez la priorité sur P0. Pour P0 et P1 vous devez également justifier son urgence. Le tableau suivant fournit une Mappage de la priorité du bug et du délai de résolution (ESRT):

    Priorité TR
    P0 Deux jours ouvrés
    P1 5 jours ouvrés
    P2 10 jours ouvrés
    P3 15 jours ouvrables
  • Vous devez envoyer une demande de respin distincte pour chaque branche de release. Par exemple, si un respin est nécessaire pour android12-5.10-2022-08 et android12-5.10-2022-09, vous devez créer deux requêtes de respins.

  • Une fois qu'un build est fourni et qu'une requête de relance est marquée comme corrigée, vous ne doit pas rouvrir la requête de relance pour ajouter des CL supplémentaires. Vous devez envoyer un nouveau renvoyer la requête si des correctifs supplémentaires doivent être fusionnés.

  • Pour chaque CL prise en compte, ajoutez les balises suivantes.

    • Bug: l'ID de bug doit être ajouté au message de commit pour chaque CL.
    • Change-Id: doit être identique à l'ID de modification de la modification de branche de base.
  • Si une demande de respin nécessite votre réponse et que vous ne répondez pas dans les trois jours ouvrés, la priorité est rétrogradée d'un niveau (par exemple, P0 revient à P1). Si vous ne répondez pas pendant deux semaines, le bug est marqué comme Won't Fix (Obsolete) (Ne sera pas corrigé (Obsolète)).

Envoyer une demande de renvoi

Le schéma suivant illustre le processus de respinage. Le processus commence lorsque Le partenaire OEM (vous) envoie la demande de renvoi.

Processus de renvoi d'urgence Figure 2 : Le processus de respin

Pour lancer le processus de relance:

  1. Remplissez le formulaire de demande GKI Respin. et contactez immédiatement votre responsable de compte technique Google. Ce formulaire crée un bug de demande GKI respin. Vous pouvez voir les bugs des demandes de résolution (le demandeur), l'équipe GKI et les personnes spécifiques que vous ajoutez au liste CC du bug.
    • Si vous disposez déjà d'une correction, la requête doit pointer vers le correctif dans AOSP pour que Google puisse l'examiner. Si vous n'envoyez pas le correctif doit être joint sous forme de fichier texte à la requête.
    • Si vous ne disposez pas d'une solution, la demande doit contenir autant d'éléments les informations que possible, notamment le numéro de version et les journaux du noyau, afin que Google peut vous aider à résoudre le problème.
  2. L'équipe GKI de Google examine la demande et l'approuve ou la réattribue si des informations supplémentaires sont nécessaires.
  3. Une fois qu'un correctif est convenu, l'équipe GKI de Google examine le code (RS + 2) le changement. L'examen commence le délai ESRT. L'équipe GKI fusionne, compile et teste contre la régression et certifie la modification.
  4. Le binaire est libéré pour ci.android.com. La Le délai ESRT se termine, et l'équipe Google GKI marque la demande comme étant corrigée. référencer la compilation respin. Le build respin est également publié sur le Page des builds GKI (Generic Kernel Image).

Qualification GKI

Types de builds GKI Application des critères de qualité Notes
Toutes les semaines Tests de seiches
  • Botte
  • Sous-ensemble de VTS
  • Sous-ensemble de CTS
  • Non certifié. Uniquement pour les tests et l'affichage de
    appareil.
  • Ne peut pas être utilisée pour lancer des appareils.
Mensuel (certifié) Tests de seiches
  • Botte
  • VTS
  • CTS
Tests du matériel de référence
<ph type="x-smartling-placeholder">
    </ph>
  • Botte
  • VTS
  • CTS
Respins (certifiés) Tests de seiches
  • Botte
  • VTS
  • Sous-ensemble de CTS
Tests sur les appareils de référence
<ph type="x-smartling-placeholder">
    </ph>
  • Botte
  • VTS
  • Développé sur un build certifié GKI.
  • Le build est certifié après qualification.

Emplacement d'obtention des artefacts de compilation

Les artefacts de toutes les versions peuvent être récupérés à partir de ci.android.com.

Pour en savoir plus sur la CI, y compris sur le test dans l'intégration continue Android tableau de bord.

Questions fréquentes

Voici quelques questions fréquentes concernant le processus de lancement de GKI.

Est-il possible de créer un nouveau binaire GKI basé sur un GKI déjà publié ?

Oui, c'est ce qu'on appelle un respin. Le processus de respin est pris en charge tant que le le build GKI publié (sur lequel le respin est demandé) est conforme à la version LTS. dans le bulletin de sécurité Android (ASB).

Est-il possible de reproduire des binaires GKI ?

Oui, voici un exemple:

GKI 2.0
5.10 kernel prebuilts from build 7364300
https://ci.android.com/builds/submitted/7364300/kernel_aarch64/latest

Pour reproduire l'exemple, téléchargez manifest_$id.xml et exécutez la commande suivante : :

repo init -u https://android.googlesource.com/kernel/manifest
mv manifest_7364300.xml .repo/manifests
repo init -m manifest_7364300.xml --depth=1
repo sync
# build the GKI images
# You may want to use LTO=thin to build faster for development
BUILD_CONFIG=common/build.config.gki.aarch64 build/build.sh
# (optional) build virtual platform modules
BUILD_CONFIG=common-modules/virtual-device/build.config.virtual_device.aarch64 build/build.sh

Vous pouvez récupérer la copie de votre artefact GKI à partir de out/.../dist.

Le binaire GKI (y compris le correctif de rotation d'urgence) a-t-il été créé sur la dernière version du codebase ?

Non. Les résolutions ne contiennent que des correctifs qui s'ajoutent aux correctifs mensuels les noyaux qui ont été choisis. Ces résolutions contiennent tous les bugs bloquant le lancement de correction signalées jusqu'à un certain moment par les OEM en utilisant la tarification version mensuelle. Consultez l'exemple suivant qui illustre comment ce type de scénario se produit.

  • Les OEM1 et OEM2 décident d'utiliser la version binaire GKI à partir de novembre 2021.
  • Les OEM1 et OEM2 identifient les problèmes qui nécessitent des correctifs pour l'assistance. Ces correctifs peuvent être différentes ou identiques.
  • Les retours au-dessus du binaire de novembre 2021 ont un blocage lors du lancement. correctifs signalés à la fois par OEM1 et OEM2 pendant la fenêtre de relance, mais plus encore.
  • Les problèmes mentionnés dans le deuxième point sont également inclus dans les GKI suivants des versions mensuelles.

Le rapport d'octobre présente tous les correctifs envoyés par les OEM, mais d'autres correctifs OEM nous concernent, car ils n'ont pas été spécifiquement testés avec nos produits. Est-il possible d'inclure uniquement notre correctif ?

Ce n'est pas possible. Une métrique "par OEM" de respin n'est pas évolutif. Au lieu de cela, l'équipe GKI examine chaque changement qui revient à compilation et teste les modifications sur tout le matériel disponible avant de créer une nouvelle créer. Si l'équipe GKI constate que le problème est spécifique à un OEM, à un appareil l'équipe GKI peut s'assurer que le code ajouté par la modification ne s'exécute sur l'appareil, le modèle ou le SKU concernés.

Le principal avantage des respins unifiées est que chaque appareil qui utilisent la même base de versions bénéficient les uns des autres, surtout si les bugs qu’ils découvrent sont génériques et applicables à tous les utilisateurs. Bugs principaux du noyau détectés dans les tests auprès des opérateurs est un exemple spécifique de ce concept.

Y a-t-il des situations où Google fournit des informations spécifiques sur les correctifs OEM et les scénarios de problèmes, afin que les OEM puissent évaluer l'impact et les risques liés à l'implémentation des correctifs avec leurs produits ?

Google n'apportera aucune modification à un build respin tant que le problème n'aura pas été compris. et que tous les détails ont été collectés. Cela se voit dans le journal des modifications (message de commit). Google ne révèle pas l'appareil spécifique concerné, mais Les OEM peuvent toujours trouver la description du problème et la solution dans le journal des modifications.