Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp2767235pxv; Mon, 12 Jul 2021 01:09:49 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwn9qpuRUBe8LMdZoUEw2WQGEdlH47MHPCeUA/rlWQodWB4/TC7WdKii7EaxR7J8dqMrfyG X-Received: by 2002:a05:6402:268f:: with SMTP id w15mr47636414edd.206.1626077389096; Mon, 12 Jul 2021 01:09:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626077389; cv=none; d=google.com; s=arc-20160816; b=zYaTIBLQq8EjhBoXN8cyV++G9qqoPsDbUOSboNUrSpgDL6rx3k3+PXVAelV09+yu2B o7pXVuqdM6lJ1bJ3sTE8YYfFEN+WytVWDgOlLFIixNRuM0kOFByZneR+YHPjFUp+H+AO 3UMWWdvZW1WbXKZGzDkFzujMT7KyJ2QW13Uo+S4NNhJ46lz1K08fDad7kCT35HwGgxlG PysVoV93HqG9fUT6j6Nfo/JubTaIfhrHXPJbyzYOfjyaskrUtxpZZYzZ/cNwrK5wvseJ Z05w6NO7eyKBX0M4V9Jr4Q7pP8tdLZagrrB0ifdDlEd8zg0/bzdAp/p5Qh3d3RYd1SDP pZjg== 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=cuI4v9EhJG42de9dzP+Ph2UUXdP+RgSGLkPhdA9to2PaK6yXjcYeU6ODRoTbjpGrG3 BNvUZqxC/MNG80O6L2MLsGb+f3L+rqej9lAhk8XG2uUrqQ1EBun1h21/Yan4vZM1PpJq jdINP8vvnWVOb/zTG70AIX9xgoccMWTajpxtz0LYNLlicEoeK0BxwNXYnCQC1rZ7XwI8 sQznG9CHt7x2ddqhkhh/waqlIdhiyqq/dGN1i9gQaNKnMURXx9dmO8DA7+/dIW6SevQ6 7Z7wxf6zzcTYKyxN1KKDhfCNdNm11vNHJGuY4D7Nt4drv0oM+ze4eq8QeLS3mgbQBBZh 9BXQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=JN5razPS; 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 g8si18239054eds.273.2021.07.12.01.09.26; Mon, 12 Jul 2021 01:09:49 -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=JN5razPS; 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 S230413AbhGLIKq (ORCPT + 99 others); Mon, 12 Jul 2021 04:10:46 -0400 Received: from mail.kernel.org ([198.145.29.99]:47742 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1346213AbhGLHaj (ORCPT ); Mon, 12 Jul 2021 03:30:39 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id A509F60230; Mon, 12 Jul 2021 07:27:49 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626074870; bh=nucrAFs0kQP9IRBcjH0nakZVfYgdC/gs8SR+BZz4lzw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=JN5razPSlh2SQCsWVi07zkqj3YkAbqImNV6sxPgTVeMoR3nogdAG9bD3h0S+q6OV3 M5E8ivok053v+amXFDUmTNPTRcDy6Wav8rk/yLpYWeErs67Z0QtYNbWSzbVrq51AlA YzVGWOZlZM4r3en7TmvnLccE05JoBlrbElx4UWow= 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.13 024/800] usb: renesas-xhci: Fix handling of unknown ROM state Date: Mon, 12 Jul 2021 08:00:47 +0200 Message-Id: <20210712060916.499546891@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210712060912.995381202@linuxfoundation.org> References: <20210712060912.995381202@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