18c2ecf20Sopenharmony_ci.. SPDX-License-Identifier: GPL-2.0
28c2ecf20Sopenharmony_ci
38c2ecf20Sopenharmony_ci.. include:: ../disclaimer-ita.rst
48c2ecf20Sopenharmony_ci
58c2ecf20Sopenharmony_ci:Original: :ref:`Documentation/process/deprecated.rst <deprecated>`
68c2ecf20Sopenharmony_ci:Translator: Federico Vaga <federico.vaga@vaga.pv.it>
78c2ecf20Sopenharmony_ci
88c2ecf20Sopenharmony_ci.. _it_deprecated:
98c2ecf20Sopenharmony_ci
108c2ecf20Sopenharmony_ci==============================================================================
118c2ecf20Sopenharmony_ciInterfacce deprecate, caratteristiche del linguaggio, attributi, e convenzioni
128c2ecf20Sopenharmony_ci==============================================================================
138c2ecf20Sopenharmony_ci
148c2ecf20Sopenharmony_ciIn un mondo perfetto, sarebbe possibile prendere tutti gli usi di
158c2ecf20Sopenharmony_ciun'interfaccia deprecata e convertirli in quella nuova, e così sarebbe
168c2ecf20Sopenharmony_cipossibile rimuovere la vecchia interfaccia in un singolo ciclo di sviluppo.
178c2ecf20Sopenharmony_ciTuttavia, per via delle dimensioni del kernel, la gerarchia dei manutentori e
188c2ecf20Sopenharmony_cile tempistiche, non è sempre possibile fare questo tipo di conversione tutta
198c2ecf20Sopenharmony_ciin una volta. Questo significa che nuove istanze di una vecchia interfaccia
208c2ecf20Sopenharmony_cipotrebbero aggiungersi al kernel proprio quando si sta cercando di rimuoverle,
218c2ecf20Sopenharmony_ciaumentando così il carico di lavoro. Al fine di istruire gli sviluppatori su
228c2ecf20Sopenharmony_cicosa è considerato deprecato (e perché), è stata create la seguente lista a cui
238c2ecf20Sopenharmony_cifare riferimento quando qualcuno propone modifiche che usano cose deprecate.
248c2ecf20Sopenharmony_ci
258c2ecf20Sopenharmony_ci__deprecated
268c2ecf20Sopenharmony_ci------------
278c2ecf20Sopenharmony_ciNonostante questo attributo marchi visibilmente un interfaccia come deprecata,
288c2ecf20Sopenharmony_ci`non produce più alcun avviso durante la compilazione
298c2ecf20Sopenharmony_ci<https://git.kernel.org/linus/771c035372a036f83353eef46dbb829780330234>`_
308c2ecf20Sopenharmony_ciperché uno degli obiettivi del kernel è quello di compilare senza avvisi;
318c2ecf20Sopenharmony_ciinoltre, nessuno stava agendo per rimuovere queste interfacce. Nonostante l'uso
328c2ecf20Sopenharmony_cidi `__deprecated` in un file d'intestazione sia opportuno per segnare una
338c2ecf20Sopenharmony_ciinterfaccia come 'vecchia', questa non è una soluzione completa. L'interfaccia
348c2ecf20Sopenharmony_cideve essere rimossa dal kernel, o aggiunta a questo documento per scoraggiarne
358c2ecf20Sopenharmony_cil'uso.
368c2ecf20Sopenharmony_ci
378c2ecf20Sopenharmony_ciBUG() e BUG_ON()
388c2ecf20Sopenharmony_ci----------------
398c2ecf20Sopenharmony_ciAl loro posto usate WARN() e WARN_ON() per gestire le
408c2ecf20Sopenharmony_cicondizioni "impossibili" e gestitele come se fosse possibile farlo.
418c2ecf20Sopenharmony_ciNonostante le funzioni della famiglia BUG() siano state progettate
428c2ecf20Sopenharmony_ciper asserire "situazioni impossibili" e interrompere in sicurezza un
438c2ecf20Sopenharmony_cithread del kernel, queste si sono rivelate essere troppo rischiose
448c2ecf20Sopenharmony_ci(per esempio, in quale ordine rilasciare i *lock*? Ci sono stati che
458c2ecf20Sopenharmony_cisono stati ripristinati?). Molto spesso l'uso di BUG()
468c2ecf20Sopenharmony_cidestabilizza il sistema o lo corrompe del tutto, il che rende
478c2ecf20Sopenharmony_ciimpossibile un'attività di debug o anche solo leggere un rapporto
488c2ecf20Sopenharmony_cicirca l'errore.  Linus ha un'opinione molto critica al riguardo:
498c2ecf20Sopenharmony_ci`email 1
508c2ecf20Sopenharmony_ci<https://lore.kernel.org/lkml/CA+55aFy6jNLsywVYdGp83AMrXBo_P-pkjkphPGrO=82SPKCpLQ@mail.gmail.com/>`_,
518c2ecf20Sopenharmony_ci`email 2
528c2ecf20Sopenharmony_ci<https://lore.kernel.org/lkml/CAHk-=whDHsbK3HTOpTF=ue_o04onRwTEaK_ZoJp_fjbqq4+=Jw@mail.gmail.com/>`_
538c2ecf20Sopenharmony_ci
548c2ecf20Sopenharmony_ciTenete presente che la famiglia di funzioni WARN() dovrebbe essere
558c2ecf20Sopenharmony_ciusato solo per situazioni che si suppone siano "impossibili".  Se
568c2ecf20Sopenharmony_civolete avvisare gli utenti riguardo a qualcosa di possibile anche se
578c2ecf20Sopenharmony_ciindesiderato, usare le funzioni della famiglia pr_warn().  Chi
588c2ecf20Sopenharmony_ciamministra il sistema potrebbe aver attivato l'opzione sysctl
598c2ecf20Sopenharmony_ci*panic_on_warn* per essere sicuri che il sistema smetta di funzionare
608c2ecf20Sopenharmony_ciin caso si verifichino delle condizioni "inaspettate". (per esempio,
618c2ecf20Sopenharmony_cidate un'occhiata al questo `commit
628c2ecf20Sopenharmony_ci<https://git.kernel.org/linus/d4689846881d160a4d12a514e991a740bcb5d65a>`_)
638c2ecf20Sopenharmony_ci
648c2ecf20Sopenharmony_ciCalcoli codificati negli argomenti di un allocatore
658c2ecf20Sopenharmony_ci----------------------------------------------------
668c2ecf20Sopenharmony_ciIl calcolo dinamico delle dimensioni (specialmente le moltiplicazioni) non
678c2ecf20Sopenharmony_cidovrebbero essere fatto negli argomenti di funzioni di allocazione di memoria
688c2ecf20Sopenharmony_ci(o simili) per via del rischio di overflow. Questo può portare a valori più
698c2ecf20Sopenharmony_cipiccoli di quelli che il chiamante si aspettava. L'uso di questo modo di
708c2ecf20Sopenharmony_ciallocare può portare ad un overflow della memoria di heap e altri
718c2ecf20Sopenharmony_cimalfunzionamenti. (Si fa eccezione per valori numerici per i quali il
728c2ecf20Sopenharmony_cicompilatore può generare avvisi circa un potenziale overflow. Tuttavia usare
738c2ecf20Sopenharmony_cii valori numerici come suggerito di seguito è innocuo).
748c2ecf20Sopenharmony_ci
758c2ecf20Sopenharmony_ciPer esempio, non usate ``count * size`` come argomento::
768c2ecf20Sopenharmony_ci
778c2ecf20Sopenharmony_ci	foo = kmalloc(count * size, GFP_KERNEL);
788c2ecf20Sopenharmony_ci
798c2ecf20Sopenharmony_ciAl suo posto, si dovrebbe usare l'allocatore a due argomenti::
808c2ecf20Sopenharmony_ci
818c2ecf20Sopenharmony_ci	foo = kmalloc_array(count, size, GFP_KERNEL);
828c2ecf20Sopenharmony_ci
838c2ecf20Sopenharmony_ciSe questo tipo di allocatore non è disponibile, allora dovrebbero essere usate
848c2ecf20Sopenharmony_cile funzioni del tipo *saturate-on-overflow*::
858c2ecf20Sopenharmony_ci
868c2ecf20Sopenharmony_ci	bar = vmalloc(array_size(count, size));
878c2ecf20Sopenharmony_ci
888c2ecf20Sopenharmony_ciUn altro tipico caso da evitare è quello di calcolare la dimensione di una
898c2ecf20Sopenharmony_cistruttura seguita da un vettore di altre strutture, come nel seguente caso::
908c2ecf20Sopenharmony_ci
918c2ecf20Sopenharmony_ci	header = kzalloc(sizeof(*header) + count * sizeof(*header->item),
928c2ecf20Sopenharmony_ci			 GFP_KERNEL);
938c2ecf20Sopenharmony_ci
948c2ecf20Sopenharmony_ciInvece, usate la seguente funzione::
958c2ecf20Sopenharmony_ci
968c2ecf20Sopenharmony_ci	header = kzalloc(struct_size(header, item, count), GFP_KERNEL);
978c2ecf20Sopenharmony_ci
988c2ecf20Sopenharmony_ciPer maggiori dettagli fate riferimento a array_size(),
998c2ecf20Sopenharmony_ciarray3_size(), e struct_size(), così come la famiglia di
1008c2ecf20Sopenharmony_cifunzioni check_add_overflow() e check_mul_overflow().
1018c2ecf20Sopenharmony_ci
1028c2ecf20Sopenharmony_cisimple_strtol(), simple_strtoll(), simple_strtoul(), simple_strtoull()
1038c2ecf20Sopenharmony_ci----------------------------------------------------------------------
1048c2ecf20Sopenharmony_ciLe funzioni simple_strtol(), simple_strtoll(),
1058c2ecf20Sopenharmony_cisimple_strtoul(), e simple_strtoull() ignorano volutamente
1068c2ecf20Sopenharmony_cii possibili overflow, e questo può portare il chiamante a generare risultati
1078c2ecf20Sopenharmony_ciinaspettati. Le rispettive funzioni kstrtol(), kstrtoll(),
1088c2ecf20Sopenharmony_cikstrtoul(), e kstrtoull() sono da considerarsi le corrette
1098c2ecf20Sopenharmony_cisostitute; tuttavia va notato che queste richiedono che la stringa sia
1108c2ecf20Sopenharmony_citerminata con il carattere NUL o quello di nuova riga.
1118c2ecf20Sopenharmony_ci
1128c2ecf20Sopenharmony_cistrcpy()
1138c2ecf20Sopenharmony_ci--------
1148c2ecf20Sopenharmony_ciLa funzione strcpy() non fa controlli agli estremi del buffer
1158c2ecf20Sopenharmony_cidi destinazione. Questo può portare ad un overflow oltre i limiti del
1168c2ecf20Sopenharmony_cibuffer e generare svariati tipi di malfunzionamenti. Nonostante l'opzione
1178c2ecf20Sopenharmony_ci`CONFIG_FORTIFY_SOURCE=y` e svariate opzioni del compilatore aiutano
1188c2ecf20Sopenharmony_cia ridurne il rischio, non c'è alcuna buona ragione per continuare ad usare
1198c2ecf20Sopenharmony_ciquesta funzione. La versione sicura da usare è strscpy().
1208c2ecf20Sopenharmony_ci
1218c2ecf20Sopenharmony_cistrncpy() su stringe terminate con NUL
1228c2ecf20Sopenharmony_ci--------------------------------------
1238c2ecf20Sopenharmony_ciL'utilizzo di strncpy() non fornisce alcuna garanzia sul fatto che
1248c2ecf20Sopenharmony_ciil buffer di destinazione verrà terminato con il carattere NUL. Questo
1258c2ecf20Sopenharmony_cipotrebbe portare a diversi overflow di lettura o altri malfunzionamenti
1268c2ecf20Sopenharmony_cicausati, appunto, dalla mancanza del terminatore. Questa estende la
1278c2ecf20Sopenharmony_citerminazione nel buffer di destinazione quando la stringa d'origine è più
1288c2ecf20Sopenharmony_cicorta; questo potrebbe portare ad una penalizzazione delle prestazioni per
1298c2ecf20Sopenharmony_cichi usa solo stringe terminate. La versione sicura da usare è
1308c2ecf20Sopenharmony_cistrscpy(). (chi usa strscpy() e necessita di estendere la
1318c2ecf20Sopenharmony_citerminazione con NUL deve aggiungere una chiamata a memset())
1328c2ecf20Sopenharmony_ci
1338c2ecf20Sopenharmony_ciSe il chiamate no usa stringhe terminate con NUL, allore strncpy()
1348c2ecf20Sopenharmony_cipuò continuare ad essere usata, ma i buffer di destinazione devono essere
1358c2ecf20Sopenharmony_cimarchiati con l'attributo `__nonstring <https://gcc.gnu.org/onlinedocs/gcc/Common-Variable-Attributes.html>`_
1368c2ecf20Sopenharmony_ciper evitare avvisi durante la compilazione.
1378c2ecf20Sopenharmony_ci
1388c2ecf20Sopenharmony_cistrlcpy()
1398c2ecf20Sopenharmony_ci---------
1408c2ecf20Sopenharmony_ciLa funzione strlcpy(), per prima cosa, legge interamente il buffer di
1418c2ecf20Sopenharmony_ciorigine, magari leggendo più di quanto verrà effettivamente copiato. Questo
1428c2ecf20Sopenharmony_ciè inefficiente e può portare a overflow di lettura quando la stringa non è
1438c2ecf20Sopenharmony_citerminata con NUL. La versione sicura da usare è strscpy().
1448c2ecf20Sopenharmony_ci
1458c2ecf20Sopenharmony_ciSegnaposto %p nella stringa di formato
1468c2ecf20Sopenharmony_ci--------------------------------------
1478c2ecf20Sopenharmony_ci
1488c2ecf20Sopenharmony_ciTradizionalmente, l'uso del segnaposto "%p" nella stringa di formato
1498c2ecf20Sopenharmony_ciesponne un indirizzo di memoria in dmesg, proc, sysfs, eccetera.  Per
1508c2ecf20Sopenharmony_cievitare che questi indirizzi vengano sfruttati da malintenzionati,
1518c2ecf20Sopenharmony_citutto gli usi di "%p" nel kernel rappresentano l'hash dell'indirizzo,
1528c2ecf20Sopenharmony_cirendendolo di fatto inutilizzabile.  Nuovi usi di "%p" non dovrebbero
1538c2ecf20Sopenharmony_ciessere aggiunti al kernel.  Per una rappresentazione testuale di un
1548c2ecf20Sopenharmony_ciindirizzo usate "%pS", l'output è migliore perché mostrerà il nome del
1558c2ecf20Sopenharmony_cisimbolo.  Per tutto il resto, semplicemente non usate "%p".
1568c2ecf20Sopenharmony_ci
1578c2ecf20Sopenharmony_ciParafrasando la `guida
1588c2ecf20Sopenharmony_ci<https://lore.kernel.org/lkml/CA+55aFwQEd_d40g4mUCSsVRZzrFPUJt74vc6PPpb675hYNXcKw@mail.gmail.com/>`_
1598c2ecf20Sopenharmony_cidi Linus:
1608c2ecf20Sopenharmony_ci
1618c2ecf20Sopenharmony_ci- Se il valore hash di "%p" è inutile, chiediti se il puntatore stesso
1628c2ecf20Sopenharmony_ci  è importante. Forse dovrebbe essere rimosso del tutto?
1638c2ecf20Sopenharmony_ci- Se credi davvero che il vero valore del puntatore sia importante,
1648c2ecf20Sopenharmony_ci  perché alcuni stati del sistema o i livelli di privilegi di un
1658c2ecf20Sopenharmony_ci  utente sono considerati "special"? Se pensi di poterlo giustificare
1668c2ecf20Sopenharmony_ci  (in un commento e nel messaggio del commit) abbastanza bene da
1678c2ecf20Sopenharmony_ci  affrontare il giudizio di Linus, allora forse potrai usare "%px",
1688c2ecf20Sopenharmony_ci  assicurandosi anche di averne il permesso.
1698c2ecf20Sopenharmony_ci
1708c2ecf20Sopenharmony_ciInfine, sappi che un cambio in favore di "%p" con hash `non verrà
1718c2ecf20Sopenharmony_ciaccettato
1728c2ecf20Sopenharmony_ci<https://lore.kernel.org/lkml/CA+55aFwieC1-nAs+NFq9RTwaR8ef9hWa4MjNBWL41F-8wM49eA@mail.gmail.com/>`_.
1738c2ecf20Sopenharmony_ci
1748c2ecf20Sopenharmony_ciVettori a dimensione variabile (VLA)
1758c2ecf20Sopenharmony_ci------------------------------------
1768c2ecf20Sopenharmony_ci
1778c2ecf20Sopenharmony_ciUsare VLA sullo stack produce codice molto peggiore rispetto a quando si usano
1788c2ecf20Sopenharmony_civettori a dimensione fissa. Questi `problemi di prestazioni <https://git.kernel.org/linus/02361bc77888>`_,
1798c2ecf20Sopenharmony_citutt'altro che banali, sono già un motivo valido per eliminare i VLA; in
1808c2ecf20Sopenharmony_ciaggiunta sono anche un problema per la sicurezza. La crescita dinamica di un
1818c2ecf20Sopenharmony_civettore nello stack potrebbe eccedere la memoria rimanente in tale segmento.
1828c2ecf20Sopenharmony_ciQuesto può portare a dei malfunzionamenti, potrebbe sovrascrivere
1838c2ecf20Sopenharmony_cidati importanti alla fine dello stack (quando il kernel è compilato senza
1848c2ecf20Sopenharmony_ci`CONFIG_THREAD_INFO_IN_TASK=y`), o sovrascrivere un pezzo di memoria adiacente
1858c2ecf20Sopenharmony_ciallo stack (quando il kernel è compilato senza `CONFIG_VMAP_STACK=y`).
1868c2ecf20Sopenharmony_ci
1878c2ecf20Sopenharmony_ciSalto implicito nell'istruzione switch-case
1888c2ecf20Sopenharmony_ci-------------------------------------------
1898c2ecf20Sopenharmony_ci
1908c2ecf20Sopenharmony_ciIl linguaggio C permette ai casi di un'istruzione `switch` di saltare al
1918c2ecf20Sopenharmony_ciprossimo caso quando l'istruzione "break" viene omessa alla fine del caso
1928c2ecf20Sopenharmony_cicorrente. Tuttavia questo rende il codice ambiguo perché non è sempre ovvio se
1938c2ecf20Sopenharmony_cil'istruzione "break" viene omessa intenzionalmente o è un baco. Per esempio,
1948c2ecf20Sopenharmony_ciosservando il seguente pezzo di codice non è chiaro se lo stato
1958c2ecf20Sopenharmony_ci`STATE_ONE` è stato progettato apposta per eseguire anche `STATE_TWO`::
1968c2ecf20Sopenharmony_ci
1978c2ecf20Sopenharmony_ci  switch (value) {
1988c2ecf20Sopenharmony_ci  case STATE_ONE:
1998c2ecf20Sopenharmony_ci          do_something();
2008c2ecf20Sopenharmony_ci  case STATE_TWO:
2018c2ecf20Sopenharmony_ci          do_other();
2028c2ecf20Sopenharmony_ci          break;
2038c2ecf20Sopenharmony_ci  default:
2048c2ecf20Sopenharmony_ci          WARN("unknown state");
2058c2ecf20Sopenharmony_ci  }
2068c2ecf20Sopenharmony_ci
2078c2ecf20Sopenharmony_ciDato che c'è stata una lunga lista di problemi `dovuti alla mancanza dell'istruzione
2088c2ecf20Sopenharmony_ci"break" <https://cwe.mitre.org/data/definitions/484.html>`_, oggigiorno non
2098c2ecf20Sopenharmony_cipermettiamo più che vi sia un "salto implicito" (*fall-through*). Per
2108c2ecf20Sopenharmony_ciidentificare un salto implicito intenzionale abbiamo adottato la pseudo
2118c2ecf20Sopenharmony_ciparola chiave 'fallthrough' che viene espansa nell'estensione di gcc
2128c2ecf20Sopenharmony_ci`__attribute__((fallthrough))` `Statement Attributes
2138c2ecf20Sopenharmony_ci<https://gcc.gnu.org/onlinedocs/gcc/Statement-Attributes.html>`_.
2148c2ecf20Sopenharmony_ci(Quando la sintassi C17/C18 `[[fallthrough]]` sarà più comunemente
2158c2ecf20Sopenharmony_cisupportata dai compilatori C, analizzatori statici, e dagli IDE,
2168c2ecf20Sopenharmony_ciallora potremo usare quella sintassi per la pseudo parola chiave)
2178c2ecf20Sopenharmony_ci
2188c2ecf20Sopenharmony_ciQuando la sintassi [[fallthrough]] sarà più comunemente supportata dai
2198c2ecf20Sopenharmony_cicompilatori, analizzatori statici, e ambienti di sviluppo IDE,
2208c2ecf20Sopenharmony_ciallora potremo usarla anche noi.
2218c2ecf20Sopenharmony_ci
2228c2ecf20Sopenharmony_ciNe consegue che tutti i blocchi switch/case devono finire in uno dei seguenti
2238c2ecf20Sopenharmony_cimodi:
2248c2ecf20Sopenharmony_ci
2258c2ecf20Sopenharmony_ci* ``break;``
2268c2ecf20Sopenharmony_ci* `fallthrough;``
2278c2ecf20Sopenharmony_ci* ``continue;``
2288c2ecf20Sopenharmony_ci* ``goto <label>;``
2298c2ecf20Sopenharmony_ci* ``return [expression];``
230