CVE-2026-23125
Gravedad:
Pendiente de análisis
Tipo:
No Disponible / Otro tipo
Fecha de publicación:
14/02/2026
Última modificación:
18/02/2026
Descripción
En el kernel de Linux, la siguiente vulnerabilidad ha sido resuelta:<br />
<br />
sctp: mover SCTP_CMD_ASSOC_SHKEY justo después de SCTP_CMD_PEER_INIT<br />
<br />
Se informó de una desreferencia de puntero nulo (null-ptr-deref) en la ruta de transmisión SCTP cuando falla la inicialización de la clave SCTP-AUTH:<br />
<br />
==================================================================<br />
KASAN: null-ptr-deref in range [0x0000000000000018-0x000000000000001f]<br />
CPU: 0 PID: 16 Comm: ksoftirqd/0 Tainted: G W 6.6.0 #2<br />
RIP: 0010:sctp_packet_bundle_auth net/sctp/output.c:264 [inline]<br />
RIP: 0010:sctp_packet_append_chunk+0xb36/0x1260 net/sctp/output.c:401<br />
Call Trace:<br />
<br />
sctp_packet_transmit_chunk+0x31/0x250 net/sctp/output.c:189<br />
sctp_outq_flush_data+0xa29/0x26d0 net/sctp/outqueue.c:1111<br />
sctp_outq_flush+0xc80/0x1240 net/sctp/outqueue.c:1217<br />
sctp_cmd_interpreter.isra.0+0x19a5/0x62c0 net/sctp/sm_sideeffect.c:1787<br />
sctp_side_effects net/sctp/sm_sideeffect.c:1198 [inline]<br />
sctp_do_sm+0x1a3/0x670 net/sctp/sm_sideeffect.c:1169<br />
sctp_assoc_bh_rcv+0x33e/0x640 net/sctp/associola.c:1052<br />
sctp_inq_push+0x1dd/0x280 net/sctp/inqueue.c:88<br />
sctp_rcv+0x11ae/0x3100 net/sctp/input.c:243<br />
sctp6_rcv+0x3d/0x60 net/sctp/ipv6.c:1127<br />
<br />
El problema se activa cuando sctp_auth_asoc_init_active_key() falla en sctp_sf_do_5_1C_ack() mientras se procesa un INIT_ACK. En este caso, la secuencia de comandos es actualmente:<br />
<br />
- SCTP_CMD_PEER_INIT<br />
- SCTP_CMD_TIMER_STOP (T1_INIT)<br />
- SCTP_CMD_TIMER_START (T1_COOKIE)<br />
- SCTP_CMD_NEW_STATE (COOKIE_ECHOED)<br />
- SCTP_CMD_ASSOC_SHKEY<br />
- SCTP_CMD_GEN_COOKIE_ECHO<br />
<br />
Si SCTP_CMD_ASSOC_SHKEY falla, asoc-&gt;shkey permanece NULL, mientras que asoc-&gt;peer.auth_capable y asoc-&gt;peer.peer_chunks ya han sido establecidos por SCTP_CMD_PEER_INIT. Esto permite que un fragmento DATA con auth = 1 y shkey = NULL sea encolado por sctp_datamsg_from_user().<br />
<br />
Dado que la interpretación de comandos se detiene en caso de fallo, no debería haberse enviado ningún COOKIE_ECHO a través de SCTP_CMD_GEN_COOKIE_ECHO. Sin embargo, el temporizador T1_COOKIE ya se ha iniciado, y puede encolar un COOKIE_ECHO en la cola de salida (outqueue) más tarde. Como resultado, el fragmento DATA puede transmitirse junto con el COOKIE_ECHO en sctp_outq_flush_data(), lo que lleva al problema observado.<br />
<br />
De forma similar a otros lugares donde llama a sctp_auth_asoc_init_active_key() justo después de sctp_process_init(), este parche mueve el SCTP_CMD_ASSOC_SHKEY inmediatamente después de SCTP_CMD_PEER_INIT, antes de detener T1_INIT e iniciar T1_COOKIE. Esto asegura que si la generación de clave compartida falla, los datos autenticados (authenticated DATA) no puedan ser enviados. También permite que el temporizador T1_INIT retransmita INIT, dando al cliente otra oportunidad de procesar INIT_ACK y reintentar la configuración de la clave.
Impacto
Referencias a soluciones, herramientas e información
- https://git.kernel.org/stable/c/0c4adb1f391a7b92a0405e9d7c05624c0d9f8a65
- https://git.kernel.org/stable/c/5a309bedf02ee08b0653215f06c94d61ec7a214a
- https://git.kernel.org/stable/c/784428ab1889eb185a1459e9d6bc52df33d572ef
- https://git.kernel.org/stable/c/a80c9d945aef55b23b54838334345f20251dad83
- https://git.kernel.org/stable/c/bf2b543b3cc4ebb4ab5bca4f8dfa5612035d45b8
- https://git.kernel.org/stable/c/e7e81abbcc5620c9532080538f9709a6ea382855
- https://git.kernel.org/stable/c/e94294798548e8cfbd80869e1d2f97efce92582c



