Warning

Si tiene alguna duda sobre la exactitud del contenido de esta traducción, la única referencia válida es la documentación oficial en inglés.

Original:

Documentation/process/submitting-patches.rst

Translator:

Carlos Bilbao <carlos.bilbao@amd.com>

Envío de parches: la guía esencial para incluir su código en el kernel

Para una persona o empresa que desee enviar un cambio al kernel Linux, el proceso puede en ocasiones resultar desalentador si no se está familiarizado con "el sistema". Este texto es una colección de sugerencias que pueden aumentar considerablemente las posibilidades de que se acepte su cambio.

Este documento contiene una gran cantidad de sugerencias en un formato relativamente conciso. Para obtener información detallada sobre cómo funciona el proceso de desarrollo del kernel, consulte A guide to the Kernel Development Process. Además, lea Linux Kernel patch submission checklist para obtener una lista de elementos a verificar antes de enviar código. Para los parches de "binding" del árbol de dispositivos, lea Submitting Devicetree (DT) binding patches.

Esta documentación asume que está usando git para preparar sus parches. Si no está familiarizado con git, le recomendamos que aprenda a usarlo, le hará la vida como desarrollador del kernel y en general mucho más sencilla.

Algunos subsistemas y árboles de mantenimiento cuentan con información adicional sobre su flujo de trabajo y expectativas, consulte Documentation/process/maintainer-handbooks.rst.

Obtenga el código fuente actual

Si no tiene a mano un repositorio con el código fuente actual del kernel, use git para obtener uno. Querrá comenzar con el repositorio principal, que se puede descargar con:

git clone git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git

Tenga en cuenta, sin embargo, que es posible que no desee desarrollar con el árbol principal directamente. La mayoría de los maintainers de subsistemas usan sus propios árboles de código fuente y quieren ver parches preparados para esos árboles. Revise el campo T: para el subsistema en el archivo MAINTAINERS para encontrar dicho árbol, o simplemente pregunte al maintainer si el árbol no está listado allí.

Describa sus cambios

Describa su problema. Sea su parche una corrección de un error de una línea o 5000 líneas para una nuevo "feature", debe haber un problema subyacente que le motivó a hacer ese trabajo. Convenza al revisor de que hay un problema que merece la pena solucionar y de que tiene sentido que lea más allá del primer párrafo.

Describa el impacto relativo al usuario. Cosas que estropeen el kernel y los bloqueos son bastante convincentes, pero no todos los errores son tan evidentes. Incluso si se detectó un problema durante la revisión del código, describa el impacto que cree pueda tener en los usuarios. Tenga en cuenta que la mayoría de instalaciones de Linux ejecutan kernels desde árboles estables secundarios o árboles específicos de proveedor/producto que seleccionan ("cherry-pick") solo parches específicos de upstream, así que incluya cualquier cosa que pueda ayudar a dirigir su cambio aguas abajo: circunstancias que producen cierta situación, extractos de dmesg, descripciones del error fatal, regresiones de rendimiento, picos de latencia, bloqueos, etc.

Cuantifique optimizaciones y beneficios/perdidas. Si asegura mejoras en rendimiento, consumo de memoria, huella del stack o tamaño de binario, incluya números que lo respalden. Pero también describa costes no obvios. Las optimizaciones generalmente no son gratuitas, sino un equilibrio entre CPU, memoria y legibilidad; o, cuando se trata de heurísticas, entre diferentes cargas de trabajo. Describa las desventajas esperadas de su optimización para que el revisor pueda comparar las perdidas con los beneficios.

Una vez establecido el problema, describa lo que realmente está haciendo al respecto en detalles técnicos. Es importante describir el cambio en lenguaje sencillo para que el revisor verifique que el código se está comportando como se pretende.

El maintainer le agradecerá que escriba la descripción de su parche en un formato que se pueda incorporar fácilmente en la gestión del código fuente del sistema, git, como un "commit log" (registros de los commits). Consulte Formato de parche canónico.

Resuelva solo un problema por parche. Si su descripción comienza a ser muy larga, eso es una señal de que probablemente necesite dividir su parche. Lea Separate your changes.

Cuando envíe o vuelva a enviar un parche o una serie de parches, incluya la descripción completa del parche y justificación del mismo. No se limite a decir que esa es la versión N del parche (serie). No espere que el maintainer del subsistema referencie versiones de parches anteriores o use referencias URL para encontrar la descripción del parche y colocarla en el parche. Es decir, el parche (serie) y su descripción deben ser independientes. Esto beneficia tanto a los maintainers como a los revisores. Algunos revisores probablemente ni siquiera recibieran versiones anteriores del parche.

Describa sus cambios en la forma imperativa, por ejemplo, "hacer que xyzzy haga frotz" en lugar de "[Este parche] hace que xyzzy haga frotz" o "[Yo] Cambié xyzzy para que haga frotz", como si estuviera dando órdenes al código fuente para cambiar su comportamiento.

Si desea hacer referencia a un commit específico, no se limite a hacer referencia al ID SHA-1 del commit. Incluya también el resumen de una línea del commit, para que sea más fácil para los revisores saber de qué se trata. Ejemplo:

Commit e21d2170f36602ae2708 ("video: quitar platform_set_drvdata()
innecesario") eliminó innecesario platform_set_drvdata(), pero dejó la
variable "dev" sin usar, bórrese.

También debe asegurarse de utilizar al menos los primeros doce caracteres del identificador SHA-1. El repositorio del kernel contiene muchos muchos objetos, por lo que las colisiones con identificaciones más cortas son una posibilidad real. Tenga en cuenta que, aunque no hay colisión con su identificación de seis caracteres ahora, esa condición puede cambiar dentro de cinco años.

Si las discusiones relacionadas o cualquier otra información relativa al cambio se pueden encontrar en la web, agregue las etiquetas 'Link:' que apunten a estos. En caso de que su parche corrija un error, por poner un ejemplo, agregue una etiqueta con una URL que haga referencia al informe en los archivos de las listas de correo o un rastreador de errores; si el parche es el resultado de alguna discusión anterior de la lista de correo o algo documentado en la web, referencie esto.

Cuando se vincule a archivos de listas de correo, preferiblemente use el servicio de archivador de mensajes lore.kernel.org. Para crear la URL del enlace, utilice el contenido del encabezado ("header") Message-Id del mensaje sin los corchetes angulares que lo rodean. Por ejemplo:

Link: https://lore.kernel.org/r/30th.anniversary.repost@klaava.Helsinki.FI/

Verifique el enlace para asegurarse de que realmente funciona y apunta al mensaje correspondiente.

Sin embargo, intente que su explicación sea comprensible sin recursos externos. Además de dar una URL a un archivo o error de la lista de correo, resuma los puntos relevantes de la discusión que condujeron al parche tal y como se envió.

Si su parche corrige un error en un commit específico, por ejemplo encontró un problema usando git bisect, utilice la etiqueta 'Fixes:' con los primeros 12 caracteres del ID SHA-1 y el resumen de una línea. No divida la etiqueta en varias líneas, las etiquetas están exentas de la regla "ajustar a 75 columnas" para simplificar análisis de scripts. Por ejemplo:

Fixes: 54a4f0239f2e ("KVM: MMU: hacer que kvm_mmu_zap_page()
devuelva la cantidad de páginas que realmente liberó")

Las siguientes configuraciones de git config se pueden usar para agregar un bonito formato y generar este estilo con los comandos git log o git show:

[core]
        abbrev = 12
[pretty]
        fixes = Fixes: %h (\"%s\")

Un ejemplo de uso:

$ git log -1 --pretty=fixes 54a4f0239f2e
Fixes: 54a4f0239f2e ("KVM: MMU: hacer que kvm_mmu_zap_page() devuelva la cantidad de páginas que realmente liberó")

Separe sus cambios

Separe cada cambio lógico en un parche separado.

Por ejemplo, si sus cambios incluyen correcciones de errores y mejoras en el rendimiento de un controlador, separe esos cambios en dos o más parches. Si sus cambios incluyen una actualización de la API y una nueva controlador que usa esta nueva API, sepárelos en dos parches.

Por otro lado, si realiza un solo cambio en numerosos archivos, agrupe esos cambios en un solo parche. Por lo tanto, un solo cambio lógico estará contenido en un solo parche.

El punto a recordar es que cada parche debe realizar un cambio que puede ser verificado por los revisores fácilmente. Cada parche debe ser justificable por sus propios méritos.

Si un parche depende de otro parche para que un cambio sea completo, eso está bien. Simplemente incluya que "este parche depende del parche X" en la descripción de su parche.

Cuando divida su cambio en una serie de parches, tenga especial cuidado en asegurarse de que el kernel se compila y ejecuta correctamente después de cada parche en la serie. Los desarrolladores que usan git bisect para rastrear un problema pueden terminar dividiendo su serie de parches en cualquier punto; no le agradecerán si introdujo errores a la mitad.

Si no puede condensar su conjunto de parches en un conjunto más pequeño de parches, solo publique, más o menos 15 a la vez, y espere la revisión e integración.

Revise el estilo en sus cambios

Revise su parche para ver si hay violaciones de estilo básico, cuyos detalles pueden ser encontrados en Linux kernel coding style. No hacerlo simplemente desperdicia el tiempo de los revisores y su parche será rechazado, probablemente sin siquiera ser leído.

Una excepción importante es cuando se mueve código de un archivo a otro. En tal caso, en absoluto debe modificar el código movido en el mismo parche en que lo mueve. Esto divide claramente el acto de mover el código y sus cambios. Esto ayuda mucho a la revisión de la diferencias reales y permite que las herramientas rastreen mejor el historial del código en sí.

Verifique sus parches con el verificador de estilo de parches antes de enviarlos (scripts/checkpatch.pl). Tenga en cuenta, sin embargo, que el verificador de estilo debe ser visto como una guía, no como un reemplazo del juicio humano. Si su código es mejor con una violación entonces probablemente sea mejor dejarlo estar.

El verificador informa a tres niveles:
  • ERROR: cosas que es muy probable que estén mal

  • WARNING: Advertencia. Cosas que requieren una revisión cuidadosa

  • CHECK: Revisar. Cosas que requieren pensarlo

Debe poder justificar todas las violaciones que permanezcan en su parche.

Seleccione los destinatarios de su parche

Siempre debe incluir en copia a los apropiados maintainers del subsistema en cualquier parche con código que mantengan; revise a través del archivo MAINTAINERS y el historial de revisión del código fuente para ver quiénes son esos maintainers. El script scripts/get_maintainer.pl puede ser muy útil en este paso (pase rutas a sus parches como argumentos para scripts/get_maintainer.pl). Si no puede encontrar un maintainer del subsistema en el que está trabajando, Andrew Morton (akpm@linux-foundation.org) sirve como maintainer de último recurso.

Normalmente, también debe elegir al menos una lista de correo para recibir una copia de su conjunto de parches. linux-kernel@vger.kernel.org debe usarse de forma predeterminada para todos los parches, pero el volumen en esta lista ha hecho que muchos desarrolladores se desconecten. Busque en el archivo MAINTAINERS una lista específica de los subsistemas; su parche probablemente recibirá más atención allí. Sin embargo, no envíe spam a listas no relacionadas.

Muchas listas relacionadas con el kernel están alojadas en vger.kernel.org; puedes encontrar un listado de estas en http://vger.kernel.org/vger-lists.html. Existen listas relacionadas con el kernel alojadas en otros lugares, no obstante.

¡No envíe más de 15 parches a la vez a las listas de correo de vger!

Linus Torvalds es el árbitro final de todos los cambios aceptados en el kernel de Linux. Su dirección de correo electrónico es <torvalds@linux-foundation.org>. Recibe muchos correos electrónicos y, en este momento, muy pocos parches pasan por Linus directamente, por lo que normalmente debe hacer todo lo posible para -evitar- enviarle un correo electrónico.

Si tiene un parche que corrige un error de seguridad explotable, envíe ese parche a security@kernel.org. Para errores graves, se debe mantener un poco de discreción y permitir que los distribuidores entreguen el parche a los usuarios; en esos casos, obviamente, el parche no debe enviarse a ninguna lista pública. Revise también Security bugs.

Los parches que corrigen un error grave en un kernel en uso deben dirigirse hacia los maintainers estables poniendo una línea como esta:

CC: stable@vger.kernel.org

en el área de sign-off de su parche (es decir, NO un destinatario de correo electrónico). También debe leer Everything you ever wanted to know about Linux -stable releases además de este documento.

Si los cambios afectan las interfaces del kernel para el usuario, envíe al maintainer de las MAN-PAGES (como se indica en el archivo MAINTAINERS) un parche de páginas de manual, o al menos una notificación del cambio, para que alguna información se abra paso en las páginas del manual. Los cambios de la API del espacio de usuario también deben copiarse en linux-api@vger.kernel.org.

Sin MIME, enlaces, compresión o archivos adjuntos. Solo texto plano

Linus y otros desarrolladores del kernel deben poder leer y comentar sobre los cambios que está enviando. Es importante para un desarrollador kernel poder "citar" sus cambios, utilizando herramientas estándar de correo electrónico, de modo que puedan comentar sobre partes específicas de su código.

Por este motivo, todos los parches deben enviarse por correo electrónico "inline". La forma más sencilla de hacerlo es con git send-email, que es muy recomendable. Un tutorial interactivo para git send-email está disponible en https://git-send-email.io.

Si elige no usar git send-email:

Warning

Tenga cuidado con el ajuste de palabras de su editor que corrompe su parche, si elige cortar y pegar su parche.

No adjunte el parche como un archivo adjunto MIME, comprimido o no. Muchas populares aplicaciones de correo electrónico no siempre transmiten un MIME archivo adjunto como texto sin formato, por lo que es imposible comentar en su código. Linus también necesita un poco más de tiempo para procesar un archivo adjunto MIME, disminuyendo la probabilidad de que se acepte su cambio adjunto en MIME.

Excepción: si su proveedor de correo está destrozando parches, entonces alguien puede pedir que los vuelva a enviar usando MIME.

Consulte Email clients info for Linux para obtener sugerencias sobre cómo configurar su cliente de correo electrónico para que envíe sus parches intactos.

Responda a los comentarios de revisión

Es casi seguro que su parche recibirá comentarios de los revisores sobre maneras en que se pueda mejorar el parche, en forma de respuesta a su correo electrónico. Debe responder a esos comentarios; ignorar a los revisores es una buena manera de ser ignorado de vuelta. Simplemente puede responder a sus correos electrónicos para contestar a sus comentarios. Revisiones a los comentarios o preguntas que no conduzcan a un cambio de código deben casi con certeza generar un comentario o una entrada en el "changelog" para que el próximo revisor entienda lo que está pasando.

Asegúrese de decirles a los revisores qué cambios está haciendo y de agradecerles que dediquen su tiempo. La revisión del código es un proceso agotador y lento, y los revisores a veces se ponen de mal humor. Sin embargo, incluso en ese caso, responda cortésmente y aborde los problemas que hayan señalado. Al enviar un siguiente versión, agregue un patch changelog (registro de cambios en los parches) a la carta de presentación ("cover letter") o a parches individuales explicando la diferencia con la presentación anterior (ver Formato de parche canónico).

Consulte Email clients info for Linux para obtener recomendaciones sobre clientes de correo electrónico y normas de etiqueta en la lista de correo.

No se desanime o impaciente

Después de haber entregado su cambio, sea paciente y espere. Los revisores son personas ocupadas y es posible que no lleguen a su parche de inmediato.

Érase una vez, los parches solían desaparecer en el vacío sin comentarios, pero el proceso de desarrollo funciona mejor que eso ahora. Debería recibir comentarios dentro de una semana más o menos; si eso no sucede, asegúrese de que ha enviado sus parches al lugar correcto. Espere un mínimo de una semana antes de volver a enviar o hacer ping a los revisores, posiblemente más durante periodos de mucho trabajo ocupados como "merge windows".

También está bien volver a enviar el parche o la serie de parches después de un par de semanas con la palabra "RESEND" (reenviar) añadida a la línea de asunto:

[PATCH Vx RESEND] sub/sys: Resumen condensado de parche

No incluya "RESEND" cuando envíe una versión modificada de su parche o serie de parches: "RESEND" solo se aplica al reenvío de un parche o serie de parches que no hayan sido modificados de ninguna manera con respecto a la presentación anterior.

Incluya PATCH en el asunto

Debido al alto tráfico de correo electrónico a Linus y al kernel de Linux, es común prefijar su línea de asunto con [PATCH]. Esto le permite a Linus y otros desarrolladores del kernel distinguir más fácilmente los parches de otras discusiones por correo electrónico.

git send-email lo hará automáticamente.

Firme su trabajo: el Certificado de Origen del Desarrollador

Para mejorar el seguimiento de quién hizo qué, especialmente con parches que pueden filtrarse hasta su destino final a través de varias capas de maintainers, hemos introducido un procedimiento de "sign-off" (aprobación) en parches que se envían por correo electrónico.

La aprobación es una simple línea al final de la explicación del parche, que certifica que usted lo escribió o que tiene derecho a enviarlo como un parche de código abierto. Las reglas son bastante simples: si usted puede certificar lo siguiente:

Certificado de Origen del Desarrollador 1.1

Al hacer una contribución a este proyecto, certifico que:

  1. La contribución fue creada en su totalidad o en parte por mí y tengo derecho a enviarlo bajo la licencia de código abierto indicada en el documento; o

  2. La contribución se basa en trabajo previo que, hasta donde yo soy consciente, está cubierto por una licencia de código abierto apropiada y tengo el derecho bajo esa licencia de presentar tal trabajo con modificaciones, ya sean creadas en su totalidad o en parte por mí, bajo la misma licencia de código (salvo que sea permitido presentar bajo una licencia diferente), tal y como se indica en el documento; o

  3. La contribución me fue proporcionada directamente por alguna otra persona que certificó (a), (b) o (c) y no he modificado esto.

  4. Entiendo y acepto que este proyecto y la contribución son públicos y que un registro de la contribución (incluyendo toda la información personal que envío con él, incluida mi firma) es mantenida indefinidamente y puede ser redistribuida de manera consistente con este proyecto o la(s) licencia(s) de código abierto involucradas.

entonces simplemente incluya una línea que rece:

Signed-off-by: Random J Developer <random@developer.example.org>

usando su nombre real (lamentablemente, no pseudónimos ni contribuciones anónimas). Esto se hará por usted automáticamente si usa git commit -s. Las reversiones de código también deben incluir "Signed-off-by". git revert -s hace eso por usted.

Algunas personas también ponen etiquetas adicionales al final. Simplemente serán ignoradas por ahora, pero puede hacer esto para marcar procedimientos internos de su empresa o simplemente señalar algún detalle especial sobre la firma.

Cualquier otro SoB (Signed-off-by:) después del SoB del autor es de personas que manipulen y transporten el parche, pero no participaron en su desarrollo. Las cadenas de SoB deben reflejar la ruta real del parche de cómo se propagó a los maintainers y, en última instancia, a Linus, con la primera entrada de SoB que señala la autoría principal de un solo autor.

Cuándo usar Acked-by:, Cc: y Co-developed-by por:

La etiqueta Signed-off-by: indica que el firmante estuvo involucrado en el desarrollo del parche, o que él/ella se encontraba en el camino de entrega del parche.

Si una persona no estuvo directamente involucrada en la preparación o administración de un parche pero desea expresar y registrar su aprobación, entonces puede pedir que se agregue una línea Acked-by: al registro de cambios del parche.

Acked-by: a menudo lo usa el maintainer del código afectado cuando ese maintainer no contribuyó ni envió el parche.

Acked-by: no es tan formal como Signed-off-by:. Es una manera de marcar que el "acker" ha revisado al menos ese parche y ha indicado su aceptación. Por los merge de parches a veces convertirán manualmente el "sí, me parece bien" de un acker en un Acked-by: (pero tenga en cuenta que por lo general es mejor pedir un acuse de recibo explícito).

Acked-by: no necesariamente indica el reconocimiento de todo el parche. Por ejemplo, si un parche afecta a varios subsistemas y tiene un Acked-by: de un maintainer del subsistema, entonces esto generalmente indica el reconocimiento de solo la parte que afecta el código de ese maintainer. Buen juicio debe ejercitarse aquí. En caso de duda, la gente debe consultar la discusión original en los archivos de la lista de correo.

Si una persona ha tenido la oportunidad de comentar un parche, pero no lo ha hecho, puede incluir opcionalmente una etiqueta Cc: al parche. Esta es la única etiqueta que se puede agregar sin una acción explícita por parte de la persona a la que se nombre - pero debe indicar que esta persona fue copiada en el parche. Esta etiqueta documenta que las partes potencialmente interesadas han sido incluidas en la discusión.

Co-developed-by: establece que el parche fue co-creado por múltiples desarrolladores; se utiliza para dar atribución a los coautores (además del autor atribuido por la etiqueta From:) cuando varias personas trabajan en un solo parche. Ya que Co-developed-by: denota autoría, cada Co-developed-by: debe ser inmediatamente seguido de Signed-off-by: del coautor asociado. Se mantiene el procedimiento estándar, es decir, el orden de las etiquetas Signed-off-by: debe reflejar el historial cronológico del parche en la medida de lo posible, independientemente de si el autor se atribuye a través de From: o Co-developed-by:. Cabe destacar que el último Signed-off-by: siempre debe ser del desarrollador que envía el parche.

Tenga en cuenta que la etiqueta From: es opcional cuando el autor From: es también la persona (y correo electrónico) enumerados en la línea From: del encabezado del correo electrónico.

Ejemplo de un parche enviado por el From: autor:

<changelog>

Co-developed-by: Primer coautor <primer@coauthor.example.org>
Signed-off-by: Primer coautor <primer@coauthor.example.org>
Co-developed-by: Segundo coautor <segundo@coautor.ejemplo.org>
Signed-off-by: Segundo coautor <segundo@coautor.ejemplo.org>
Signed-off-by: Autor del From <from@author.example.org>

Ejemplo de un parche enviado por un Co-developed-by: autor:

From: Autor del From <from@author.example.org>

<changelog>

Co-developed-by: Co-Autor aleatorio <aleatorio@coauthor.example.org>
Signed-off-by: Coautor aleatorio <aleatorio@coauthor.example.org>
Signed-off-by: Autor del From <from@author.example.org>
Co-developed-by: Coautor que envió <sub@coauthor.example.org>
Signed-off-by: Coautor que envía <sub@coauthor.example.org>

Uso de Reported-by:, Tested-by:, Reviewed-by:, Suggested-by: y Fixes:

La etiqueta Reported-by (Reportado-por) otorga crédito a las personas que encuentran errores y los reportan. Por favor, tenga en cuenta que si se informó de un error en privado, debe pedir primero permiso antes de usar la etiqueta Reported-by. La etiqueta está destinada a errores; por favor no la use para acreditar peticiones de características.

Una etiqueta Tested-by: indica que el parche se probó con éxito (en algún entorno) por la persona nombrada. Esta etiqueta informa a los maintainers de que se han realizado algunas pruebas, proporciona un medio para ubicar "testers" (gente que pruebe) otros parches futuros y asegura el crédito para los testers.

Reviewed-by: en cambio, indica que el parche ha sido revisado y encontrado aceptable de acuerdo con la Declaración del Revisor:

Declaración de Supervisión del Revisor

Al ofrecer mi etiqueta Reviewed-by:, afirmo que:

(a) He llevado a cabo una revisión técnica de este parche para evaluar su idoneidad y preparación para su inclusión en el kernel principal.

(b) Cualquier problema, inquietud o pregunta relacionada con el parche han sido comunicados al remitente. Estoy satisfecho con la respuesta del remitente a mis comentarios.

(c) Si bien puede haber cosas que podrían mejorarse con esta entrega, creo que es, en este momento, (1) una modificación valiosa al kernel, y (2) libre de conocidas cuestiones que argumentarían en contra de su inclusión.

(d) Si bien he revisado el parche y creo que es correcto, no hago (a menos que se indique explícitamente en otro lugar) ninguna garantía o avales de que logrará su definido propósito o función en cualquier situación dada.

Una etiqueta Reviewed-by es una declaración de opinión de que el parche es una modificación apropiada al kernel sin que haya ningún problema grave a nivel técnico. Cualquier revisor interesado (que haya hecho el trabajo) puede ofrecer una etiqueta Reviewed-by para un parche. Esta etiqueta sirve para dar crédito a revisores e informar a los maintainers del grado de revisión que se ha hecho en el parche. Las etiquetas Reviewed-by, cuando las otorgan revisores conocidos por entender del tema y realizar revisiones exhaustivas, normalmente aumentan la probabilidad de que su parche entre en el kernel.

Las etiquetas Tested-by y Reviewed-by, una vez recibidas en la lista de correo por el tester o revisor, deben ser incluidas por el autor de los parches pertinentes al enviar próximas versiones. Sin embargo, si el parche ha cambiado sustancialmente en la siguiente versión, es posible que estas etiquetas ya no sean aplicables y, por lo tanto, deben eliminarse. Por lo general, se debe mencionar la eliminación de las etiquetas Tested-by o Reviewed-by de alguien en el registro de cambios del parche (después del separador '---').

Una etiqueta Suggested-by: indica que la idea del parche es sugerida por la persona nombrada y asegura el crédito a la persona por la idea. Tenga en cuenta que esto no debe agregarse sin el permiso del "reporter", especialmente si la idea no fue publicada en un foro público. Dicho esto, si diligentemente acreditamos a los reporters de ideas, con suerte, se sentirán inspirados para ayudarnos nuevamente en el futuro.

Una etiqueta Fixes: indica que el parche corrige un problema en un commit anterior. Esto se utiliza para facilitar descubrir dónde se originó un error, lo que puede ayudar a revisar una corrección de errores. Esta etiqueta también ayuda al equipo del kernel estable a determinar qué versiones estables del kernel deberían recibir su corrección. Este es el método preferido para indicar un error corregido por el parche. Revise Describe your changes para más detalles.

Nota: Adjuntar una etiqueta Fixes: no subvierte las reglas estables del proceso del kernel ni el requisito de CC: stable@vger.kernel.org en todos los parches candidatos de ramas estables. Para obtener más información, lea Everything you ever wanted to know about Linux -stable releases.

Formato de parche canónico

Esta sección describe cómo debe darse formato al propio parche. Tenga en cuenta que, si tiene sus parches almacenados en un repositorio git, el parche con formato adecuado se puede obtener con git format-patch. Las herramientas no pueden crear el texto necesario, sin embargo, así que lea las instrucciones a continuación de todos modos.

La línea de asunto del parche canónico es:

Asunto: [PATCH 001/123] subsistema: frase de resumen

El cuerpo del mensaje del parche canónico contiene lo siguiente:

  • Una línea from que especifica el autor del parche, seguida de una línea vacía (solo es necesario si la persona que envía el parche no es el autor).

  • El cuerpo de la explicación, línea envuelta en 75 columnas, que se copiara en el registro de cambios permanente para describir este parche.

  • Una línea vacía.

  • Las líneas Signed-off-by:, descritas anteriormente, que también vaya en el registro de cambios.

  • Una línea de marcador que contiene simplemente ---.

  • Cualquier comentario adicional que no sea adecuado para el registro de cambios.

  • El parche real (output de diff).

El formato de la línea de asunto hace que sea muy fácil ordenar los correos electrónicos alfabéticamente por línea de asunto - prácticamente cualquier lector de correo electrónico permite esto, ya que debido a que el número de secuencia se rellena con ceros, el orden numérico y alfabético es el mismo.

El subsistema en el asunto del correo electrónico debe identificar qué área o subsistema del kernel está siendo parcheado.

La frase de resumen en el Asunto del correo electrónico debe describir de forma concisa el parche que contiene ese correo electrónico. La frase resumen no debe ser un nombre de archivo. No use la mismo frase resumen para cada parche en una serie completa de parches (donde una `` serie de parches`` (patch series) es una secuencia ordenada de múltiples parches relacionados).

Tenga en cuenta que la frase de resumen de su correo electrónico se convierte en un identificador global único para ese parche. Se propaga por hasta el registro de cambios de git. La frase resumida se puede usar más adelante en discusiones de desarrolladores que se refieran al parche. La gente querrá buscar en Google la frase de resumen para leer la discusión al respecto del parche. También será lo único que la gente podrá ver rápidamente cuando, dos o tres meses después, estén pasando por quizás miles de parches usando herramientas como gitk o git log --oneline.

Por estas razones, el resumen no debe tener más de 70-75 caracteres, y debe describir tanto lo que cambia el parche como por qué el parche podría ser necesario. Es un reto ser tanto sucinto como descriptivo, pero eso es lo que un resumen bien escrito debería hacer.

La frase de resumen puede estar precedida por etiquetas encerradas en corchetes: "Asunto: [PATCH <etiqueta>...] <frase de resumen>". Las etiquetas no se consideran parte de la frase de resumen, pero describen cómo debería ser tratado el parche. Las etiquetas comunes pueden incluir un descriptor de versión si las múltiples versiones del parche se han enviado en respuesta a comentarios (es decir, "v1, v2, v3") o "RFC" para indicar una solicitud de comentarios.

Si hay cuatro parches en una serie de parches, los parches individuales pueden enumerarse así: 1/4, 2/4, 3/4, 4/4. Esto asegura que los desarrolladores entiendan el orden en que se deben aplicar los parches y que han revisado o aplicado todos los parches de la serie de parches.

Aquí hay algunos buenos ejemplos de Asuntos:

Asunto: [PATCH 2/5] ext2: mejorar la escalabilidad de la búsqueda de mapas de bits
Asunto: [PATCH v2 27/01] x86: corregir el seguimiento de eflags
Asunto: [PATCH v2] sub/sys: resumen conciso del parche
Asunto: [PATCH v2 M/N] sub/sys: resumen conciso del parche

La línea from debe ser la primera línea en el cuerpo del mensaje, y tiene la forma:

From: Autor del parche <autor@ejemplo.com>

La línea From especifica quién será acreditado como el autor del parche en el registro de cambios permanente. Si falta la línea from, entonces la línea From: del encabezado del correo electrónico se usará para determinar el autor del parche en el registro de cambios.

La explicación estará incluida en el commit del changelog permanente, por lo que debería tener sentido para un lector competente que hace mucho tiempo ha olvidado los detalles de la discusión que podrían haber llevado a este parche. Incluidos los síntomas del fallo que el parche trate (mensajes de registro del kernel, mensajes de oops, etc.) son especialmente útiles para personas que podrían estar buscando en los registros de commits en busca de la aplicación del parche. El texto debe estar escrito con tal detalle que cuando se lea semanas, meses o incluso años después, pueda dar al lector la información necesaria y detalles para comprender el razonamiento de por qué se creó el parche.

Si un parche corrige una falla de compilación, puede que no sea necesario incluir _todos_ los errores de compilación; pero lo suficiente como para que sea probable que alguien que busque el parche puede encontrarlo. Como en la frase de resumen, es importante ser tanto sucinto como descriptivo.

La línea marcadora --- cumple el propósito esencial de marcar para herramientas de manejo de parches donde termina el mensaje de registro de cambios.

Un buen uso de los comentarios adicionales después del marcador --- es para diffstat, para mostrar qué archivos han cambiado, y el número de líneas insertadas y eliminadas por archivo. Un diffstat es especialmente útil en parches más grandes. Si va a incluir un diffstat después del marcador ---, utilice las opciones diffstat -p 1 -w 70 para que los nombres de archivo se enumeran desde la parte superior del árbol de fuentes del kernel y no use demasiado espacio horizontal (que encaje fácilmente en 80 columnas, tal vez con alguna indentación). (git genera diffstats apropiados por defecto).

Otros comentarios relevantes solo en el momento o para el maintainer, pero no adecuados para el registro de cambios permanente, también debe ir aquí. Un buen ejemplo de tales comentarios podría ser registros de cambios de parches que describen qué ha cambiado entre la versión v1 y v2 del parche.

Por favor, ponga esta información después de la línea --- que separa el registro de cambios del resto del parche. La información de la versión no forma parte del registro de cambios que se incluye con el árbol git. Es información adicional para los revisores. Si se coloca encima de la etiquetas de commit, necesita interacción manual para eliminarlo. Si esta debajo de la línea de separación, se quita automáticamente al aplicar el parche:

<mensaje de commit>
...
Signed-off-by: Autor <autor@correo>
---
V2 -> V3: función auxiliar redundante eliminada
V1 -> V2: estilo de código limpio y comentarios de revisión abordados

ruta/al/archivo | 5+++--
...

Revise más detalles sobre el formato de parche adecuado en las siguientes referencias

Retrocesos en mensajes de confirmación

Los "backtraces" (deshacer el camino) ayuda a documentar la cadena de llamadas que conducen a un problema. Sin embargo, no todos los rastreos son útiles. Por ejemplo, las tempranas cadenas de llamadas de inicio son únicas y obvias. Sin embargo, al copiar la salida completa de dmesg textualmente, incluye información que distrae, como marcas de tiempo, listas de módulos, registro y volcados de pila.

Por lo tanto, los backtraces más útiles deben contener los datos relevantes de la información vertida, lo que hace que sea más fácil centrarse en el verdadero tema. Este es un ejemplo de un backtrace bien recortado:

error de acceso de MSR no verificado: WRMSR a 0xd51 (intentó escribir 0x0000000000000064)
en rIP: 0xffffffffae059994 (native_write_msr+0x4/0x20)
Rastreo de llamadas:
mba_wrmsr
update_domains
rdtgroup_mkdir

In-Reply-To explicitos en las cabeceras

Puede ser útil agregar manualmente encabezados In-Reply-To: a un parche (por ejemplo, al usar git send-email) para asociar el parche con una discusión anterior relevante, por ejemplo para vincular una corrección de errores al correo electrónico con el informe de errores. Sin embargo, para una serie de parches múltiples, generalmente es mejor evitar usar In-Reply-To: para vincular a versiones anteriores de la serie. De esta forma, varias versiones del parche no se convierten en un inmanejable bosque de referencias en clientes de correo electrónico. Si un enlace es útil, puede usar el redirector https://lore.kernel.org/ (por ejemplo, en el texto de la carta de introducción del correo electrónico) para vincular a una versión anterior de la serie de parches.

Proporcionar información de árbol base

Cuando otros desarrolladores reciben sus parches y comienzan el proceso de revisión, a menudo es útil para ellos saber en qué parte del historial del árbol deben colocar su trabajo. Esto es particularmente útil para CI automatizado de procesos que intentan ejecutar una serie de pruebas para establecer la calidad de su envío antes de que el maintainer comience la revisión.

Si está utilizando git format-patch para generar sus parches, puede incluir automáticamente la información del árbol base en su envío usando el parámetro --base. La forma más fácil y conveniente de usar esta opción es con "topical branches" (ramas de temas):

$ git checkout -t -b my-topical-branch master
Branch 'my-topical-branch' set up to track local branch 'master'.
Switched to a new branch 'my-topical-branch'

[realice sus cambios y ediciones]

$ git format-patch --base=auto --cover-letter -o outgoing/ master
outgoing/0000-cover-letter.patch
outgoing/0001-First-Commit.patch
outgoing/...

Cuando abra outgoing/0000-cover-letter.patch para editar, tenga en cuenta que tendrá el tráiler base-commit: al final, que proporciona al revisor y a las herramientas de CI suficiente información para realizar correctamente git am sin preocuparse por los conflictos:

$ git checkout -b patch-review [base-commit-id]
Switched to a new branch 'patch-review'
$ git am patches.mbox
Applying: First Commit
Applying: ...

Consulte man git-format-patch para obtener más información al respecto de esta opción.

Note

La función --base se introdujo en la versión 2.9.0 de git.

Si no está utilizando git para dar forma a sus parches, aún puede incluir el mismo tráiler base-commit para indicar el hash de confirmación del árbol en que se basa su trabajo. Debe agregarlo en la carta de presentación o en el primer parche de la serie y debe colocarse ya sea bajo la línea --- o en la parte inferior de todos los demás contenido, justo antes de su firma del correo electrónico.

Referencias

"The perfect patch" (tpp) por Andrew Morton.

<https://www.ozlabs.org/~akpm/stuff/tpp.txt>

"Linux kernel patch submission format" por Jeff Garzik.

<https://web.archive.org/web/20180829112450/http://linux.yyz.us/patch-format.html>

"How to piss off a kernel subsystem maintainer" por Greg Kroah-Hartman.

<http://www.kroah.com/log/linux/maintainer.html>

<http://www.kroah.com/log/linux/maintainer-02.html>

<http://www.kroah.com/log/linux/maintainer-03.html>

<http://www.kroah.com/log/linux/maintainer-04.html>

<http://www.kroah.com/log/linux/maintainer-05.html>

<http://www.kroah.com/log/linux/maintainer-06.html>

NO!!!! Gente, no mas bombas enormes de parches a linux-kernel@vger.kernel.org!

<https://lore.kernel.org/r/20050711.125305.08322243.davem@davemloft.net>

Kernel Linux kernel coding style

Email de Linus Torvalds sobre la forma canónica de los parches:

<https://lore.kernel.org/r/Pine.LNX.4.58.0504071023190.28951@ppc970.osdl.org>

"On submitting kernel patches" por Andi Kleen

Algunas estrategias para conseguir incluir cambios complicados o controvertidos.

http://halobates.de/on-submitting-patches.pdf