io_uring: ensure finish_wait() is always called in __io_uring_task_cancel()
[linux/fpc-iii.git] / Documentation / translations / it_IT / process / submitting-patches.rst
blob966cd3242a60ff50612e8b09b58af131f3d351e0
1 .. include:: ../disclaimer-ita.rst
3 :Original: :ref:`Documentation/process/submitting-patches.rst <submittingpatches>`
4 :Translator: Federico Vaga <federico.vaga@vaga.pv.it>
6 .. _it_submittingpatches:
8 Inviare patch: la guida essenziale per vedere il vostro codice nel kernel
9 =========================================================================
11 Una persona o un'azienda che volesse inviare una patch al kernel potrebbe
12 sentirsi scoraggiata dal processo di sottomissione, specialmente quando manca
13 una certa familiarità col "sistema".  Questo testo è una raccolta di
14 suggerimenti che aumenteranno significativamente le probabilità di vedere le
15 vostre patch accettate.
17 Questo documento contiene un vasto numero di suggerimenti concisi.  Per
18 maggiori dettagli su come funziona il processo di sviluppo del kernel leggete
19 :doc:`development-process`.
20 Leggete anche :doc:`submit-checklist` per una lista di punti da
21 verificare prima di inviare del codice.  Se state inviando un driver,
22 allora leggete anche :doc:`submitting-drivers`; per delle patch
23 relative alle associazioni per Device Tree leggete
24 :doc:`submitting-patches`.
26 Questa documentazione assume che sappiate usare ``git`` per preparare le patch.
27 Se non siete pratici di ``git``, allora è bene che lo impariate;
28 renderà la vostra vita di sviluppatore del kernel molto più semplice.
30 Ottenere i sorgenti attuali
31 ---------------------------
33 Se non avete un repositorio coi sorgenti del kernel più recenti, allora usate
34 ``git`` per ottenerli.  Vorrete iniziare col repositorio principale che può
35 essere recuperato col comando::
37   git clone git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
39 Notate, comunque, che potreste non voler sviluppare direttamente coi sorgenti
40 principali del kernel.  La maggior parte dei manutentori hanno i propri
41 sorgenti e desiderano che le patch siano preparate basandosi su di essi.
42 Guardate l'elemento **T:** per un determinato sottosistema nel file MAINTANERS
43 che troverete nei sorgenti, o semplicemente chiedete al manutentore nel caso
44 in cui i sorgenti da usare non siano elencati il quel file.
46 .. _it_describe_changes:
48 Descrivete le vostre modifiche
49 ------------------------------
51 Descrivete il vostro problema. Esiste sempre un problema che via ha spinto
52 ha fare il vostro lavoro, che sia la correzione di un baco da una riga o una
53 nuova funzionalità da 5000 righe di codice.  Convincete i revisori che vale
54 la pena risolvere il vostro problema e che ha senso continuare a leggere oltre
55 al primo paragrafo.
57 Descrivete ciò che sarà visibile agli utenti.  Chiari incidenti nel sistema
58 e blocchi sono abbastanza convincenti, ma non tutti i bachi sono così evidenti.
59 Anche se il problema è stato scoperto durante la revisione del codice,
60 descrivete l'impatto che questo avrà sugli utenti.  Tenete presente che
61 la maggior parte delle installazioni Linux usa un kernel che arriva dai
62 sorgenti stabili o dai sorgenti di una distribuzione particolare che prende
63 singolarmente le patch dai sorgenti principali; quindi, includete tutte
64 le informazioni che possono essere utili a capire le vostre modifiche:
65 le circostanze che causano il problema, estratti da dmesg, descrizioni di
66 un incidente di sistema, prestazioni di una regressione, picchi di latenza,
67 blocchi, eccetera.
69 Quantificare le ottimizzazioni e i compromessi.  Se affermate di aver
70 migliorato le prestazioni, il consumo di memoria, l'impatto sollo stack,
71 o la dimensione del file binario, includete dei numeri a supporto della
72 vostra dichiarazione.  Ma ricordatevi di descrivere anche eventuali costi
73 che non sono ovvi.  Solitamente le ottimizzazioni non sono gratuite, ma sono
74 un compromesso fra l'uso di CPU, la memoria e la leggibilità; o, quando si
75 parla di ipotesi euristiche, fra differenti carichi.  Descrivete i lati
76 negativi che vi aspettate dall'ottimizzazione cosicché i revisori possano
77 valutare i costi e i benefici.
79 Una volta che il problema è chiaro, descrivete come lo risolvete andando
80 nel dettaglio tecnico.  È molto importante che descriviate la modifica
81 in un inglese semplice cosicché i revisori possano verificare che il codice si
82 comporti come descritto.
84 I manutentori vi saranno grati se scrivete la descrizione della patch in un
85 formato che sia compatibile con il gestore dei sorgenti usato dal kernel,
86 ``git``, come un "commit log".  Leggete :ref:`it_explicit_in_reply_to`.
88 Risolvete solo un problema per patch.  Se la vostra descrizione inizia ad
89 essere lunga, potrebbe essere un segno che la vostra patch necessita d'essere
90 divisa. Leggete :ref:`split_changes`.
92 Quando inviate o rinviate una patch o una serie, includete la descrizione
93 completa delle modifiche e la loro giustificazione.  Non limitatevi a dire che
94 questa è la versione N della patch (o serie).  Non aspettatevi che i
95 manutentori di un sottosistema vadano a cercare le versioni precedenti per
96 cercare la descrizione da aggiungere.  In pratica, la patch (o serie) e la sua
97 descrizione devono essere un'unica cosa.  Questo aiuta i manutentori e i
98 revisori.  Probabilmente, alcuni revisori non hanno nemmeno ricevuto o visto
99 le versioni precedenti della patch.
101 Descrivete le vostro modifiche usando l'imperativo, per esempio "make xyzzy
102 do frotz" piuttosto che "[This patch] makes xyzzy do frotz" or "[I] changed
103 xyzzy to do frotz", come se steste dando ordini al codice di cambiare il suo
104 comportamento.
106 Se la patch corregge un baco conosciuto, fare riferimento a quel baco inserendo
107 il suo numero o il suo URL.  Se la patch è la conseguenza di una discussione
108 su una lista di discussione, allora fornite l'URL all'archivio di quella
109 discussione;  usate i collegamenti a https://lkml.kernel.org/ con il
110 ``Message-Id``, in questo modo vi assicurerete che il collegamento non diventi
111 invalido nel tempo.
113 Tuttavia, cercate di rendere la vostra spiegazione comprensibile anche senza
114 far riferimento a fonti esterne.  In aggiunta ai collegamenti a bachi e liste
115 di discussione, riassumente i punti più importanti della discussione che hanno
116 portato alla creazione della patch.
118 Se volete far riferimento a uno specifico commit, non usate solo
119 l'identificativo SHA-1.  Per cortesia, aggiungete anche la breve riga
120 riassuntiva del commit per rendere la chiaro ai revisori l'oggetto.
121 Per esempio::
123         Commit e21d2170f36602ae2708 ("video: remove unnecessary
124         platform_set_drvdata()") removed the unnecessary
125         platform_set_drvdata(), but left the variable "dev" unused,
126         delete it.
128 Dovreste anche assicurarvi di usare almeno i primi 12 caratteri
129 dell'identificativo SHA-1.  Il repositorio del kernel ha *molti* oggetti e
130 questo rende possibile la collisione fra due identificativi con pochi
131 caratteri.  Tenete ben presente che anche se oggi non ci sono collisioni con il
132 vostro identificativo a 6 caratteri, potrebbero essercene fra 5 anni da oggi.
134 Se la vostra patch corregge un baco in un commit specifico, per esempio avete
135 trovato un problema usando ``git bisect``, per favore usate l'etichetta
136 'Fixes:' indicando i primi 12 caratteri dell'identificativo SHA-1 seguiti
137 dalla riga riassuntiva.  Per esempio::
139         Fixes: e21d2170f366 ("video: remove unnecessary platform_set_drvdata()")
141 La seguente configurazione di ``git config`` può essere usata per formattare
142 i risultati dei comandi ``git log`` o ``git show`` come nell'esempio
143 precedente::
145         [core]
146                 abbrev = 12
147         [pretty]
148                 fixes = Fixes: %h (\"%s\")
150 Un esempio::
152        $ git log -1 --pretty=fixes 54a4f0239f2e
153        Fixes: 54a4f0239f2e ("KVM: MMU: make kvm_mmu_zap_page() return the number of pages it actually freed")
155 .. _it_split_changes:
157 Separate le vostre modifiche
158 ----------------------------
160 Separate ogni **cambiamento logico** in patch distinte.
162 Per esempio, se i vostri cambiamenti per un singolo driver includono
163 sia delle correzioni di bachi che miglioramenti alle prestazioni,
164 allora separateli in due o più patch.  Se i vostri cambiamenti includono
165 un aggiornamento dell'API e un nuovo driver che lo sfrutta, allora separateli
166 in due patch.
168 D'altro canto, se fate una singola modifica su più file, raggruppate tutte
169 queste modifiche in una singola patch.  Dunque, un singolo cambiamento logico
170 è contenuto in una sola patch.
172 Il punto da ricordare è che ogni modifica dovrebbe fare delle modifiche
173 che siano facilmente comprensibili e che possano essere verificate dai revisori.
174 Ogni patch dovrebbe essere giustificabile di per sé.
176 Se al fine di ottenere un cambiamento completo una patch dipende da un'altra,
177 va bene.  Semplicemente scrivete una nota nella descrizione della patch per
178 farlo presente: **"this patch depends on patch X"**.
180 Quando dividete i vostri cambiamenti in una serie di patch, prestate
181 particolare attenzione alla verifica di ogni patch della serie; per ognuna
182 il kernel deve compilare ed essere eseguito correttamente.  Gli sviluppatori
183 che usano ``git bisect`` per scovare i problemi potrebbero finire nel mezzo
184 della vostra serie in un punto qualsiasi; non vi saranno grati se nel mezzo
185 avete introdotto dei bachi.
187 Se non potete condensare la vostra serie di patch in una più piccola, allora
188 pubblicatene una quindicina alla volta e aspettate che vengano revisionate
189 ed integrate.
192 4) Verificate lo stile delle vostre modifiche
193 ---------------------------------------------
195 Controllate che la vostra patch non violi lo stile del codice, maggiori
196 dettagli sono disponibili in :ref:`Documentation/translations/it_IT/process/coding-style.rst <it_codingstyle>`.
197 Non farlo porta semplicemente a una perdita di tempo da parte dei revisori e
198 voi vedrete la vostra patch rifiutata, probabilmente senza nemmeno essere stata
199 letta.
201 Un'eccezione importante si ha quando del codice viene spostato da un file
202 ad un altro -- in questo caso non dovreste modificare il codice spostato
203 per nessun motivo, almeno non nella patch che lo sposta.  Questo separa
204 chiaramente l'azione di spostare il codice e il vostro cambiamento.
205 Questo aiuta enormemente la revisione delle vere differenze e permette agli
206 strumenti di tenere meglio la traccia della storia del codice.
208 Prima di inviare una patch, verificatene lo stile usando l'apposito
209 verificatore (scripts/checkpatch.pl).  Da notare, comunque, che il verificator
210 di stile dovrebbe essere visto come una guida, non come un sostituto al
211 giudizio umano.  Se il vostro codice è migliore nonostante una violazione
212 dello stile, probabilmente è meglio lasciarlo com'è.
214 Il verificatore ha tre diversi livelli di severità:
215  - ERROR: le cose sono molto probabilmente sbagliate
216  - WARNING: le cose necessitano d'essere revisionate con attenzione
217  - CHECK: le cose necessitano di un pensierino
219 Dovreste essere in grado di giustificare tutte le eventuali violazioni rimaste
220 nella vostra patch.
223 5) Selezionate i destinatari della vostra patch
224 -----------------------------------------------
226 Dovreste sempre inviare una copia della patch ai manutentori dei sottosistemi
227 interessati dalle modifiche; date un'occhiata al file MAINTAINERS e alla storia
228 delle revisioni per scoprire chi si occupa del codice.  Lo script
229 scripts/get_maintainer.pl può esservi d'aiuto.  Se non riuscite a trovare un
230 manutentore per il sottosistema su cui state lavorando, allora Andrew Morton
231 (akpm@linux-foundation.org) sarà la vostra ultima possibilità.
233 Normalmente, dovreste anche scegliere una lista di discussione a cui inviare
234 la vostra serie di patch.  La lista di discussione linux-kernel@vger.kernel.org
235 è proprio l'ultima spiaggia, il volume di email su questa lista fa si che
236 diversi sviluppatori non la seguano.  Guardate nel file MAINTAINERS per trovare
237 la lista di discussione dedicata ad un sottosistema; probabilmente lì la vostra
238 patch riceverà molta più attenzione.  Tuttavia, per favore, non spammate le
239 liste di discussione che non sono interessate al vostro lavoro.
241 Molte delle liste di discussione relative al kernel vengono ospitate su
242 vger.kernel.org; potete trovare un loro elenco alla pagina
243 http://vger.kernel.org/vger-lists.html.  Tuttavia, ci sono altre liste di
244 discussione ospitate altrove.
246 Non inviate più di 15 patch alla volta sulle liste di discussione vger!!!
248 L'ultimo giudizio sull'integrazione delle modifiche accettate spetta a
249 Linux Torvalds.  Il suo indirizzo e-mail è <torvalds@linux-foundation.org>.
250 Riceve moltissime e-mail, e, a questo punto, solo poche patch passano
251 direttamente attraverso il suo giudizio; quindi, dovreste fare del vostro
252 meglio per -evitare di- inviargli e-mail.
254 Se avete una patch che corregge un baco di sicurezza che potrebbe essere
255 sfruttato, inviatela a security@kernel.org.  Per bachi importanti, un breve
256 embargo potrebbe essere preso in considerazione per dare il tempo alle
257 distribuzioni di prendere la patch e renderla disponibile ai loro utenti;
258 in questo caso, ovviamente, la patch non dovrebbe essere inviata su alcuna
259 lista di discussione pubblica. Leggete anche
260 :doc:`/admin-guide/security-bugs`.
262 Patch che correggono bachi importanti su un kernel già rilasciato, dovrebbero
263 essere inviate ai manutentori dei kernel stabili aggiungendo la seguente riga::
265   Cc: stable@vger.kernel.org
267 nella vostra patch, nell'area dedicata alle firme (notate, NON come destinatario
268 delle e-mail).  In aggiunta a questo file, dovreste leggere anche
269 :ref:`Documentation/translations/it_IT/process/stable-kernel-rules.rst <it_stable_kernel_rules>`
271 Tuttavia, notate, che alcuni manutentori di sottosistema preferiscono avere
272 l'ultima parola su quali patch dovrebbero essere aggiunte ai kernel stabili.
273 La rete di manutentori, in particolare, non vorrebbe vedere i singoli
274 sviluppatori aggiungere alle loro patch delle righe come quella sopracitata.
276 Se le modifiche hanno effetti sull'interfaccia con lo spazio utente, per favore
277 inviate una patch per le pagine man ai manutentori di suddette pagine (elencati
278 nel file MAINTAINERS), o almeno una notifica circa la vostra modifica,
279 cosicché l'informazione possa trovare la sua strada nel manuale.  Le modifiche
280 all'API dello spazio utente dovrebbero essere inviate in copia anche a
281 linux-api@vger.kernel.org.
283 Per le piccole patch potreste aggiungere in CC l'indirizzo
284 *Trivial Patch Monkey trivial@kernel.org* che ha lo scopo di raccogliere
285 le patch "banali".  Date uno sguardo al file MAINTAINERS per vedere chi
286 è l'attuale amministratore.
288 Le patch banali devono rientrare in una delle seguenti categorie:
290 - errori grammaticali nella documentazione
291 - errori grammaticali negli errori che potrebbero rompere :manpage:`grep(1)`
292 - correzione di avvisi di compilazione (riempirsi di avvisi inutili è negativo)
293 - correzione di errori di compilazione (solo se correggono qualcosa sul serio)
294 - rimozione di funzioni/macro deprecate
295 - sostituzione di codice non potabile con uno portabile (anche in codice
296   specifico per un'architettura, dato che le persone copiano, fintanto che
297   la modifica sia banale)
298 - qualsiasi modifica dell'autore/manutentore di un file (in pratica
299   "patch monkey" in modalità ritrasmissione)
302 Niente: MIME, links, compressione, allegati.  Solo puro testo
303 -------------------------------------------------------------
305 Linus e gli altri sviluppatori del kernel devono poter commentare
306 le modifiche che sottomettete.  Per uno sviluppatore è importante
307 essere in grado di "citare" le vostre modifiche, usando normali
308 programmi di posta elettronica, cosicché sia possibile commentare
309 una porzione specifica del vostro codice.
311 Per questa ragione tutte le patch devono essere inviate via e-mail
312 come testo. Il modo più facile, e quello raccomandato, è con ``git
313 send-email``.  Al sito https://git-send-email.io è disponibile una
314 guida interattiva sull'uso di ``git send-email``.
316 Se decidete di non usare ``git send-email``:
318 .. warning::
320   Se decidete di copiare ed incollare la patch nel corpo dell'e-mail, state
321   attenti che il vostro programma non corrompa il contenuto con andate
322   a capo automatiche.
324 La patch non deve essere un allegato MIME, compresso o meno.  Molti
325 dei più popolari programmi di posta elettronica non trasmettono un allegato
326 MIME come puro testo, e questo rende impossibile commentare il vostro codice.
327 Inoltre, un allegato MIME rende l'attività di Linus più laboriosa, diminuendo
328 così la possibilità che il vostro allegato-MIME venga accettato.
330 Eccezione: se il vostro servizio di posta storpia le patch, allora qualcuno
331 potrebbe chiedervi di rinviarle come allegato MIME.
333 Leggete :doc:`/translations/it_IT/process/email-clients`
334 per dei suggerimenti sulla configurazione del programmi di posta elettronica
335 per l'invio di patch intatte.
337 Rispondere ai commenti di revisione
338 -----------------------------------
340 In risposta alla vostra email, quasi certamente i revisori vi
341 invieranno dei commenti su come migliorare la vostra patch.  Dovete
342 rispondere a questi commenti; ignorare i revisori è un ottimo modo per
343 essere ignorati.  Riscontri o domande che non conducono ad una
344 modifica del codice quasi certamente dovrebbero portare ad un commento
345 nel changelog cosicché il prossimo revisore potrà meglio comprendere
346 cosa stia accadendo.
348 Assicuratevi di dire ai revisori quali cambiamenti state facendo e di
349 ringraziarli per il loro tempo.  Revisionare codice è un lavoro faticoso e che
350 richiede molto tempo, e a volte i revisori diventano burberi.  Tuttavia, anche
351 in questo caso, rispondete con educazione e concentratevi sul problema che
352 hanno evidenziato.
354 Leggete :doc:`/translations/it_IT/process/email-clients` per
355 le raccomandazioni sui programmi di posta elettronica e l'etichetta da usare
356 sulle liste di discussione.
358 Non scoraggiatevi - o impazientitevi
359 ------------------------------------
361 Dopo che avete inviato le vostre modifiche, siate pazienti e aspettate.
362 I revisori sono persone occupate e potrebbero non ricevere la vostra patch
363 immediatamente.
365 Un tempo, le patch erano solite scomparire nel vuoto senza alcun commento,
366 ma ora il processo di sviluppo funziona meglio.  Dovreste ricevere commenti
367 in una settimana o poco più; se questo non dovesse accadere, assicuratevi di
368 aver inviato le patch correttamente.  Aspettate almeno una settimana prima di
369 rinviare le modifiche o sollecitare i revisori - probabilmente anche di più
370 durante la finestra d'integrazione.
372 Aggiungete PATCH nell'oggetto
373 -----------------------------
375 Dato l'alto volume di e-mail per Linus, e la lista linux-kernel, è prassi
376 prefiggere il vostro oggetto con [PATCH].  Questo permette a Linus e agli
377 altri sviluppatori del kernel di distinguere facilmente le patch dalle altre
378 discussioni.
380 ``git send-email`` lo fa automaticamente.
383 Firmate il vostro lavoro - Il certificato d'origine dello sviluppatore
384 ----------------------------------------------------------------------
386 Per migliorare la tracciabilità su "chi ha fatto cosa", specialmente per
387 quelle patch che per raggiungere lo stadio finale passano attraverso
388 diversi livelli di manutentori, abbiamo introdotto la procedura di "firma"
389 delle patch che vengono inviate per e-mail.
391 La firma è una semplice riga alla fine della descrizione della patch che
392 certifica che l'avete scritta voi o che avete il diritto di pubblicarla
393 come patch open-source.  Le regole sono abbastanza semplici: se potete
394 certificare quanto segue:
396 Il certificato d'origine dello sviluppatore 1.1
397 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
399 Contribuendo a questo progetto, io certifico che:
401         (a) Il contributo è stato creato interamente, o in parte, da me e che
402             ho il diritto di inviarlo in accordo con la licenza open-source
403             indicata nel file; oppure
405         (b) Il contributo è basato su un lavoro precedente che, nei limiti
406             della mia conoscenza, è coperto da un'appropriata licenza
407             open-source che mi da il diritto di modificarlo e inviarlo,
408             le cui modifiche sono interamente o in parte mie, in accordo con
409             la licenza open-source (a meno che non abbia il permesso di usare
410             un'altra licenza) indicata nel file; oppure
412         (c) Il contributo mi è stato fornito direttamente da qualcuno che
413             ha certificato (a), (b) o (c) e non l'ho modificata.
415         (d) Capisco e concordo col fatto che questo progetto e i suoi
416             contributi sono pubblici e che un registro dei contributi (incluse
417             tutte le informazioni personali che invio con essi, inclusa la mia
418             firma) verrà mantenuto indefinitamente e che possa essere
419             ridistribuito in accordo con questo progetto o le licenze
420             open-source coinvolte.
422 poi dovete solo aggiungere una riga che dice::
424         Signed-off-by: Random J Developer <random@developer.example.org>
426 usando il vostro vero nome (spiacenti, non si accettano pseudonimi o
427 contributi anonimi). Questo verrà fatto automaticamente se usate
428 ``git commit -s``. Anche il ripristino di uno stato precedente dovrebbe
429 includere "Signed-off-by", se usate ``git revert -s`` questo verrà
430 fatto automaticamente.
432 Alcune persone aggiungono delle etichette alla fine.  Per ora queste verranno
433 ignorate, ma potete farlo per meglio identificare procedure aziendali interne o
434 per aggiungere dettagli circa la firma.
436 Quando utilizzare Acked-by:, Cc:, e Co-developed-by:
437 ----------------------------------------------------
439 L'etichetta Signed-off-by: indica che il firmatario è stato coinvolto nello
440 sviluppo della patch, o che era nel suo percorso di consegna.
442 Se una persona non è direttamente coinvolta con la preparazione o gestione
443 della patch ma desidera firmare e mettere agli atti la loro approvazione,
444 allora queste persone possono chiedere di aggiungere al changelog della patch
445 una riga Acked-by:.
447 Acked-by: viene spesso utilizzato dai manutentori del sottosistema in oggetto
448 quando quello stesso manutentore non ha contribuito né trasmesso la patch.
450 Acked-by: non è formale come Signed-off-by:.  Questo indica che la persona ha
451 revisionato la patch e l'ha trovata accettabile.  Per cui, a volte, chi
452 integra le patch convertirà un "sì, mi sembra che vada bene" in un Acked-by:
453 (ma tenete presente che solitamente è meglio chiedere esplicitamente).
455 Acked-by: non indica l'accettazione di un'intera patch.  Per esempio, quando
456 una patch ha effetti su diversi sottosistemi e ha un Acked-by: da un
457 manutentore di uno di questi, significa che il manutentore accetta quella
458 parte di codice relativa al sottosistema che mantiene.  Qui dovremmo essere
459 giudiziosi.  Quando si hanno dei dubbi si dovrebbe far riferimento alla
460 discussione originale negli archivi della lista di discussione.
462 Se una persona ha avuto l'opportunità di commentare la patch, ma non lo ha
463 fatto, potete aggiungere l'etichetta ``Cc:`` alla patch.  Questa è l'unica
464 etichetta che può essere aggiunta senza che la persona in questione faccia
465 alcunché - ma dovrebbe indicare che la persona ha ricevuto una copia della
466 patch.  Questa etichetta documenta che terzi potenzialmente interessati sono
467 stati inclusi nella discussione.
469 Co-developed-by: indica che la patch è stata cosviluppata da diversi
470 sviluppatori; viene usato per assegnare più autori (in aggiunta a quello
471 associato all'etichetta From:) quando più persone lavorano ad una patch.  Dato
472 che Co-developed-by: implica la paternità della patch, ogni Co-developed-by:
473 dev'essere seguito immediatamente dal Signed-off-by: del corrispondente
474 coautore. Qui si applica la procedura di base per sign-off, in pratica
475 l'ordine delle etichette Signed-off-by: dovrebbe riflettere il più possibile
476 l'ordine cronologico della storia della patch, indipendentemente dal fatto che
477 la paternità venga assegnata via From: o Co-developed-by:. Da notare che
478 l'ultimo Signed-off-by: dev'essere quello di colui che ha sottomesso la patch.
480 Notate anche che l'etichetta From: è opzionale quando l'autore in From: è
481 anche la persona (e indirizzo email) indicato nel From: dell'intestazione
482 dell'email.
484 Esempio di una patch sottomessa dall'autore in From:::
486         <changelog>
488         Co-developed-by: First Co-Author <first@coauthor.example.org>
489         Signed-off-by: First Co-Author <first@coauthor.example.org>
490         Co-developed-by: Second Co-Author <second@coauthor.example.org>
491         Signed-off-by: Second Co-Author <second@coauthor.example.org>
492         Signed-off-by: From Author <from@author.example.org>
494 Esempio di una patch sottomessa dall'autore Co-developed-by:::
496         From: From Author <from@author.example.org>
498         <changelog>
500         Co-developed-by: Random Co-Author <random@coauthor.example.org>
501         Signed-off-by: Random Co-Author <random@coauthor.example.org>
502         Signed-off-by: From Author <from@author.example.org>
503         Co-developed-by: Submitting Co-Author <sub@coauthor.example.org>
504         Signed-off-by: Submitting Co-Author <sub@coauthor.example.org>
506 Utilizzare Reported-by:, Tested-by:, Reviewed-by:, Suggested-by: e Fixes:
507 -------------------------------------------------------------------------
509 L'etichetta Reported-by da credito alle persone che trovano e riportano i bachi
510 e si spera che questo possa ispirarli ad aiutarci nuovamente in futuro.
511 Rammentate che se il baco è stato riportato in privato, dovrete chiedere il
512 permesso prima di poter utilizzare l'etichetta Reported-by.
514 L'etichetta Tested-by: indica che la patch è stata verificata con successo
515 (su un qualche sistema) dalla persona citata.  Questa etichetta informa i
516 manutentori che qualche verifica è stata fatta, fornisce un mezzo per trovare
517 persone che possano verificare il codice in futuro, e garantisce che queste
518 stesse persone ricevano credito per il loro lavoro.
520 Reviewd-by:, invece, indica che la patch è stata revisionata ed è stata
521 considerata accettabile in accordo con la dichiarazione dei revisori:
523 Dichiarazione di svista dei revisori
524 ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
526 Offrendo la mia etichetta Reviewed-by, dichiaro quanto segue:
528          (a) Ho effettuato una revisione tecnica di questa patch per valutarne
529              l'adeguatezza ai fini dell'inclusione nel ramo principale del
530              kernel.
532          (b) Tutti i problemi e le domande riguardanti la patch sono stati
533              comunicati al mittente.  Sono soddisfatto dalle risposte
534              del mittente.
536          (c) Nonostante ci potrebbero essere cose migliorabili in queste
537              sottomissione, credo che sia, in questo momento, (1) una modifica
538              di interesse per il kernel, e (2) libera da problemi che
539              potrebbero metterne in discussione l'integrazione.
541          (d) Nonostante abbia revisionato la patch e creda che vada bene,
542              non garantisco (se non specificato altrimenti) che questa
543              otterrà quello che promette o funzionerà correttamente in tutte
544              le possibili situazioni.
546 L'etichetta Reviewed-by è la dichiarazione di un parere sulla bontà di
547 una modifica che si ritiene appropriata e senza alcun problema tecnico
548 importante.  Qualsiasi revisore interessato (quelli che lo hanno fatto)
549 possono offrire il proprio Reviewed-by per la patch.  Questa etichetta serve
550 a dare credito ai revisori e a informare i manutentori sul livello di revisione
551 che è stato fatto sulla patch.  L'etichetta Reviewd-by, quando fornita da
552 revisori conosciuti per la loro conoscenza sulla materia in oggetto e per la
553 loro serietà nella revisione, accrescerà le probabilità che la vostra patch
554 venga integrate nel kernel.
556 Quando si riceve una email sulla lista di discussione da un tester o
557 un revisore, le etichette Tested-by o Reviewd-by devono essere
558 aggiunte dall'autore quando invierà nuovamente la patch. Tuttavia, se
559 la patch è cambiata in modo significativo, queste etichette potrebbero
560 non avere più senso e quindi andrebbero rimosse. Solitamente si tiene traccia
561 della rimozione nel changelog della patch (subito dopo il separatore '---').
563 L'etichetta Suggested-by: indica che l'idea della patch è stata suggerita
564 dalla persona nominata e le da credito. Tenete a mente che questa etichetta
565 non dovrebbe essere aggiunta senza un permesso esplicito, specialmente se
566 l'idea non è stata pubblicata in un forum pubblico.  Detto ciò, dando credito
567 a chi ci fornisce delle idee, si spera di poterli ispirare ad aiutarci
568 nuovamente in futuro.
570 L'etichetta Fixes: indica che la patch corregge un problema in un commit
571 precedente.  Serve a chiarire l'origine di un baco, il che aiuta la revisione
572 del baco stesso.  Questa etichetta è di aiuto anche per i manutentori dei
573 kernel stabili al fine di capire quale kernel deve ricevere la correzione.
574 Questo è il modo suggerito per indicare che un baco è stato corretto nella
575 patch. Per maggiori dettagli leggete :ref:`it_describe_changes`
578 Il formato canonico delle patch
579 -------------------------------
581 Questa sezione descrive il formato che dovrebbe essere usato per le patch.
582 Notate che se state usando un repositorio ``git`` per salvare le vostre patch
583 potere usare il comando ``git format-patch`` per ottenere patch nel formato
584 appropriato.  Lo strumento non crea il testo necessario, per cui, leggete
585 le seguenti istruzioni.
587 L'oggetto di una patch canonica è la riga::
589     Subject: [PATCH 001/123] subsystem: summary phrase
591 Il corpo di una patch canonica contiene i seguenti elementi:
593   - Una riga ``from`` che specifica l'autore della patch, seguita
594     da una riga vuota (necessaria soltanto se la persona che invia la
595     patch non ne è l'autore).
597   - Il corpo della spiegazione, con linee non più lunghe di 75 caratteri,
598     che verrà copiato permanentemente nel changelog per descrivere la patch.
600   - Una riga vuota
602   - Le righe ``Signed-off-by:``, descritte in precedenza, che finiranno
603     anch'esse nel changelog.
605   - Una linea di demarcazione contenente semplicemente ``---``.
607   - Qualsiasi altro commento che non deve finire nel changelog.
609   - Le effettive modifiche al codice (il prodotto di ``diff``).
611 Il formato usato per l'oggetto permette ai programmi di posta di usarlo
612 per ordinare le patch alfabeticamente - tutti i programmi di posta hanno
613 questa funzionalità - dato che al numero sequenziale si antepongono degli zeri;
614 in questo modo l'ordine numerico ed alfabetico coincidono.
616 Il ``subsystem`` nell'oggetto dell'email dovrebbe identificare l'area
617 o il sottosistema modificato dalla patch.
619 La ``summary phrase`` nell'oggetto dell'email dovrebbe descrivere brevemente
620 il contenuto della patch.  La ``summary phrase`` non dovrebbe essere un nome
621 di file. Non utilizzate la stessa ``summary phrase`` per tutte le patch in
622 una serie (dove una ``serie di patch`` è una sequenza ordinata di diverse
623 patch correlate).
625 Ricordatevi che la ``summary phrase`` della vostra email diventerà un
626 identificatore globale ed unico per quella patch.  Si propaga fino al
627 changelog ``git``.  La ``summary phrase`` potrà essere usata in futuro
628 dagli sviluppatori per riferirsi a quella patch.  Le persone vorranno
629 cercare la ``summary phrase`` su internet per leggere le discussioni che la
630 riguardano.  Potrebbe anche essere l'unica cosa che le persone vedranno
631 quando, in due o tre mesi, riguarderanno centinaia di patch usando strumenti
632 come ``gitk`` o ``git log --oneline``.
634 Per queste ragioni, dovrebbe essere lunga fra i 70 e i 75 caratteri, e deve
635 descrivere sia cosa viene modificato, sia il perché sia necessario. Essere
636 brevi e descrittivi è una bella sfida, ma questo è quello che fa un riassunto
637 ben scritto.
639 La ``summary phrase`` può avere un'etichetta (*tag*) di prefisso racchiusa fra
640 le parentesi quadre "Subject: [PATCH <tag>...] <summary phrase>".
641 Le etichette non verranno considerate come parte della frase riassuntiva, ma
642 indicano come la patch dovrebbe essere trattata.  Fra le etichette più comuni
643 ci sono quelle di versione che vengono usate quando una patch è stata inviata
644 più volte (per esempio, "v1, v2, v3"); oppure "RFC" per indicare che si
645 attendono dei commenti (*Request For Comments*).  Se ci sono quattro patch
646 nella serie, queste dovrebbero essere enumerate così: 1/4, 2/4, 3/4, 4/4.
647 Questo assicura che gli sviluppatori capiranno l'ordine in cui le patch
648 dovrebbero essere applicate, e per tracciare quelle che hanno revisionate o
649 che hanno applicato.
651 Un paio di esempi di oggetti::
653     Subject: [PATCH 2/5] ext2: improve scalability of bitmap searching
654     Subject: [PATCH v2 01/27] x86: fix eflags tracking
656 La riga ``from`` dev'essere la prima nel corpo del messaggio ed è nel
657 formato:
659         From: Patch Author <author@example.com>
661 La riga ``from`` indica chi verrà accreditato nel changelog permanente come
662 l'autore della patch.  Se la riga ``from`` è mancante, allora per determinare
663 l'autore da inserire nel changelog verrà usata la riga ``From``
664 nell'intestazione dell'email.
666 Il corpo della spiegazione verrà incluso nel changelog permanente, per cui
667 deve aver senso per un lettore esperto che è ha dimenticato i dettagli della
668 discussione che hanno portato alla patch.  L'inclusione di informazioni
669 sui problemi oggetto dalla patch (messaggi del kernel, messaggi di oops,
670 eccetera) è particolarmente utile per le persone che potrebbero cercare fra
671 i messaggi di log per la patch che li tratta.  Se la patch corregge un errore
672 di compilazione, non sarà necessario includere proprio _tutto_ quello che
673 è uscito dal compilatore; aggiungete solo quello che è necessario per far si
674 che la vostra patch venga trovata.  Come nella ``summary phrase``, è importante
675 essere sia brevi che descrittivi.
677 La linea di demarcazione ``---`` serve essenzialmente a segnare dove finisce
678 il messaggio di changelog.
680 Aggiungere il ``diffstat`` dopo ``---`` è un buon uso di questo spazio, per
681 mostrare i file che sono cambiati, e il numero di file aggiunto o rimossi.
682 Un ``diffstat`` è particolarmente utile per le patch grandi.  Altri commenti
683 che sono importanti solo per i manutentori, quindi inadatti al changelog
684 permanente, dovrebbero essere messi qui.  Un buon esempio per questo tipo
685 di commenti potrebbe essere quello di descrivere le differenze fra le versioni
686 della patch.
688 Se includete un ``diffstat`` dopo ``---``, usate le opzioni ``-p 1 -w70``
689 cosicché i nomi dei file elencati non occupino troppo spazio (facilmente
690 rientreranno negli 80 caratteri, magari con qualche indentazione).
691 (``git`` genera di base dei diffstat adatti).
693 Maggiori dettagli sul formato delle patch nei riferimenti qui di seguito.
695 .. _it_explicit_in_reply_to:
697 Usare esplicitamente In-Reply-To nell'intestazione
698 --------------------------------------------------
700 Aggiungere manualmente In-Reply-To: nell'intestazione dell'e-mail
701 potrebbe essere d'aiuto per associare una patch ad una discussione
702 precedente, per esempio per collegare la correzione di un baco con l'e-mail
703 che lo riportava.  Tuttavia, per serie di patch multiple è generalmente
704 sconsigliato l'uso di In-Reply-To: per collegare precedenti versioni.
705 In questo modo versioni multiple di una patch non diventeranno un'ingestibile
706 giungla di riferimenti all'interno dei programmi di posta.  Se un collegamento
707 è utile, potete usare https://lkml.kernel.org/ per ottenere i collegamenti
708 ad una versione precedente di una serie di patch (per esempio, potete usarlo
709 per l'email introduttiva alla serie).
711 Riferimenti
712 -----------
714 Andrew Morton, "La patch perfetta" (tpp).
715   <http://www.ozlabs.org/~akpm/stuff/tpp.txt>
717 Jeff Garzik, "Formato per la sottomissione di patch per il kernel Linux"
718   <https://web.archive.org/web/20180829112450/http://linux.yyz.us/patch-format.html>
720 Greg Kroah-Hartman, "Come scocciare un manutentore di un sottosistema"
721   <http://www.kroah.com/log/linux/maintainer.html>
723   <http://www.kroah.com/log/linux/maintainer-02.html>
725   <http://www.kroah.com/log/linux/maintainer-03.html>
727   <http://www.kroah.com/log/linux/maintainer-04.html>
729   <http://www.kroah.com/log/linux/maintainer-05.html>
731   <http://www.kroah.com/log/linux/maintainer-06.html>
733 No!!!! Basta gigantesche bombe patch alle persone sulla lista linux-kernel@vger.kernel.org!
734   <https://lkml.org/lkml/2005/7/11/336>
736 Kernel Documentation/translations/it_IT/process/coding-style.rst:
737   :ref:`Documentation/translations/it_IT/process/coding-style.rst <it_codingstyle>`
739 E-mail di Linus Torvalds sul formato canonico di una patch:
740   <http://lkml.org/lkml/2005/4/7/183>
742 Andi Kleen, "Su come sottomettere patch del kernel"
743   Alcune strategie su come sottomettere modifiche toste o controverse.
745   http://halobates.de/on-submitting-patches.pdf