Received: by 2002:a5b:505:0:0:0:0:0 with SMTP id o5csp3370045ybp; Sun, 6 Oct 2019 10:26:34 -0700 (PDT) X-Google-Smtp-Source: APXvYqxF/fEG2h82bG7rhdfO9EjjDGCDkcBNbyd+qVcs0v50R7NkmAk+c1tV733pU3T6KsGtOLHV X-Received: by 2002:a05:6402:a4b:: with SMTP id bt11mr25037570edb.175.1570382793916; Sun, 06 Oct 2019 10:26:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1570382793; cv=none; d=google.com; s=arc-20160816; b=WvhtEbhQ3sNwHJ+R7l32tf0tW5ev53MT4VlWFu1cYavn1hK5BmZm/iKCQkRaXrh64W h/F5q28EfLDFMRTDl+UsDO0DvA/Z7tRlU8ZQjA4W8xm3sJccvhYtx/+7Ut/nzddwvVek AEUYVxOG/P8rhxQjG2sUAUhUHYNny6Jn4kq35A9x6lUlp0WTpkfIFWnHhOHEQcivbU1K EsRTh8cKFNC5wt+6OEJKpeiBjSw6CPRX8hVA4yq5go2IByPAx73IcwgAwiQHhQUtPJ59 5a+Z9XZyuhHqTTYo0HxWxroRoZjTHpbpPJfab7tgg5Y4lfg6a0F8n7ug0lOyZ6ktQeZK dT7Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=ckTynO65JkXfO8oxmVotIaxdpR0hICRUWYC+Es+k+VU=; b=Vhbj+v914B4Zj4RYSsPRpDTchOoUHCUoQDoL/91BUdQn4zWQOOLu/ZRzx2ot6MKTak 1SoY6X1mFWMcnXHghEtANJ4/yBINleJ1v7xf4SerWyZNzF39EgpCH0tAyi5qVIrWqSdu syhburTcaNsNJEp4opWtkzEU+7uZF1CzqRLoYpxZus6NnDQHJ4XxYC1w6X7FTkHJilKL 6qEyAUvh8ECNL5XFPTRsmm0jiFSkufMktC6tVl0b/ekheHzMKuogaXZcSGgvvm6CGU/4 EjqeQXLhlxR/re8qrGLV4AdcwmEGQxUFZ3mTunEyNwrju44uKMdcG8w40hpKjMCatA35 77Vw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=jxBBRi6e; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id n19si5787043ejk.264.2019.10.06.10.26.10; Sun, 06 Oct 2019 10:26:33 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=jxBBRi6e; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727941AbfJFRYi (ORCPT + 99 others); Sun, 6 Oct 2019 13:24:38 -0400 Received: from mail.kernel.org ([198.145.29.99]:49578 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727935AbfJFRYg (ORCPT ); Sun, 6 Oct 2019 13:24:36 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 52B2D2087E; Sun, 6 Oct 2019 17:24:35 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1570382675; bh=Oqfmo4XaG8wZDKY/gBAMCLXD+TvETva4MCUu/fq0kXo=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=jxBBRi6e6trZcQYG9Z61FvOwSnJZNPW14z+/Divnf8azgrgbH0obnpYzsYryOcRvM SDj643m0YlPcoXmaHFDb0ztmAP+2LrQQAXo9qxK/3JfPMES7SuDl3nDbXHmA15ySQh pT1z6bdu0BT/yIMYN8vzfdGWlS6P53EjlCx0NYng= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Andrey Konovalov , Andy Shevchenko , "David S. Miller" Subject: [PATCH 4.9 47/47] NFC: fix attrs checks in netlink interface Date: Sun, 6 Oct 2019 19:21:34 +0200 Message-Id: <20191006172019.364029870@linuxfoundation.org> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20191006172016.873463083@linuxfoundation.org> References: <20191006172016.873463083@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Andrey Konovalov commit 18917d51472fe3b126a3a8f756c6b18085eb8130 upstream. nfc_genl_deactivate_target() relies on the NFC_ATTR_TARGET_INDEX attribute being present, but doesn't check whether it is actually provided by the user. Same goes for nfc_genl_fw_download() and NFC_ATTR_FIRMWARE_NAME. This patch adds appropriate checks. Found with syzkaller. Signed-off-by: Andrey Konovalov Signed-off-by: Andy Shevchenko Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- net/nfc/netlink.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) --- a/net/nfc/netlink.c +++ b/net/nfc/netlink.c @@ -973,7 +973,8 @@ static int nfc_genl_dep_link_down(struct int rc; u32 idx; - if (!info->attrs[NFC_ATTR_DEVICE_INDEX]) + if (!info->attrs[NFC_ATTR_DEVICE_INDEX] || + !info->attrs[NFC_ATTR_TARGET_INDEX]) return -EINVAL; idx = nla_get_u32(info->attrs[NFC_ATTR_DEVICE_INDEX]); @@ -1022,7 +1023,8 @@ static int nfc_genl_llc_get_params(struc struct sk_buff *msg = NULL; u32 idx; - if (!info->attrs[NFC_ATTR_DEVICE_INDEX]) + if (!info->attrs[NFC_ATTR_DEVICE_INDEX] || + !info->attrs[NFC_ATTR_FIRMWARE_NAME]) return -EINVAL; idx = nla_get_u32(info->attrs[NFC_ATTR_DEVICE_INDEX]);