Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp7902038rwb; Wed, 23 Nov 2022 12:20:24 -0800 (PST) X-Google-Smtp-Source: AA0mqf6tWVwa2BVL3cxEZaIXjFYxzJ+/iqPrdaaiN98s45tjsacfy2VFlYemvgVgs9nXmlf2uMXH X-Received: by 2002:aa7:9195:0:b0:574:7558:9bd6 with SMTP id x21-20020aa79195000000b0057475589bd6mr2067648pfa.80.1669234824431; Wed, 23 Nov 2022 12:20:24 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1669234824; cv=none; d=google.com; s=arc-20160816; b=xL7r1eXEzGipe6EAAGLpKMRTxdbVDUEDQRiOTm0hW9WvgZCc2UAdkz2L2VXoAb4TRy mfZmoR2xj9fPmXhLdwnGYfoqODX73v/eKARfMdvl8l5Gd0zigafD8PymfpQgUUNYevES 9IFfsx/+TSQOgb0f6PcfYpfYliZHZxCtB+AYVFimqI6ZfLH/PNKlRdoKRb0hU275lD0x ww6V2HiACI0ZhC97+PYP/uQ5daDBC8XhRsgHy2Mw0aEIRr/wz8/AyT5FLBUMk1yEuYsQ Ci4V/0eCxhqT8faKDRCov/ai67RzyjpAiotNafqEvG/s2H+3LWWBly4G4pirt8p3kHtZ 2ajQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=uxGv3kzhxR8ww4pD26mStoo/spKfUXiA9jBRige5czY=; b=g/mMOEMc1v+Tw+6BZ+aFOHWzZFQs3MfMYt6IDz3PnnOn355wLkxuzk/DOOUSNmlsns bFy/i5fLiw9j/aTm1SbIA0az9janxz5K0T650HkQrapQDMA52PzZBK7qJ4ufWI5qR03n RNC4FMVxwOuscvsyFPMXwSjAglBLJIFv3zNCcwefWUdCa8qWEN7BlwAO6BcEY60Di/cW wU0Hl74TTRxQdTb4HM2Hq8qjieVpmfQ4bwP6jP4AWpe4LCQ6JZ2cGssc2HP1QOrtCzb3 S3N4ThHNSUsSLE75z109RII1tGTxp1aIoudC6IVGrfC01JkWfjO2t+ALihj8njyQN0yE 6UOQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@poorly.run header.s=google header.b="Y//ZtKSE"; 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 h184-20020a6383c1000000b0046abab88fd9si338957pge.677.2022.11.23.12.20.13; Wed, 23 Nov 2022 12:20:24 -0800 (PST) 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=@poorly.run header.s=google header.b="Y//ZtKSE"; 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 S239032AbiKWUQu (ORCPT + 88 others); Wed, 23 Nov 2022 15:16:50 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:38066 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238856AbiKWUQl (ORCPT ); Wed, 23 Nov 2022 15:16:41 -0500 Received: from mail-qt1-x836.google.com (mail-qt1-x836.google.com [IPv6:2607:f8b0:4864:20::836]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2EFE378184 for ; Wed, 23 Nov 2022 12:16:39 -0800 (PST) Received: by mail-qt1-x836.google.com with SMTP id w9so11960568qtv.13 for ; Wed, 23 Nov 2022 12:16:39 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=poorly.run; s=google; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:from:date:from:to:cc:subject:date:message-id:reply-to; bh=uxGv3kzhxR8ww4pD26mStoo/spKfUXiA9jBRige5czY=; b=Y//ZtKSEYVadE93lrav/cQYmX4TGIu3e3q2dKtzGrx+eWs2ufu0BELDuiDB+h9qdl/ m8+dWiZP6GGFzU/WZpLU6BKkfWjgiVy+8z2nZcqVWxeq/GfsBYvafwMfywkn5E9EJvI6 dEmzkTU9oqQtz9wstjrxVCHigy+bsxV4WAopk4CcXqbOZSQpQ2C7tQo32tfRGS52walj NVOMnjnWW7H1gg4+GAlsSfmHmiXdHFbrtAvFZhGNQ7pfoCviv+3ZdxucbX12Luc/uoAw LZy2LJNvu4PkJbxdEuvLwHDrsfA8NoEXMppKo7S6vIkcHJW8Bjyhk1HqlHzrtSmLKwz0 nPEw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=in-reply-to:content-disposition:mime-version:references:message-id :subject:cc:to:from:date:x-gm-message-state:from:to:cc:subject:date :message-id:reply-to; bh=uxGv3kzhxR8ww4pD26mStoo/spKfUXiA9jBRige5czY=; b=02XBwZ1YVnSTsSUdEL8oxJE8xBHa0uibSrHX/t6loek1wuTAUTWlkbO3CXmfQ+cBB5 6UQeZYgDjuW5CTsyv0JM26nnCGCeDhkxwF4wc2p8iVRk1dCs3U5TYuBPuqbTG1kiFtcg lN0ag+WoyIqmGUWVqILJYnAuMcvjJXT2rIYa2mv5oisNQZ9X6QFERpQ5TgevVk6nwsq8 BL9SO45dAV1f3Vm7mCgvj4lyyyfMCiifTbil++Zu1jIwwSjKsCNEF5J/6uM0ILFTqR0K pspxtTHh4JboBPA7a81e9Of7y7FKHGhTw1oTeJGB1F1qqSjSbNlsKdlOPTiDqd7cr7Q6 JLbA== X-Gm-Message-State: ANoB5pkj4xfbLQfNpMXQwr/QXO5XvsGKO4DTMLJpoUnWHGjJ1WxXK3U8 RPohxq64fp0eeL134FvL8BpvpQ== X-Received: by 2002:a05:622a:1aa9:b0:3a5:32c8:7825 with SMTP id s41-20020a05622a1aa900b003a532c87825mr27939773qtc.486.1669234598760; Wed, 23 Nov 2022 12:16:38 -0800 (PST) Received: from localhost (200.234.86.34.bc.googleusercontent.com. [34.86.234.200]) by smtp.gmail.com with ESMTPSA id ca9-20020a05622a1f0900b00398a7c860c2sm10385366qtb.4.2022.11.23.12.16.38 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 23 Nov 2022 12:16:38 -0800 (PST) Date: Wed, 23 Nov 2022 20:16:37 +0000 From: Sean Paul To: Hsin-Yi Wang Cc: Sean Paul , Douglas Anderson , Robert Foss , Thomas Zimmermann , Allen Chen , linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org Subject: Re: [PATCH v7 3/3] drm/bridge: it6505: handle HDCP request Message-ID: References: <20221123100529.3943662-1-hsinyi@chromium.org> <20221123100529.3943662-3-hsinyi@chromium.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20221123100529.3943662-3-hsinyi@chromium.org> X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS 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 Wed, Nov 23, 2022 at 10:05:29AM +0000, Hsin-Yi Wang wrote: > it6505 supports HDCP 1.3, but current implementation lacks the update of > HDCP status through drm_hdcp_update_content_protection(). > > it6505 default enables the HDCP. Remove this and only turn on when user > requests it. > > Signed-off-by: Hsin-Yi Wang > Reviewed-by: allen chen > --- > v6->v7: remove enable hdcp by default. > --- > drivers/gpu/drm/bridge/ite-it6505.c | 60 +++++++++++++++++++++++++++-- > 1 file changed, 57 insertions(+), 3 deletions(-) > > diff --git a/drivers/gpu/drm/bridge/ite-it6505.c b/drivers/gpu/drm/bridge/ite-it6505.c > index 21a9b8422bda..93626698c31e 100644 > --- a/drivers/gpu/drm/bridge/ite-it6505.c > +++ b/drivers/gpu/drm/bridge/ite-it6505.c > @@ -423,6 +423,7 @@ struct it6505 { > struct extcon_dev *extcon; > struct work_struct extcon_wq; > int extcon_state; > + struct drm_connector *connector; > enum drm_connector_status connector_status; > enum link_train_status link_state; > struct work_struct link_works; > @@ -2159,9 +2160,6 @@ static void it6505_link_train_ok(struct it6505 *it6505) > DRM_DEV_DEBUG_DRIVER(dev, "Enable audio!"); > it6505_enable_audio(it6505); > } > - > - if (it6505->hdcp_desired) > - it6505_start_hdcp(it6505); > } > > static void it6505_link_step_train_process(struct it6505 *it6505) > @@ -2399,6 +2397,14 @@ static void it6505_irq_hdcp_done(struct it6505 *it6505) > > DRM_DEV_DEBUG_DRIVER(dev, "hdcp done interrupt"); > it6505->hdcp_status = HDCP_AUTH_DONE; > + if (it6505->connector) { > + struct drm_device *drm_dev = it6505->connector->dev; > + > + drm_modeset_lock(&drm_dev->mode_config.connection_mutex, NULL); > + drm_hdcp_update_content_protection(it6505->connector, > + DRM_MODE_CONTENT_PROTECTION_ENABLED); > + drm_modeset_unlock(&drm_dev->mode_config.connection_mutex); > + } > it6505_show_hdcp_info(it6505); > } > > @@ -2931,6 +2937,7 @@ static void it6505_bridge_atomic_enable(struct drm_bridge *bridge, > if (WARN_ON(!connector)) > return; > > + it6505->connector = connector; > conn_state = drm_atomic_get_new_connector_state(state, connector); > > if (WARN_ON(!conn_state)) > @@ -2974,6 +2981,7 @@ static void it6505_bridge_atomic_disable(struct drm_bridge *bridge, > > DRM_DEV_DEBUG_DRIVER(dev, "start"); > > + it6505->connector = NULL; > if (it6505->powered) { > it6505_drm_dp_link_set_power(&it6505->aux, &it6505->link, > DP_SET_POWER_D3); > @@ -3028,6 +3036,50 @@ static struct edid *it6505_bridge_get_edid(struct drm_bridge *bridge, > return edid; > } > > +static int it6505_connector_atomic_check(struct it6505 *it6505, > + struct drm_connector_state *state) > +{ > + struct device *dev = &it6505->client->dev; > + int cp = state->content_protection; > + > + DRM_DEV_DEBUG_DRIVER(dev, "hdcp connector state:%d, curr hdcp state:%d", > + cp, it6505->hdcp_status); > + > + if (!it6505->hdcp_desired) { > + DRM_DEV_DEBUG_DRIVER(dev, "sink not support hdcp"); > + return 0; > + } > + > + if (it6505->hdcp_status == HDCP_AUTH_GOING) > + return -EINVAL; > + > + if (cp == DRM_MODE_CONTENT_PROTECTION_UNDESIRED) { > + if (it6505->hdcp_status == HDCP_AUTH_DONE) > + it6505_stop_hdcp(it6505); You shouldn't touch the hardware in atomic_check, this should be done in the commit. > + } else if (cp == DRM_MODE_CONTENT_PROTECTION_DESIRED) { > + if (it6505->hdcp_status == HDCP_AUTH_IDLE && > + it6505->link_state == LINK_OK) > + it6505_start_hdcp(it6505); Same here > + } else { > + if (it6505->hdcp_status == HDCP_AUTH_IDLE) { > + DRM_DEV_DEBUG_DRIVER(dev, "invalid to set hdcp enabled"); > + return -EINVAL; > + } > + } In general, I think there are a number of locking and state issues with this approach. I had pulled all of this logic into a set of helpers [1], but the patchset has gotten stale on the list. You might consider looking at patches 1-4 to see how the state and locking should be handled to avoid races. Sean [1] - https://lore.kernel.org/all/20220411204741.1074308-1-sean@poorly.run/ > + > + return 0; > +} > + > +static int it6505_bridge_atomic_check(struct drm_bridge *bridge, > + struct drm_bridge_state *bridge_state, > + struct drm_crtc_state *crtc_state, > + struct drm_connector_state *conn_state) > +{ > + struct it6505 *it6505 = bridge_to_it6505(bridge); > + > + return it6505_connector_atomic_check(it6505, conn_state); > +} > + > static const struct drm_bridge_funcs it6505_bridge_funcs = { > .atomic_duplicate_state = drm_atomic_helper_bridge_duplicate_state, > .atomic_destroy_state = drm_atomic_helper_bridge_destroy_state, > @@ -3035,6 +3087,7 @@ static const struct drm_bridge_funcs it6505_bridge_funcs = { > .attach = it6505_bridge_attach, > .detach = it6505_bridge_detach, > .mode_valid = it6505_bridge_mode_valid, > + .atomic_check = it6505_bridge_atomic_check, > .atomic_enable = it6505_bridge_atomic_enable, > .atomic_disable = it6505_bridge_atomic_disable, > .atomic_pre_enable = it6505_bridge_atomic_pre_enable, > @@ -3354,6 +3407,7 @@ static int it6505_i2c_probe(struct i2c_client *client, > it6505->bridge.type = DRM_MODE_CONNECTOR_DisplayPort; > it6505->bridge.ops = DRM_BRIDGE_OP_DETECT | DRM_BRIDGE_OP_EDID | > DRM_BRIDGE_OP_HPD; > + it6505->bridge.support_hdcp = true; > drm_bridge_add(&it6505->bridge); > > return 0; > -- > 2.38.1.584.g0f3c55d4c2-goog > -- Sean Paul, Software Engineer, Google / Chromium OS