Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp4642667pxj; Wed, 12 May 2021 09:54:26 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwrGI8bboD9AVdCLJeDkQNB9k9WMdgftVJ7LJZRuyXtny5KCoGhVM0MrzWcQqVKfvKYcSJ/ X-Received: by 2002:a17:907:7848:: with SMTP id lb8mr16204488ejc.494.1620838466293; Wed, 12 May 2021 09:54:26 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620838466; cv=none; d=google.com; s=arc-20160816; b=j9OiZNKNwabRd+8R1byrgDUFWNZInIJvGiW4/DrzLLO1ZgDmbjfKixq00bdnu+JA1X qY1lkoMSCr4L2CWTW+ISzTuGo3qAtn2h9kcSef6sNT/WmtmlFt7NUsfe+31J7uvuo55Y CUyZ3WfQ2HZVNBhoyet2IywV1eRiImRTLoLc4A//js2rDn8BOPThvF1lXidfFV5eniH9 vQ5lobkppLaYiZe7JKxYpG4qY95ETOXTCReOXgm6S4hRH3zrlMFLXws/4wY/MWQvCm7U 5TAOseYBiretp+Z6vGto9iszI75fzeGqARiBqWXmUUrMXd+oFQxxp92Xfm5RyjNal0sN 5yOg== 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=Lv+suUJj3fgVX23QNPemZI04lq1nSDgRhBqafQPYktw=; b=M7R8IkuLu5HoTx0AEpBui/4zqAAPLqhNOaRu5nVOrkgBOaxBY2vGT4q3ldnSaHLRUV gEuuU6sXe8okcr04FzgjcmToZ3ffv+c6TS8j0ai5MuqiHcNMO50PPLFdsDcd/MuYnX19 GIq6CToog280kcTFjxjCmD7c/qK3k6mdRMe6m/tGj2cS/7yCiukLGvMeAZ+qfWEHFUyJ 5pQkFM7ux5K4r7QSdcJPp2PLEBV7sncW4trLCdITEFcoahuXRgYGzwdC8psOr+c5I3VY R3bAI8vxIf18TnQLV2R63mGTaqLwWE/bHXAexQZc2gQKGWmE/KdvZkg/ZVZ8OP5YNG7H WUhA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=HL29KqMe; 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 a14si152382edr.341.2021.05.12.09.53.58; Wed, 12 May 2021 09:54:26 -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=HL29KqMe; 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 S245001AbhELQvz (ORCPT + 99 others); Wed, 12 May 2021 12:51:55 -0400 Received: from mail.kernel.org ([198.145.29.99]:56044 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237464AbhELPue (ORCPT ); Wed, 12 May 2021 11:50:34 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id F0C9161430; Wed, 12 May 2021 15:25:51 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620833152; bh=9m/TwkgxOlj5FNTpbQ7MuMQxwO46mEjF4yQitXn0H+g=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=HL29KqMelvrbavoxXhXPuqd3iv06JRkbHYVbw38w4t77mbQcg1sH9TRLsNNfhBLv0 iYRjHCFAWvZThCbz8zt6ErixE7trkJ+pwKKV21SWSMhQ0CEWJBRsByMGv1yMeOoqxR iZIpurBoUi+BsPOY8dOAEwJQtfKt4TavFEaRqayw= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Annaliese McDermond Subject: [PATCH 5.11 039/601] sc16is7xx: Defer probe if device read fails Date: Wed, 12 May 2021 16:41:56 +0200 Message-Id: <20210512144829.110354915@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210512144827.811958675@linuxfoundation.org> References: <20210512144827.811958675@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: Annaliese McDermond commit 158e800e0fde91014812f5cdfb92ce812e3a33b4 upstream. A test was added to the probe function to ensure the device was actually connected and working before successfully completing a probe. If the device was actually there, but the I2C bus was not ready yet for whatever reason, the probe fails permanently. Change the probe so that we defer the probe on a regmap read failure so that we try the probe again when the dependent drivers are potentially loaded. This should not affect the case where the device truly isn't present because the probe will never successfully complete. Fixes: 2aa916e67db3 ("sc16is7xx: Read the LSR register for basic device presence check") Cc: stable@vger.kernel.org Signed-off-by: Annaliese McDermond Link: https://lore.kernel.org/r/010101787f9c3fd8-c1815c00-2d6b-4c85-a96a-a13e68597fda-000000@us-west-2.amazonses.com Signed-off-by: Greg Kroah-Hartman Signed-off-by: Greg Kroah-Hartman --- drivers/tty/serial/sc16is7xx.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) --- a/drivers/tty/serial/sc16is7xx.c +++ b/drivers/tty/serial/sc16is7xx.c @@ -1196,7 +1196,7 @@ static int sc16is7xx_probe(struct device ret = regmap_read(regmap, SC16IS7XX_LSR_REG << SC16IS7XX_REG_SHIFT, &val); if (ret < 0) - return ret; + return -EPROBE_DEFER; /* Alloc port structure */ s = devm_kzalloc(dev, struct_size(s, p, devtype->nr_uart), GFP_KERNEL);