From patchwork Mon Jan 12 15:37:45 2015 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Krzysztof Kozlowski X-Patchwork-Id: 5611021 Return-Path: X-Original-To: patchwork-linux-samsung-soc@patchwork.kernel.org Delivered-To: patchwork-parsemail@patchwork2.web.kernel.org Received: from mail.kernel.org (mail.kernel.org [198.145.29.136]) by patchwork2.web.kernel.org (Postfix) with ESMTP id 7F0A3C058D for ; Mon, 12 Jan 2015 15:38:35 +0000 (UTC) Received: from mail.kernel.org (localhost [127.0.0.1]) by mail.kernel.org (Postfix) with ESMTP id B9AE3203DC for ; Mon, 12 Jan 2015 15:38:33 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id 7AA6E203B0 for ; Mon, 12 Jan 2015 15:38:31 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752277AbbALPiL (ORCPT ); Mon, 12 Jan 2015 10:38:11 -0500 Received: from mailout1.w1.samsung.com ([210.118.77.11]:52835 "EHLO mailout1.w1.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751159AbbALPiI (ORCPT ); Mon, 12 Jan 2015 10:38:08 -0500 Received: from eucpsbgm1.samsung.com (unknown [203.254.199.244]) by mailout1.w1.samsung.com (Oracle Communications Messaging Server 7u4-24.01(7.0.4.24.0) 64bit (built Nov 17 2011)) with ESMTP id <0NI200GUMMAD4F00@mailout1.w1.samsung.com>; Mon, 12 Jan 2015 15:42:13 +0000 (GMT) X-AuditID: cbfec7f4-b7f126d000001e9a-99-54b3ea5dfe68 Received: from eusync4.samsung.com ( [203.254.199.214]) by eucpsbgm1.samsung.com (EUCPMTA) with SMTP id DE.02.07834.D5AE3B45; Mon, 12 Jan 2015 15:38:05 +0000 (GMT) Received: from AMDC1943.digital.local ([106.116.151.171]) by eusync4.samsung.com (Oracle Communications Messaging Server 7u4-24.01(7.0.4.24.0) 64bit (built Nov 17 2011)) with ESMTPA id <0NI2004U8M3EE0A0@eusync4.samsung.com>; Mon, 12 Jan 2015 15:38:05 +0000 (GMT) From: Krzysztof Kozlowski To: Russell King , Kukjin Kim , linux-arm-kernel@lists.infradead.org, linux-samsung-soc@vger.kernel.org, linux-kernel@vger.kernel.org Cc: Krzysztof Kozlowski Subject: [PATCH] ARM: EXYNOS: Handle of of_iomap() failure Date: Mon, 12 Jan 2015 16:37:45 +0100 Message-id: <1421077065-30175-1-git-send-email-k.kozlowski@samsung.com> X-Mailer: git-send-email 1.9.1 X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFrrOJMWRmVeSWpSXmKPExsVy+t/xa7qxrzaHGJzcLW/x+oWhRf/j18wW mx5fY7W4vGsOm8WM8/uYLG5f5nVg82hp7mHz2LSqk81j85J6j74tqxg9Pm+SC2CN4rJJSc3J LEst0rdL4Mr48Woza0EDe8Xrbz+ZGhhfs3YxcnJICJhITDvczw5hi0lcuLeerYuRi0NIYCmj xNJNVxkhnD4miTNbX4JVsQkYS2xevgSsSkRgM6NEf+NusFHMAoYSP9/9ASsSFrCS2Hh8ATOI zSKgKrH12hQWEJtXwF1i18wtzBDr5CROHpvMOoGRewEjwypG0dTS5ILipPRcQ73ixNzi0rx0 veT83E2MkMD4soNx8TGrQ4wCHIxKPLwTZDaHCLEmlhVX5h5ilOBgVhLhdS0DCvGmJFZWpRbl xxeV5qQWH2Jk4uCUamDMbAgJviv/10yIS23ZJet5Dqm7fFZeubpaxSGyLzx3lsTMHUsVpuom lr2ocy4TV9l/ScJn2tn+xKML61btll4gvWJ/S85Zu1nmJova0o7IJPmEMfVfmrfxtYfpD9bJ AbNMK+5mfv9ftb9J7k7dV78Fbzh6dovFTNG6FnXp+fr7xZX2Oo+Mza4osRRnJBpqMRcVJwIA pyPKO+oBAAA= Sender: linux-samsung-soc-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-samsung-soc@vger.kernel.org X-Spam-Status: No, score=-6.9 required=5.0 tests=BAYES_00, RCVD_IN_DNSWL_HI, T_RP_MATCHES_RCVD, UNPARSEABLE_RELAY autolearn=unavailable version=3.3.1 X-Spam-Checker-Version: SpamAssassin 3.3.1 (2010-03-16) on mail.kernel.org X-Virus-Scanned: ClamAV using ClamSMTP Prevent possible NULL pointer dereference if of_iomap() fails. Handle the error by skipping such power domain. Signed-off-by: Krzysztof Kozlowski --- arch/arm/mach-exynos/pm_domains.c | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/arch/arm/mach-exynos/pm_domains.c b/arch/arm/mach-exynos/pm_domains.c index 20f267121b3e..fd7640a6b503 100644 --- a/arch/arm/mach-exynos/pm_domains.c +++ b/arch/arm/mach-exynos/pm_domains.c @@ -128,6 +128,13 @@ static __init int exynos4_pm_init_power_domain(void) pd->pd.name = kstrdup(np->name, GFP_KERNEL); pd->name = pd->pd.name; pd->base = of_iomap(np, 0); + if (!pd->base) { + dev_warn(&pdev->dev, "Failed to map memory\n"); + kfree(pd); + of_node_put(np); + continue; + } + pd->pd.power_off = exynos_pd_power_off; pd->pd.power_on = exynos_pd_power_on;