Received: by 2002:a05:6a10:eb17:0:0:0:0 with SMTP id hx23csp4007712pxb; Tue, 7 Sep 2021 12:27:54 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxIV5qh30eIAevKt2PC6CxV6Lqh5LMYoUrupL0D7TMCs5rBvTgBZzWR6FMDaZ0NR/5Okr+D X-Received: by 2002:a5d:9bd3:: with SMTP id d19mr6439289ion.202.1631042873956; Tue, 07 Sep 2021 12:27:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1631042873; cv=none; d=google.com; s=arc-20160816; b=hF1ehvj+qh2sirXHgzql20OZA1r+fTPQWbfr0j1LiQ53lhOtHQcN/kbnLPrz5T5S9s lsZ3EupJczFYUm1kLHXa5mH/T212ffBKiFXk3+noZBXGHglh9nv1taw2sd2tI+nKSTT+ WclNkWjES6GBe/NDcZzviwcVSS3BWSXuJke4JvP4ARnz8x1xQNEjIV+jPFo17o4KsI06 dLzZklIz++fN8hms+pT89dKoPXlr/SlRIZR2LtvgppPCHGLCxrK9WvRvDFvKC2/WyAZW 9yhR7TyfAuMTzOyw+HhoF9Ef0jAMNTCKDXHQtstAyw5gN6cg4gmKLlbEqX9tRmvYGIn+ CTcQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:subject:cc:to:from :dkim-signature; bh=7oSk+wKoZ3BVty3BFSJBJQY1G+ErQO7nO/DMMUu128M=; b=Wf+hUpxMEGEiQvUv6QW0LEZHhDdDD0IPKZ34gG+pZJPJatYra/FloV2JGPbE5TFrs3 SRGFzTEzpZR3ocalsxOF5yg1ZQWSY9iEj17t5yj6BuL1W3n+kucUj+1M15UdfV28Kzmm qn9h0PMVLgVAQ8C64Q0Gva8y1qOkbTk8GVixvvjSrFaT5wUV8/zYRn78jTqer/gOi2S5 DYo+VRsBPFHCQY5FgNZsrX7YBQXpEBYcpDWdyH8LAHKIswxccxdcitxlpqgUI4guLbIK wvAxHG0b2H9qu2bqF46tGx3CkhbTFb2nTUxJdjCLXGCUhhdVQMZ/6ELDjSd/w9wYMqyF bX7Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@quicinc.com header.s=qcdkim header.b=kM8Tpd0C; 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=quicinc.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id t195si12753735iof.69.2021.09.07.12.27.42; Tue, 07 Sep 2021 12:27:53 -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=@quicinc.com header.s=qcdkim header.b=kM8Tpd0C; 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=quicinc.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1344715AbhIGTCr (ORCPT + 99 others); Tue, 7 Sep 2021 15:02:47 -0400 Received: from alexa-out.qualcomm.com ([129.46.98.28]:65375 "EHLO alexa-out.qualcomm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230203AbhIGTCq (ORCPT ); Tue, 7 Sep 2021 15:02:46 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; i=@quicinc.com; q=dns/txt; s=qcdkim; t=1631041300; x=1662577300; h=from:to:cc:subject:date:message-id:mime-version; bh=7oSk+wKoZ3BVty3BFSJBJQY1G+ErQO7nO/DMMUu128M=; b=kM8Tpd0CrEDuI0glBMWu3eZ8LyIZwv8skKEjADmmJdGq8tbO9VNduoCo v0HpA82CsWFW3uUYRomv8UyenhCEc9AlTP/jEdcqQGAQmD7aH1RpLVBof wrAyO+kSCV/9jNvHifwx4diSpyjBb6UQe9vKTmMwrr537kjmFuUKKnJXf 0=; Received: from ironmsg-lv-alpha.qualcomm.com ([10.47.202.13]) by alexa-out.qualcomm.com with ESMTP; 07 Sep 2021 12:01:40 -0700 X-QCInternal: smtphost Received: from nalasex01a.na.qualcomm.com ([10.47.209.196]) by ironmsg-lv-alpha.qualcomm.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 07 Sep 2021 12:01:39 -0700 Received: from hu-subbaram-lv.qualcomm.com (10.49.16.6) by nalasex01a.na.qualcomm.com (10.47.209.196) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.922.7; Tue, 7 Sep 2021 12:01:39 -0700 From: Subbaraman Narayanamurthy To: Zhang Rui , Daniel Lezcano , Amit Kucheria CC: , , David Collins , Manaf Meethalavalappu Pallikunhi , Ram Chandrasekar , Subbaraman Narayanamurthy , Subject: [PATCH v2] thermal: Fix a NULL pointer dereference Date: Tue, 7 Sep 2021 12:01:29 -0700 Message-ID: <1631041289-11804-1-git-send-email-quic_subbaram@quicinc.com> X-Mailer: git-send-email 2.7.4 MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.49.16.6] X-ClientProxiedBy: nalasex01a.na.qualcomm.com (10.47.209.196) To nalasex01a.na.qualcomm.com (10.47.209.196) Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org of_parse_thermal_zones() parses the thermal-zones node and registers a thermal_zone device for each subnode. However, if a thermal zone is consuming a thermal sensor and that thermal sensor device hasn't probed yet, an attempt to set trip_point_*_temp for that thermal zone device can cause a NULL pointer dereference. Fix it. console:/sys/class/thermal/thermal_zone87 # echo 120000 > trip_point_0_temp ... Unable to handle kernel NULL pointer dereference at virtual address 0000000000000020 ... Call trace: of_thermal_set_trip_temp+0x40/0xc4 trip_point_temp_store+0xc0/0x1dc dev_attr_store+0x38/0x88 sysfs_kf_write+0x64/0xc0 kernfs_fop_write_iter+0x108/0x1d0 vfs_write+0x2f4/0x368 ksys_write+0x7c/0xec __arm64_sys_write+0x20/0x30 el0_svc_common.llvm.7279915941325364641+0xbc/0x1bc do_el0_svc+0x28/0xa0 el0_svc+0x14/0x24 el0_sync_handler+0x88/0xec el0_sync+0x1c0/0x200 While at it, fix the possible NULL pointer dereference in other functions as well: of_thermal_get_temp(), of_thermal_set_emul_temp(), of_thermal_get_trend(). Cc: stable@vger.kernel.org Suggested-by: David Collins Signed-off-by: Subbaraman Narayanamurthy --- Changes for v2: - Added checks in of_thermal_get_temp(), of_thermal_set_emul_temp(), of_thermal_get_trend(). drivers/thermal/thermal_of.c | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/drivers/thermal/thermal_of.c b/drivers/thermal/thermal_of.c index 6379f26..9233f7e 100644 --- a/drivers/thermal/thermal_of.c +++ b/drivers/thermal/thermal_of.c @@ -89,7 +89,7 @@ static int of_thermal_get_temp(struct thermal_zone_device *tz, { struct __thermal_zone *data = tz->devdata; - if (!data->ops->get_temp) + if (!data->ops || !data->ops->get_temp) return -EINVAL; return data->ops->get_temp(data->sensor_data, temp); @@ -186,6 +186,9 @@ static int of_thermal_set_emul_temp(struct thermal_zone_device *tz, { struct __thermal_zone *data = tz->devdata; + if (!data->ops || !data->ops->set_emul_temp) + return -EINVAL; + return data->ops->set_emul_temp(data->sensor_data, temp); } @@ -194,7 +197,7 @@ static int of_thermal_get_trend(struct thermal_zone_device *tz, int trip, { struct __thermal_zone *data = tz->devdata; - if (!data->ops->get_trend) + if (!data->ops || !data->ops->get_trend) return -EINVAL; return data->ops->get_trend(data->sensor_data, trip, trend); @@ -301,7 +304,7 @@ static int of_thermal_set_trip_temp(struct thermal_zone_device *tz, int trip, if (trip >= data->ntrips || trip < 0) return -EDOM; - if (data->ops->set_trip_temp) { + if (data->ops && data->ops->set_trip_temp) { int ret; ret = data->ops->set_trip_temp(data->sensor_data, trip, temp); -- 2.7.4