mirror of https://github.com/Qortal/Brooklyn
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
53 lines
2.5 KiB
53 lines
2.5 KiB
.. include:: ../disclaimer-ita.rst |
|
|
|
:Original: :ref:`Documentation/process/programming-language.rst <programming_language>` |
|
:Translator: Federico Vaga <[email protected]> |
|
|
|
.. _it_programming_language: |
|
|
|
Linguaggio di programmazione |
|
============================ |
|
|
|
Il kernel è scritto nel linguaggio di programmazione C [it-c-language]_. |
|
Più precisamente, il kernel viene compilato con ``gcc`` [it-gcc]_ usando |
|
l'opzione ``-std=gnu89`` [it-gcc-c-dialect-options]_: il dialetto GNU |
|
dello standard ISO C90 (con l'aggiunta di alcune funzionalità da C99). |
|
Linux supporta anche ``clang`` [it-clang]_, leggete la documentazione |
|
:ref:`Building Linux with Clang/LLVM <kbuild_llvm>`. |
|
|
|
Questo dialetto contiene diverse estensioni al linguaggio [it-gnu-extensions]_, |
|
e molte di queste vengono usate sistematicamente dal kernel. |
|
|
|
Il kernel offre un certo livello di supporto per la compilazione con |
|
``icc`` [it-icc]_ su diverse architetture, tuttavia in questo momento |
|
il supporto non è completo e richiede delle patch aggiuntive. |
|
|
|
Attributi |
|
--------- |
|
|
|
Una delle estensioni più comuni e usate nel kernel sono gli attributi |
|
[it-gcc-attribute-syntax]_. Gli attributi permettono di aggiungere una semantica, |
|
definita dell'implementazione, alle entità del linguaggio (come le variabili, |
|
le funzioni o i tipi) senza dover fare importanti modifiche sintattiche al |
|
linguaggio stesso (come l'aggiunta di nuove parole chiave) [it-n2049]_. |
|
|
|
In alcuni casi, gli attributi sono opzionali (ovvero un compilatore che non |
|
dovesse supportarli dovrebbe produrre comunque codice corretto, anche se |
|
più lento o che non esegue controlli aggiuntivi durante la compilazione). |
|
|
|
Il kernel definisce alcune pseudo parole chiave (per esempio ``__pure``) |
|
in alternativa alla sintassi GNU per gli attributi (per esempio |
|
``__attribute__((__pure__))``) allo scopo di mostrare quali funzionalità si |
|
possono usare e/o per accorciare il codice. |
|
|
|
Per maggiori informazioni consultate il file d'intestazione |
|
``include/linux/compiler_attributes.h``. |
|
|
|
.. [it-c-language] http://www.open-std.org/jtc1/sc22/wg14/www/standards |
|
.. [it-gcc] https://gcc.gnu.org |
|
.. [it-clang] https://clang.llvm.org |
|
.. [it-icc] https://software.intel.com/en-us/c-compilers |
|
.. [it-gcc-c-dialect-options] https://gcc.gnu.org/onlinedocs/gcc/C-Dialect-Options.html |
|
.. [it-gnu-extensions] https://gcc.gnu.org/onlinedocs/gcc/C-Extensions.html |
|
.. [it-gcc-attribute-syntax] https://gcc.gnu.org/onlinedocs/gcc/Attribute-Syntax.html |
|
.. [it-n2049] http://www.open-std.org/jtc1/sc22/wg14/www/docs/n2049.pdf
|
|
|