Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp4645083ybl; Wed, 22 Jan 2020 01:57:52 -0800 (PST) X-Google-Smtp-Source: APXvYqy9M/YaxxfVGsqyzhzcZl4Z4/zAf3kdP/4CoCuCf1O0bemvlzOdyeKuBYGkr7nFcFrL6Mmo X-Received: by 2002:a05:6830:c2:: with SMTP id x2mr4303723oto.8.1579687072556; Wed, 22 Jan 2020 01:57:52 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1579687072; cv=none; d=google.com; s=arc-20160816; b=wlUKSRK1gfgroIln2ypnRwFccmAHmog4+/hd3u+8j0i3O345jV8qNWGLMY8HFS6H5/ zcfBc/qwaLyYMDABz67cLdhUqzsM/mIqHRZ56p3bFZJkatIoYB2tDkKmfVw02BLi2cAw yUEJk2zh32buOzaSyYkyLTZb7VOgM5bVQV4Ml+OcNs28p27BbKssur6/R6hgWxGFPYNa 2dbUwoo3FtZo1UxRxthF8xoCaVQKFD5dg+W1p+6/cDxHMPg9unZrdlqiUnMSMvXZ6oU4 G/3nGKbWdEAf7vp524F2I6WV0Q8YggKnN9WKpvQOp+uETQCWc5g0mQztDcy6c4mJHEs0 P6xQ== 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=WNB155t67NPuXDMdBtyiFBA9d7PfwqmJDjqJeHQTv74=; b=ljwxc4D9U4e/EO31bQna+Oz06bAmKQZgORnTeD+BLvEb3MAQkuVhaphhPCdlahz7Cq niLsRCR31AiwsZG8NpHHsPpi+PIO3VYGIpmlKFs7FFEAsfbarN/qRrn3vRrrb2DNoX9+ 0sVD6N92xGHr40lC6sMPHKN4bfqWBjhI8Vq/J4V16xYJnWYe6Y4oCZxlmWsAop4Ut7+2 jQtzF9HEvHasa3pSZenZwtMibqKFdG309oLU9+qWpFwvQtuxPR8iGBf8LMpSexNYZ4Te R74OzIZdfqA9VjTFyIGjXFl+Lsx/jUSfigfHGXsnNNVRMueK/V8cnjlZYi1Rd78YEgmD OZLQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="yh/hWh7T"; 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 l20si20478116oil.224.2020.01.22.01.57.41; Wed, 22 Jan 2020 01:57:52 -0800 (PST) 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="yh/hWh7T"; 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 S1729635AbgAVJ4u (ORCPT + 99 others); Wed, 22 Jan 2020 04:56:50 -0500 Received: from mail.kernel.org ([198.145.29.99]:44368 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729903AbgAVJbz (ORCPT ); Wed, 22 Jan 2020 04:31:55 -0500 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 E06D124673; Wed, 22 Jan 2020 09:31:54 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1579685515; bh=lFrp2fT6oAwU0C505gdh33LnzaHuMVacMPBXsfkRemY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=yh/hWh7TK5NYf+qQeqasmNwDzcgmcHF2UFDwp20ki1dhaPmmERLz5MGCHGroxFwti v8q+WaVQ1xYFEEO0Hvp/TDVSFc+1E5ShuPQfSAbyq8iT+/Xc6cbs+gPymzVCSNAx2k tr1djPCaxsy8l+k4Onppla0fNp+O7LJEZqHke/Kg= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Johan Hovold Subject: [PATCH 4.4 46/76] USB: serial: ch341: handle unbound port at reset_resume Date: Wed, 22 Jan 2020 10:29:02 +0100 Message-Id: <20200122092757.494045423@linuxfoundation.org> X-Mailer: git-send-email 2.25.0 In-Reply-To: <20200122092751.587775548@linuxfoundation.org> References: <20200122092751.587775548@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: Johan Hovold commit 4d5ef53f75c22d28f490bcc5c771fcc610a9afa4 upstream. Check for NULL port data in reset_resume() to avoid dereferencing a NULL pointer in case the port device isn't bound to a driver (e.g. after a failed control request at port probe). Fixes: 1ded7ea47b88 ("USB: ch341 serial: fix port number changed after resume") Cc: stable # 2.6.30 Reviewed-by: Greg Kroah-Hartman Signed-off-by: Johan Hovold Signed-off-by: Greg Kroah-Hartman --- drivers/usb/serial/ch341.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) --- a/drivers/usb/serial/ch341.c +++ b/drivers/usb/serial/ch341.c @@ -555,9 +555,13 @@ static int ch341_tiocmget(struct tty_str static int ch341_reset_resume(struct usb_serial *serial) { struct usb_serial_port *port = serial->port[0]; - struct ch341_private *priv = usb_get_serial_port_data(port); + struct ch341_private *priv; int ret; + priv = usb_get_serial_port_data(port); + if (!priv) + return 0; + /* reconfigure ch341 serial port after bus-reset */ ch341_configure(serial->dev, priv);