Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp2926860iog; Mon, 27 Jun 2022 05:57:11 -0700 (PDT) X-Google-Smtp-Source: AGRyM1vYP76/JL2tPMGEbS7xouezmHUzjkv7L+0DbZckh003Hvhaf7b4xjYj9qCBZ2xwFrntJ9T6 X-Received: by 2002:a62:7cc3:0:b0:525:20fc:275f with SMTP id x186-20020a627cc3000000b0052520fc275fmr14679323pfc.70.1656334630950; Mon, 27 Jun 2022 05:57:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1656334630; cv=none; d=google.com; s=arc-20160816; b=HqRrCU9iqIQdlTXNmy7ugaOfz85rqyxl1XVPz044N21JAtD2oa7ZIT2EdTZUGUOH8V JOALYOZZ1zHe2mcB82+CCR0cDsW0i76jVTPe6X+YMwaMlDbggbVfnlpOc9g5IjfypfVT YH3rWgQTmqqdaZrmPoyiRf3DzPOaIrJ36Vs/gd8w783JydT7vnuibOKGG/6fIa1C566F ShsSph7u3jtIVj8yIgeNjxeNrpTU+GY1bk2FdkNjnrk21oRXxQ6pn6Bl4ZldlPbQLKCT KVOJPR9mAiKSYhbWZ0CmNLIdPMxuO2cN2jhFiBgn/+06uymApYRqf4Vw8Imhxc+GZvnr 7JwQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to :organization:from:references:cc:to:content-language:subject :user-agent:mime-version:date:message-id:dkim-signature; bh=1g17xM8gnJx00whU//iJuDwTqW1vNMfdEO12lxgIMRg=; b=LMTrN478/2VtubnipmRHVqlUzub+BMLu8XhnA4YboZVqab4hy6OjAdkjhUdgrVa2uC FOOu5WyrTMnPK7biMDOvHcfwfGiTonCOwWrwqooa1Isp8Si0oLz2PAljWZsZ8PTnzu/7 v1VANkyURxYuCz0F7NxunfG/WucXbHZ0ViJm/sG24fExCsCA9OHbwmTgNJLjpt8Box+g /PmJk2M1F5H5poKLoiu8HmGw563bD0yzqA3bRGv8Ug+PKmSZHpuwN40nuSkyu4XLVz92 eYRjvR5D3vMnVmE4cZN7+qPWo4kOOwCY4rZ2AU7n9VCAv3IEEsANSMALExq6MOhef81B XMFg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baylibre-com.20210112.gappssmtp.com header.s=20210112 header.b=nnRWhRQQ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id s18-20020a63e812000000b0040d2a16174dsi14201429pgh.599.2022.06.27.05.56.58; Mon, 27 Jun 2022 05:57:10 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@baylibre-com.20210112.gappssmtp.com header.s=20210112 header.b=nnRWhRQQ; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S240485AbiF0MTB (ORCPT + 99 others); Mon, 27 Jun 2022 08:19:01 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:55698 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234757AbiF0MTA (ORCPT ); Mon, 27 Jun 2022 08:19:00 -0400 Received: from mail-wr1-x430.google.com (mail-wr1-x430.google.com [IPv6:2a00:1450:4864:20::430]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D6823BC2F for ; Mon, 27 Jun 2022 05:18:59 -0700 (PDT) Received: by mail-wr1-x430.google.com with SMTP id e28so7626109wra.0 for ; Mon, 27 Jun 2022 05:18:59 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baylibre-com.20210112.gappssmtp.com; s=20210112; h=message-id:date:mime-version:user-agent:subject:content-language:to :cc:references:from:organization:in-reply-to :content-transfer-encoding; bh=1g17xM8gnJx00whU//iJuDwTqW1vNMfdEO12lxgIMRg=; b=nnRWhRQQn7M0KwLCecW+Y+EkDq9bIjiupyRwyOtlwv8MrNFBuARr4zHKZSKrIsTIJ3 0gVSH/b6ge/jCVktMQDQ9QJX+6tNNIRN2Q/t/GUu+KI1gIxGwHNo1WhQnFKh8HiSn/X7 T9D3s0EQPQHzZgXuF2Z8RgB64TURRpe8MnzR8VF+xLoTuDZUpN1v3nXW1GmVcbNvzJWO EI6NRPO7CBAKwlqTVeEdrnJn5pTXP6yzTXLbxSZ3AdWKHH6s6ZEKXdHUDRpzyqTh0l5l B3vZkhEahSCbwj8OTzKuyLIElzg+4OYLundvzQmrZ8/Na3/9XU2mD6yo5y6mawwpE/E2 CItA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:message-id:date:mime-version:user-agent:subject :content-language:to:cc:references:from:organization:in-reply-to :content-transfer-encoding; bh=1g17xM8gnJx00whU//iJuDwTqW1vNMfdEO12lxgIMRg=; b=TS3Ff1Xfs/7PZsJ5TTDPybTxD5Tb38tTePv1BXvpm3uVO0V4eDDogRXl2nN+AJkT1j zX/yYQzaV2SKifGYmvkA+c9l/5WGE8raS7Y2DgJpJJix53Drv7Y5FNNmoVSl7M6hUqtp +ft0E258VH8ROEmhFkB5pKWAt3J+nHq4KtP9JEgxCBPSVchnfWR3bWbpYnVqc5flvnOg RYjol2HAOmlhCCON5IOI45dHB/XF2e0t2ki9zBbBHSEMElrqGUqx3DmtMGIXrGrjsKdx 3JKhS+mJmJPQ9eitkV/A4ZYEvuCcgXfTX95d+GUE8R+jwpsgil+LcjY3kghhF3zJIVf6 kzOg== X-Gm-Message-State: AJIora+RNTEgIcKBDMus/k6RWwjry2QpQtFcHcbOxdq03lGT3b41YEBT EvJljQwhJBSrFZYtouopWUTu4A== X-Received: by 2002:a5d:69cd:0:b0:21b:a9a2:e6e2 with SMTP id s13-20020a5d69cd000000b0021ba9a2e6e2mr12114876wrw.332.1656332338290; Mon, 27 Jun 2022 05:18:58 -0700 (PDT) Received: from ?IPV6:2001:861:44c0:66c0:6f56:f3c6:ba4f:bf5c? ([2001:861:44c0:66c0:6f56:f3c6:ba4f:bf5c]) by smtp.gmail.com with ESMTPSA id ay4-20020a05600c1e0400b003a047dccfffsm5564078wmb.42.2022.06.27.05.18.57 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 27 Jun 2022 05:18:57 -0700 (PDT) Message-ID: <19a3fd3b-ec9a-6b8e-5a79-46ff13f8f4e5@baylibre.com> Date: Mon, 27 Jun 2022 14:18:56 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:91.0) Gecko/20100101 Thunderbird/91.8.1 Subject: Re: [PATCH] drm/bridge: add it6505 driver read config from dt property Content-Language: en-US To: allen Cc: Pin-yen Lin , Jau-Chih Tseng , Hermes Wu , Kenneth Hung , Pin-yen Lin , Andrzej Hajda , Robert Foss , Laurent Pinchart , Jonas Karlman , Jernej Skrabec , David Airlie , Daniel Vetter , "open list:DRM DRIVERS" , open list References: <20220627054038.18600-1-allen.chen@ite.com.tw> From: Neil Armstrong Organization: Baylibre In-Reply-To: <20220627054038.18600-1-allen.chen@ite.com.tw> Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,NICE_REPLY_A,RCVD_IN_DNSWL_NONE,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 27/06/2022 07:40, allen wrote: > From: allen chen > > add read max-lane and max-pixel-clock from dt property Those 2 properties should be documented first in the DT bindings. Neil > > Signed-off-by: Allen Chen > Signed-off-by: Pin-yen Lin > --- > drivers/gpu/drm/bridge/ite-it6505.c | 35 ++++++++++++++++++++++++++--- > 1 file changed, 32 insertions(+), 3 deletions(-) > > diff --git a/drivers/gpu/drm/bridge/ite-it6505.c b/drivers/gpu/drm/bridge/ite-it6505.c > index 4b673c4792d77..c9121d4635a52 100644 > --- a/drivers/gpu/drm/bridge/ite-it6505.c > +++ b/drivers/gpu/drm/bridge/ite-it6505.c > @@ -436,6 +436,8 @@ struct it6505 { > bool powered; > bool hpd_state; > u32 afe_setting; > + u32 max_dpi_pixel_clock; > + u32 max_lane_count; > enum hdcp_state hdcp_status; > struct delayed_work hdcp_work; > struct work_struct hdcp_wait_ksv_list; > @@ -1466,7 +1468,8 @@ static void it6505_parse_link_capabilities(struct it6505 *it6505) > it6505->lane_count = link->num_lanes; > DRM_DEV_DEBUG_DRIVER(dev, "Sink support %d lanes training", > it6505->lane_count); > - it6505->lane_count = min_t(int, it6505->lane_count, MAX_LANE_COUNT); > + it6505->lane_count = min_t(int, it6505->lane_count, > + it6505->max_lane_count); > > it6505->branch_device = drm_dp_is_branch(it6505->dpcd); > DRM_DEV_DEBUG_DRIVER(dev, "Sink %sbranch device", > @@ -2895,7 +2898,7 @@ it6505_bridge_mode_valid(struct drm_bridge *bridge, > if (mode->flags & DRM_MODE_FLAG_INTERLACE) > return MODE_NO_INTERLACE; > > - if (mode->clock > DPI_PIXEL_CLK_MAX) > + if (mode->clock > it6505->max_dpi_pixel_clock) > return MODE_CLOCK_HIGH; > > it6505->video_info.clock = mode->clock; > @@ -3057,6 +3060,8 @@ static void it6505_parse_dt(struct it6505 *it6505) > { > struct device *dev = &it6505->client->dev; > u32 *afe_setting = &it6505->afe_setting; > + u32 *max_lane_count = &it6505->max_lane_count; > + u32 *max_dpi_pixel_clock = &it6505->max_dpi_pixel_clock; > > it6505->lane_swap_disabled = > device_property_read_bool(dev, "no-laneswap"); > @@ -3072,7 +3077,31 @@ static void it6505_parse_dt(struct it6505 *it6505) > } else { > *afe_setting = 0; > } > - DRM_DEV_DEBUG_DRIVER(dev, "using afe_setting: %d", *afe_setting); > + > + if (device_property_read_u32(dev, "max-lane-count", > + max_lane_count) == 0) { > + if (*max_lane_count > 4 || *max_lane_count == 3) { > + dev_err(dev, "max lane count error, use default"); > + *max_lane_count = MAX_LANE_COUNT; > + } > + } else { > + *max_lane_count = MAX_LANE_COUNT; > + } > + > + if (device_property_read_u32(dev, "max-dpi-pixel-clock", > + max_dpi_pixel_clock) == 0) { > + if (*max_dpi_pixel_clock > 297000) { > + dev_err(dev, "max pixel clock error, use default"); > + *max_dpi_pixel_clock = DPI_PIXEL_CLK_MAX; > + } > + } else { > + *max_dpi_pixel_clock = DPI_PIXEL_CLK_MAX; > + } > + > + DRM_DEV_DEBUG_DRIVER(dev, "using afe_setting: %u, max_lane_count: %u", > + it6505->afe_setting, it6505->max_lane_count); > + DRM_DEV_DEBUG_DRIVER(dev, "using max_dpi_pixel_clock: %u kHz", > + it6505->max_dpi_pixel_clock); > } > > static ssize_t receive_timing_debugfs_show(struct file *file, char __user *buf,