From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755303AbdDLUIY (ORCPT ); Wed, 12 Apr 2017 16:08:24 -0400 Received: from mail-wm0-f45.google.com ([74.125.82.45]:38767 "EHLO mail-wm0-f45.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751620AbdDLUIV (ORCPT ); Wed, 12 Apr 2017 16:08:21 -0400 MIME-Version: 1.0 In-Reply-To: References: From: Cong Wang Date: Wed, 12 Apr 2017 13:07:59 -0700 Message-ID: Subject: Re: net/ipv4: use-after-free in ipv4_datagram_support_cmsg To: Willem de Bruijn Cc: Andrey Konovalov , "David S. Miller" , Alexey Kuznetsov , James Morris , Hideaki YOSHIFUJI , Patrick McHardy , netdev , LKML , Eric Dumazet , Dmitry Vyukov , Kostya Serebryany , syzkaller Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Apr 12, 2017 at 8:39 AM, Willem de Bruijn wrote: > =================== >> BUG: KASAN: use-after-free in ipv4_datagram_support_cmsg >> net/ipv4/ip_sockglue.c:500 [inline] at addr ffff880059be0128 > > Thanks for the report. This is accessing skb->dev from within recvmsg() at line > > info->ipi_ifindex = skb->dev->ifindex; > > Introduced in 829ae9d61165 ("net-timestamp: allow reading recv cmsg on > errqueue with origin tstamp"). At this time the device may indeed have > gone away. I'm having a look at a way to read this in the receive BH > and store the ifindex. Why not use skb_iif? diff --git a/net/ipv4/ip_sockglue.c b/net/ipv4/ip_sockglue.c index ebd953b..a2aef45 100644 --- a/net/ipv4/ip_sockglue.c +++ b/net/ipv4/ip_sockglue.c @@ -497,7 +497,7 @@ static bool ipv4_datagram_support_cmsg(const struct sock *sk, info = PKTINFO_SKB_CB(skb); info->ipi_spec_dst.s_addr = ip_hdr(skb)->saddr; - info->ipi_ifindex = skb->dev->ifindex; + info->ipi_ifindex = skb->skb_iif; return true; }