Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp2718056pxv; Sun, 11 Jul 2021 23:41:57 -0700 (PDT) X-Google-Smtp-Source: ABdhPJztP77UMTGwct+tv2eX2SWGnjpLw6xbWF66LGRuOkuaqd0VmN+9FZhlprCaxGZoewlthLE8 X-Received: by 2002:a17:906:b301:: with SMTP id n1mr6559545ejz.271.1626072117208; Sun, 11 Jul 2021 23:41:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626072117; cv=none; d=google.com; s=arc-20160816; b=PijWwur+EfTsFKDsmbD4tNV49NBaKTcrtKqsOKlypz42QepeDUP1HmE6KfNNORc5Ii K7e0U5jmLu4QduxwRAI3fG71D6yYYDk6ggIMe89AjX2dvwDx0tyCWYRDz/Fni95R7011 kINqH6MsJo4YABqGopbs1v2wLu/IOI+Lyq8XtaQDiE5w+9mbBPL9zSnscTjPNmu2yn6t kXlo9f0Ui896dsTyjHou+j/YlY6/zo3aZxP0KZl5LEW4gGlfXeoKvG25ccmDKY4iBEvk mdzE96ZUzu6xGVU8I9qekwxhjA5NgJB/Uipa4C2b/g8gucb1GfJeBbxw+7tKMGvEtANz Y7BA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=+nyiUwZAf7NZ5N31dghp3Sh26tgnAzrTivGLKhwS08Y=; b=cBXuYw0fZTfS+uhzspToTYePYrCZz1yy/O17Rc7WpM0mI/uhY9RtNs6Wz1Vvrd1ymz WKtvvSoXVB7HJn69vHuGwKm6NQheqNX9CPUoi+v/jn97IUZXgvmN7vDjomv2eVbpY9pv ae0dCy9QHD8V4b6EOFKYRqZpn3UwyDN5mDDHbETVp08l219tQ9I5Ie7V2pv1jvrlji9n hbZw/I8oqnkxrCIa8opL5yb5ZI/SvI9dD4lJizlV8sP2jKsLxGUrActTeqcbwQZXbduS HQbrMJ1n4wXUe4GTKHN8hGgMWucVi1jHHOnjdjAbkwX4odGrlo6t+r/98/yY7p6jgsQq L4Aw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="gomcs/lG"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y7si16326871eds.311.2021.07.11.23.41.35; Sun, 11 Jul 2021 23:41:57 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="gomcs/lG"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236807AbhGLGk4 (ORCPT + 99 others); Mon, 12 Jul 2021 02:40:56 -0400 Received: from mail.kernel.org ([198.145.29.99]:55268 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236963AbhGLGcO (ORCPT ); Mon, 12 Jul 2021 02:32:14 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id D591660FD8; Mon, 12 Jul 2021 06:29:25 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626071366; bh=nucrAFs0kQP9IRBcjH0nakZVfYgdC/gs8SR+BZz4lzw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=gomcs/lGkMB5VuazJO5s0Sf8wMWIC9sUBbHI7Mgby8OAKrA8K1bbtzFHsv8EWWnc+ M0vKEaBVgxyy3nwsQS7ROvOuXdN/5Vjy86pasPKqIbFn3Pr0s2SBxCjiCPtw3L+I2x brbT2IAbVOK9L1EKKjhGqjvdkfKKbwVTR+kgzf/I= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Mathias Nyman , Vinod Koul , Moritz Fischer Subject: [PATCH 5.10 022/593] usb: renesas-xhci: Fix handling of unknown ROM state Date: Mon, 12 Jul 2021 08:03:02 +0200 Message-Id: <20210712060845.644006882@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210712060843.180606720@linuxfoundation.org> References: <20210712060843.180606720@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Moritz Fischer commit d143825baf15f204dac60acdf95e428182aa3374 upstream. The ROM load sometimes seems to return an unknown status (RENESAS_ROM_STATUS_NO_RESULT) instead of success / fail. If the ROM load indeed failed this leads to failures when trying to communicate with the controller later on. Attempt to load firmware using RAM load in those cases. Fixes: 2478be82de44 ("usb: renesas-xhci: Add ROM loader for uPD720201") Cc: stable@vger.kernel.org Cc: Mathias Nyman Cc: Greg Kroah-Hartman Cc: Vinod Koul Tested-by: Vinod Koul Reviewed-by: Vinod Koul Signed-off-by: Moritz Fischer Link: https://lore.kernel.org/r/20210615153758.253572-1-mdf@kernel.org Signed-off-by: Greg Kroah-Hartman --- drivers/usb/host/xhci-pci-renesas.c | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) --- a/drivers/usb/host/xhci-pci-renesas.c +++ b/drivers/usb/host/xhci-pci-renesas.c @@ -207,7 +207,8 @@ static int renesas_check_rom_state(struc return 0; case RENESAS_ROM_STATUS_NO_RESULT: /* No result yet */ - return 0; + dev_dbg(&pdev->dev, "Unknown ROM status ...\n"); + break; case RENESAS_ROM_STATUS_ERROR: /* Error State */ default: /* All other states are marked as "Reserved states" */ @@ -224,13 +225,12 @@ static int renesas_fw_check_running(stru u8 fw_state; int err; - /* Check if device has ROM and loaded, if so skip everything */ - err = renesas_check_rom(pdev); - if (err) { /* we have rom */ - err = renesas_check_rom_state(pdev); - if (!err) - return err; - } + /* + * Only if device has ROM and loaded FW we can skip loading and + * return success. Otherwise (even unknown state), attempt to load FW. + */ + if (renesas_check_rom(pdev) && !renesas_check_rom_state(pdev)) + return 0; /* * Test if the device is actually needing the firmware. As most