Received: by 2002:a5b:505:0:0:0:0:0 with SMTP id o5csp3724156ybp; Sun, 6 Oct 2019 18:49:24 -0700 (PDT) X-Google-Smtp-Source: APXvYqxiDR9XAXLP/AEZVPfUbD1bktvVHcnwE40ZbMuzX9zbjuGTYlG+/+Leq59sAFxuJUrepXEW X-Received: by 2002:aa7:c812:: with SMTP id a18mr27503482edt.240.1570412963926; Sun, 06 Oct 2019 18:49:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1570412963; cv=none; d=google.com; s=arc-20160816; b=OLJYxVcQscawV846Hp/hZKx5Lgzh+N2eQ/dB8lh0lxRNsM2N/y/LbSKm4WCj+wOqq3 wjOWbmnXooYu+C1ifpT4DV2SzgrLpMyFeh7TeR2pTm2FAmH0f0XI8RDJm1I8ASVq4jbI Adln2oRoBrRl5SFrI+kAq8HtnQG3Zg2tLI3k9DmOgtGSFWI0GxveDNGblwgJCY8h2F5I zslh9cHExKIF2ybBjejT7oh4jZ7tfT7hP9YCXaE2wIoJtdQSCv7F6w4YDTZIATx0xdFn 4ardiu8cYByFR8JEuhJzdP9Hbnx59g/ZDFPR3F7CIk8DBUhpsbxHRMvNGnWYaaccb+yz DHPQ== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=MueNndKQbyUlZMlKJkIFWaj86quHGvnILJvt6P+Kj6o=; b=SnAtpRzOHg1Dg1lBzHizYjy2bZllWyJAaU3ohWkVpqv+GW50IqWsRa2dS/QXdBwpjz SBArdX0FLBfIkvKOsX84hJb21bu+GzJn/wxZU7/QURHoSc1UBW/ZL6JuyMlMJ+E40zUC WS41FW/eIbAIhU8Jy29rC52NdhWGMw/nzuXR4/T7lO7MHDJ3X+VsGRaLMFui1dvPJyhL TJs9xC1PQEQZnDimMCeg078BUAkuiqobXpeuTV9v0SI60BxQYr8In74JqJxPA9BYF90p ejbsXDT7dQ3SHLKpt95VEB6Zjjbbdg0RUhzeyUNjAaWi4bXZgNFyxvcxmKd9GWUkA8wg jvEw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@onstation.org header.s=default header.b=bhYAtfG+; 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 b3si6151896eju.357.2019.10.06.18.49.00; Sun, 06 Oct 2019 18:49:23 -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 (test mode) header.i=@onstation.org header.s=default header.b=bhYAtfG+; 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 S1727261AbfJGBpf (ORCPT + 99 others); Sun, 6 Oct 2019 21:45:35 -0400 Received: from onstation.org ([52.200.56.107]:33016 "EHLO onstation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726781AbfJGBpW (ORCPT ); Sun, 6 Oct 2019 21:45:22 -0400 Received: from localhost.localdomain (c-98-239-145-235.hsd1.wv.comcast.net [98.239.145.235]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits)) (No client certificate requested) (Authenticated sender: masneyb) by onstation.org (Postfix) with ESMTPSA id D60943F230; Mon, 7 Oct 2019 01:45:21 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=onstation.org; s=default; t=1570412722; bh=eRhUOSJT70X+Sx4VC7+xmjW4CgqLv3ArFwLDB0ZPKsU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=bhYAtfG+PVYsR5Zyv24EW+FNMDahNcIB7R4WgdlnsbSY1BIhljjmT9rM605Msch2n /SSQtVlMqZosCTOlz6OM8kpLmcy5G81gzF+QWUn6eG59PYPjwel1R5WSkX6qND3r74 c9LlZmBsiZORXbtzvlTVRalr1HyMfK9yvz27NlMU= From: Brian Masney To: robdclark@gmail.com, sean@poorly.run Cc: bjorn.andersson@linaro.org, a.hajda@samsung.com, Laurent.pinchart@ideasonboard.com, airlied@linux.ie, daniel@ffwll.ch, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, linux-arm-msm@vger.kernel.org, freedreno@lists.freedesktop.org, jonathan@marek.ca Subject: [PATCH RFC v2 1/5] drm/bridge: analogix-anx78xx: add support for avdd33 regulator Date: Sun, 6 Oct 2019 21:45:05 -0400 Message-Id: <20191007014509.25180-2-masneyb@onstation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20191007014509.25180-1-masneyb@onstation.org> References: <20191007014509.25180-1-masneyb@onstation.org> 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 Add support for the avdd33 regulator to the analogix-anx78xx driver. Note that the regulator is currently enabled during driver probe and disabled when the driver is removed. This is currently how the downstream MSM kernel sources do this. Let's not merge this upstream for the mean time until I get the external display fully working on the Nexus 5 and then I can submit proper support then that powers down this regulator in the power off function. Signed-off-by: Brian Masney --- Changes since v1: - None drivers/gpu/drm/bridge/analogix-anx78xx.c | 33 +++++++++++++++++++++++ 1 file changed, 33 insertions(+) diff --git a/drivers/gpu/drm/bridge/analogix-anx78xx.c b/drivers/gpu/drm/bridge/analogix-anx78xx.c index dec3f7e66aa0..e25fae36dbe1 100644 --- a/drivers/gpu/drm/bridge/analogix-anx78xx.c +++ b/drivers/gpu/drm/bridge/analogix-anx78xx.c @@ -56,6 +56,7 @@ static const u8 anx781x_i2c_addresses[] = { struct anx78xx_platform_data { struct regulator *dvdd10; + struct regulator *avdd33; struct gpio_desc *gpiod_hpd; struct gpio_desc *gpiod_pd; struct gpio_desc *gpiod_reset; @@ -715,10 +716,42 @@ static int anx78xx_start(struct anx78xx *anx78xx) return err; } +static void anx78xx_disable_regulator_action(void *_data) +{ + struct anx78xx_platform_data *pdata = _data; + + regulator_disable(pdata->avdd33); +} + static int anx78xx_init_pdata(struct anx78xx *anx78xx) { struct anx78xx_platform_data *pdata = &anx78xx->pdata; struct device *dev = &anx78xx->client->dev; + int err; + + /* 3.3V digital core power regulator */ + pdata->avdd33 = devm_regulator_get(dev, "avdd33"); + if (IS_ERR(pdata->avdd33)) { + err = PTR_ERR(pdata->avdd33); + if (err != -EPROBE_DEFER) + DRM_ERROR("avdd33 regulator not found\n"); + + return err; + } + + err = regulator_enable(pdata->avdd33); + if (err) { + DRM_ERROR("Failed to enable avdd33 regulator: %d\n", err); + return err; + } + + err = devm_add_action(dev, anx78xx_disable_regulator_action, + pdata); + if (err < 0) { + dev_err(dev, "Failed to setup regulator cleanup action %d\n", + err); + return err; + } /* 1.0V digital core power regulator */ pdata->dvdd10 = devm_regulator_get(dev, "dvdd10"); -- 2.21.0