programming-language.rst 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. .. _programming_language:
  2. Programming Language
  3. ====================
  4. The kernel is written in the C programming language [c-language]_.
  5. More precisely, the kernel is typically compiled with ``gcc`` [gcc]_
  6. under ``-std=gnu11`` [gcc-c-dialect-options]_: the GNU dialect of ISO C11.
  7. ``clang`` [clang]_ is also supported, see docs on
  8. :ref:`Building Linux with Clang/LLVM <kbuild_llvm>`.
  9. This dialect contains many extensions to the language [gnu-extensions]_,
  10. and many of them are used within the kernel as a matter of course.
  11. There is some support for compiling the kernel with ``icc`` [icc]_ for several
  12. of the architectures, although at the time of writing it is not completed,
  13. requiring third-party patches.
  14. Attributes
  15. ----------
  16. One of the common extensions used throughout the kernel are attributes
  17. [gcc-attribute-syntax]_. Attributes allow to introduce
  18. implementation-defined semantics to language entities (like variables,
  19. functions or types) without having to make significant syntactic changes
  20. to the language (e.g. adding a new keyword) [n2049]_.
  21. In some cases, attributes are optional (i.e. a compiler not supporting them
  22. should still produce proper code, even if it is slower or does not perform
  23. as many compile-time checks/diagnostics).
  24. The kernel defines pseudo-keywords (e.g. ``__pure``) instead of using
  25. directly the GNU attribute syntax (e.g. ``__attribute__((__pure__))``)
  26. in order to feature detect which ones can be used and/or to shorten the code.
  27. Please refer to ``include/linux/compiler_attributes.h`` for more information.
  28. .. [c-language] http://www.open-std.org/jtc1/sc22/wg14/www/standards
  29. .. [gcc] https://gcc.gnu.org
  30. .. [clang] https://clang.llvm.org
  31. .. [icc] https://software.intel.com/en-us/c-compilers
  32. .. [gcc-c-dialect-options] https://gcc.gnu.org/onlinedocs/gcc/C-Dialect-Options.html
  33. .. [gnu-extensions] https://gcc.gnu.org/onlinedocs/gcc/C-Extensions.html
  34. .. [gcc-attribute-syntax] https://gcc.gnu.org/onlinedocs/gcc/Attribute-Syntax.html
  35. .. [n2049] http://www.open-std.org/jtc1/sc22/wg14/www/docs/n2049.pdf