€•fŒsphinx.addnodes”Œdocument”“”)”}”(Œ rawsource”Œ”Œchildren”]”(Œ translations”Œ LanguagesNode”“”)”}”(hhh]”(hŒ pending_xref”“”)”}”(hhh]”Œdocutils.nodes”ŒText”“”ŒEnglish”…””}”Œparent”hsbaŒ attributes”}”(Œids”]”Œclasses”]”Œnames”]”Œdupnames”]”Œbackrefs”]”Œ refdomain”Œstd”Œreftype”Œdoc”Œ reftarget”Œ/process/submitting-patches”Œmodname”NŒ classname”NŒ refexplicit”ˆuŒtagname”hhh ubh)”}”(hhh]”hŒChinese (Simplified)”…””}”hh2sbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ./translations/zh_CN/process/submitting-patches”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒChinese (Traditional)”…””}”hhFsbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ./translations/zh_TW/process/submitting-patches”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒItalian”…””}”hhZsbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ./translations/it_IT/process/submitting-patches”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒJapanese”…””}”hhnsbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ./translations/ja_JP/process/submitting-patches”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubh)”}”(hhh]”hŒKorean”…””}”hh‚sbah}”(h]”h ]”h"]”h$]”h&]”Œ refdomain”h)Œreftype”h+Œ reftarget”Œ./translations/ko_KR/process/submitting-patches”Œmodname”NŒ classname”NŒ refexplicit”ˆuh1hhh ubeh}”(h]”h ]”h"]”h$]”h&]”Œcurrent_language”ŒSpanish”uh1h hhŒ _document”hŒsource”NŒline”NubhŒwarning”“”)”}”(hX?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. Además, por defecto, los enlaces a documentos redirigen a la documentación en inglés, incluso si existe una versión traducida. Consulte el índice para más información.”h]”hŒ paragraph”“”)”}”(hX?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. Además, por defecto, los enlaces a documentos redirigen a la documentación en inglés, incluso si existe una versión traducida. Consulte el índice para más información.”h]”hX?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. Además, por defecto, los enlaces a documentos redirigen a la documentación en inglés, incluso si existe una versión traducida. Consulte el índice para más información.”…””}”(hh©hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸŒ2Documentation/translations/sp_SP/disclaimer-sp.rst”h Khh£ubah}”(h]”h ]”h"]”h$]”h&]”uh1h¡hhhžhhŸh·h NubhŒ field_list”“”)”}”(hhh]”(hŒfield”“”)”}”(hhh]”(hŒ field_name”“”)”}”(hŒOriginal”h]”hŒOriginal”…””}”(hhÊhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÈhhÅhŸŒ[/var/lib/git/docbuild/linux/Documentation/translations/sp_SP/process/submitting-patches.rst”h KubhŒ field_body”“”)”}”(hŒG:ref:`Documentation/process/submitting-patches.rst `”h]”h¨)”}”(hhÝh]”h)”}”(hhÝh]”hŒinline”“”)”}”(hhÝh]”hŒ,Documentation/process/submitting-patches.rst”…””}”(hhçhžhhŸNh Nubah}”(h]”h ]”(Œxref”Œstd”Œstd-ref”eh"]”h$]”h&]”uh1håhhâubah}”(h]”h ]”h"]”h$]”h&]”Œrefdoc”Œ-translations/sp_SP/process/submitting-patches”Œ refdomain”hòŒreftype”Œref”Œ refexplicit”ˆŒrefwarn”ˆŒ reftarget”Œsubmittingpatches”uh1hhŸhØh Khhßubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh KhhÛubah}”(h]”h ]”h"]”h$]”h&]”uh1hÙhhÅubeh}”(h]”h ]”h"]”h$]”h&]”uh1hÃhŸhØh KhhÀhžhubhÄ)”}”(hhh]”(hÉ)”}”(hŒ Translator”h]”hŒ Translator”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1hÈhjhŸhØh KubhÚ)”}”(hŒ.Carlos Bilbao ”h]”h¨)”}”(hŒ-Carlos Bilbao ”h]”(hŒCarlos Bilbao <”…””}”(hj-hžhhŸNh NubhŒ reference”“”)”}”(hŒcarlos.bilbao.osdev@gmail.com”h]”hŒcarlos.bilbao.osdev@gmail.com”…””}”(hj7hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”Œ$mailto:carlos.bilbao.osdev@gmail.com”uh1j5hj-ubhŒ>”…””}”(hj-hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Khj)ubah}”(h]”h ]”h"]”h$]”h&]”uh1hÙhjubeh}”(h]”h ]”h"]”h$]”h&]”uh1hÃhŸhØh KhhÀhžhubeh}”(h]”h ]”h"]”h$]”h&]”uh1h¾hhhžhhŸhØh KubhŒtarget”“”)”}”(hŒ.. _sp_submittingpatches:”h]”h}”(h]”h ]”h"]”h$]”h&]”Œrefid”Œsp-submittingpatches”uh1jch KhhhžhhŸhØubhŒsection”“”)”}”(hhh]”(hŒtitle”“”)”}”(hŒIEnvío de parches: la guía esencial para incluir su código en el kernel”h]”hŒIEnvío de parches: la guía esencial para incluir su código en el kernel”…””}”(hjxhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jvhjshžhhŸhØh K ubh¨)”}”(hX)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.”h]”hX-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.”…””}”(hj†hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh K hjshžhubh¨)”}”(hXì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 Documentation/process/development-process.rst. Además, lea Documentation/process/submit-checklist.rst para obtener una lista de elementos a verificar antes de enviar código. Para los parches de "binding" del árbol de dispositivos, lea Documentation/devicetree/bindings/submitting-patches.rst.”h]”hXð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 Documentation/process/development-process.rst. Además, lea Documentation/process/submit-checklist.rst para obtener una lista de elementos a verificar antes de enviar código. Para los parches de “binding†del árbol de dispositivos, lea Documentation/devicetree/bindings/submitting-patches.rst.”…””}”(hj”hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Khjshžhubh¨)”}”(hŒë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.”h]”(hŒ+Esta documentación asume que está usando ”…””}”(hj¢hžhhŸNh NubhŒliteral”“”)”}”(hŒ``git``”h]”hŒgit”…””}”(hj¬hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhj¢ubhŒ: para preparar sus parches. Si no está familiarizado con ”…””}”(hj¢hžhhŸNh Nubj«)”}”(hŒ``git``”h]”hŒgit”…””}”(hj¾hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhj¢ubhŒx, le recomendamos que aprenda a usarlo, le hará la vida como desarrollador del kernel y en general mucho más sencilla.”…””}”(hj¢hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Khjshžhubh¨)”}”(hŒØAlgunos subsistemas y árboles de mantenimiento cuentan con información adicional sobre su flujo de trabajo y expectativas, consulte :ref:`Documentation/process/maintainer-handbooks.rst `.”h]”(hŒ†Algunos subsistemas y árboles de mantenimiento cuentan con información adicional sobre su flujo de trabajo y expectativas, consulte ”…””}”(hjÖhžhhŸNh Nubh)”}”(hŒQ:ref:`Documentation/process/maintainer-handbooks.rst `”h]”hæ)”}”(hjàh]”hŒ.Documentation/process/maintainer-handbooks.rst”…””}”(hjâhžhhŸNh Nubah}”(h]”h ]”(hñŒstd”Œstd-ref”eh"]”h$]”h&]”uh1håhjÞubah}”(h]”h ]”h"]”h$]”h&]”Œrefdoc”hþŒ refdomain”jìŒreftype”Œref”Œ refexplicit”ˆŒrefwarn”ˆjŒmaintainer_handbooks_main”uh1hhŸhØh KhjÖubhŒ.”…””}”(hjÖhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Khjshžhubjr)”}”(hhh]”(jw)”}”(hŒ Obtenga el código fuente actual”h]”hŒ Obtenga el código fuente actual”…””}”(hj hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jvhjhžhhŸhØh K$ubh¨)”}”(hŒ´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::”h]”(hŒOSi no tiene a mano un repositorio con el código fuente actual del kernel, use ”…””}”(hjhžhhŸNh Nubj«)”}”(hŒ``git``”h]”hŒgit”…””}”(hj!hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjubhŒ] para obtener uno. Querrá comenzar con el repositorio principal, que se puede descargar con:”…””}”(hjhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh K&hjhžhubhŒ literal_block”“”)”}”(hŒJgit clone git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git”h]”hŒJgit clone git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git”…””}”hj;sbah}”(h]”h ]”h"]”h$]”h&]”Œ xml:space”Œpreserve”uh1j9hŸhØh K*hjhžhubh¨)”}”(hX¥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í.”h]”(hX 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 ”…””}”(hjKhžhhŸNh NubhŒstrong”“”)”}”(hŒ**T:**”h]”hŒT:”…””}”(hjUhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jShjKubhŒ” para el subsistema en el archivo MAINTAINERS para encontrar dicho árbol, o simplemente pregunte al maintainer si el árbol no está listado allí.”…””}”(hjKhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh K,hjhžhubjd)”}”(hŒ.. _sp_describe_changes:”h]”h}”(h]”h ]”h"]”h$]”h&]”joŒsp-describe-changes”uh1jch K@hjhžhhŸhØubeh}”(h]”Œobtenga-el-codigo-fuente-actual”ah ]”h"]”Œ obtenga el código fuente actual”ah$]”h&]”uh1jqhjshžhhŸhØh K$ubjr)”}”(hhh]”(jw)”}”(hŒDescriba sus cambios”h]”hŒDescriba sus cambios”…””}”(hjƒhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jvhj€hžhhŸhØh K6ubh¨)”}”(hXDDescriba 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.”h]”hXHDescriba 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.”…””}”(hj‘hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh K8hj€hžhubh¨)”}”(hXò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.”h]”hXö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.”…””}”(hjŸhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh K>hj€hžhubh¨)”}”(hXCuantifique 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.”h]”hXCuantifique 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.”…””}”(hj­hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh KJhj€hžhubh¨)”}”(hŒ÷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.”h]”hŒ÷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.”…””}”(hj»hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh KShj€hžhubh¨)”}”(hXEl 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 :ref:`sp_the_canonical_patch_format`.”h]”(hŒ§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, ”…””}”(hjÉhžhhŸNh Nubj«)”}”(hŒ``git``”h]”hŒgit”…””}”(hjÑhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjÉubhŒ@, como un “commit log†(registros de los commits). Consulte ”…””}”(hjÉhžhhŸNh Nubh)”}”(hŒ$:ref:`sp_the_canonical_patch_format`”h]”hæ)”}”(hjåh]”hŒsp_the_canonical_patch_format”…””}”(hjçhžhhŸNh Nubah}”(h]”h ]”(hñŒstd”Œstd-ref”eh"]”h$]”h&]”uh1håhjãubah}”(h]”h ]”h"]”h$]”h&]”Œrefdoc”hþŒ refdomain”jñŒreftype”Œref”Œ refexplicit”‰Œrefwarn”ˆjŒsp_the_canonical_patch_format”uh1hhŸhØh KXhjÉubhŒ.”…””}”(hjÉhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh KXhj€hžhubh¨)”}”(hŒ¯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 :ref:`split_changes`.”h]”(hŒš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 ”…””}”(hj hžhhŸNh Nubh)”}”(hŒ:ref:`split_changes`”h]”hæ)”}”(hjh]”hŒ split_changes”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”(hñŒstd”Œstd-ref”eh"]”h$]”h&]”uh1håhjubah}”(h]”h ]”h"]”h$]”h&]”Œrefdoc”hþŒ refdomain”j#Œreftype”Œref”Œ refexplicit”‰Œrefwarn”ˆjŒ split_changes”uh1hhŸhØh K]hj ubhŒ.”…””}”(hj hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh K]hj€hžhubh¨)”}”(hXXCuando 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.”h]”hXXCuando 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.”…””}”(hj?hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Kahj€hžhubh¨)”}”(hX 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.”h]”hXDescriba 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.”…””}”(hjMhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Kkhj€hžhubh¨)”}”(hŒî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::”h]”hŒí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:”…””}”(hj[hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Kphj€hžhubj:)”}”(hŒ®Commit e21d2170f36602ae2708 ("video: quitar platform_set_drvdata() innecesario") eliminó innecesario platform_set_drvdata(), pero dejó la variable "dev" sin usar, bórrese.”h]”hŒ®Commit e21d2170f36602ae2708 ("video: quitar platform_set_drvdata() innecesario") eliminó innecesario platform_set_drvdata(), pero dejó la variable "dev" sin usar, bórrese.”…””}”hjisbah}”(h]”h ]”h"]”h$]”h&]”jIjJuh1j9hŸhØh Kvhj€hžhubh¨)”}”(hX†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.”h]”(hŒŽTambién debe asegurarse de utilizar al menos los primeros doce caracteres del identificador SHA-1. El repositorio del kernel contiene muchos ”…””}”(hjwhžhhŸNh NubhŒemphasis”“”)”}”(hŒ*muchos*”h]”hŒmuchos”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jhjwubhŒð 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.”…””}”(hjwhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Kzhj€hžhubh¨)”}”(hXç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.”h]”hXë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.”…””}”(hj™hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Khj€hžhubh¨)”}”(hXCuando 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::”h]”(hŒÎ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â€) ”…””}”(hj§hžhhŸNh Nubj«)”}”(hŒ``Message-Id``”h]”hŒ Message-Id”…””}”(hj¯hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhj§ubhŒD del mensaje sin los corchetes angulares que lo rodean. Por ejemplo:”…””}”(hj§hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh K‰hj€hžhubj:)”}”(hŒKLink: https://lore.kernel.org/r/30th.anniversary.repost@klaava.Helsinki.FI/”h]”hŒKLink: https://lore.kernel.org/r/30th.anniversary.repost@klaava.Helsinki.FI/”…””}”hjÇsbah}”(h]”h ]”h"]”h$]”h&]”jIjJuh1j9hŸhØh Khj€hžhubh¨)”}”(hŒbVerifique el enlace para asegurarse de que realmente funciona y apunta al mensaje correspondiente.”h]”hŒbVerifique el enlace para asegurarse de que realmente funciona y apunta al mensaje correspondiente.”…””}”(hjÕhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh K‘hj€hžhubh¨)”}”(hŒð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ó.”h]”hŒð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ó.”…””}”(hjãhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh K”hj€hžhubh¨)”}”(hXtSi 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::”h]”(hŒaSi su parche corrige un error en un commit específico, por ejemplo encontró un problema usando ”…””}”(hjñhžhhŸNh Nubj«)”}”(hŒ``git bisect``”h]”hŒ git bisect”…””}”(hjùhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjñubhX , 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:”…””}”(hjñhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh K™hj€hžhubj:)”}”(hŒuFixes: 54a4f0239f2e ("KVM: MMU: hacer que kvm_mmu_zap_page() devuelva la cantidad de páginas que realmente liberó")”h]”hŒuFixes: 54a4f0239f2e ("KVM: MMU: hacer que kvm_mmu_zap_page() devuelva la cantidad de páginas que realmente liberó")”…””}”hjsbah}”(h]”h ]”h"]”h$]”h&]”jIjJuh1j9hŸhØh K hj€hžhubh¨)”}”(hŒ¢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``::”h]”(hŒ"Las siguientes configuraciones de ”…””}”(hjhžhhŸNh Nubj«)”}”(hŒ``git config``”h]”hŒ git config”…””}”(hj'hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjubhŒV se pueden usar para agregar un bonito formato y generar este estilo con los comandos ”…””}”(hjhžhhŸNh Nubj«)”}”(hŒ ``git log``”h]”hŒgit log”…””}”(hj9hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjubhŒ o ”…””}”(hjhžhhŸNh Nubj«)”}”(hŒ ``git show``”h]”hŒgit show”…””}”(hjKhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjubhŒ:”…””}”(hjhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh K£hj€hžhubj:)”}”(hŒF[core] abbrev = 12 [pretty] fixes = Fixes: %h (\"%s\")”h]”hŒF[core] abbrev = 12 [pretty] fixes = Fixes: %h (\"%s\")”…””}”hjcsbah}”(h]”h ]”h"]”h$]”h&]”jIjJuh1j9hŸhØh K§hj€hžhubh¨)”}”(hŒUn ejemplo de uso::”h]”hŒUn ejemplo de uso:”…””}”(hjqhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh K¬hj€hžhubj:)”}”(hŒž$ 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ó")”h]”hŒž$ 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ó")”…””}”hjsbah}”(h]”h ]”h"]”h$]”h&]”jIjJuh1j9hŸhØh K®hj€hžhubjd)”}”(hŒ.. _sp_split_changes:”h]”h}”(h]”h ]”h"]”h$]”h&]”joŒsp-split-changes”uh1jch K¾hj€hžhhŸhØubeh}”(h]”(Œdescriba-sus-cambios”jweh ]”h"]”(Œdescriba sus cambios”Œsp_describe_changes”eh$]”h&]”uh1jqhjshžhhŸhØh K6Œexpect_referenced_by_name”}”jžjmsŒexpect_referenced_by_id”}”jwjmsubjr)”}”(hhh]”(jw)”}”(hŒSepare sus cambios”h]”hŒSepare sus cambios”…””}”(hj¨hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jvhj¥hžhhŸhØh K´ubh¨)”}”(hŒ5Separe cada **cambio lógico** en un parche separado.”h]”(hŒ Separe cada ”…””}”(hj¶hžhhŸNh NubjT)”}”(hŒ**cambio lógico**”h]”hŒcambio lógico”…””}”(hj¾hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jShj¶ubhŒ en un parche separado.”…””}”(hj¶hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh K¶hj¥hžhubh¨)”}”(hXPor 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.”h]”hXPor 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.”…””}”(hjÖhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh K¸hj¥hžhubh¨)”}”(hŒ°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.”h]”hŒ°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.”…””}”(hjähžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh K½hj¥hžhubh¨)”}”(hŒ²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.”h]”hŒ²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.”…””}”(hjòhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh KÁhj¥hžhubh¨)”}”(hŒ´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.”h]”(hŒmSi un parche depende de otro parche para que un cambio sea completo, eso está bien. Simplemente incluya que ”…””}”(hjhžhhŸNh NubjT)”}”(hŒ&**"este parche depende del parche X"**”h]”hŒ&“este parche depende del parche X—…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jShjubhŒ! en la descripción de su parche.”…””}”(hjhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh KÅhj¥hžhubh¨)”}”(hXkCuando 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.”h]”(hŒÌ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 ”…””}”(hj hžhhŸNh Nubj«)”}”(hŒ``git bisect``”h]”hŒ git bisect”…””}”(hj(hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhj ubhŒ‘ para rastrear un problema pueden terminar dividiendo su serie de parches en cualquier punto; no le agradecerán si introdujo errores a la mitad.”…””}”(hj hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh KÉhj¥hžhubh¨)”}”(hŒ¤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.”h]”hŒ¤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.”…””}”(hj@hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh KÏhj¥hžhubeh}”(h]”(Œsepare-sus-cambios”j—eh ]”h"]”(Œsepare sus cambios”Œsp_split_changes”eh$]”h&]”uh1jqhjshžhhŸhØh K´j¡}”jTjsj£}”j—jsubjr)”}”(hhh]”(jw)”}”(hŒRevise el estilo en sus cambios”h]”hŒRevise el estilo en sus cambios”…””}”(hj\hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jvhjYhžhhŸhØh KÕubh¨)”}”(hXRevise su parche para ver si hay violaciones de estilo básico, cuyos detalles pueden ser encontrados en Documentation/process/coding-style.rst. No hacerlo simplemente desperdicia el tiempo de los revisores y su parche será rechazado, probablemente sin siquiera ser leído.”h]”hXRevise su parche para ver si hay violaciones de estilo básico, cuyos detalles pueden ser encontrados en Documentation/process/coding-style.rst. No hacerlo simplemente desperdicia el tiempo de los revisores y su parche será rechazado, probablemente sin siquiera ser leído.”…””}”(hjjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh K×hjYhžhubh¨)”}”(hXrUna 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í.”h]”hXrUna 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í.”…””}”(hjxhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh KÜhjYhžhubh¨)”}”(hXEVerifique 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.”h]”hXEVerifique 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.”…””}”(hj†hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh KâhjYhžhubhŒdefinition_list”“”)”}”(hhh]”hŒdefinition_list_item”“”)”}”(hŒÌ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 ”h]”(hŒterm”“”)”}”(hŒ&El verificador informa a tres niveles:”h]”hŒ&El verificador informa a tres niveles:”…””}”(hj¡hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jŸhŸhØh Këhj›ubhŒ definition”“”)”}”(hhh]”hŒ bullet_list”“”)”}”(hhh]”(hŒ list_item”“”)”}”(hŒ/ERROR: cosas que es muy probable que estén mal”h]”h¨)”}”(hj½h]”hŒ/ERROR: cosas que es muy probable que estén mal”…””}”(hj¿hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Kéhj»ubah}”(h]”h ]”h"]”h$]”h&]”uh1j¹hj¶ubjº)”}”(hŒAWARNING: Advertencia. Cosas que requieren una revisión cuidadosa”h]”h¨)”}”(hjÔh]”hŒAWARNING: Advertencia. Cosas que requieren una revisión cuidadosa”…””}”(hjÖhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh KêhjÒubah}”(h]”h ]”h"]”h$]”h&]”uh1j¹hj¶ubjº)”}”(hŒ-CHECK: Revisar. Cosas que requieren pensarlo ”h]”h¨)”}”(hŒ,CHECK: Revisar. Cosas que requieren pensarlo”h]”hŒ,CHECK: Revisar. Cosas que requieren pensarlo”…””}”(hjíhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Këhjéubah}”(h]”h ]”h"]”h$]”h&]”uh1j¹hj¶ubeh}”(h]”h ]”h"]”h$]”h&]”Œbullet”Œ-”uh1j´hŸhØh Kéhj±ubah}”(h]”h ]”h"]”h$]”h&]”uh1j¯hj›ubeh}”(h]”h ]”h"]”h$]”h&]”uh1j™hŸhØh Këhj–ubah}”(h]”h ]”h"]”h$]”h&]”uh1j”hjYhžhhŸNh Nubh¨)”}”(hŒIDebe poder justificar todas las violaciones que permanezcan en su parche.”h]”hŒIDebe poder justificar todas las violaciones que permanezcan en su parche.”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh KíhjYhžhubeh}”(h]”Œrevise-el-estilo-en-sus-cambios”ah ]”h"]”Œrevise el estilo en sus cambios”ah$]”h&]”uh1jqhjshžhhŸhØh KÕubjr)”}”(hhh]”(jw)”}”(hŒ)Seleccione los destinatarios de su parche”h]”hŒ)Seleccione los destinatarios de su parche”…””}”(hj4hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jvhj1hžhhŸhØh Kñubh¨)”}”(hX+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.”h]”(hXç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 (”…””}”(hjBhžhhŸNh Nubj6)”}”(hŒakpm@linux-foundation.org”h]”hŒakpm@linux-foundation.org”…””}”(hjJhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”Œ mailto:akpm@linux-foundation.org”uh1j5hjBubhŒ+) sirve como maintainer de último recurso.”…””}”(hjBhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Kóhj1hžhubh¨)”}”(hXÔ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.”h]”(hŒqNormalmente, también debe elegir al menos una lista de correo para recibir una copia de su conjunto de parches. ”…””}”(hjdhžhhŸNh Nubj6)”}”(hŒlinux-kernel@vger.kernel.org”h]”hŒlinux-kernel@vger.kernel.org”…””}”(hjlhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”Œ#mailto:linux-kernel@vger.kernel.org”uh1j5hjdubhXG 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.”…””}”(hjdhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Kühj1hžhubh¨)”}”(hŒî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.”h]”(hŒuMuchas listas relacionadas con el kernel están alojadas en vger.kernel.org; puedes encontrar un listado de estas en ”…””}”(hj†hžhhŸNh Nubj6)”}”(hŒ&http://vger.kernel.org/vger-lists.html”h]”hŒ&http://vger.kernel.org/vger-lists.html”…””}”(hjŽhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”juh1j5hj†ubhŒS. Existen listas relacionadas con el kernel alojadas en otros lugares, no obstante.”…””}”(hj†hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mhj1hžhubh¨)”}”(hŒG¡No envíe más de 15 parches a la vez a las listas de correo de vger!”h]”hŒG¡No envíe más de 15 parches a la vez a las listas de correo de vger!”…””}”(hj§hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M hj1hžhubh¨)”}”(hXkLinus Torvalds es el árbitro final de todos los cambios aceptados en el kernel de Linux. Su dirección de correo electrónico es . 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.”h]”(hŒƒLinus Torvalds es el árbitro final de todos los cambios aceptados en el kernel de Linux. Su dirección de correo electrónico es <”…””}”(hjµhžhhŸNh Nubj6)”}”(hŒtorvalds@linux-foundation.org”h]”hŒtorvalds@linux-foundation.org”…””}”(hj½hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”Œ$mailto:torvalds@linux-foundation.org”uh1j5hjµubhŒË>. 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.”…””}”(hjµhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M hj1hžhubh¨)”}”(hXuSi 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 Documentation/process/security-bugs.rst.”h]”(hŒUSi tiene un parche que corrige un error de seguridad explotable, envíe ese parche a ”…””}”(hj×hžhhŸNh Nubj6)”}”(hŒsecurity@kernel.org”h]”hŒsecurity@kernel.org”…””}”(hjßhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”Œmailto:security@kernel.org”uh1j5hj×ubhX . 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 Documentation/process/security-bugs.rst.”…””}”(hj×hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mhj1hžhubh¨)”}”(hŒŠLos parches que corrigen un error grave en un kernel en uso deben dirigirse hacia los maintainers estables poniendo una línea como esta::”h]”hŒ‰Los parches que corrigen un error grave en un kernel en uso deben dirigirse hacia los maintainers estables poniendo una línea como esta:”…””}”(hjùhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mhj1hžhubj:)”}”(hŒCC: stable@vger.kernel.org”h]”hŒCC: stable@vger.kernel.org”…””}”hjsbah}”(h]”h ]”h"]”h$]”h&]”jIjJuh1j9hŸhØh Mhj1hžhubh¨)”}”(hŒ·en el área de sign-off de su parche (es decir, NO un destinatario de correo electrónico). También debe leer Documentation/process/stable-kernel-rules.rst además de este documento.”h]”hŒ·en el área de sign-off de su parche (es decir, NO un destinatario de correo electrónico). También debe leer Documentation/process/stable-kernel-rules.rst además de este documento.”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mhj1hžhubh¨)”}”(hX…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.”h]”(hXkSi 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 ”…””}”(hj#hžhhŸNh Nubj6)”}”(hŒlinux-api@vger.kernel.org”h]”hŒlinux-api@vger.kernel.org”…””}”(hj+hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”Œ mailto:linux-api@vger.kernel.org”uh1j5hj#ubhŒ.”…””}”(hj#hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M"hj1hžhubeh}”(h]”Œ)seleccione-los-destinatarios-de-su-parche”ah ]”h"]”Œ)seleccione los destinatarios de su parche”ah$]”h&]”uh1jqhjshžhhŸhØh Kñubjr)”}”(hhh]”(jw)”}”(hŒDSin MIME, enlaces, compresión o archivos adjuntos. Solo texto plano”h]”hŒDSin MIME, enlaces, compresión o archivos adjuntos. Solo texto plano”…””}”(hjPhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jvhjMhžhhŸhØh M+ubh¨)”}”(hX/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.”h]”hX3Linus 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.”…””}”(hj^hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M-hjMhžhubh¨)”}”(hXPor 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.”h]”(hŒPor este motivo, todos los parches deben enviarse por correo electrónico “inlineâ€. La forma más sencilla de hacerlo es con ”…””}”(hjlhžhhŸNh Nubj«)”}”(hŒ``git send-email``”h]”hŒgit send-email”…””}”(hjthžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjlubhŒ8, que es muy recomendable. Un tutorial interactivo para ”…””}”(hjlhžhhŸNh Nubj«)”}”(hŒ``git send-email``”h]”hŒgit send-email”…””}”(hj†hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjlubhŒ está disponible en ”…””}”(hjlhžhhŸNh Nubj6)”}”(hŒhttps://git-send-email.io”h]”hŒhttps://git-send-email.io”…””}”(hj˜hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”jšuh1j5hjlubhŒ.”…””}”(hjlhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M3hjMhžhubh¨)”}”(hŒ$Si elige no usar ``git send-email``:”h]”(hŒSi elige no usar ”…””}”(hj±hžhhŸNh Nubj«)”}”(hŒ``git send-email``”h]”hŒgit send-email”…””}”(hj¹hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhj±ubhŒ:”…””}”(hj±hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M8hjMhžhubh¢)”}”(hŒoTenga cuidado con el ajuste de palabras de su editor que corrompe su parche, si elige cortar y pegar su parche.”h]”h¨)”}”(hŒoTenga cuidado con el ajuste de palabras de su editor que corrompe su parche, si elige cortar y pegar su parche.”h]”hŒoTenga cuidado con el ajuste de palabras de su editor que corrompe su parche, si elige cortar y pegar su parche.”…””}”(hjÕhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M<hjÑubah}”(h]”h ]”h"]”h$]”h&]”uh1h¡hjMhžhhŸhØh Nubh¨)”}”(hXNo 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.”h]”hXNo 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.”…””}”(hjéhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M?hjMhžhubh¨)”}”(hŒ‚Excepción: si su proveedor de correo está destrozando parches, entonces alguien puede pedir que los vuelva a enviar usando MIME.”h]”hŒ‚Excepción: si su proveedor de correo está destrozando parches, entonces alguien puede pedir que los vuelva a enviar usando MIME.”…””}”(hj÷hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MFhjMhžhubh¨)”}”(hŒ¨Consulte Documentation/process/email-clients.rst para obtener sugerencias sobre cómo configurar su cliente de correo electrónico para que envíe sus parches intactos.”h]”hŒ¨Consulte Documentation/process/email-clients.rst para obtener sugerencias sobre cómo configurar su cliente de correo electrónico para que envíe sus parches intactos.”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MIhjMhžhubeh}”(h]”Œ@sin-mime-enlaces-compresion-o-archivos-adjuntos-solo-texto-plano”ah ]”h"]”ŒDsin mime, enlaces, compresión o archivos adjuntos. solo texto plano”ah$]”h&]”uh1jqhjshžhhŸhØh M+ubjr)”}”(hhh]”(jw)”}”(hŒ'Responda a los comentarios de revisión”h]”hŒ'Responda a los comentarios de revisión”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jvhjhžhhŸhØh MNubh¨)”}”(hXBEs 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.”h]”hXFEs 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.”…””}”(hj,hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MPhjhžhubh¨)”}”(hXFAsegú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 :ref:`sp_the_canonical_patch_format`).”h]”(hXeAsegú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 ”…””}”(hj:hžhhŸNh Nubj«)”}”(hŒ``patch changelog``”h]”hŒpatch changelog”…””}”(hjBhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhj:ubhŒ¬ (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 ”…””}”(hj:hžhhŸNh Nubh)”}”(hŒ$:ref:`sp_the_canonical_patch_format`”h]”hæ)”}”(hjVh]”hŒsp_the_canonical_patch_format”…””}”(hjXhžhhŸNh Nubah}”(h]”h ]”(hñŒstd”Œstd-ref”eh"]”h$]”h&]”uh1håhjTubah}”(h]”h ]”h"]”h$]”h&]”Œrefdoc”hþŒ refdomain”jbŒreftype”Œref”Œ refexplicit”‰Œrefwarn”ˆjŒsp_the_canonical_patch_format”uh1hhŸhØh MYhj:ubhŒ).”…””}”(hj:hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MYhjhžhubh¨)”}”(hŒŸConsulte Documentation/process/email-clients.rst para obtener recomendaciones sobre clientes de correo electrónico y normas de etiqueta en la lista de correo.”h]”hŒŸConsulte Documentation/process/email-clients.rst para obtener recomendaciones sobre clientes de correo electrónico y normas de etiqueta en la lista de correo.”…””}”(hj~hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mchjhžhubjd)”}”(hŒ.. _sp_interleaved_replies:”h]”h}”(h]”h ]”h"]”h$]”h&]”joŒsp-interleaved-replies”uh1jch MthjhžhhŸhØubeh}”(h]”Œ&responda-a-los-comentarios-de-revision”ah ]”h"]”Œ'responda a los comentarios de revisión”ah$]”h&]”uh1jqhjshžhhŸhØh MNubjr)”}”(hhh]”(jw)”}”(hŒTUso de respuestas intercaladas recortadas en las discusiones por correo electrónico”h]”hŒTUso de respuestas intercaladas recortadas en las discusiones por correo electrónico”…””}”(hj¢hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jvhjŸhžhhŸhØh Mjubh¨)”}”(hXPSe desaconseja encarecidamente la publicación en la parte superior de las discusiones sobre el desarrollo del kernel de Linux. Las respuestas intercaladas (o "en línea") hacen que las conversaciones sean mucho más fáciles de seguir. Para obtener más detalles, consulte: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style”h]”(hXSe desaconseja encarecidamente la publicación en la parte superior de las discusiones sobre el desarrollo del kernel de Linux. Las respuestas intercaladas (o “en líneaâ€) hacen que las conversaciones sean mucho más fáciles de seguir. Para obtener más detalles, consulte: ”…””}”(hj°hžhhŸNh Nubj6)”}”(hŒ=https://en.wikipedia.org/wiki/Posting_style#Interleaved_style”h]”hŒ=https://en.wikipedia.org/wiki/Posting_style#Interleaved_style”…””}”(hj¸hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”jºuh1j5hj°ubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MlhjŸhžhubh¨)”}”(hŒ3Como se cita frecuentemente en la lista de correo::”h]”hŒ2Como se cita frecuentemente en la lista de correo:”…””}”(hjÍhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MrhjŸhžhubj:)”}”(hX0A: http://en.wikipedia.org/wiki/Top_post Q: ¿Dónde puedo encontrar información sobre esto que se llama top-posting? A: Porque desordena el orden en el que la gente normalmente lee el texto. Q: ¿Por qué es tan malo el top-posting? A: Top-posting. Q: ¿Qué es lo más molesto del correo electrónico?”h]”hX0A: http://en.wikipedia.org/wiki/Top_post Q: ¿Dónde puedo encontrar información sobre esto que se llama top-posting? A: Porque desordena el orden en el que la gente normalmente lee el texto. Q: ¿Por qué es tan malo el top-posting? A: Top-posting. Q: ¿Qué es lo más molesto del correo electrónico?”…””}”hjÛsbah}”(h]”h ]”h"]”h$]”h&]”jIjJuh1j9hŸhØh MthjŸhžhubh¨)”}”(hXDel mismo modo, por favor, recorte todas las citas innecesarias que no sean relevantes para su respuesta. Esto hace que las respuestas sean más fáciles de encontrar y ahorra tiempo y espacio. Para obtener más información, consulte: http://daringfireball.net/2007/07/on_top ::”h]”(hŒìDel mismo modo, por favor, recorte todas las citas innecesarias que no sean relevantes para su respuesta. Esto hace que las respuestas sean más fáciles de encontrar y ahorra tiempo y espacio. Para obtener más información, consulte: ”…””}”(hjéhžhhŸNh Nubj6)”}”(hŒ(http://daringfireball.net/2007/07/on_top”h]”hŒ(http://daringfireball.net/2007/07/on_top”…””}”(hjñhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”jóuh1j5hjéubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M{hjŸhžhubj:)”}”(hŒ8A: No. Q: ¿Debo incluir citas después de mi respuesta?”h]”hŒ8A: No. Q: ¿Debo incluir citas después de mi respuesta?”…””}”hj sbah}”(h]”h ]”h"]”h$]”h&]”jIjJuh1j9hŸhØh M€hjŸhžhubjd)”}”(hŒ.. _sp_resend_reminders:”h]”h}”(h]”h ]”h"]”h$]”h&]”joŒsp-resend-reminders”uh1jch MhjŸhžhhŸhØubeh}”(h]”(ŒSuso-de-respuestas-intercaladas-recortadas-en-las-discusiones-por-correo-electronico”j–eh ]”h"]”(ŒTuso de respuestas intercaladas recortadas en las discusiones por correo electrónico”Œsp_interleaved_replies”eh$]”h&]”uh1jqhjshžhhŸhØh Mjj¡}”j% jŒsj£}”j–jŒsubjr)”}”(hhh]”(jw)”}”(hŒNo se desanime o impaciente”h]”hŒNo se desanime o impaciente”…””}”(hj- hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jvhj* hžhhŸhØh M†ubh¨)”}”(hŒ—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.”h]”hŒ—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.”…””}”(hj; hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mˆhj* hžhubh¨)”}”(hXÁÉ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".”h]”hXÅÉ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â€.”…””}”(hjI hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M‹hj* hžhubh¨)”}”(hŒ¥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::”h]”hŒ¨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:”…””}”(hjW hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M“hj* hžhubj:)”}”(hŒ7[PATCH Vx RESEND] sub/sys: Resumen condensado de parche”h]”hŒ7[PATCH Vx RESEND] sub/sys: Resumen condensado de parche”…””}”hje sbah}”(h]”h ]”h"]”h$]”h&]”jIjJuh1j9hŸhØh M—hj* hžhubh¨)”}”(hŒø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.”h]”hXNo 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.”…””}”(hjs hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M™hj* hžhubeh}”(h]”(Œno-se-desanime-o-impaciente”j eh ]”h"]”(Œno se desanime o impaciente”Œsp_resend_reminders”eh$]”h&]”uh1jqhjshžhhŸhØh M†j¡}”j‡ j sj£}”j j subjr)”}”(hhh]”(jw)”}”(hŒIncluya PATCH en el asunto”h]”hŒIncluya PATCH en el asunto”…””}”(hj hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jvhjŒ hžhhŸhØh M ubh¨)”}”(hXDebido 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.”h]”hXDebido 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.”…””}”(hj hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M¢hjŒ hžhubh¨)”}”(hŒ-``git send-email`` lo hará automáticamente.”h]”(j«)”}”(hŒ``git send-email``”h]”hŒgit send-email”…””}”(hj¯ hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhj« ubhŒ lo hará automáticamente.”…””}”(hj« hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M§hjŒ hžhubeh}”(h]”Œincluya-patch-en-el-asunto”ah ]”h"]”Œincluya patch en el asunto”ah$]”h&]”uh1jqhjshžhhŸhØh M ubjr)”}”(hhh]”(jw)”}”(hŒ ubah}”(h]”h ]”h"]”h$]”h&]”uh1j¹hj# ubjº)”}”(hŒ‚La contribución me fue proporcionada directamente por alguna otra persona que certificó (a), (b) o (c) y no he modificado esto. ”h]”h¨)”}”(hŒLa contribución me fue proporcionada directamente por alguna otra persona que certificó (a), (b) o (c) y no he modificado esto.”h]”hŒLa contribución me fue proporcionada directamente por alguna otra persona que certificó (a), (b) o (c) y no he modificado esto.”…””}”(hjZ hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MÈhjV ubah}”(h]”h ]”h"]”h$]”h&]”uh1j¹hj# ubjº)”}”(hXPEntiendo 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. ”h]”h¨)”}”(hXOEntiendo 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.”h]”hXOEntiendo 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.”…””}”(hjr hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MÌhjn ubah}”(h]”h ]”h"]”h$]”h&]”uh1j¹hj# ubeh}”(h]”h ]”h"]”h$]”h&]”Œenumtype”Œ loweralpha”Œprefix”Œ(”Œsuffix”Œ)”uh1j! hj ubah}”(h]”h ]”h"]”h$]”h&]”uh1j hŸhØh M¼hjü hžhubh¨)”}”(hŒ2entonces simplemente incluya una línea que rece::”h]”hŒ1entonces simplemente incluya una línea que rece:”…””}”(hj˜ hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MÓhjü hžhubj:)”}”(hŒ@Signed-off-by: Random J Developer ”h]”hŒ@Signed-off-by: Random J Developer ”…””}”hj¦ sbah}”(h]”h ]”h"]”h$]”h&]”jIjJuh1j9hŸhØh MÕhjü hžhubh¨)”}”(hXusando 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.”h]”(hŒ†usando su nombre real (lamentablemente, no pseudónimos ni contribuciones anónimas). Esto se hará por usted automáticamente si usa ”…””}”(hj´ hžhhŸNh Nubj«)”}”(hŒ``git commit -s``”h]”hŒ git commit -s”…””}”(hj¼ hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhj´ ubhŒI. Las reversiones de código también deben incluir “Signed-off-byâ€. ”…””}”(hj´ hžhhŸNh Nubj«)”}”(hŒ``git revert -s``”h]”hŒ git revert -s”…””}”(hjÎ hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhj´ ubhŒ hace eso por usted.”…””}”(hj´ hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M×hjü hžhubh¨)”}”(hŒî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.”h]”hŒî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.”…””}”(hjæ hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MÜhjü hžhubh¨)”}”(hXtCualquier 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.”h]”(hŒÆ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 ”…””}”(hjô hžhhŸNh NubjT)”}”(hŒ**real**”h]”hŒreal”…””}”(hjü hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jShjô ubhŒ¦ 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.”…””}”(hjô hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Máhjü hžhubeh}”(h]”Œ+certificado-de-origen-del-desarrollador-1-1”ah ]”h"]”Œ+certificado de origen del desarrollador 1.1”ah$]”h&]”uh1jqhjÏ hžhhŸhØh M¸ubeh}”(h]”Œ;firme-su-trabajo-el-certificado-de-origen-del-desarrollador”ah ]”h"]”Œ Co-developed-by: Primer coautor Signed-off-by: Primer coautor Co-developed-by: Segundo coautor Signed-off-by: Segundo coautor Signed-off-by: Autor del From ”h]”hX: Co-developed-by: Primer coautor Signed-off-by: Primer coautor Co-developed-by: Segundo coautor Signed-off-by: Segundo coautor Signed-off-by: Autor del From ”…””}”hjÅ sbah}”(h]”h ]”h"]”h$]”h&]”jIjJuh1j9hŸhØh Mhj$ hžhubh¨)”}”(hŒ Co-developed-by: Co-Autor aleatorio Signed-off-by: Coautor aleatorio Signed-off-by: Autor del From Co-developed-by: Coautor que envió Signed-off-by: Coautor que envía ”h]”hXwFrom: Autor del From Co-developed-by: Co-Autor aleatorio Signed-off-by: Coautor aleatorio Signed-off-by: Autor del From Co-developed-by: Coautor que envió Signed-off-by: Coautor que envía ”…””}”hjá sbah}”(h]”h ]”h"]”h$]”h&]”jIjJuh1j9hŸhØh M&hj$ hžhubeh}”(h]”Œ-cuando-usar-acked-by-cc-y-co-developed-by-por”ah ]”h"]”Œ2cuándo usar acked-by:, cc: y co-developed-by por:”ah$]”h&]”uh1jqhjshžhhŸhØh Méubjr)”}”(hhh]”(jw)”}”(hŒEUso de Reported-by:, Tested-by:, Reviewed-by:, Suggested-by: y Fixes:”h]”hŒEUso de Reported-by:, Tested-by:, Reviewed-by:, Suggested-by: y Fixes:”…””}”(hjú hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jvhj÷ hžhhŸhØh M1ubh¨)”}”(hX_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.”h]”hX_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.”…””}”(hj hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M3hj÷ hžhubh¨)”}”(hX;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.”h]”hX?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.”…””}”(hj hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M9hj÷ hžhubh¨)”}”(hŒ€Reviewed-by: en cambio, indica que el parche ha sido revisado y encontrado aceptable de acuerdo con la Declaración del Revisor:”h]”hŒ€Reviewed-by: en cambio, indica que el parche ha sido revisado y encontrado aceptable de acuerdo con la Declaración del Revisor:”…””}”(hj$ hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M?hj÷ hžhubjr)”}”(hhh]”(jw)”}”(hŒ(Declaración de Supervisión del Revisor”h]”hŒ(Declaración de Supervisión del Revisor”…””}”(hj5 hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jvhj2 hžhhŸhØh MCubh¨)”}”(hŒ0Al ofrecer mi etiqueta Reviewed-by:, afirmo que:”h]”hŒ0Al ofrecer mi etiqueta Reviewed-by:, afirmo que:”…””}”(hjC hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MEhj2 hžhubh¨)”}”(hŒ(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.”h]”hŒ(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.”…””}”(hjQ hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MGhj2 hžhubh¨)”}”(hŒ¬(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.”h]”hŒ¬(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.”…””}”(hj_ hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MKhj2 hžhubh¨)”}”(hŒà(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.”h]”hŒà(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.”…””}”(hjm hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MOhj2 hžhubh¨)”}”(hŒã(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.”h]”hŒã(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.”…””}”(hj{ hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MThj2 hžhubh¨)”}”(hXaUna 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.”h]”hXaUna 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.”…””}”(hj‰ hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MYhj2 hžhubh¨)”}”(hXLas 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 '---').”h]”hXLas 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 ‘---‘).”…””}”(hj— hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mchj2 hžhubh¨)”}”(hX¥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.”h]”hX©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.”…””}”(hj¥ hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mlhj2 hžhubh¨)”}”(hXÞ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 :ref:`describe_changes` para más detalles.”h]”(hX³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 ”…””}”(hj³ hžhhŸNh Nubh)”}”(hŒ:ref:`describe_changes`”h]”hæ)”}”(hj½ h]”hŒdescribe_changes”…””}”(hj¿ hžhhŸNh Nubah}”(h]”h ]”(hñŒstd”Œstd-ref”eh"]”h$]”h&]”uh1håhj» ubah}”(h]”h ]”h"]”h$]”h&]”Œrefdoc”hþŒ refdomain”jÉ Œreftype”Œref”Œ refexplicit”‰Œrefwarn”ˆjŒdescribe_changes”uh1hhŸhØh Mshj³ ubhŒ para más detalles.”…””}”(hj³ hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mshj2 hžhubh¨)”}”(hXNota: 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 Documentation/process/stable-kernel-rules.rst.”h]”(hŒrNota: Adjuntar una etiqueta Fixes: no subvierte las reglas estables del proceso del kernel ni el requisito de CC: ”…””}”(hjå hžhhŸNh Nubj6)”}”(hŒstable@vger.kernel.org”h]”hŒstable@vger.kernel.org”…””}”(hjí hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”Œmailto:stable@vger.kernel.org”uh1j5hjå ubhŒ† en todos los parches candidatos de ramas estables. Para obtener más información, lea Documentation/process/stable-kernel-rules.rst.”…””}”(hjå hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M{hj2 hžhubjd)”}”(hŒ".. _sp_the_canonical_patch_format:”h]”h}”(h]”h ]”h"]”h$]”h&]”joŒsp-the-canonical-patch-format”uh1jch Mhj2 hžhhŸhØubeh}”(h]”Œ&declaracion-de-supervision-del-revisor”ah ]”h"]”Œ(declaración de supervisión del revisor”ah$]”h&]”uh1jqhj÷ hžhhŸhØh MCubeh}”(h]”Œ=uso-de-reported-by-tested-by-reviewed-by-suggested-by-y-fixes”ah ]”h"]”ŒEuso de reported-by:, tested-by:, reviewed-by:, suggested-by: y fixes:”ah$]”h&]”uh1jqhjshžhhŸhØh M1ubjr)”}”(hhh]”(jw)”}”(hŒFormato de parche canónico”h]”hŒFormato de parche canónico”…””}”(hj% hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jvhj" hžhhŸhØh Mƒubh¨)”}”(hX]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.”h]”(hŒŠEsta sección describe cómo debe darse formato al propio parche. Tenga en cuenta que, si tiene sus parches almacenados en un repositorio ”…””}”(hj3 hžhhŸNh Nubj«)”}”(hŒ``git``”h]”hŒgit”…””}”(hj; hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhj3 ubhŒ6, el parche con formato adecuado se puede obtener con ”…””}”(hj3 hžhhŸNh Nubj«)”}”(hŒ``git format-patch``”h]”hŒgit format-patch”…””}”(hjM hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhj3 ubhŒ‚. Las herramientas no pueden crear el texto necesario, sin embargo, así que lea las instrucciones a continuación de todos modos.”…””}”(hj3 hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M…hj" hžhubh¨)”}”(hŒ-La línea de asunto del parche canónico es::”h]”hŒ,La línea de asunto del parche canónico es:”…””}”(hje hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M‹hj" hžhubj:)”}”(hŒ4Asunto: [PATCH 001/123] subsistema: frase de resumen”h]”hŒ4Asunto: [PATCH 001/123] subsistema: frase de resumen”…””}”hjs sbah}”(h]”h ]”h"]”h$]”h&]”jIjJuh1j9hŸhØh Mhj" hžhubh¨)”}”(hŒAEl cuerpo del mensaje del parche canónico contiene lo siguiente:”h]”hŒAEl cuerpo del mensaje del parche canónico contiene lo siguiente:”…””}”(hj hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mhj" hžhubj )”}”(hXo- 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``). ”h]”jµ)”}”(hhh]”(jº)”}”(hŒœ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). ”h]”h¨)”}”(hŒ›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).”h]”(hŒ Una línea ”…””}”(hjš hžhhŸNh Nubj«)”}”(hŒ``from``”h]”hŒfrom”…””}”(hj¢ hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjš ubhŒˆ 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).”…””}”(hjš hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M‘hj– ubah}”(h]”h ]”h"]”h$]”h&]”uh1j¹hj“ ubjº)”}”(hŒŽ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. ”h]”h¨)”}”(hŒ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.”h]”hŒ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.”…””}”(hjÄ hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M•hjÀ ubah}”(h]”h ]”h"]”h$]”h&]”uh1j¹hj“ ubjº)”}”(hŒUna línea vacía. ”h]”h¨)”}”(hŒUna línea vacía.”h]”hŒUna línea vacía.”…””}”(hjÜ hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M˜hjØ ubah}”(h]”h ]”h"]”h$]”h&]”uh1j¹hj“ ubjº)”}”(hŒfLas líneas ``Signed-off-by:``, descritas anteriormente, que también vaya en el registro de cambios. ”h]”h¨)”}”(hŒeLas líneas ``Signed-off-by:``, descritas anteriormente, que también vaya en el registro de cambios.”h]”(hŒ Las líneas ”…””}”(hjô hžhhŸNh Nubj«)”}”(hŒ``Signed-off-by:``”h]”hŒSigned-off-by:”…””}”(hjü hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjô ubhŒG, descritas anteriormente, que también vaya en el registro de cambios.”…””}”(hjô hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mšhjð ubah}”(h]”h ]”h"]”h$]”h&]”uh1j¹hj“ ubjº)”}”(hŒ9Una línea de marcador que contiene simplemente ``---``. ”h]”h¨)”}”(hŒ8Una línea de marcador que contiene simplemente ``---``.”h]”(hŒ0Una línea de marcador que contiene simplemente ”…””}”(hjhžhhŸNh Nubj«)”}”(hŒ``---``”h]”hŒ---”…””}”(hj&hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjubhŒ.”…””}”(hjhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mhjubah}”(h]”h ]”h"]”h$]”h&]”uh1j¹hj“ ubjº)”}”(hŒPCualquier comentario adicional que no sea adecuado para el registro de cambios. ”h]”h¨)”}”(hŒOCualquier comentario adicional que no sea adecuado para el registro de cambios.”h]”hŒOCualquier comentario adicional que no sea adecuado para el registro de cambios.”…””}”(hjHhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MŸhjDubah}”(h]”h ]”h"]”h$]”h&]”uh1j¹hj“ ubjº)”}”(hŒ%El parche real (output de ``diff``). ”h]”h¨)”}”(hŒ$El parche real (output de ``diff``).”h]”(hŒEl parche real (output de ”…””}”(hj`hžhhŸNh Nubj«)”}”(hŒ``diff``”h]”hŒdiff”…””}”(hjhhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhj`ubhŒ).”…””}”(hj`hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M¢hj\ubah}”(h]”h ]”h"]”h$]”h&]”uh1j¹hj“ ubeh}”(h]”h ]”h"]”h$]”h&]”jjuh1j´hŸhØh M‘hj ubah}”(h]”h ]”h"]”h$]”h&]”uh1j hŸhØh M‘hj" hžhubh¨)”}”(hX8El 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.”h]”hX8El 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.”…””}”(hj’hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M¤hj" hžhubh¨)”}”(hŒ‚El ``subsistema`` en el asunto del correo electrónico debe identificar qué área o subsistema del kernel está siendo parcheado.”h]”(hŒEl ”…””}”(hj hžhhŸNh Nubj«)”}”(hŒ``subsistema``”h]”hŒ subsistema”…””}”(hj¨hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhj ubhŒq en el asunto del correo electrónico debe identificar qué área o subsistema del kernel está siendo parcheado.”…””}”(hj hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M©hj" hžhubh¨)”}”(hX†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).”h]”(hŒLa ”…””}”(hjÀhžhhŸNh Nubj«)”}”(hŒ``frase de resumen``”h]”hŒfrase de resumen”…””}”(hjÈhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjÀubhŒy en el Asunto del correo electrónico debe describir de forma concisa el parche que contiene ese correo electrónico. La ”…””}”(hjÀhžhhŸNh Nubj«)”}”(hŒ``frase resumen``”h]”hŒ frase resumen”…””}”(hjÚhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjÀubhŒ3 no debe ser un nombre de archivo. No use la mismo ”…””}”(hjÀhžhhŸNh Nubj«)”}”(hŒ``frase resumen``”h]”hŒ frase resumen”…””}”(hjìhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjÀubhŒ¡ 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).”…””}”(hjÀhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M¬hj" hžhubh¨)”}”(hX^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``.”h]”(hŒTenga en cuenta que la ”…””}”(hjhžhhŸNh Nubj«)”}”(hŒ``frase de resumen``”h]”hŒfrase de resumen”…””}”(hj hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjubhŒŠ de su correo electrónico se convierte en un identificador global único para ese parche. Se propaga por hasta el registro de cambios de ”…””}”(hjhžhhŸNh Nubj«)”}”(hŒ``git``”h]”hŒgit”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjubhŒ. La ”…””}”(hjhžhhŸNh Nubj«)”}”(hŒ``frase resumida``”h]”hŒfrase resumida”…””}”(hj0hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjubhŒ se puede usar más adelante en discusiones de desarrolladores que se refieran al parche. La gente querrá buscar en Google la ”…””}”(hjhžhhŸNh Nubj«)”}”(hŒ``frase de resumen``”h]”hŒfrase de resumen”…””}”(hjBhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjubhŒ× 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 ”…””}”(hjhžhhŸNh Nubj«)”}”(hŒ``gitk``”h]”hŒgitk”…””}”(hjThžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjubhŒ o ”…””}”(hjhžhhŸNh Nubj«)”}”(hŒ``git log --oneline``”h]”hŒgit log --oneline”…””}”(hjfhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjubhŒ.”…””}”(hjhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M³hj" hžhubh¨)”}”(hXPor 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.”h]”(hŒPor estas razones, el ”…””}”(hj~hžhhŸNh Nubj«)”}”(hŒ ``resumen``”h]”hŒresumen”…””}”(hj†hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhj~ubhŒð 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.”…””}”(hj~hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M½hj" hžhubh¨)”}”(hXÖLa ``frase de resumen`` puede estar precedida por etiquetas encerradas en corchetes: "Asunto: [PATCH ...] ". 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.”h]”(hŒLa ”…””}”(hjžhžhhŸNh Nubj«)”}”(hŒ``frase de resumen``”h]”hŒfrase de resumen”…””}”(hj¦hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjžubhXË puede estar precedida por etiquetas encerradas en corchetes: “Asunto: [PATCH ...] â€. 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.”…””}”(hjžhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MÂhj" hžhubh¨)”}”(hXSi 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.”h]”hXSi 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.”…””}”(hj¾hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MÊhj" hžhubh¨)”}”(hŒ.Aquí hay algunos buenos ejemplos de Asuntos::”h]”hŒ-Aquí hay algunos buenos ejemplos de Asuntos:”…””}”(hjÌhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MÏhj" hžhubj:)”}”(hXAsunto: [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”h]”hXAsunto: [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”…””}”hjÚsbah}”(h]”h ]”h"]”h$]”h&]”jIjJuh1j9hŸhØh MÑhj" hžhubh¨)”}”(hŒZLa línea ``from`` debe ser la primera línea en el cuerpo del mensaje, y tiene la forma::”h]”(hŒ La línea ”…””}”(hjèhžhhŸNh Nubj«)”}”(hŒ``from``”h]”hŒfrom”…””}”(hjðhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjèubhŒG debe ser la primera línea en el cuerpo del mensaje, y tiene la forma:”…””}”(hjèhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MÖhj" hžhubj:)”}”(hŒ*From: Autor del parche ”h]”hŒ*From: Autor del parche ”…””}”hjsbah}”(h]”h ]”h"]”h$]”h&]”jIjJuh1j9hŸhØh MÙhj" hžhubh¨)”}”(hXLa 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.”h]”(hŒ La línea ”…””}”(hjhžhhŸNh Nubj«)”}”(hŒ``From``”h]”hŒFrom”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjubhŒv especifica quién será acreditado como el autor del parche en el registro de cambios permanente. Si falta la línea ”…””}”(hjhžhhŸNh Nubj«)”}”(hŒ``from``”h]”hŒfrom”…””}”(hj0hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjubhŒ, entonces la línea ”…””}”(hjhžhhŸNh Nubj«)”}”(hŒ ``From:``”h]”hŒFrom:”…””}”(hjBhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjubhŒp del encabezado del correo electrónico se usará para determinar el autor del parche en el registro de cambios.”…””}”(hjhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MÛhj" hžhubh¨)”}”(hXÈ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.”h]”(hX¨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 ”…””}”(hjZhžhhŸNh NubjT)”}”(hŒ **por qué**”h]”hŒpor qué”…””}”(hjbhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jShjZubhŒ se creó el parche.”…””}”(hjZhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Màhj" hžhubh¨)”}”(hX,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.”h]”(hŒå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 ”…””}”(hjzhžhhŸNh Nubj«)”}”(hŒ``frase de resumen``”h]”hŒfrase de resumen”…””}”(hj‚hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjzubhŒ3, es importante ser tanto sucinto como descriptivo.”…””}”(hjzhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mëhj" hžhubh¨)”}”(hŒ›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.”h]”(hŒLa línea marcadora ”…””}”(hjšhžhhŸNh Nubj«)”}”(hŒ``---``”h]”hŒ---”…””}”(hj¢hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjšubhŒ€ cumple el propósito esencial de marcar para herramientas de manejo de parches donde termina el mensaje de registro de cambios.”…””}”(hjšhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mñhj" hžhubh¨)”}”(hX|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).”h]”(hŒAUn buen uso de los comentarios adicionales después del marcador ”…””}”(hjºhžhhŸNh Nubj«)”}”(hŒ``---``”h]”hŒ---”…””}”(hjÂhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjºubhŒ es para ”…””}”(hjºhžhhŸNh Nubj«)”}”(hŒ ``diffstat``”h]”hŒdiffstat”…””}”(hjÔhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjºubhŒk, para mostrar qué archivos han cambiado, y el número de líneas insertadas y eliminadas por archivo. Un ”…””}”(hjºhžhhŸNh Nubj«)”}”(hŒ ``diffstat``”h]”hŒdiffstat”…””}”(hjæhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjºubhŒD es especialmente útil en parches más grandes. Si va a incluir un ”…””}”(hjºhžhhŸNh Nubj«)”}”(hŒ ``diffstat``”h]”hŒdiffstat”…””}”(hjøhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjºubhŒ después del marcador ”…””}”(hjºhžhhŸNh Nubj«)”}”(hŒ``---``”h]”hŒ---”…””}”(hj hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjºubhŒ, utilice las opciones ”…””}”(hjºhžhhŸNh Nubj«)”}”(hŒ ``diffstat``”h]”hŒdiffstat”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjºubhŒ ”…””}”(hjºhžhhŸNh Nubj«)”}”(hŒ``-p 1 -w 70``”h]”hŒ -p 1 -w 70”…””}”(hj.hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjºubhŒ× 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). (”…””}”(hjºhžhhŸNh Nubj«)”}”(hŒ``git``”h]”hŒgit”…””}”(hj@hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjºubhŒ* genera diffstats apropiados por defecto).”…””}”(hjºhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mõhj" hžhubh¨)”}”(hX1Otros 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.”h]”(hŒÉ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 ”…””}”(hjXhžhhŸNh Nubj«)”}”(hŒ#``registros de cambios de parches``”h]”hŒregistros de cambios de parches”…””}”(hj`hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjXubhŒE que describen qué ha cambiado entre la versión v1 y v2 del parche.”…””}”(hjXhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mÿhj" hžhubh¨)”}”(hXÌ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::”h]”(hŒ#Por favor, ponga esta información ”…””}”(hjxhžhhŸNh NubjT)”}”(hŒ **después**”h]”hŒdespués”…””}”(hj€hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jShjxubhŒ de la línea ”…””}”(hjxhžhhŸNh Nubj«)”}”(hŒ``---``”h]”hŒ---”…””}”(hj’hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjxubhX‡ 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:”…””}”(hjxhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mhj" hžhubj:)”}”(hŒÖ ... Signed-off-by: Autor --- V2 -> V3: función auxiliar redundante eliminada V1 -> V2: estilo de código limpio y comentarios de revisión abordados ruta/al/archivo | 5+++-- ...”h]”hŒÖ ... Signed-off-by: Autor --- V2 -> V3: función auxiliar redundante eliminada V1 -> V2: estilo de código limpio y comentarios de revisión abordados ruta/al/archivo | 5+++-- ...”…””}”hjªsbah}”(h]”h ]”h"]”h$]”h&]”jIjJuh1j9hŸhØh M hj" hžhubh¨)”}”(hŒVRevise más detalles sobre el formato de parche adecuado en las siguientes referencias”h]”hŒVRevise más detalles sobre el formato de parche adecuado en las siguientes referencias”…””}”(hj¸hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mhj" hžhubjd)”}”(hŒ.. _sp_backtraces:”h]”h}”(h]”h ]”h"]”h$]”h&]”joŒ sp-backtraces”uh1jch M'hj" hžhhŸhØubjr)”}”(hhh]”(jw)”}”(hŒ'Retrocesos en mensajes de confirmación”h]”hŒ'Retrocesos en mensajes de confirmación”…””}”(hjÔhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jvhjÑhžhhŸhØh Mubh¨)”}”(hX”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.”h]”hX˜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.”…””}”(hjâhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MhjÑhžhubh¨)”}”(hŒÝ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::”h]”hŒÜ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:”…””}”(hjðhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M&hjÑhžhubj:)”}”(hŒÎ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”h]”hŒÎ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”…””}”hjþsbah}”(h]”h ]”h"]”h$]”h&]”jIjJuh1j9hŸhØh M+hjÑhžhubjd)”}”(hŒ.. _sp_explicit_in_reply_to:”h]”h}”(h]”h ]”h"]”h$]”h&]”joŒsp-explicit-in-reply-to”uh1jch M?hjÑhžhhŸhØubeh}”(h]”(Œ&retrocesos-en-mensajes-de-confirmacion”jÐeh ]”h"]”(Œ'retrocesos en mensajes de confirmación”Œ sp_backtraces”eh$]”h&]”uh1jqhj" hžhhŸhØh Mj¡}”jjÆsj£}”jÐjÆsubeh}”(h]”(Œformato-de-parche-canonico”j eh ]”h"]”(Œformato de parche canónico”Œsp_the_canonical_patch_format”eh$]”h&]”uh1jqhjshžhhŸhØh Mƒj¡}”j(j sj£}”j j subjr)”}”(hhh]”(jw)”}”(hŒ'In-Reply-To explicitos en las cabeceras”h]”hŒ'In-Reply-To explicitos en las cabeceras”…””}”(hj0hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jvhj-hžhhŸhØh M5ubh¨)”}”(hX 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.”h]”(hŒ_Puede ser útil agregar manualmente encabezados In-Reply-To: a un parche (por ejemplo, al usar ”…””}”(hj>hžhhŸNh Nubj«)”}”(hŒ``git send-email``”h]”hŒgit send-email”…””}”(hjFhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhj>ubhXó) 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 ”…””}”(hj>hžhhŸNh Nubj6)”}”(hŒhttps://lore.kernel.org/”h]”hŒhttps://lore.kernel.org/”…””}”(hjXhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”jZuh1j5hj>ubhŒŽ (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.”…””}”(hj>hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M7hj-hžhubeh}”(h]”(Œ'in-reply-to-explicitos-en-las-cabeceras”jeh ]”h"]”(Œ'in-reply-to explicitos en las cabeceras”Œsp_explicit_in_reply_to”eh$]”h&]”uh1jqhjshžhhŸhØh M5j¡}”jwj sj£}”jj subjr)”}”(hhh]”(jw)”}”(hŒ(Proporcionar información de árbol base”h]”hŒ(Proporcionar información de árbol base”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jvhj|hžhhŸhØh MEubh¨)”}”(hX}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.”h]”hX}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.”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MGhj|hžhubh¨)”}”(hXSi 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)::”h]”(hŒSi está utilizando ”…””}”(hj›hžhhŸNh Nubj«)”}”(hŒ``git format-patch``”h]”hŒgit format-patch”…””}”(hj£hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhj›ubhŒ| para generar sus parches, puede incluir automáticamente la información del árbol base en su envío usando el parámetro ”…””}”(hj›hžhhŸNh Nubj«)”}”(hŒ ``--base``”h]”hŒ--base”…””}”(hjµhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhj›ubhŒi. La forma más fácil y conveniente de usar esta opción es con “topical branches†(ramas de temas):”…””}”(hj›hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MNhj|hžhubj:)”}”(hXQ$ 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/...”h]”hXQ$ 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/...”…””}”hjÍsbah}”(h]”h ]”h"]”h$]”h&]”jIjJuh1j9hŸhØh MShj|hžhubh¨)”}”(hXCuando 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::”h]”(hŒ Cuando abra ”…””}”(hjÛhžhhŸNh Nubj«)”}”(hŒ$``outgoing/0000-cover-letter.patch``”h]”hŒ outgoing/0000-cover-letter.patch”…””}”(hjãhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjÛubhŒ6 para editar, tenga en cuenta que tendrá el tráiler ”…””}”(hjÛhžhhŸNh Nubj«)”}”(hŒ``base-commit:``”h]”hŒ base-commit:”…””}”(hjõhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjÛubhŒu al final, que proporciona al revisor y a las herramientas de CI suficiente información para realizar correctamente ”…””}”(hjÛhžhhŸNh Nubj«)”}”(hŒ ``git am``”h]”hŒgit am”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjÛubhŒ$ sin preocuparse por los conflictos:”…””}”(hjÛhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M^hj|hžhubj:)”}”(hŒ’$ git checkout -b patch-review [base-commit-id] Switched to a new branch 'patch-review' $ git am patches.mbox Applying: First Commit Applying: ...”h]”hŒ’$ git checkout -b patch-review [base-commit-id] Switched to a new branch 'patch-review' $ git am patches.mbox Applying: First Commit Applying: ...”…””}”hjsbah}”(h]”h ]”h"]”h$]”h&]”jIjJuh1j9hŸhØh Mchj|hžhubh¨)”}”(hŒ]Consulte ``man git-format-patch`` para obtener más información al respecto de esta opción.”h]”(hŒ Consulte ”…””}”(hj-hžhhŸNh Nubj«)”}”(hŒ``man git-format-patch``”h]”hŒman git-format-patch”…””}”(hj5hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhj-ubhŒ< para obtener más información al respecto de esta opción.”…””}”(hj-hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mihj|hžhubhŒnote”“”)”}”(hŒ@La función ``--base`` se introdujo en la versión 2.9.0 de git.”h]”h¨)”}”(hjQh]”(hŒ La función ”…””}”(hjShžhhŸNh Nubj«)”}”(hŒ ``--base``”h]”hŒ--base”…””}”(hjZhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjSubhŒ* se introdujo en la versión 2.9.0 de git.”…””}”(hjShžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MnhjOubah}”(h]”h ]”h"]”h$]”h&]”uh1jMhj|hžhhŸhØh Nubh¨)”}”(hXSi 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.”h]”(hŒ^Si no está utilizando git para dar forma a sus parches, aún puede incluir el mismo tráiler ”…””}”(hjxhžhhŸNh Nubj«)”}”(hŒ``base-commit``”h]”hŒ base-commit”…””}”(hj€hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjxubhŒÂ 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 ”…””}”(hjxhžhhŸNh Nubj«)”}”(hŒ``---``”h]”hŒ---”…””}”(hj’hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jªhjxubhŒg o en la parte inferior de todos los demás contenido, justo antes de su firma del correo electrónico.”…””}”(hjxhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mphj|hžhubeh}”(h]”Œ&proporcionar-informacion-de-arbol-base”ah ]”h"]”Œ(proporcionar información de árbol base”ah$]”h&]”uh1jqhjshžhhŸhØh MEubjr)”}”(hhh]”(jw)”}”(hŒ Referencias”h]”hŒ Referencias”…””}”(hjµhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jvhj²hžhhŸhØh Myubj•)”}”(hhh]”(jš)”}”(hŒZ"The perfect patch" (tpp) por Andrew Morton. ”h]”(j )”}”(hŒ,"The perfect patch" (tpp) por Andrew Morton.”h]”hŒ0“The perfect patch†(tpp) por Andrew Morton.”…””}”(hjÊhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jŸhŸhØh M|hjÆubj°)”}”(hhh]”h¨)”}”(hŒ,”h]”(hŒ<”…””}”(hjÛhžhhŸNh Nubj6)”}”(hŒ*https://www.ozlabs.org/~akpm/stuff/tpp.txt”h]”hŒ*https://www.ozlabs.org/~akpm/stuff/tpp.txt”…””}”(hjãhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”jåuh1j5hjÛubhŒ>”…””}”(hjÛhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M|hjØubah}”(h]”h ]”h"]”h$]”h&]”uh1j¯hjÆubeh}”(h]”h ]”h"]”h$]”h&]”uh1j™hŸhØh M|hjÃubjš)”}”(hŒ‹"Linux kernel patch submission format" por Jeff Garzik. ”h]”(j )”}”(hŒ7"Linux kernel patch submission format" por Jeff Garzik.”h]”hŒ;“Linux kernel patch submission format†por Jeff Garzik.”…””}”(hj hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jŸhŸhØh Mhjubj°)”}”(hhh]”h¨)”}”(hŒR”h]”(hŒ<”…””}”(hjhžhhŸNh Nubj6)”}”(hŒPhttps://web.archive.org/web/20180829112450/http://linux.yyz.us/patch-format.html”h]”hŒPhttps://web.archive.org/web/20180829112450/http://linux.yyz.us/patch-format.html”…””}”(hj%hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”j'uh1j5hjubhŒ>”…””}”(hjhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mhjubah}”(h]”h ]”h"]”h$]”h&]”uh1j¯hjubeh}”(h]”h ]”h"]”h$]”h&]”uh1j™hŸhØh MhjÃhžhubjš)”}”(hX‚"How to piss off a kernel subsystem maintainer" por Greg Kroah-Hartman. ”h]”(j )”}”(hŒG"How to piss off a kernel subsystem maintainer" por Greg Kroah-Hartman.”h]”hŒK“How to piss off a kernel subsystem maintainer†por Greg Kroah-Hartman.”…””}”(hjNhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jŸhŸhØh MŒhjJubj°)”}”(hhh]”(h¨)”}”(hŒ0”h]”(hŒ<”…””}”(hj_hžhhŸNh Nubj6)”}”(hŒ.http://www.kroah.com/log/linux/maintainer.html”h]”hŒ.http://www.kroah.com/log/linux/maintainer.html”…””}”(hjghžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”jiuh1j5hj_ubhŒ>”…””}”(hj_hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M‚hj\ubh¨)”}”(hŒ3”h]”(hŒ<”…””}”(hj€hžhhŸNh Nubj6)”}”(hŒ1http://www.kroah.com/log/linux/maintainer-02.html”h]”hŒ1http://www.kroah.com/log/linux/maintainer-02.html”…””}”(hjˆhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”jŠuh1j5hj€ubhŒ>”…””}”(hj€hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M„hj\ubh¨)”}”(hŒ3”h]”(hŒ<”…””}”(hj¡hžhhŸNh Nubj6)”}”(hŒ1http://www.kroah.com/log/linux/maintainer-03.html”h]”hŒ1http://www.kroah.com/log/linux/maintainer-03.html”…””}”(hj©hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”j«uh1j5hj¡ubhŒ>”…””}”(hj¡hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M†hj\ubh¨)”}”(hŒ3”h]”(hŒ<”…””}”(hjÂhžhhŸNh Nubj6)”}”(hŒ1http://www.kroah.com/log/linux/maintainer-04.html”h]”hŒ1http://www.kroah.com/log/linux/maintainer-04.html”…””}”(hjÊhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”jÌuh1j5hjÂubhŒ>”…””}”(hjÂhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mˆhj\ubh¨)”}”(hŒ3”h]”(hŒ<”…””}”(hjãhžhhŸNh Nubj6)”}”(hŒ1http://www.kroah.com/log/linux/maintainer-05.html”h]”hŒ1http://www.kroah.com/log/linux/maintainer-05.html”…””}”(hjëhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”jíuh1j5hjãubhŒ>”…””}”(hjãhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MŠhj\ubh¨)”}”(hŒ3”h]”(hŒ<”…””}”(hjhžhhŸNh Nubj6)”}”(hŒ1http://www.kroah.com/log/linux/maintainer-06.html”h]”hŒ1http://www.kroah.com/log/linux/maintainer-06.html”…””}”(hj hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”juh1j5hjubhŒ>”…””}”(hjhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MŒhj\ubeh}”(h]”h ]”h"]”h$]”h&]”uh1j¯hjJubeh}”(h]”•õ!h ]”h"]”h$]”h&]”uh1j™hŸhØh MŒhjÃhžhubjš)”}”(hŒ˜NO!!!! Gente, no mas bombas enormes de parches a linux-kernel@vger.kernel.org! ”h]”(j )”}”(hŒNNO!!!! Gente, no mas bombas enormes de parches a linux-kernel@vger.kernel.org!”h]”(hŒ1NO!!!! Gente, no mas bombas enormes de parches a ”…””}”(hj5hžhhŸNh Nubj6)”}”(hŒlinux-kernel@vger.kernel.org”h]”hŒlinux-kernel@vger.kernel.org”…””}”(hj=hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”Œ#mailto:linux-kernel@vger.kernel.org”uh1j5hj5ubhŒ!”…””}”(hj5hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1jŸhŸhØh Mhj1ubj°)”}”(hhh]”h¨)”}”(hŒH”h]”(hŒ<”…””}”(hjZhžhhŸNh Nubj6)”}”(hŒFhttps://lore.kernel.org/r/20050711.125305.08322243.davem@davemloft.net”h]”hŒFhttps://lore.kernel.org/r/20050711.125305.08322243.davem@davemloft.net”…””}”(hjbhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”jduh1j5hjZubhŒ>”…””}”(hjZhžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh MhjWubah}”(h]”h ]”h"]”h$]”h&]”uh1j¯hj1ubeh}”(h]”h ]”h"]”h$]”h&]”uh1j™hŸhØh MhjÃhžhubeh}”(h]”h ]”h"]”h$]”h&]”uh1j”hj²hžhhŸhØh Nubh¨)”}”(hŒ-Kernel Documentation/process/coding-style.rst”h]”hŒ-Kernel Documentation/process/coding-style.rst”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M‘hj²hžhubj•)”}”(hhh]”(jš)”}”(hŒEmail de Linus Torvalds sobre la forma canónica de los parches: ”h]”(j )”}”(hŒ@Email de Linus Torvalds sobre la forma canónica de los parches:”h]”hŒ@Email de Linus Torvalds sobre la forma canónica de los parches:”…””}”(hj¢hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jŸhŸhØh M”hjžubj°)”}”(hhh]”h¨)”}”(hŒM”h]”(hŒ<”…””}”(hj³hžhhŸNh Nubj6)”}”(hŒKhttps://lore.kernel.org/r/Pine.LNX.4.58.0504071023190.28951@ppc970.osdl.org”h]”hŒKhttps://lore.kernel.org/r/Pine.LNX.4.58.0504071023190.28951@ppc970.osdl.org”…””}”(hj»hžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”j½uh1j5hj³ubhŒ>”…””}”(hj³hžhhŸNh Nubeh}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M”hj°ubah}”(h]”h ]”h"]”h$]”h&]”uh1j¯hjžubeh}”(h]”h ]”h"]”h$]”h&]”uh1j™hŸhØh M”hj›ubjš)”}”(hŒ­"On submitting kernel patches" por Andi Kleen Algunas estrategias para conseguir incluir cambios complicados o controvertidos. http://halobates.de/on-submitting-patches.pdf”h]”(j )”}”(hŒ-"On submitting kernel patches" por Andi Kleen”h]”hŒ1“On submitting kernel patches†por Andi Kleen”…””}”(hjähžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1jŸhŸhØh M™hjàubj°)”}”(hhh]”(h¨)”}”(hŒPAlgunas estrategias para conseguir incluir cambios complicados o controvertidos.”h]”hŒPAlgunas estrategias para conseguir incluir cambios complicados o controvertidos.”…””}”(hjõhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh M—hjòubh¨)”}”(hŒ-http://halobates.de/on-submitting-patches.pdf”h]”j6)”}”(hjh]”hŒ-http://halobates.de/on-submitting-patches.pdf”…””}”(hjhžhhŸNh Nubah}”(h]”h ]”h"]”h$]”h&]”Œrefuri”juh1j5hjubah}”(h]”h ]”h"]”h$]”h&]”uh1h§hŸhØh Mšhjòubeh}”(h]”h ]”h"]”h$]”h&]”uh1j¯hjàubeh}”(h]”h ]”h"]”h$]”h&]”uh1j™hŸhØh M™hj›hžhubeh}”(h]”h ]”h"]”h$]”h&]”uh1j”hj²hžhhŸhØh Nubeh}”(h]”Œ referencias”ah ]”h"]”Œ referencias”ah$]”h&]”uh1jqhjshžhhŸhØh Myubeh}”(h]”(ŒEenvio-de-parches-la-guia-esencial-para-incluir-su-codigo-en-el-kernel”jpeh ]”h"]”(ŒIenvío de parches: la guía esencial para incluir su código en el kernel”Œsp_submittingpatches”eh$]”h&]”uh1jqhhhžhhŸhØh K j¡}”j;jesj£}”jpjesubeh}”(h]”h ]”h"]”h$]”h&]”Œsource”hØuh1hŒcurrent_source”NŒ current_line”NŒsettings”Œdocutils.frontend”ŒValues”“”)”}”(jvNŒ generator”NŒ datestamp”NŒ source_link”NŒ source_url”NŒ toc_backlinks”Œentry”Œfootnote_backlinks”KŒ sectnum_xform”KŒstrip_comments”NŒstrip_elements_with_classes”NŒ strip_classes”NŒ report_level”KŒ halt_level”KŒexit_status_level”KŒdebug”NŒwarning_stream”NŒ traceback”ˆŒinput_encoding”Œ utf-8-sig”Œinput_encoding_error_handler”Œstrict”Œoutput_encoding”Œutf-8”Œoutput_encoding_error_handler”jcŒerror_encoding”Œutf-8”Œerror_encoding_error_handler”Œbackslashreplace”Œ language_code”Œen”Œrecord_dependencies”NŒconfig”NŒ id_prefix”hŒauto_id_prefix”Œid”Œ dump_settings”NŒdump_internals”NŒdump_transforms”NŒdump_pseudo_xml”NŒexpose_internals”NŒstrict_visitor”NŒ_disable_config”NŒ_source”hØŒ _destination”NŒ _config_files”]”Œ7/var/lib/git/docbuild/linux/Documentation/docutils.conf”aŒfile_insertion_enabled”ˆŒ raw_enabled”KŒline_length_limit”M'Œpep_references”NŒ pep_base_url”Œhttps://peps.python.org/”Œpep_file_url_template”Œpep-%04d”Œrfc_references”NŒ rfc_base_url”Œ&https://datatracker.ietf.org/doc/html/”Œ tab_width”KŒtrim_footnote_reference_space”‰Œsyntax_highlight”Œlong”Œ smart_quotes”ˆŒsmartquotes_locales”]”Œcharacter_level_inline_markup”‰Œdoctitle_xform”‰Œ docinfo_xform”KŒsectsubtitle_xform”‰Œ image_loading”Œlink”Œembed_stylesheet”‰Œcloak_email_addresses”ˆŒsection_self_link”‰Œenv”NubŒreporter”NŒindirect_targets”]”Œsubstitution_defs”}”Œsubstitution_names”}”Œrefnames”}”Œrefids”}”(jp]”jeajw]”jmaj—]”jaj–]”jŒaj ]”j aj ]”j ajÐ]”jÆaj]”j auŒnameids”}”(j;jpj:j7j}jzjžjwjjšjTj—jSjPj.j+jJjGjjjœj™j% j–j$ j! j‡ j j† jƒ jÌ jÉ j! j j j jô jñ j j j j j(j j'j$jjÐjjjwjjvjsj¯j¬j2j/uŒ nametypes”}”(j;ˆj:‰j}‰jžˆj‰jTˆjS‰j.‰jJ‰j‰jœ‰j% ˆj$ ‰j‡ ˆj† ‰jÌ ‰j! ‰j ‰jô ‰j ‰j ‰j(ˆj'‰jˆj‰jwˆjv‰j¯‰j2‰uh}”(jpjsj7jsjzjjwj€jšj€j—j¥jPj¥j+jYjGj1jjMj™jj–jŸj! jŸj j* jƒ j* jÉ jŒ j jÏ j jü jñ j$ j j÷ j j2 j j" j$j" jÐjÑjjÑjj-jsj-j¬j|j/j²uŒ footnote_refs”}”Œ citation_refs”}”Œ autofootnotes”]”Œautofootnote_refs”]”Œsymbol_footnotes”]”Œsymbol_footnote_refs”]”Œ footnotes”]”Œ citations”]”Œautofootnote_start”KŒsymbol_footnote_start”KŒ id_counter”Œ collections”ŒCounter”“”}”…”R”Œparse_messages”]”Œtransform_messages”]”(hŒsystem_message”“”)”}”(hhh]”h¨)”}”(hhh]”hŒ:Hyperlink target "sp-submittingpatches" is not referenced.”…””}”hjÔsbah}”(h]”h ]”h"]”h$]”h&]”uh1h§hjÑubah}”(h]”h ]”h"]”h$]”h&]”Œlevel”KŒtype”ŒINFO”Œsource”hØŒline”Kuh1jÏubjÐ)”}”(hhh]”h¨)”}”(hhh]”hŒ9Hyperlink target "sp-describe-changes" is not referenced.”…””}”hjïsbah}”(h]”h ]”h"]”h$]”h&]”uh1h§hjìubah}”(h]”h ]”h"]”h$]”h&]”Œlevel”KŒtype”jéŒsource”hØŒline”K@uh1jÏubjÐ)”}”(hhh]”h¨)”}”(hhh]”hŒ6Hyperlink target "sp-split-changes" is not referenced.”…””}”hj sbah}”(h]”h ]”h"]”h$]”h&]”uh1h§hjubah}”(h]”h ]”h"]”h$]”h&]”Œlevel”KŒtype”jéŒsource”hØŒline”K¾uh1jÏubjÐ)”}”(hhh]”h¨)”}”(hhh]”hŒ