ipv6(7) | Miscellaneous Information Manual | ipv6(7) |
ipv6 - Implementación Linux del protocolo IPv6
#include <sys/socket.h> #include <netinet/in.h>
tcp6_socket = socket(AF_INET6, SOCK_STREAM, 0); raw6_socket = socket(AF_INET6, SOCK_RAW, protocolo); udp6_socket = socket(AF_INET6, SOCK_DGRAM, protocolo);
La versión 2.2 de Linux implementa opcionalmente el Protocolo de Internet, versión 6. Esta página de manual contiene una descripción de la API básica IPv6 tal como la implementa el núcleo de Linux y glibc 2.1. La interfaz está basada en la interfaz de conectores (sockets) BSD; véase socket(7).
La API IPv6 pretende ser sobre todo compatible con la API IPv4 (consulte ip(7)). En esta página de manual sólo se describen las diferencias.
Para enlazar un conector AF_INET6 a cualquier proceso debe copiarse la dirección local de la variable in6addr_any cuyo tipo es in6_addr. En inicializaciones estáticas puede utilizarse también IN6ADDR_ANY_INIT, la cual se expande a una expresión constante. Ambas están en el orden de bytes de la red.
La dirección de loopback IPv6 (::1) está disponible en la variable global in6addr_loopback. Se debe utilizar IN6ADDR_LOOPBACK_INIT para la inicialización.
Las conexiones IPv4 pueden ser manejadas con la API v6 usando el tipo de dirección v4-mapeada-a-v6; así un programa solamente necesita tener soporte para este tipo de API para gestionar ambos protocolos. Esto se gestiona de forma transparente por las funciones de direcciones de libc.
IPv4 y IPv6 comparten el espacio de puertos local. Cuando recibe una petición de conexión IPv4 o un paquete para un conector IPv6, la dirección de origen se convierte a v6.
struct sockaddr_in6 {
sa_family_t sin6_family; /* AF_INET6 */
in_port_t sin6_port; /* número de puerto */
uint32_t sin6_flowinfo; /* Información de flujo IPv6 */
struct in6_addr sin6_addr; /* dirección IPv6 */
uint32_t sin6_scope_id; /* identificador de ámbito (nuevo en 2.4) */ }; struct in6_addr {
unsigned char s6_addr[16]; /* dirección IPv6 */ };
sin6_family siempre contiene el valor AF_INET6; sin6_port es el puerto del protocolo (véase sin_port en ip(7)); sin6_flowinfo es el identificador de flujo IPv6; sin6_addr es la dirección IPv6 de 128 bits. sin6_scope_id es un identificador que depende del ámbito de la dirección. Esto es nuevo en Linux 2.4. Linux sólo tiene soporte para direcciones del nivel de enlace, en cuyo caso sin6_scope_id contiene el índice de la interfaz (vea netdevice(7))
IPv6 soporta varios tipos de dirección: unidestino para referirse a un host individual, multidestino para referirse a un grupo de hosts, "cualquier destino" para referirse al miembro más cercano de un grupo de hosts (no implementado en Linux), IPv4-sobre-IPv6 para refererise a un host IPv4, y otros tipos de dirección reservados.
La notación para direcciones IPv6 consiste en un grupo de 8 números hexadecimales de 4 dígitos, separados por ':'. "::" representa una cadena de 0 bits. Direcciones especiales son ::1 para loopback y ::FFFF:<dirección IPv4> para IPv4-mapeada-a-IPv6.
El espacio de puertos de IPv6 es compartido con IPv4.
IPv6 soporta algunas opciones de conectores específicas del protocolo que pueden ser activadas con setsockopt(2) y leídas con getsockopt(2). El nivel de opciones de conectores para IPv6 es IPPROTO_IPV6. Una bandera entera booleana es cero cuando es falsa, en otro caso es verdadera.
Linux 2.4 rompe la compatibilidad binaria para sockaddr_in6 en hosts de 64bit al cambiar la alineación de in6_addr y al añadir un campo sin6_scope_id adicional. Las interfaces del núcleo siguen siendo compatibles, pero un programa que incluya sockaddr_in6 o in6_addr en otras estructuras puede no serlo. Esto no es un problema para hosts de 32bits como i386.
El campo sin6_flowinfo es nuevo en la versión 2.4 de Linux. El núcleo lo pasa/lee transparentemente cuando la longitud de la dirección pasada lo contiene. Algunos programas que pasan un buffer de dirección mayor y comprueban después la longitud de la dirección de salida pueden fallar.
La estructura sockaddr_in6 es mayor que la genérica sockaddr. Los programas que asumen que todos los tipos de dirección se pueden almacenar de manera segura en una struct sockaddr necesitan cambiarse para usar en su lugar struct sockaddr_storage.
SOL_IP, SOL_IPV6, SOL_ICMPV6 y otras opciones de conector de la forma SOL_* son variantes no portables de IPPROTO_*. Consulte ip(7).
Actualmente, la API IPv6 extendida, tal y como se describe en RFC 2292, sólo está parcialmente implementada; aunque el núcleo 2.2 soporta casi por completo las opciones de recepción, no existen macros en la glibc 2.1 para generar opciones IPv6.
No hay soporte IPSec para cabeceras EH y AH.
La gestión de las etiquetas de flujos no está completa y no se documenta aquí.
Esta página de manual no está completa.
RFC 2553: IPv6 BASIC API. Linux intenta amoldarse a esto. RFC 2460: especificación de IPv6.
La traducción al español de esta página del manual fue creada por Juan Piernas <piernas@ditec.um.es> y Marcos Fouces <marcos@debian.org>
Esta traducción es documentación libre; lea la GNU General Public License Version 3 o posterior con respecto a las condiciones de copyright. No existe NINGUNA RESPONSABILIDAD.
Si encuentra algún error en la traducción de esta página del manual, envíe un correo electrónico a debian-l10n-spanish@lists.debian.org.
5 Febrero 2023 | Páginas de manual de Linux 6.03 |