Received: by 2002:ac0:8845:0:0:0:0:0 with SMTP id g63csp964479img; Tue, 26 Feb 2019 11:37:28 -0800 (PST) X-Google-Smtp-Source: AHgI3IYgdvkdl58BtBC61py1U5aSdlkfTPnqHp/HffmcgXlulLqMsaxp0mkHAX5JKYODoeGfBTCK X-Received: by 2002:a17:902:2e81:: with SMTP id r1mr26704883plb.278.1551209848118; Tue, 26 Feb 2019 11:37:28 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1551209848; cv=none; d=google.com; s=arc-20160816; b=jzGk3+kl7RtBmRmPiYLVhDjXcBY4WAFFehlr2cFeve3g1xm0nVZ35AgyUwSlo92rxe OEM77HoWAYY00J3V+DyZHys83/ouartS8M3hJqRHujROkhuZO+RqIk/IkT57rMSDHYCH JvurRPoMpJuzGfgs2BAcuYFiCu8HJPcqoRCiJnroZzKu4n0/0GlaM9SmZCuig5nYKZlt bRCy3Cth80QgyNQ206pLf6g5AZXylBMqb4XAMcoXZkWgcb8jQ2f++yJQHEN+xSPkE8EP Byuw8J1kKtMOOideI/1Kp/TAQfk12lg9QU2dA/nNMNwIXm0o5MuXhB4uwzXm64qA0HH2 bAew== 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=RGzhHRXCSSTUV8y9+sZJ9O8fW6lSd15+7S2lT8PZLKA=; b=nzn+G50RkHpKl27ahTZTaH1oivTtLmxOi/ohEsxIhh6rD1fQFDMy+kH0c1oPN5tnlI UViGMfHqyDlNSXFeacjCKodI6cjK6SUDZlaZkIYSpWjb3rmdl5SvW7XQZJRLe8DNUcFn 2mixR+6jOeV/25AxoP2KxakWBUxF6mcxKZ3NJ4cuuQFtWJjuqQP4LmYUDi7EdGRFNlPe vQe25Ry22bnxktDOEm9alBy5jZgP6Xd57G4WZCd5+5SwAwZUOP0TQDfA+n6XZMuCZlBp qTHWDCM5xlIRWRuurHHidLcfxUJBRKuC0OKmKkz2ayBbUyXtHQ2WAPNaPCDYzCQ8Kt1n pO1g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=oVsb9oQL; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id l11si13149652pgc.473.2019.02.26.11.37.13; Tue, 26 Feb 2019 11:37:28 -0800 (PST) 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=@gmail.com header.s=20161025 header.b=oVsb9oQL; 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; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729136AbfBZTgm (ORCPT + 99 others); Tue, 26 Feb 2019 14:36:42 -0500 Received: from mail-pf1-f193.google.com ([209.85.210.193]:43828 "EHLO mail-pf1-f193.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729066AbfBZTgj (ORCPT ); Tue, 26 Feb 2019 14:36:39 -0500 Received: by mail-pf1-f193.google.com with SMTP id q17so6711864pfh.10 for ; Tue, 26 Feb 2019 11:36:38 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=RGzhHRXCSSTUV8y9+sZJ9O8fW6lSd15+7S2lT8PZLKA=; b=oVsb9oQLiw7fuySZNvlTxYC1ZehjkTc/1qbDebFX0OVzzj1lDRVZYVj/hVcKlX2UgJ 6RiYPPmIM4CxFqs23wm6SwGZXpVFGvgffu6sCZCP3yTHs3pUefaHP1YSTD4BMop17Y37 S185yh8XgT4Ucv6nhw6jK7Q5uygOunVf16nDnp60gGvwVFK9Z1y8Ct9HvB8DNzHruGwJ zjx+8ecwX0piZrihN/7y4y/C9IWiy7qoo0VNO/7jr5mMz/Ewiyg4hcXjUFG2vkuy1qPf SfF9aFi8PphRz4iz+6IbaR7Qh/TZQkLf6B1LJY1bgfurGFXhC4nd/9nc5lE0T+eFy/vC lx5g== 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:in-reply-to :references:mime-version:content-transfer-encoding; bh=RGzhHRXCSSTUV8y9+sZJ9O8fW6lSd15+7S2lT8PZLKA=; b=HDlviJvWiQ2pRe/NBprn5QoYlc4Y5Eu80vaR8Q6tgSYZG5RlJmxdQev8YQhQcAWq1U h3V5+3EGLySOtr2hXLUF5/EOJHO4ClMr5lHcMfc7ovVN+t4I8lkyJUQ1mhxz5a8lmFfL YY6xAC8J6+b3Y1xlgET4/iaajylSlML7B7/TGl6IRq1xY3iTo7D7AG00L+YlpW+GyK9l xqSn3MCWyIcCdNrzT64It8o1aEc96lZrxnbqm4ph+ItNwsV+7irZVUMR4+ImX6maK3nj pz6dSJSFxLgpBA1ZvPBPbxnHcdmDo2/LqXNuNioQP6N7/bjbwR9B4IaHj1i0AU4VK5b0 yt/Q== X-Gm-Message-State: AHQUAubVa+zA1ei447zq7T/5DNWX0beSLbQG6m8IdQEK5nHfCNKZlVVN 0cSIqU4uzx3E+aEcMjQwK3s= X-Received: by 2002:a63:8942:: with SMTP id v63mr25177689pgd.406.1551209798004; Tue, 26 Feb 2019 11:36:38 -0800 (PST) Received: from squirtle.lan (c-24-22-235-96.hsd1.wa.comcast.net. [24.22.235.96]) by smtp.gmail.com with ESMTPSA id l79sm28951220pfb.102.2019.02.26.11.36.36 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Tue, 26 Feb 2019 11:36:37 -0800 (PST) From: Andrey Smirnov To: dri-devel@lists.freedesktop.org Cc: Andrey Smirnov , Archit Taneja , Andrzej Hajda , Laurent Pinchart , Chris Healy , Lucas Stach , linux-kernel@vger.kernel.org Subject: [PATCH 8/9] drm/bridge: tc358767: Introduce tc_pllupdate_pllen() Date: Tue, 26 Feb 2019 11:36:08 -0800 Message-Id: <20190226193609.9862-9-andrew.smirnov@gmail.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190226193609.9862-1-andrew.smirnov@gmail.com> References: <20190226193609.9862-1-andrew.smirnov@gmail.com> 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 Tc_wait_pll_lock() is always called as a follow-up for updating PLLUPDATE and PLLEN bit of a given PLL control register. To simplify things, merge the two operation into a single helper function tc_pllupdate_pllen() and convert the rest of the code to use it. No functional change intended. Signed-off-by: Andrey Smirnov Cc: Archit Taneja Cc: Andrzej Hajda Cc: Laurent Pinchart Cc: Chris Healy Cc: Lucas Stach Cc: dri-devel@lists.freedesktop.org Cc: linux-kernel@vger.kernel.org --- drivers/gpu/drm/bridge/tc358767.c | 36 +++++++++++++++++++------------ 1 file changed, 22 insertions(+), 14 deletions(-) diff --git a/drivers/gpu/drm/bridge/tc358767.c b/drivers/gpu/drm/bridge/tc358767.c index 227f14cd2d3d..239b3aaa255d 100644 --- a/drivers/gpu/drm/bridge/tc358767.c +++ b/drivers/gpu/drm/bridge/tc358767.c @@ -390,10 +390,18 @@ static u32 tc_srcctrl(struct tc_data *tc) return reg; } -static void tc_wait_pll_lock(struct tc_data *tc) +static int tc_pllupdate_pllen(struct tc_data *tc, unsigned int pllctrl) { + int ret; + + ret = regmap_write(tc->regmap, pllctrl, PLLUPDATE | PLLEN); + if (ret) + return ret; + /* Wait for PLL to lock: up to 2.09 ms, depending on refclk */ usleep_range(3000, 6000); + + return 0; } static int tc_pxl_pll_en(struct tc_data *tc, u32 refclk, u32 pixelclock) @@ -487,11 +495,7 @@ static int tc_pxl_pll_en(struct tc_data *tc, u32 refclk, u32 pixelclock) (best_mul << 0)); /* Multiplier for PLL */ /* Force PLL parameter update and disable bypass */ - tc_write(PXL_PLLCTRL, PLLUPDATE | PLLEN); - - tc_wait_pll_lock(tc); - - return 0; + return tc_pllupdate_pllen(tc, PXL_PLLCTRL); err: return ret; } @@ -568,11 +572,13 @@ static int tc_aux_link_setup(struct tc_data *tc) * Initially PLLs are in bypass. Force PLL parameter update, * disable PLL bypass, enable PLL */ - tc_write(DP0_PLLCTRL, PLLUPDATE | PLLEN); - tc_wait_pll_lock(tc); + ret = tc_pllupdate_pllen(tc, DP0_PLLCTRL); + if (ret) + return ret; - tc_write(DP1_PLLCTRL, PLLUPDATE | PLLEN); - tc_wait_pll_lock(tc); + ret = tc_pllupdate_pllen(tc, DP1_PLLCTRL); + if (ret) + return ret; ret = tc_poll_timeout(tc->regmap, DP_PHY_CTRL, PHY_RDY, PHY_RDY, 1, 1000); @@ -846,11 +852,13 @@ static int tc_main_link_setup(struct tc_data *tc) msleep(100); /* PLL setup */ - tc_write(DP0_PLLCTRL, PLLUPDATE | PLLEN); - tc_wait_pll_lock(tc); + ret = tc_pllupdate_pllen(tc, DP0_PLLCTRL); + if (ret) + return ret; - tc_write(DP1_PLLCTRL, PLLUPDATE | PLLEN); - tc_wait_pll_lock(tc); + ret = tc_pllupdate_pllen(tc, DP1_PLLCTRL); + if (ret) + return ret; /* PXL PLL setup */ if (tc_test_pattern) { -- 2.20.1