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