Está en la página 1de 14

Núcleo Linux

Linux es un núcleo mayormente libre semejante al núcleo de Unix.4 ​


Es uno de los principales ejemplos de software libre y de código Linux Kernel
abierto. Está licenciado bajo la GPL v2 salvo el hecho que tiene
blobs binarios5 ​ no-libres6 ​ y la mayor parte del software incluido en Parte de Linux y Android
el paquete que se distribuye en su sitio web (https://www.kernel.org/)
es software libre. Está desarrollado por colaboradores de todo el
mundo. El desarrollo del día a día tiene lugar en la Linux Kernel
Mailing List Archive.

El núcleo Linux fue concebido por el entonces estudiante de ciencias


de la computación finlandés Linus Torvalds en 1991.7 ​ Linux
consiguió rápidamente desarrolladores y usuarios que adoptaron
códigos de otros proyectos de software libre para usarlos con el
nuevo núcleo de sistema.8 ​A día de hoy miles de programadores de
todo el mundo contribuyen en su desarrollo.9 ​

Linux es multiprogramado, dispone de memoria virtual, gestión de


memoria, conectividad en red y permite bibliotecas compartidas.
Linux es multiplataforma y es portable a cualquier arquitectura
siempre y cuando esta disponga de una versión de GCC
Información general
compatible.10 ​
Tipo de Núcleo del sistema
programa
Desarrollador Linus Torvalds, y la
Índice comunidad de colaboradores
Núcleo de sistema operativo alrededor del mundo.
Núcleo Modelo de Desarrollo iterativo, mediante
Sistema operativo desarrollo código abierto y colaboración
de la comunidad.1 ​
Historia
Lanzamiento 25 de agosto de 1991 (31
Aspectos técnicos
inicial años, 7 meses y 22 días)2 ​
Arquitectura
Arquitectura de máquina virtual Vulnerabilidades varias               

Depuración CVE-2017-2584
Formatos binarios soportados
CVE-2016-10147
Jerarquía de directorios
CVE-2016-10088
Kernel panic
CVE-2016-9919
Lenguajes de programación
Portabilidad CVE-2016-9806

Seguridad CVE-2016-9794
CVE-2016-9793
Versiones
Numeración CVE-2016-9777
Fechas de publicación CVE-2016-9756
8 desarrolladores principales CVE-2016-9755
Línea de tiempo de Linux CVE-2016-9754
Distribuciones CVE-2016-9685
Linux-libre CVE-2016-9644

Derechos reservados CVE-2016-9588

Marca CVE-2016-9576
CVE-2016-9555
Críticas CVE-2016-9313
Soporte de hardware CVE-2016-9191
Arquitectura monolítica CVE-2016-9178
Véase también CVE-2016-9120
Referencias CVE-2016-9084
Enlaces externos CVE-2016-9083
CVE-2016-8666

Núcleo de sistema operativo CVE-2016-8660


CVE-2016-8658
CVE-2016-8655
Núcleo CVE-2016-8650
CVE-2016-8646
En el archivo Léeme de Linux se indica que es un clon del sistema
operativo Unix.10 ​ Sin embargo, Linux es un núcleo semejante al CVE-2016-8645
núcleo de un sistema operativo Unix. De hecho, inicialmente se CVE-2016-8633
publicó como núcleo semejante a Minix,4 ​que a su vez era semejante CVE-2016-8632
a Unix, pero con una concepción de micronúcleo en vez de CVE-2016-8630
monolítica.
CVE-2016-7917
Un micronúcleo contiene una funcionalidad mínima en comparación CVE-2016-7916
con un núcleo monolítico tradicional. CVE-2016-7915
CVE-2016-7914
It's important to realize that these programs are not part of the
operating system (...). The operating system is the portion of CVE-2016-7913
the software that runs in kernel mode (...). A trend in modern CVE-2016-7912
operating systems is to take this idea of moving code up into
higher layers even further and remove as much as possible CVE-2016-7911
from the operating system, leaving a minimal kernel. CVE-2016-7910
Es importante darse cuenta de que estos programas no son CVE-2016-7425
parte del sistema operativo (...). El sistema operativo es la CVE-2016-7117
porción de software que se ejecuta en modo kernel (...). Una
tendencia en sistemas operativos modernos es tomar esta idea CVE-2016-7097
de mover código hacia capas más lejanas y eliminar cuanto sea CVE-2016-7042
posible del sistema operativo, dejando un kernel mínimo.
CVE-2016-7039
Operating Systems Design & Implementation, Tanenbaum y
Woodhull. (Refiriéndose a un sistema micronúcleo basado en CVE-2016-6828
el modelo cliente-servidor. El autor indica repetidamente que CVE-2016-6516
es razonable argumentar que las funciones que pasan a
ejecutarse en espacio de usuario siguen siendo parte del CVE-2016-6480
sistema operativo). CVE-2016-6327
CVE-2016-6213
Darwin y GNU Hurd tienen núcleos que son una versión de Mach.
CVE-2016-6198
Minix, sistema operativo en el que se basó inicialmente Linux,
también es micronúcleo. Todos ellos tienen en común el traslado de CVE-2016-6197
parte de la funcionalidad en espacio privilegiado a espacio de CVE-2016-6187
usuario. CVE-2016-6162
CVE-2016-6156
Sistema operativo CVE-2016-6136
CVE-2016-6130
La parte de un sistema operativo que se ejecuta sin privilegios o en
CVE-2016-5829
espacio de usuario es la biblioteca del lenguaje C, que provee el
entorno de tiempo de ejecución, y una serie de programas o CVE-2016-5828
herramientas que permiten la administración y uso del núcleo y CVE-2016-5728
proveer servicios al resto de programas en espacio de usuario, CVE-2016-5696
formando junto con el núcleo el sistema operativo.
CVE-2016-5412
CVE-2016-5400
En un sistema con núcleo CVE-2016-5244
monolítico como Linux la CVE-2016-5243
biblioteca de lenguaje C
CVE-2016-5195
consiste en una abstracción
de acceso al núcleo. Algunas CVE-2016-4998
bibliotecas como la biblioteca CVE-2016-4997
de GNU proveen
CVE-2016-4951
funcionalidad adicional para
facilitar la vida del CVE-2016-4913
programador y usuario o CVE-2016-4805
mejorar el rendimiento de los CVE-2016-4794
programas. CVE-2016-4581
En un sistema con CVE-2016-4580
micronúcleo la biblioteca de CVE-2016-4578
lenguaje C puede gestionar CVE-2016-4569
sistemas de archivos o
controladores además del CVE-2016-4568
acceso al núcleo del sistema. CVE-2016-4565
La instalación mínima de Ubuntu
consiste en una serie de software
CVE-2016-4558
A los sistemas operativos que
que forma una distribución mínima CVE-2016-4557
llevan Linux se les llama de
de GNU/Linux. Todo el software CVE-2016-4486
forma genérica distribuciones
termina dependiendo del entorno de
Linux. Estas consisten en una CVE-2016-4485
ejecución del proyecto GNU, la
recopilación de software que CVE-2016-4482
biblioteca de C GNU libc.
incluyen el núcleo Linux y el
CVE-2016-4470
resto de programas
11
necesarios para completar un sistema operativo. ​Las distribuciones CVE-2016-4440
más comunes son de hecho distribuciones GNU/Linux o CVE-2016-3955
distribuciones Android. El hecho de que compartan núcleo no CVE-2016-3951
significa que sean compatibles entre sí. Una aplicación hecha para
CVE-2016-3841
GNU/Linux no es compatible con Android sin la labor adicional
necesaria para que sea multiplataforma. CVE-2016-3713
CVE-2016-3699
Las distribuciones GNU/Linux usan Linux como núcleo junto con el
CVE-2016-3689
entorno de tiempo de ejecución del Proyecto GNU y una serie de
programas y herramientas del mismo que garantizan un sistema CVE-2016-3672
funcional mínimo. La mayoría de distribuciones GNU/Linux incluye CVE-2016-3156
software adicional como entornos gráficos o navegadores web así CVE-2016-3140
como los programas necesarios para permitirse instalar a sí
CVE-2016-3139
mismas.11 ​ Los programas de instalación son aportados por el
desarrollador de la distribución. Se les conoce como gestores de CVE-2016-3138
paquetes. Los creadores de una distribución también se pueden CVE-2016-3137
encargar de añadir configuraciones iniciales de los distintos CVE-2016-3136
programas incluidos en la distribución. CVE-2016-3135
Las distribuciones Android incluyen el núcleo Linux junto con el CVE-2016-3134
entorno de ejecución y herramientas del proyecto AOSP de Google. CVE-2016-3070
Cada fabricante de teléfonos dispone de su propia distribución de CVE-2016-2854
Android a la cual modifica, elimina o añade programas extra:
interfaces gráficas, tiendas de aplicaciones y clientes de correo CVE-2016-2853
electrónico son algunos ejemplos de programas susceptibles de ser CVE-2016-2847
añadidos, modificados o eliminados. Además de las distribuciones de CVE-2016-2782
los fabricantes de teléfonos existen grupos de programadores CVE-2016-2550
independientes que también desarrollan distribuciones de Android.
CVE-2016-2549
CVE-2016-2548
CVE-2016-2547
CVE-2016-2546
LineageOS (antes CyanogenMod), Replicant y Pixel Experience son CVE-2016-2545
tres ejemplos de distribuciones Android independientes también CVE-2016-2544
llamadas custom "ROMs" o firmwares no oficiales.
CVE-2016-2543
CVE-2016-2384
Historia
CVE-2016-2383

En abril de 1991,2 ​Linus Torvalds, de 21 años, empezó a trabajar en CVE-2016-2188


unas simples ideas para un núcleo de un sistema operativo. Comenzó CVE-2016-2187
intentando obtener un núcleo de sistema operativo gratuito similar a CVE-2016-2186
Unix que funcionara con microprocesadores Intel 80386. Para ello CVE-2016-2185
tomó como base al sistema Minix (un clon de Unix) e hizo un núcleo
monolítico compatible que inicialmente requería software de Minix CVE-2016-2184
para funcionar.4 ​ El 26 de agosto de 1991 Torvalds escribió en el CVE-2016-2143
grupo de noticias comp.os.minix:12 ​ CVE-2016-2117
CVE-2016-2085
CVE-2016-2070
"Estoy haciendo un sistema operativo (gratuito, solo un
pasatiempo, no será nada grande ni profesional como GNU) CVE-2016-2069
para clones AT 386(486). Llevo en ello desde abril y está CVE-2016-2053
empezando a estar listo. Me gustaría saber su opinión sobre las
cosas que les gustan o disgustan en minix, ya que mi SO tiene CVE-2016-1583
algún parecido con él.[...] Actualmente he portado bash(1.08) CVE-2016-1576
y gcc(1.40), y parece que las cosas funcionan. Esto implica
que tendré algo práctico dentro de unos meses..." CVE-2016-1575
CVE-2016-1237
CVE-2016-0758
Tras dicho mensaje, muchas personas ayudaron con el código. En
CVE-2016-0728
septiembre de 1991 se lanzó la versión 0.01 de Linux. Tenía 10.239
líneas de código. En octubre de ese año (1991), salió la versión 0.02 CVE-2016-0723
de Linux; luego, en diciembre se lanzó la versión 0.11(1991). Esta CVE-2015-8970
versión fue la primera en ser self-hosted (autoalbergada). Es decir, CVE-2015-8967
Linux 0.11 podía ser compilado por una computadora que ejecutase
CVE-2015-8966
Linux 0.11, mientras que las versiones anteriores de Linux se
compilaban usando otros sistemas operativos. Cuando lanzó la CVE-2015-8964
siguiente versión, Torvalds adoptó la GPL como su propio boceto de CVE-2015-8963
licencia, la cual no permite su redistribución con otra licencia que no CVE-2015-8962
sea GPL. Antes de este cambio, se impedía el cobro por la
CVE-2015-8961
distribución del código fuente.
CVE-2015-8956
Se inició un grupo de noticias llamado alt.os.linux y el 19 de enero CVE-2015-8955
de 1992 se publicó en ese grupo la primera publicación (post). El 31
CVE-2015-8953
de marzo, alt.os.linux se convirtió en comp.os.linux. XFree86, una
implementación del X Window System, fue portada a Linux, la CVE-2015-8952
versión del núcleo 0.95 fue la primera en ser capaz de ejecutarla. Este CVE-2015-8845
gran salto de versiones (de 0.1x a 0.9x) fue por la sensación de que CVE-2015-8844
una versión 1.0 acabada no parecía estar lejos. Sin embargo, estas
CVE-2015-4176
previsiones resultaron ser un poco optimistas: desde 1993 hasta
principios de 1994 se desarrollaron 15 versiones diferentes de 0.99 CVE-2015-4170
(llegando a la versión 0.99r15). CVE-2015-4167
CVE-2015-4036
El 14 de marzo de 1994, salió Linux 1.0.0, que constaba de 176.250
líneas de código. En marzo de 1995 se lanzó Linux 1.2.0, que ya CVE-2015-4004
estaba compuesto de 310.950 líneas de código. CVE-2015-4003
CVE-2015-4002
Mayo de 1996: Torvalds decidió adoptar al pingüino Tux
como mascota para Linux. CVE-2015-4001
9 de junio de 1996: se lanzó la versión 2 de Linux, con CVE-2015-3636
una recepción positiva. CVE-2015-3339
25 de enero de 1999: se lanzó Linux 2.2.0 con 1.800.847 CVE-2015-3332
líneas de código.
18 de diciembre de 1999: se publicaron parches de IBM CVE-2015-3331
Mainframe para 2.2.13, permitiendo de esta forma que CVE-2015-3291
Linux fuera usado en ordenadores corporativos.
CVE-2015-3290
4 de enero de 2001: se lanzó Linux 2.4.0 con 3.377.902
líneas de código. CVE-2015-3288
17 de diciembre de 2003: se lanzó Linux 2.6.0 con CVE-2015-3214
5.929.913 líneas de código. CVE-2015-3212
19 de mayo de 2008: La Free Software Foundation
CVE-2015-2925
publica Linux-libre, una bifurcación de Linux que no
incluye en su distribución ningún BLOB privativo, como CVE-2015-2922
firmware de dispositivos. CVE-2015-2830
24 de diciembre de 2008: se lanzó Linux 2.6.28 con CVE-2015-2686
10.195.402 líneas de código.13 ​ CVE-2015-2672
20 de octubre de 2010: se lanzó Linux 2.6.36 con
CVE-2015-2666
13.499.457 líneas de código.14 ​
CVE-2015-2150
30 de mayo de 2011: Linus Torvalds anunció15 ​ que la
versión del núcleo dará el salto a la 3.0 en la siguiente CVE-2015-2042
publicación. CVE-2015-2041
21 de julio de 2011: Torvalds publicó en su perfil en la red CVE-2015-1805
social Google+ que el núcleo versión 3.0 estaba listo con CVE-2015-1593
la frase "3.0 Pushed Out".16 ​
CVE-2015-1573
22 de julio de 2011: fue lanzada la versión 3.0 del núcleo
en http://www.kernel.org CVE-2015-1465
12 de mayo y 13 de mayo de 2012: fueron lanzadas las CVE-2015-1421
versiones 3.3.6 y 3.4-rc7 del núcleo en CVE-2015-1420
http://www.kernel.org respectivamente.
CVE-2015-1350
2 de febrero de 2015: fue lanzada la versión 3.19.
CVE-2015-1339
12 de abril de 2015: fue lanzada la versión 4.0.
CVE-2015-1333
27 de marzo de 2019: fue lanzada la versión 5.05.
2 de agosto de 2020: se anuncia la versión 5.8. Linux CVE-2015-1328
Kernel 5.8: «uno de los lanzamientos más grandes de CVE-2015-0275
todos los tiempos» 17 ​ CVE-2015-0274
CVE-2015-0239
Su código fuente está disponible para descarga en el sitio web oficial:
http://www.kernel.org CVE-2015-5706
CVE-2016-6786

Aspectos técnicos CVE-2016-6787


CVE-2015-7872
Linux provee controladores, planificadores, gestores de memoria CVE-2015-5364
virtual, sistemas de archivos y protocolos de red como IPv4 e CVE-2016-0774
IPv6.10 ​ Además está disponible para múltiples arquitecturas
CVE-2016-0821
hardware y está diseñado de manera que se facilite su portabilidad a
arquitecturas nuevas. CVE-2016-0823

Licencia GPL v2, salvo los no-libres


BLOBs
Arquitectura
Estado actual En Desarrollo
Actualmente Linux es un núcleo monolítico híbrido. Los Idiomas Inglés
controladores de dispositivos y las extensiones del núcleo Información técnica
normalmente se ejecutan en un espacio privilegiado conocido como
Programado en C, ensamblador3 ​, Rust
anillo 0 (ring 0), con acceso irrestricto al hardware, aunque algunos
se ejecutan en espacio de usuario. A diferencia de los núcleos Núcleo Unix-like
monolíticos tradicionales, los controladores de dispositivos y las Tipo de núcleo Monolítico
extensiones al núcleo se pueden cargar y descargar fácilmente como Plataformas DEC Alpha, ARM, AVR32,
módulos, mientras el sistema continúa funcionando sin
admitidas Blackfin, ETRAX CRIS, FR-V,
interrupciones. A diferencia de los núcleos monolíticos tradicionales,
H8/300, Itanium, M32R, m68k,
los controladores también pueden ser pre-volcados (detenidos
Microblaze, MIPS, MN103,
momentáneamente por actividades más importantes) bajo ciertas PA-RISC, PowerPC, s390,
condiciones. Esta habilidad fue agregada para gestionar S+core, SuperH, SPARC,
correctamente interrupciones de hardware y para mejorar el soporte TILE64, Unicore32, x86,
de multiprocesamiento simétrico. Xtensa
Versiones
El hecho de que Linux no fuera desarrollado siguiendo el diseño de
un micronúcleo (diseño que, en aquella época, era considerado el Última versión 6.2
más apropiado para un núcleo por muchos teóricos informáticos), fue estable 19 de febrero de 2023
motivo de una famosa y acalorada discusión entre Linus Torvalds y Artículos relacionados
Andrew S. Tanenbaum.18 19​ ​
Historia de Linux
GNU/Linux
Arquitectura de máquina virtual
Anexo:Distribuciones GNU/Linux -
El núcleo Linux puede correr sobre muchas arquitecturas de máquina Distribuciones Linux: Debian GNU/Linux,
virtual, tanto como host del sistema operativo o como cliente. La Ubuntu, Red Hat Enterprise Linux,
máquina virtual usualmente emula la familia de procesadores Intel Slackware, SUSE Linux, etc.
x86, aunque en algunos casos también son emulados procesadores de Enlaces
PowerPC o ARM. Linux Kernel Sitio web oficial (http://www.kernel.o
rg/)
Depuración Blog (https://planet.kernel.org/)
Repositorio de código (https://git.kernel.org/pub/s
Para verificar el correcto funcionamiento del núcleo este provee la cm/linux/kernel/git/torvalds/linux.git)
posibilidad de compilarse contra la arquitectura ficticia bajo «User Seguimiento de errores (https://bugzilla.kernel.or
Mode Linux» (UML). Compilando Linux para UML el núcleo pasa g/)
a ejecutarse
como un proceso más de
usuario ejecutándose en el
núcleo Linux del sistema
anfitrión. También puede servir
como virtualización o para
aislar procesos, entre otros
usos.

Formatos binarios
La ubicuidad del núcleo Linux
soportados

Linux 1.0 admitía solo el formato binario a.out. La siguiente serie estable (Linux
1.2) agregó la utilización del formato ELF, el cual simplifica la creación de
bibliotecas compartidas (usadas de forma extensa por los actuales ambientes de
escritorio como GNOME y KDE). ELF es el formato usado de forma
predeterminada por el GCC desde alrededor de la versión 2.6.0. El formato a.out
Notas de publicación de Linux 0.01
actualmente no es usado, convirtiendo a ELF en el formato binario utilizado por
Linux en la actualidad.

Linux tiene la capacidad de permitir al usuario añadir el manejo de otros formatos


binarios. También binfmt_misc permite correr el programa asociado a un archivo de
datos.

Jerarquía de directorios

En Linux existe un sistema de archivos que carga y contiene todos los directorios,
redes, programas, particiones, dispositivos, etc. que el sistema sabe reconocer, o por lo
menos, identificar. Este sistema de ficheros y directorios, tiene como base al carácter (/);
ese mismo carácter sirve también para demarcar los directorios, como por ejemplo:
"/home/usuario/imagen.jpg". El directorio especificado por una ruta consistente solo
por este carácter contiene toda la jerarquía de los directorios que constituyen todo el Diagrama del núcleo 2.4.0.
sistema. A este directorio suele llamárselo directorio raíz. En Linux, a los discos no se les asigna una letra como en Windows
(p.e. "C:"), sino que se les asigna un directorio de la jerarquía del directorio raíz (/), como por ejemplo: "/media/floppy". Es
práctica común en el sistema de ficheros de Linux, utilizar varias sub-jerarquías de directorios, según las diferentes
funciones y estilos de utilización de los archivos.20 ​Estos directorios pueden clasificarse en:

Estáticos: Contiene archivos que no cambian sin la intervención del administrador (root), sin embargo,
pueden ser leídos por cualquier otro usuario. (/bin, /sbin, /opt, /boot, /usr/bin...)
Dinámicos: Contiene archivos que son cambiantes, y pueden leerse y escribirse (algunos solo por su
respectivo usuario y el root). Contienen configuraciones, documentos, etc. Para estos directorios, es
recomendable una copia de seguridad con frecuencia, o mejor aún, deberían ser montados en una
partición aparte en el mismo disco, como por ejemplo, montar el directorio /home en otra partición del
mismo disco, independiente de la partición principal del sistema; de esta forma, puede repararse el
sistema sin afectar o borrar los documentos de los usuarios. (/var/mail, /var/spool, /var/run, /var/lock,
/home...)
Compartidos: Contiene archivos que se pueden encontrar en un ordenador y utilizarse en otro, o incluso
compartirse entre usuarios.
Restringidos: Contiene ficheros que no se pueden compartir, solo son modificables por el administrador.
(/etc, /boot, /var/run, /var/lock...)

Kernel panic

En Linux, un panic es un error casi siempre insalvable del sistema detectado por el
núcleo en oposición a los errores similares detectados en el código del espacio de
usuario. Es posible para el código del núcleo indicar estas condiciones mediante una
llamada a la función de pánico situada en el archivo header sys/systm.h. Sin embargo,
la mayoría de las alertas son el resultado de excepciones en el código del núcleo que el
procesador no puede manejar, como referencias a direcciones de memorias inválidas.
Generalmente esto es indicador de la existencia de un bug en algún lugar de la cadena
de alerta. También pueden indicar un fallo en el hardware como un fallo de la RAM o Kernel panic.
errores en las funciones aritméticas en el procesador, o por un error en el software. En
muchas ocasiones es posible reiniciar o apagar adecuadamente el núcleo mediante una
combinación de teclas como ALT+SysRq+REISUB.

Lenguajes de programación

Linux está escrito en el lenguaje de programación C, en la variante utilizada por el compilador GCC (que ha introducido un
número de extensiones y cambios al C estándar), junto a unas pequeñas secciones de código escritas con el lenguaje
ensamblador. Por el uso de sus extensiones al lenguaje, GCC fue durante mucho tiempo el único compilador capaz de
construir correctamente Linux. Sin embargo, Intel afirmó haber modificado su compilador C de forma que permitiera
compilarlo correctamente.

Asimismo se usan muchos otros lenguajes en alguna forma, básicamente en la conexión con el proceso de construcción del
núcleo (el método a través del cual las imágenes arrancables son creadas desde el código fuente). Estos incluyen a Perl,
Python y varios lenguajes shell scripting. Algunos controladores también pueden ser escritos en C++, Fortran, u otros
lenguajes, pero esto no es aconsejable. El sistema de construcción de Linux oficialmente solo soporta GCC como núcleo y
compilador de controlador.

Portabilidad

Aun cuando Linus Torvalds no ideó originalmente Linux como un núcleo portable, ha evolucionado en esa dirección.
Linux es ahora de hecho, uno de los núcleos más ampliamente portados, y funciona en sistemas muy diversos que van
desde iPAQ (una handheld) hasta un zSeries (un mainframe masivo). Linux se ha convertido en el sistema operativo
principal de las supercomputadoras de IBM, Blue Gene, lo cual ha reducido los costos e incrementado considerablemente el
rendimiento.21 ​
De todos modos, es importante notar que los esfuerzos de Torvalds también estaban
dirigidos a un tipo diferente de portabilidad. Según su punto de vista, la portabilidad es
la habilidad de compilar fácilmente en un sistema aplicaciones de los orígenes más
diversos; así, la popularidad original de Linux se debió en parte al poco esfuerzo
necesario para tener funcionando las aplicaciones favoritas de todos, ya sean software
libre o de código abierto.

Las arquitecturas principales soportadas por Linux son DEC Alpha, ARM, AVR32,
Blackfin, ETRAX CRIS, FR-V, H8, IA64, M32R, m68k, MicroBlaze, MIPS,
MN10300, PA-RISC, PowerPC, System/390, SuperH, SPARC, x86, x86 64 y
Xtensa22 ​

Linux dispone de una arquitectura ficticia llamada «User Mode Linux» (UML). Esta
arquitectura permite ejecutar Linux como un proceso más en espacio de usuario. Los iPod ejecutando un núcleo Linux.
procesos ejecutados bajo UML tienen la visión de una máquina propia disponible para
ellos.

Seguridad

Dispone de una interfaz para crear módulos de seguridad llamada Linux Security Module. Con esta interfaz se pueden crear
módulos para aplicar control de acceso obligatorio (MAC, Mandatory Access Control).23 ​

Versiones
Más allá de haber desarrollado su propio código y de integrar los cambios
realizados por otros programas, Linus Torvalds continúa lanzando nuevas
versiones del núcleo Linux. Estos son llamados núcleos “vanilla”, lo que
significa que no han sido modificados por nadie.

Numeración
Infografía del Núcleo Linux
La versión del núcleo Linux original constaba de cuatro números. Por
ejemplo, asumamos que el número de la versión está compuesta de esta
forma: A.B.C[.D] (ej.: 2.2.1, 2.4.13 o 2.6.12.3).

El número A denota la versión del núcleo. Es el que cambia con menor frecuencia y solo lo hace cuando
se produce un gran cambio en el código o en el concepto del núcleo. Históricamente solo ha sido
modificado cinco veces: en 2004 (versión 1.0), en 2006 (versión 2.0), en 2011 (versión 3.0), en 2015
(versión 4.0) y en 2019 (versión 5.0).
El número B denota la subversión del núcleo.

Antes de la serie de Linux 2.6.x, los números pares indicaban la versión “estable” lanzada. Por ejemplo
una para uso en producción, como el 1.2, 2.4 o 2.6. Los números impares, en cambio, como la serie
2.5.x, son versiones de desarrollo, es decir que no son consideradas de producción.

Comenzando con la serie Linux 2.6.x, no hay gran diferencia entre los números pares o impares con
respecto a las nuevas herramientas desarrolladas en la misma serie del núcleo. Linus Torvalds
dictaminó que este será el modelo en el futuro.

El número C indica una revisión mayor en el núcleo. En la forma anterior de versiones con tres números,
esto fue cambiado cuando se implementaron en el núcleo los parches de seguridad, bugfixes, nuevas
características o drivers. Con la nueva política, solo es cambiado cuando se introducen nuevos
controladores o características; cambios menores se reflejan en el número D.
El número D se produjo cuando un grave error, que requiere de un arreglo inmediato, se encontró en el
código NFS de la versión 2.6.8. Sin embargo, no había otros cambios como para lanzar una nueva
revisión (la cual hubiera sido 2.6.9). Entonces se lanzó la versión 2.6.8.1, con el error arreglado como
único cambio. Con 2.6.11, esto fue adoptado como la nueva política de versiones. Bug-fixes y parches de
seguridad son actualmente manejados por el cuarto número dejando los cambios mayores para el número
C.
También, algunas veces luego de las versiones puede haber algunas letras como “rc1” o “mm2”. El “rc” se refiere a release
candidate e indica un lanzamiento no oficial. Otras letras usualmente (pero no siempre) hacen referencia a las iniciales de la
persona. Esto indica una bifurcación en el desarrollo del núcleo realizado por esa persona, por ejemplo ck se refiere a Con
Kolivas, ac a Alan Cox, mientras que mm se refiere a Andrew Morton.

El modelo de desarrollo para Linux 2.6 fue un cambio significativo desde el modelo de desarrollo de Linux 2.5.
Previamente existía una rama estable (2.4) donde se habían producido cambios menores y seguros, y una rama inestable
(2.5) donde estaban permitidos cambios mayores. Esto significó que los usuarios siempre tenían una versión 2.4 a prueba de
fallos y con lo último en seguridad y casi libre de errores, aunque tuvieran que esperar por las características de la rama 2.5.
La rama 2.5 fue finalmente declarada estable y renombrada como 2.6. Pero en vez de abrir una rama 2.7 inestable, los
desarrolladores de núcleos eligieron continuar agregando los cambios en la rama “estable” 2.6. De esta forma no había que
seguir manteniendo una rama vieja pero estable y se podía hacer que las nuevas características estuvieran rápidamente
disponibles y se pudieran realizar más pruebas con el último código.

Sin embargo, el modelo de desarrollo del nuevo 2.6 también significó que no había una rama estable para aquellos que
esperaban seguridad y bug fixes sin necesitar las últimas características. Los arreglos solo estaban en la última versión, así
que si un usuario quería una versión con todos los bug fixed conocidos también tendría las últimas características, las cuales
no habían sido bien probadas. Una solución parcial para esto fue la versión ya mencionada de cuatro números (y en
2.6.x.y), la cual significaba lanzamientos puntuales creados por el equipo estable (Greg Kroah-Hartman, Chris Wright, y
quizás otros). El equipo estable solo lanzaba actualizaciones para el núcleo más reciente, sin embargo esto no solucionó el
problema del faltante de una serie estable de núcleo. Distribuidores de Linux, como Red Hat y Debian, mantienen los
núcleos que salen con sus lanzamientos, de forma que una solución para algunas personas es seguir el núcleo de una
distribución.

Como respuesta a la falta de un núcleo estable y de gente que coordinara la colección de corrección de errores, en diciembre
de 2005 Adrian Bunk anunció que continuaría lanzando núcleos 2.6.16 aun cuando el equipo estable lanzara 2.6.17.
Además pensó en incluir actualizaciones de controladores, haciendo que el mantenimiento de la serie 2.6.16 sea muy
parecido a las viejas reglas de mantenimiento para las serie estables como 2.4. El núcleo 2.6.16 será reemplazado
próximamente por el 2.6.27 como núcleo estable en mantenimiento durante varios años.

Dado el nuevo modelo de desarrollo, que mantuvo fija la subversión de 2.6, tras la realización del Linux Kernel Summit de
ese año, Linus Torvalds decidió modificar el sistema de numeración. Se han sustituido los dos primeros números por una
única cifra, de forma que Linux 2.6.39 fue seguida por Linux 3.0 24 ​

Fechas de publicación

La primera versión del kernel Linux (0.01) fue lanzada el 17 de septiembre de 1991. Tras más de 30 años de desarrollo,
actualmente la última versióne estable corresponde a la 5.16, lanzada el 9 de febrero del 202225 ​.

8 desarrolladores principales

Posición 201226 ​ 201327 ​ 201728 ​

1 Red Hat Google Intel


2 IBM Linaro Red Hat

3 Texas Instruments SUSE Linaro

4 Broadcom IBM Desconocido


5 Nokia Samsung IBM

6 Samsung Red Hat Consultants


7 Oracle Vision Engraving Systems Consultants Samsung

8 Google Wolfson Microelectronics SUSE

Línea de tiempo de Linux


Distribuciones
Una distribución Linux es un conjunto de software acompañado del núcleo Linux que se enfoca a satisfacer las necesidades
de un grupo específico de usuarios. De este modo hay distribuciones para hogares, empresas y servidores.
Las distribuciones son ensambladas por individuos, empresas u otros organismos. Cada
distribución puede incluir cualquier número de software adicional, incluyendo software
que facilite la instalación del sistema. La base del software incluido con cada
distribución incluye el núcleo Linux, en la mayoría de los casos las herramientas GNU,
al que suelen añadirse también multitud de paquetes de software.

Las herramientas que suelen incluirse en la distribución de este sistema operativo se


obtienen de diversas fuentes, y en especial de proyectos de software libre, como: GNU,
GNOME (creado por GNU) y KDE. También se incluyen utilidades de otros
proyectos como Mozilla, Perl, Ruby, Python, PostgreSQL, MySQL, Xorg, casi todas
con licencia GPL o compatibles con esta (LGPL, MPL).

Usualmente se utiliza la plataforma X.Org Server, basada en la antigua XFree86, para


sostener la interfaz gráfica.

Linux-libre
Sharp Zaurus, un computador de
Linux es mayormente software libre tal y como se distribuye desde su web y bolsillo con Linux.
repositorio Git. Sin embargo hay fragmentos de código privativo que son empleados
para hacer funcionar los dispositivos de un computador. Por ello Linux no ha podido
ser integrado como un paquete de GNU. La Fundación del Software Libre de América Latina decidió crear y mantener una
bifurcación completamente libre llamada Linux-libre. Esta versión de Linux no incluye ningún complemento de código
cerrado ni funciones ofuscadas que integran binarios en su código. La inclusión de estos binarios en el código de Linux no
incumple la licencia GPL Versión 2 que usa Linux. Dicha licencia fue actualizada para evitar este tipo de uso privativo de la
licencia, parecido a lo que ocurre con los dispositivos TiVo. La nueva licencia es la GPL Versión 3.29 ​

Derechos reservados
Inicialmente, Torvalds distribuyó Linux bajo los términos de una licencia que prohibía la explotación comercial. Pero esta
licencia fue reemplazada, poco tiempo después, por la GNU GPL (versión 2 exclusivamente). Los términos de esta última
licencia permiten la distribución y venta de copias o incluso modificaciones, pero requiere que todas las copias del trabajo
original y trabajos de autoría derivados del original sean publicados bajo los mismos términos, y que el código fuente
siempre pueda obtenerse por el mismo medio que el programa licenciado.

Torvalds se ha referido a haber licenciado Linux bajo la GPL como "la mejor cosa que he hecho" (en inglés, "the best thing
I ever did").30 ​

Sin embargo, la versión oficial del núcleo Linux contiene firmware de código cerrado,31 ​ por ello, el Proyecto Linux-libre,
auspiciado por la FSFLA, publica y mantiene versiones modificadas del núcleo Linux a las que se les ha quitado todo el
software no libre.

Marca
A día de hoy, Linux es una marca registrada de Linus Torvalds en los Estados Unidos.32 ​

Hasta 1994 nadie registró la marca Linux en Estados Unidos. El 15 de agosto de 1994 cuando William R. Della Croce, Jr.
registró la marca Linux, pidió el pago de regalías a los distribuidores de Linux. En 1996, Torvalds y algunas organizaciones
afectadas denunciaron a Della Croce y en 1997 el caso se cerró y la marca fue asignada a Torvalds.33 ​
Desde entonces, el Linux Mark Institute gestiona la marca. En 2005 el LMI envió algunas cartas a empresas distribuidoras
de Linux exigiendo el pago de una cuota por el uso comercial del nombre. Esto es así porque la legislación estadounidense
exige que el dueño de una marca la defienda, por lo que se tuvo que pedir dinero por usar la marca Linux, algunas
compañías de forma totalmente voluntaria han cumplido con dicha exigencia, a sabiendas de que dicho dinero se iba a usar
para caridad o defender la marca Linux.34 ​

Críticas

Soporte de hardware

El núcleo Linux ha sido criticado con frecuencia por falta de controladores para cierto hardware de computadoras de
escritorio. Sin embargo, el progresivo incremento en la adopción de Linux en el escritorio ha mejorado el soporte de
hardware por parte de terceros o de los propios fabricantes, provocando que, en los últimos años, los problemas de
compatibilidad se reduzcan.

Empresas como IBM, Intel Corporation, Hewlett-Packard, Dell o MIPS Technologies35 ​tienen programadores en el equipo
de desarrolladores del núcleo Linux que se encargan de mantener los controladores para el hardware que fabrican. A este
grupo de programadores también se le suman los que proveen grandes distribuidores de soluciones Linux como Novell o
Red Hat.

Arquitectura monolítica

Andy Tanenbaum escribió el 29 de enero de 1992:

...Linux es un sistema monolítico. Esto es retroceder un paso gigante hacia la década de 1970. Es como tomar un
programa existente escrito en C y reescribirlo en BASIC. Para mí, escribir un sistema monolítico en 1991 es
verdaderamente una idea pobre.36 ​

Véase también
Portal:Linux. Contenido relacionado con Linux.
Portal:Software Libre. Contenido relacionado con Software Libre.
Historia de Linux
Disputas de SCO sobre Linux
Glibc
GNU/Linux
GNU GRUB
Llamada al sistema
LinuxDNA
Linux-libre
Linux From Scratch
Proceso de arranque en Linux
Shell (informática)
Qlinux

Referencias
3. «The linux-kernel mailing list FAQ: Why is the
1. «The Linux Kernel Mailing List Archive» (https://w
Linux kernel written in C/assembly?» (https://web.a
ww.lkml.org) (en inglés). Consultado el 30 de julio rchive.org/web/20160701221623/http://www.tux.or
de 2020. g/lkml/#s15-1). Tux.Org (en inglés). Archivado
2. «Sobre Linux» (http://www.linux-es.org/sobre_linu desde el original (http://www.tux.org/lkml/#s15-1) el
x). Linux.org. Consultado el 19 de julio de 2012. 1 de julio de 2016. Consultado el 22 de mayo de
2013.
4. Linus Torvalds (1991). «Notes for linux release 15. Linus Torvalds (30 de mayo de 2011). «Linux 3.0-
0.01» (https://www.kernel.org/pub/linux/kernel/Hist rc1» (https://web.archive.org/web/2011053123274
oric/old-versions/RELNOTES-0.01) (en inglés). 7/http://permalink.gmane.org/gmane.linux.kernel/1
Consultado el 11 de junio de 2017. 147415). Archivado desde el original (http://permali
5. git.kernel.org, ed. (16 de octubre de 2002). nk.gmane.org/gmane.linux.kernel/1147415) el 31
«kernel/git/stable/linux-stable.git» (https://archive.t de mayo de 2011. Consultado el 30 de mayo de
oday/20130113003817/http://git.kernel.org/?p=linu 2011.
x/kernel/git/stable/linux-stable.git;a=blob;f=firmwar 16. Linus Torvalds (21 de julio de 2011). «Linux 3
e/WHENCE;hb=HEAD). Archivado desde el Pushed Out - Linus Torvalds Google Plus Profile»
original (https://git.kernel.org/?p=linux/kernel/git/sta (https://plus.google.com/10215069322513000291
ble/linux-stable.git;a=blob;f=firmware/WHENCE;hb 2/posts/CJpyYdCqBL8). Consultado el 27 de julio
=HEAD) el 13 de enero de 2013. Consultado el 21 de 2011.
de agosto de 2012. «path: 17. «Linux Kernel 5.8» (https://www.stackscale.com/e
root/firmware/WHENCE ». s/blog/linux-kernel-5-8/).
6. Linus Torvalds (25 de septiembre de 2006). «Re: 18. GNU/Linux Kernel Híbrido (http://cosaslibres.com.c
GPLv3 Position Statement» (http://lkml.org/lkml/20 o/software/gnulinux-kernel-hibrido/) (en español)
06/9/25/161) (en inglés). Consultado el 22 de 19. Resumen de la afamada discusión entre Linus
mayo de 2013. Torvalds y Andrew Tanenbaum (https://web.archiv
7. Marjorie Richardson (1 de noviembre de 1999). e.org/web/20140621054711/http://www.dina.dk/~a
«Interview: Linus Torvalds» (http://www.linuxjourna braham/Linus_vs_Tanenbaum.html) (en inglés)
l.com/article/3655). Linux Journal (en inglés).
20. Organización de los directorios en Linux (http://ww
Consultado el 20 de agosto de 2009.
w.linux-es.org/node/112)
8. «Free as in Freedom by Sam Williams. O'Reilly
21. «IBM100 - Blue Gene - Technical Breakthroughs»
books, 2002» (http://www.oreilly.com/openbook/fre
(http://www-03.ibm.com/ibm/history/ibm100/us/en/i
edom/ch09.html). Oreilly.com. Consultado el 12 de cons/bluegene/breakthroughs/) (en inglés).
noviembre de 2010. Consultado el 22 de diciembre de 2016.
9. Greg Kroah-Hartman (abril de 2008). «Linux 22. /pub/scm / linux/kernel/git/torvalds/linux-2.6.git /
Kernel Development: How Fast it is Going, Who is tree (http://git.kernel.org/?p=linux/kernel/git/torvald
Doing It, What They are Doing, and Who is
s/linux-2.6.git;a=tree;f=arch;h=3ce1e42a1a3b8642
Sponsoring It» (https://web.archive.org/web/20190
8b2511152d21dd5fefb27c6e;hb=HEAD)
912023947/https://storage.pardot.com/6342/48856/
lf_kernel_development_2012.pdf) (en inglés). 23. «Linux Security Module Usage — The Linux
Archivado desde el original (http://go.linuxfoundati Kernel documentation» (https://www.kernel.org/do
on.org/who-writes-linux-2012) el 12 de septiembre c/html/v4.13/admin-guide/LSM/). www.kernel.org
de 2019. Consultado el 24 de mayo de 2013. (en inglés). Consultado el 26 de octubre de 2017.
«Since 2005, over 3700 individual developers from 24. 29 de mayo de 2011, anuncio de Linux 3.0-rc1 (htt
over 200 different companies have contributed to ps://lkml.org/lkml/2011/5/29/204).
the kernel. » 25. https://lore.kernel.org/lkml/1645015867107165@kroa
10. Linus Torvalds (11 de junio de 2017). «Linux 26. «Copia archivada» (https://web.archive.org/web/20
kernel release 4.x <http://kernel.org/>» (https://git.k 120630123427/http://www.linuxfoundation.org/new
ernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/ s-media/announcements/2012/04/linux-foundation-
tree/Documentation/admin-guide/README.rst?id= releases-annual-linux-development-report).
32c1431eea4881a6b17bd7c639315010aeefa452) Archivado desde el original (http://www.linuxfound
(en inglés). Consultado el 13 de junio de 2017. ation.org/news-media/announcements/2012/04/lin
11. Linux Journal, ed. (1 de octubre de 1994). ux-foundation-releases-annual-linux-development-
«Overview Of The Debian GNU/Linux System» (htt report) el 30 de junio de 2012. Consultado el 20 de
p://www.linuxjournal.com/article/2841) (en inglés). noviembre de 2012. The Linux Foundation
Consultado el 11 de junio de 2017. Releases Annual Linux Development Report
12. Linus Torvalds (25-08-1991) Message from 27. «The Linux Foundation Releases Annual Linux
discussion What would you like to see most in Development Report» (https://web.archive.org/we
minix? (https://groups.google.com/forum/#!msg/co b/20140329164331/http://www.linuxfoundation.org/
mp.os.minix/dlNtH7RRrGA/SwRavCzVE7gJ) news-media/announcements/2013/09/linux-founda
Newsgroups: comp.os.minix, Google Groups (en tion-releases-annual-linux-development-report).
inglés). Archivado desde el original (http://www.linuxfound
13. "Linux Kernel Data 2.6.28 (http://www.heise-online. ation.org/news-media/announcements/2013/09/lin
co.uk/open/Kernel-Log-Higher-and-Further-The-in ux-foundation-releases-annual-linux-development-
novations-of-Linux-2-6-28--/features/112299/5)." report) el 29 de marzo de 2014. Consultado el 21
de marzo de 2014.
14. "Linux Kernel Data 2.6.36 (http://www.h-online.co
m/open/features/What-s-new-in-Linux-2-6-36-1103 28. https://www.linuxfoundation.org/publications/2017/10
009.html?page=6)." state-of-linux-kernel-development/
29. The Linux Information Project (LINFO) (8 de enero 33. «Linux Timeline» (http://www.linuxjournal.com/artic
de 2007). «The dangers of tivoization and the le/9065). Linux Journal. 31 de mayo de 2006.
GPLv3» (http://www.linfo.org/tivoization.html) (en 34. «Linus gets tough on Linux trademark» (http://ww
inglés). Consultado el 12 de junio de 2017. w.infoworld.com/article/2671387/operating-system
30. Yamagata, Hiroo (11 de noviembre de 1997). «The s/linus-gets-tough-on-linux-trademark.html). 5 de
Pragmatist of Free Software: Linus Torvalds septiembre de 2005. Consultado el 11 de junio de
Interview» (https://web.archive.org/web/200712261 2017.
84929/http://www.netshooter.com/linux/linus-intervi 35. «Who writes Linux» (https://web.archive.org/web/2
ew.html). Archivado desde el original (http://netsho 0100131001507/http://www.linuxfoundation.org/pu
oter.com/linux/linus-interview.html) el 26 de blications/whowriteslinux.pdf). Agosto de 2009.
diciembre de 2007. Consultado el 30 de octubre Archivado desde el original (http://www.linuxfound
de 2011. ation.org/publications/whowriteslinux.pdf) el 31 de
31. «Publicado el kernel Linux-Libre 5.3» (https://masg enero de 2010.
nulinux.es/publicado-el-kernel-linux-libre-5-3/). 36. A. S. Tanenbaum (29 de enero de 1992), «LINUX
masGNULinuX. Consultado el 1 de febrero de is obsolete (https://groups.google.com/group/comp.
2020. os.minix/browse_thread/thread/c25870d7a41696d
32. «Registro en Estados Unidos No: 1916230» (http:// 2/f447530d082cd95d?tvc=2)»,
assignments.uspto.gov/assignments/q?db=tm&rno http://groups.google.com/group/comp.os.minix/bro
=1916230). Oficina de Patentes y Marcas wse_thread/thread/c25870d7a41696d2/f447530d0
Comerciales de Estados Unidos. Consultado el 30 82cd95d?tvc=2, consultado el 30 de octubre de
de octubre de 2011. 2011.

Enlaces externos
Wikimedia Commons alberga una galería multimedia sobre Núcleo Linux.
Sitio web oficial de Linux (http://www.kernel.org)
Código fuente completo de varias versiones de Linux (https://web.archive.org/web/20100414032751/http://l
xr.linux.no/)
Kernel Newbies (http://kernelnewbies.org/Linux) (enlace roto disponible en Internet Archive; véase el historial (htt
ps://web.archive.org/web/*/http://kernelnewbies.org/Linux), la primera versión (https://web.archive.org/web/1/http://kern
elnewbies.org/Linux) y la última (https://web.archive.org/web/2/http://kernelnewbies.org/Linux)).
Noticias y guías para actualizar o cambiar de Kernel (http://lignux.com/tag/kernel/)

Obtenido de «https://es.wikipedia.org/w/index.php?title=Núcleo_Linux&oldid=150500431»

Esta página se editó por última vez el 12 abr 2023 a las 10:51.

El texto está disponible bajo la Licencia Creative Commons Atribución Compartir Igual 3.0; pueden aplicarse cláusulas adicionales. Al
usar este sitio, usted acepta nuestros términos de uso y nuestra política de privacidad.
Wikipedia® es una marca registrada de la Fundación Wikimedia, Inc., una organización sin ánimo de lucro.

También podría gustarte