Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp3887843pxv; Mon, 19 Jul 2021 11:09:56 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyXQjvARluCXK6H0HNjOq9TLXVVryJFeXaepNqZ6exDAliasJrzdq4Osizt1KTVT7ltXviN X-Received: by 2002:a02:9648:: with SMTP id c66mr23408735jai.73.1626718196517; Mon, 19 Jul 2021 11:09:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626718196; cv=none; d=google.com; s=arc-20160816; b=Ynx+e/VCAB9qPvoXsyi57nx8t2NcBHFjGd34517kKPy1rLV1NOo6He/iJEo5MQicn+ ElTCQuJkU5ygFXDrqjQ+1CCyhrzS7Ld4z0h6lGaHhKBu/xSoWH8il06Y4aTdLZvLOlG1 nt/B4AlrPq1C/KpE9k68XvCzx6bAbcc8+UNozhJ6/hMfICv03XY/JfKModJMZ5gjS3nv U+OttW4LYCCd84aalyEnExXfjHxiiQnSykvbiPLyhCTU6THquGENaTQgYaDmYU1hwc7A NxZSCfR8uAocICs6NpTfoL1rYAK1BMUpuIPzaYLhsIwzYTwM3tenO/sAEgLg80NAvTbE vrmg== 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=qdD0B0JQBhFsObk6PIR4DBJjqj2UsWrTBnbFmQBORvc=; b=t9jAjwMAYhYSD5nb96og/W6ojf6iHUmfLKIIs7LLPTqGxhwM54qq2KxiTziBNQFYTv GjOttQrjcIORqa+Jw9qrQd72F31+mL3+4OdvMA2aqjRwFS6lda2bHppSUnQs33MrjtAw 9OlYdSAu4JfJ5AhMRKaO8wVC/bNmpmaDWOuWpeGyT8cyBE5xr0QtOQpvkAytcsQmOGNt 6eG96PA8gD0Vbc9/STH6/c6FpxEdK1sAda8l+WhDNYy+KjuRfEKFS3GGF10HmVmjgZ55 3baj7WfnN9gQmFuGt5P9DtKRWlzWlJ/X6DjryIZhpxwSxW8pIah02dm6h9DneAvrwdUY 8PVA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="k1Pg/QvC"; 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 p29si20800332jal.22.2021.07.19.11.09.44; Mon, 19 Jul 2021 11:09:56 -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="k1Pg/QvC"; 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 S1352537AbhGSRXL (ORCPT + 99 others); Mon, 19 Jul 2021 13:23:11 -0400 Received: from mail.kernel.org ([198.145.29.99]:44952 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1348905AbhGSPoe (ORCPT ); Mon, 19 Jul 2021 11:44:34 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 2158F6147E; Mon, 19 Jul 2021 16:23:17 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626711798; bh=R1dpeNmez9kyz+gPVJGnZ0wHDc64/TzsvL3fYSbC0nY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=k1Pg/QvCzhdNpdOQ5pibk5aqZ8ZT8bdaVcm4PRlsc5UjsXtTQTLkxEjI06cYleu3L ioq7+3B0+4uCdNbIkafra1hnpDQclZNWe45AtZMP2hh1p28S7yPVRww6MSH8K1go/j U69GfYzJosGSOOYhyEUDNvgB3obhPbNaqZwvQH4k= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Linus Walleij , Sebastian Reichel , Sasha Levin Subject: [PATCH 5.12 136/292] power: supply: ab8500: Avoid NULL pointers Date: Mon, 19 Jul 2021 16:53:18 +0200 Message-Id: <20210719144946.956138103@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210719144942.514164272@linuxfoundation.org> References: <20210719144942.514164272@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: Linus Walleij [ Upstream commit 5bcb5087c9dd3dca1ff0ebd8002c5313c9332b56 ] Sometimes the code will crash because we haven't enabled AC or USB charging and thus not created the corresponding psy device. Fix it by checking that it is there before notifying. Signed-off-by: Linus Walleij Signed-off-by: Sebastian Reichel Signed-off-by: Sasha Levin --- drivers/power/supply/ab8500_charger.c | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/drivers/power/supply/ab8500_charger.c b/drivers/power/supply/ab8500_charger.c index ac77c8882d17..893185448284 100644 --- a/drivers/power/supply/ab8500_charger.c +++ b/drivers/power/supply/ab8500_charger.c @@ -413,6 +413,14 @@ disable_otp: static void ab8500_power_supply_changed(struct ab8500_charger *di, struct power_supply *psy) { + /* + * This happens if we get notifications or interrupts and + * the platform has been configured not to support one or + * other type of charging. + */ + if (!psy) + return; + if (di->autopower_cfg) { if (!di->usb.charger_connected && !di->ac.charger_connected && @@ -439,7 +447,15 @@ static void ab8500_charger_set_usb_connected(struct ab8500_charger *di, if (!connected) di->flags.vbus_drop_end = false; - sysfs_notify(&di->usb_chg.psy->dev.kobj, NULL, "present"); + /* + * Sometimes the platform is configured not to support + * USB charging and no psy has been created, but we still + * will get these notifications. + */ + if (di->usb_chg.psy) { + sysfs_notify(&di->usb_chg.psy->dev.kobj, NULL, + "present"); + } if (connected) { mutex_lock(&di->charger_attached_mutex); -- 2.30.2