]> git.ipfire.org Git - thirdparty/kernel/linux.git/commit
xfrm: xfrm_alloc_spi shouldn't use 0 as SPI
authorSabrina Dubroca <sd@queasysnail.net>
Fri, 29 Aug 2025 08:54:15 +0000 (10:54 +0200)
committerSteffen Klassert <steffen.klassert@secunet.com>
Mon, 1 Sep 2025 06:56:00 +0000 (08:56 +0200)
commitcd8ae32e4e4652db55bce6b9c79267d8946765a9
treeee9c6987d18162240b70a9990f8ece2def69ef8c
parent52565a935213cd6a8662ddb8efe5b4219343a25d
xfrm: xfrm_alloc_spi shouldn't use 0 as SPI

x->id.spi == 0 means "no SPI assigned", but since commit
94f39804d891 ("xfrm: Duplicate SPI Handling"), we now create states
and add them to the byspi list with this value.

__xfrm_state_delete doesn't remove those states from the byspi list,
since they shouldn't be there, and this shows up as a UAF the next
time we go through the byspi list.

Reported-by: syzbot+a25ee9d20d31e483ba7b@syzkaller.appspotmail.com
Closes: https://syzkaller.appspot.com/bug?extid=a25ee9d20d31e483ba7b
Fixes: 94f39804d891 ("xfrm: Duplicate SPI Handling")
Signed-off-by: Sabrina Dubroca <sd@queasysnail.net>
Reviewed-by: Simon Horman <horms@kernel.org>
Signed-off-by: Steffen Klassert <steffen.klassert@secunet.com>
net/xfrm/xfrm_state.c