Received: by 2002:a25:b323:0:0:0:0:0 with SMTP id l35csp2711904ybj; Mon, 23 Sep 2019 08:13:10 -0700 (PDT) X-Google-Smtp-Source: APXvYqx2MJXBGui8JfQL00AsLgVJpS03SliPkYohQv5LOrfLPnwu06K4W9UNXVFc+4+gXjvN5kSl X-Received: by 2002:a50:ac0d:: with SMTP id v13mr542733edc.189.1569251590743; Mon, 23 Sep 2019 08:13:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1569251590; cv=none; d=google.com; s=arc-20160816; b=nRw7zLdN8YbbyMX17226JfKBhyOyL444bQR5E1TKsTZpvqRlJ4XCVUK6prxFsxws0L pkyswJKwUDnkGBDVO7rA3qfIOlGnDm6RP5zc0084jYwCHwBWifk8n8km57mHyv2c7Ajz obUHzcuVs58v7txpB5j8x/RcKBxgmwzxT4uSolSQZO0E11xMRluvHidgTEnxOX/S8er9 LihI4hcpQYdHlDXSTGikJS5/nHASf9yy/N97HMmqMScGr1BwrXt43MXlAqxOPCD0PdI8 UtL/NGzTAcu3MAjvITOmL1ZCO7pjhk2DxFKiiwoiUnO6T3mH8T0GTs1hNdy5kYbAZXwJ uUcw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=IvKUda3wPP3iGFTGjdewk44E9Cz8OvmVZ56gL+Awvg0=; b=mPyoGTkpW3zsut5eCWdZJhN1vfJNJ69bmlmQNyXqyO/iYr2OWNJCII2062Fo2axb9B fsKsCeuNiksWcwLiIqtbfnneEyRr8gmkmt1YvPd1XVLe6x2yTxP76dOTrXS49Qm4+LNW zFRSJowsNEbQGpUK0y9qE2+4kn0cDhScaSneU+SKAnLvd09X6mir8inEXobQTHxsh4PZ +2dIJWMffcQ1D3D6fYQcMAKQo1KJWQ6ehUH5oV1INYHLRHko/xjU22u9ypBoRU2IAQ1s h3+euPAlwawNTGQKse5jJF/U+WnNYulHmUNa6n+9l1Ty0+L2pPUn8pJrAsB6/EUn7uSm auog== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ingics-com.20150623.gappssmtp.com header.s=20150623 header.b=D6HIbcGc; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id g22si6833580edf.398.2019.09.23.08.12.46; Mon, 23 Sep 2019 08:13:10 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@ingics-com.20150623.gappssmtp.com header.s=20150623 header.b=D6HIbcGc; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727186AbfIVC3s (ORCPT + 99 others); Sat, 21 Sep 2019 22:29:48 -0400 Received: from mail-pf1-f195.google.com ([209.85.210.195]:38744 "EHLO mail-pf1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727170AbfIVC3s (ORCPT ); Sat, 21 Sep 2019 22:29:48 -0400 Received: by mail-pf1-f195.google.com with SMTP id h195so6939104pfe.5 for ; Sat, 21 Sep 2019 19:29:46 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ingics-com.20150623.gappssmtp.com; s=20150623; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=IvKUda3wPP3iGFTGjdewk44E9Cz8OvmVZ56gL+Awvg0=; b=D6HIbcGcbVjHy2b7DlBfG9Y+aHK9QL6IyXoebFROZ29uGsG6aIHblPieZ7v6UxUElG 5pnVfsZDALooIRBm4LBwiDgjxazF9tv0mBz766L1TK3JfFVBIyRen4jiscZ/G4hIx1ao ZC6a646ylKmE4GEjaFmg3JX0bTi193Dlt47Q3smyHKTzcQMmKhI9hNE6qBUZHPEv9AQV GG1NKH3v0Yc6RcL4SVaC2/nFWeVb+ZPU3wennCi3uSJswOW2ayv8opfg9IEt+cj4h0SF u5q5HaGCycT4Wiqel2m4hbKQaAtbBnlNgfGol01IgBwtmvRzFwbKwxWZcfNj4Fa/HwIq J6yw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=IvKUda3wPP3iGFTGjdewk44E9Cz8OvmVZ56gL+Awvg0=; b=T9gxyJ9b6GrOrMvDv5oy4T4/i9FOaT1oaYLRrDzXVAYGD7Wr1PIZLuLgneQuisB2LO YvN6efGTnP8A3NTlnJK9qR5Y30oRwJwdVMBOym+V/R/jqCdi7hriiTapTRO9sLXqGbvI lmwv9YPmKwNJhm53EYyONzf/cToxZHV6h7Hw1plpSflZ9Dgu+dua0EMxii+HWhiOPRO+ HqrStEWX5fNIGMyMJqhpnMUZ+kL8xcxy/veY0xC99LdX5ETTK8aQnd2+LBR4feSbT6/l bugYiice67NIEj4S35ax24uf8KM5BxuiIvwRUWyHzpEMXq1wrzWIAE1P/gv8GfFkNOzA 7L6w== X-Gm-Message-State: APjAAAU6mIjQgzDXIFBA+tOTLJ1mBrypE2TTHKIwiE5QoNQ+6yyUluOK JCtTycyM7yqyQBCtq5NtlhPFwhulpRU= X-Received: by 2002:a17:90b:8cf:: with SMTP id ds15mr5296174pjb.36.1569119385495; Sat, 21 Sep 2019 19:29:45 -0700 (PDT) Received: from localhost.localdomain (122-117-179-2.HINET-IP.hinet.net. [122.117.179.2]) by smtp.gmail.com with ESMTPSA id h4sm6936386pfg.159.2019.09.21.19.29.42 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sat, 21 Sep 2019 19:29:44 -0700 (PDT) From: Axel Lin To: Mark Brown Cc: Philippe Schenker , Liam Girdwood , linux-kernel@vger.kernel.org, Axel Lin Subject: [PATCH] regulator: fixed: Prevent NULL pointer dereference when !CONFIG_OF Date: Sun, 22 Sep 2019 10:29:28 +0800 Message-Id: <20190922022928.28355-1-axel.lin@ingics.com> X-Mailer: git-send-email 2.20.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Use of_device_get_match_data which has NULL test for match before dereference match->data. Add NULL test for drvtype so it still works for fixed_voltage_ops when !CONFIG_OF. Signed-off-by: Axel Lin --- drivers/regulator/fixed.c | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/drivers/regulator/fixed.c b/drivers/regulator/fixed.c index d90a6fd8cbc7..f81533070058 100644 --- a/drivers/regulator/fixed.c +++ b/drivers/regulator/fixed.c @@ -144,8 +144,7 @@ static int reg_fixed_voltage_probe(struct platform_device *pdev) struct device *dev = &pdev->dev; struct fixed_voltage_config *config; struct fixed_voltage_data *drvdata; - const struct fixed_dev_type *drvtype = - of_match_device(dev->driver->of_match_table, dev)->data; + const struct fixed_dev_type *drvtype = of_device_get_match_data(dev); struct regulator_config cfg = { }; enum gpiod_flags gflags; int ret; @@ -177,7 +176,7 @@ static int reg_fixed_voltage_probe(struct platform_device *pdev) drvdata->desc.type = REGULATOR_VOLTAGE; drvdata->desc.owner = THIS_MODULE; - if (drvtype->has_enable_clock) { + if (drvtype && drvtype->has_enable_clock) { drvdata->desc.ops = &fixed_voltage_clkenabled_ops; drvdata->enable_clock = devm_clk_get(dev, NULL); -- 2.20.1