LCOV - code coverage report
Current view: top level - drivers/gpu/drm/i915/display - intel_hdcp.c (source / functions) Hit Total Coverage
Test: combined.info Lines: 0 966 0.0 %
Date: 2022-03-28 13:20:08 Functions: 0 52 0.0 %
Branches: 0 556 0.0 %

           Branch data     Line data    Source code
       1                 :            : /* SPDX-License-Identifier: MIT */
       2                 :            : /*
       3                 :            :  * Copyright (C) 2017 Google, Inc.
       4                 :            :  * Copyright _ 2017-2019, Intel Corporation.
       5                 :            :  *
       6                 :            :  * Authors:
       7                 :            :  * Sean Paul <seanpaul@chromium.org>
       8                 :            :  * Ramalingam C <ramalingam.c@intel.com>
       9                 :            :  */
      10                 :            : 
      11                 :            : #include <linux/component.h>
      12                 :            : #include <linux/i2c.h>
      13                 :            : #include <linux/random.h>
      14                 :            : 
      15                 :            : #include <drm/drm_hdcp.h>
      16                 :            : #include <drm/i915_component.h>
      17                 :            : 
      18                 :            : #include "i915_reg.h"
      19                 :            : #include "intel_display_power.h"
      20                 :            : #include "intel_display_types.h"
      21                 :            : #include "intel_hdcp.h"
      22                 :            : #include "intel_sideband.h"
      23                 :            : #include "intel_connector.h"
      24                 :            : 
      25                 :            : #define KEY_LOAD_TRIES  5
      26                 :            : #define ENCRYPT_STATUS_CHANGE_TIMEOUT_MS        50
      27                 :            : #define HDCP2_LC_RETRY_CNT                      3
      28                 :            : 
      29                 :            : static
      30                 :          0 : bool intel_hdcp_is_ksv_valid(u8 *ksv)
      31                 :            : {
      32                 :          0 :         int i, ones = 0;
      33                 :            :         /* KSV has 20 1's and 20 0's */
      34         [ #  # ]:          0 :         for (i = 0; i < DRM_HDCP_KSV_LEN; i++)
      35         [ #  # ]:          0 :                 ones += hweight8(ksv[i]);
      36         [ #  # ]:          0 :         if (ones != 20)
      37                 :          0 :                 return false;
      38                 :            : 
      39                 :            :         return true;
      40                 :            : }
      41                 :            : 
      42                 :            : static
      43                 :            : int intel_hdcp_read_valid_bksv(struct intel_digital_port *intel_dig_port,
      44                 :            :                                const struct intel_hdcp_shim *shim, u8 *bksv)
      45                 :            : {
      46                 :            :         int ret, i, tries = 2;
      47                 :            : 
      48                 :            :         /* HDCP spec states that we must retry the bksv if it is invalid */
      49                 :            :         for (i = 0; i < tries; i++) {
      50                 :            :                 ret = shim->read_bksv(intel_dig_port, bksv);
      51                 :            :                 if (ret)
      52                 :            :                         return ret;
      53                 :            :                 if (intel_hdcp_is_ksv_valid(bksv))
      54                 :            :                         break;
      55                 :            :         }
      56                 :            :         if (i == tries) {
      57                 :            :                 DRM_DEBUG_KMS("Bksv is invalid\n");
      58                 :            :                 return -ENODEV;
      59                 :            :         }
      60                 :            : 
      61                 :            :         return 0;
      62                 :            : }
      63                 :            : 
      64                 :            : /* Is HDCP1.4 capable on Platform and Sink */
      65                 :          0 : bool intel_hdcp_capable(struct intel_connector *connector)
      66                 :            : {
      67         [ #  # ]:          0 :         struct intel_digital_port *intel_dig_port = conn_to_dig_port(connector);
      68                 :          0 :         const struct intel_hdcp_shim *shim = connector->hdcp.shim;
      69                 :          0 :         bool capable = false;
      70                 :          0 :         u8 bksv[5];
      71                 :            : 
      72         [ #  # ]:          0 :         if (!shim)
      73                 :            :                 return capable;
      74                 :            : 
      75         [ #  # ]:          0 :         if (shim->hdcp_capable) {
      76                 :          0 :                 shim->hdcp_capable(intel_dig_port, &capable);
      77                 :            :         } else {
      78         [ #  # ]:          0 :                 if (!intel_hdcp_read_valid_bksv(intel_dig_port, shim, bksv))
      79                 :          0 :                         capable = true;
      80                 :            :         }
      81                 :            : 
      82                 :          0 :         return capable;
      83                 :            : }
      84                 :            : 
      85                 :            : /* Is HDCP2.2 capable on Platform and Sink */
      86                 :          0 : bool intel_hdcp2_capable(struct intel_connector *connector)
      87                 :            : {
      88         [ #  # ]:          0 :         struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
      89         [ #  # ]:          0 :         struct intel_digital_port *intel_dig_port = conn_to_dig_port(connector);
      90                 :          0 :         struct intel_hdcp *hdcp = &connector->hdcp;
      91                 :          0 :         bool capable = false;
      92                 :            : 
      93                 :            :         /* I915 support for HDCP2.2 */
      94         [ #  # ]:          0 :         if (!hdcp->hdcp2_supported)
      95                 :            :                 return false;
      96                 :            : 
      97                 :            :         /* MEI interface is solid */
      98                 :          0 :         mutex_lock(&dev_priv->hdcp_comp_mutex);
      99   [ #  #  #  # ]:          0 :         if (!dev_priv->hdcp_comp_added ||  !dev_priv->hdcp_master) {
     100                 :          0 :                 mutex_unlock(&dev_priv->hdcp_comp_mutex);
     101                 :          0 :                 return false;
     102                 :            :         }
     103                 :          0 :         mutex_unlock(&dev_priv->hdcp_comp_mutex);
     104                 :            : 
     105                 :            :         /* Sink's capability for HDCP2.2 */
     106                 :          0 :         hdcp->shim->hdcp_2_2_capable(intel_dig_port, &capable);
     107                 :            : 
     108                 :          0 :         return capable;
     109                 :            : }
     110                 :            : 
     111                 :            : static inline
     112                 :          0 : bool intel_hdcp_in_use(struct drm_i915_private *dev_priv,
     113                 :            :                        enum transcoder cpu_transcoder, enum port port)
     114                 :            : {
     115         [ #  # ]:          0 :         return I915_READ(HDCP_STATUS(dev_priv, cpu_transcoder, port)) &
     116                 :            :                HDCP_STATUS_ENC;
     117                 :            : }
     118                 :            : 
     119                 :            : static inline
     120                 :          0 : bool intel_hdcp2_in_use(struct drm_i915_private *dev_priv,
     121                 :            :                         enum transcoder cpu_transcoder, enum port port)
     122                 :            : {
     123         [ #  # ]:          0 :         return I915_READ(HDCP2_STATUS(dev_priv, cpu_transcoder, port)) &
     124                 :            :                LINK_ENCRYPTION_STATUS;
     125                 :            : }
     126                 :            : 
     127                 :            : static int intel_hdcp_poll_ksv_fifo(struct intel_digital_port *intel_dig_port,
     128                 :            :                                     const struct intel_hdcp_shim *shim)
     129                 :            : {
     130                 :            :         int ret, read_ret;
     131                 :            :         bool ksv_ready;
     132                 :            : 
     133                 :            :         /* Poll for ksv list ready (spec says max time allowed is 5s) */
     134                 :            :         ret = __wait_for(read_ret = shim->read_ksv_ready(intel_dig_port,
     135                 :            :                                                          &ksv_ready),
     136                 :            :                          read_ret || ksv_ready, 5 * 1000 * 1000, 1000,
     137                 :            :                          100 * 1000);
     138                 :            :         if (ret)
     139                 :            :                 return ret;
     140                 :            :         if (read_ret)
     141                 :            :                 return read_ret;
     142                 :            :         if (!ksv_ready)
     143                 :            :                 return -ETIMEDOUT;
     144                 :            : 
     145                 :            :         return 0;
     146                 :            : }
     147                 :            : 
     148                 :          0 : static bool hdcp_key_loadable(struct drm_i915_private *dev_priv)
     149                 :            : {
     150                 :          0 :         struct i915_power_domains *power_domains = &dev_priv->power_domains;
     151                 :          0 :         struct i915_power_well *power_well;
     152                 :          0 :         enum i915_power_well_id id;
     153                 :          0 :         bool enabled = false;
     154                 :            : 
     155                 :            :         /*
     156                 :            :          * On HSW and BDW, Display HW loads the Key as soon as Display resumes.
     157                 :            :          * On all BXT+, SW can load the keys only when the PW#1 is turned on.
     158                 :            :          */
     159   [ #  #  #  # ]:          0 :         if (IS_HASWELL(dev_priv) || IS_BROADWELL(dev_priv))
     160                 :            :                 id = HSW_DISP_PW_GLOBAL;
     161                 :            :         else
     162                 :            :                 id = SKL_DISP_PW_1;
     163                 :            : 
     164                 :          0 :         mutex_lock(&power_domains->lock);
     165                 :            : 
     166                 :            :         /* PG1 (power well #1) needs to be enabled */
     167         [ #  # ]:          0 :         for_each_power_well(dev_priv, power_well) {
     168         [ #  # ]:          0 :                 if (power_well->desc->id == id) {
     169                 :          0 :                         enabled = power_well->desc->ops->is_enabled(dev_priv,
     170                 :            :                                                                     power_well);
     171                 :          0 :                         break;
     172                 :            :                 }
     173                 :            :         }
     174                 :          0 :         mutex_unlock(&power_domains->lock);
     175                 :            : 
     176                 :            :         /*
     177                 :            :          * Another req for hdcp key loadability is enabled state of pll for
     178                 :            :          * cdclk. Without active crtc we wont land here. So we are assuming that
     179                 :            :          * cdclk is already on.
     180                 :            :          */
     181                 :            : 
     182                 :          0 :         return enabled;
     183                 :            : }
     184                 :            : 
     185                 :          0 : static void intel_hdcp_clear_keys(struct drm_i915_private *dev_priv)
     186                 :            : {
     187                 :          0 :         I915_WRITE(HDCP_KEY_CONF, HDCP_CLEAR_KEYS_TRIGGER);
     188                 :          0 :         I915_WRITE(HDCP_KEY_STATUS, HDCP_KEY_LOAD_DONE | HDCP_KEY_LOAD_STATUS |
     189                 :            :                    HDCP_FUSE_IN_PROGRESS | HDCP_FUSE_ERROR | HDCP_FUSE_DONE);
     190                 :          0 : }
     191                 :            : 
     192                 :          0 : static int intel_hdcp_load_keys(struct drm_i915_private *dev_priv)
     193                 :            : {
     194                 :          0 :         int ret;
     195                 :          0 :         u32 val;
     196                 :            : 
     197                 :          0 :         val = I915_READ(HDCP_KEY_STATUS);
     198         [ #  # ]:          0 :         if ((val & HDCP_KEY_LOAD_DONE) && (val & HDCP_KEY_LOAD_STATUS))
     199                 :            :                 return 0;
     200                 :            : 
     201                 :            :         /*
     202                 :            :          * On HSW and BDW HW loads the HDCP1.4 Key when Display comes
     203                 :            :          * out of reset. So if Key is not already loaded, its an error state.
     204                 :            :          */
     205   [ #  #  #  # ]:          0 :         if (IS_HASWELL(dev_priv) || IS_BROADWELL(dev_priv))
     206         [ #  # ]:          0 :                 if (!(I915_READ(HDCP_KEY_STATUS) & HDCP_KEY_LOAD_DONE))
     207                 :            :                         return -ENXIO;
     208                 :            : 
     209                 :            :         /*
     210                 :            :          * Initiate loading the HDCP key from fuses.
     211                 :            :          *
     212                 :            :          * BXT+ platforms, HDCP key needs to be loaded by SW. Only Gen 9
     213                 :            :          * platforms except BXT and GLK, differ in the key load trigger process
     214                 :            :          * from other platforms. So GEN9_BC uses the GT Driver Mailbox i/f.
     215                 :            :          */
     216   [ #  #  #  # ]:          0 :         if (IS_GEN9_BC(dev_priv)) {
     217                 :          0 :                 ret = sandybridge_pcode_write(dev_priv,
     218                 :            :                                               SKL_PCODE_LOAD_HDCP_KEYS, 1);
     219         [ #  # ]:          0 :                 if (ret) {
     220                 :          0 :                         DRM_ERROR("Failed to initiate HDCP key load (%d)\n",
     221                 :            :                                   ret);
     222                 :          0 :                         return ret;
     223                 :            :                 }
     224                 :            :         } else {
     225                 :          0 :                 I915_WRITE(HDCP_KEY_CONF, HDCP_KEY_LOAD_TRIGGER);
     226                 :            :         }
     227                 :            : 
     228                 :            :         /* Wait for the keys to load (500us) */
     229                 :          0 :         ret = __intel_wait_for_register(&dev_priv->uncore, HDCP_KEY_STATUS,
     230                 :            :                                         HDCP_KEY_LOAD_DONE, HDCP_KEY_LOAD_DONE,
     231                 :            :                                         10, 1, &val);
     232         [ #  # ]:          0 :         if (ret)
     233                 :            :                 return ret;
     234         [ #  # ]:          0 :         else if (!(val & HDCP_KEY_LOAD_STATUS))
     235                 :            :                 return -ENXIO;
     236                 :            : 
     237                 :            :         /* Send Aksv over to PCH display for use in authentication */
     238                 :          0 :         I915_WRITE(HDCP_KEY_CONF, HDCP_AKSV_SEND_TRIGGER);
     239                 :            : 
     240                 :          0 :         return 0;
     241                 :            : }
     242                 :            : 
     243                 :            : /* Returns updated SHA-1 index */
     244                 :          0 : static int intel_write_sha_text(struct drm_i915_private *dev_priv, u32 sha_text)
     245                 :            : {
     246                 :          0 :         I915_WRITE(HDCP_SHA_TEXT, sha_text);
     247         [ #  # ]:          0 :         if (intel_de_wait_for_set(dev_priv, HDCP_REP_CTL, HDCP_SHA1_READY, 1)) {
     248                 :          0 :                 DRM_ERROR("Timed out waiting for SHA1 ready\n");
     249                 :          0 :                 return -ETIMEDOUT;
     250                 :            :         }
     251                 :            :         return 0;
     252                 :            : }
     253                 :            : 
     254                 :            : static
     255                 :            : u32 intel_hdcp_get_repeater_ctl(struct drm_i915_private *dev_priv,
     256                 :            :                                 enum transcoder cpu_transcoder, enum port port)
     257                 :            : {
     258                 :            :         if (INTEL_GEN(dev_priv) >= 12) {
     259                 :            :                 switch (cpu_transcoder) {
     260                 :            :                 case TRANSCODER_A:
     261                 :            :                         return HDCP_TRANSA_REP_PRESENT |
     262                 :            :                                HDCP_TRANSA_SHA1_M0;
     263                 :            :                 case TRANSCODER_B:
     264                 :            :                         return HDCP_TRANSB_REP_PRESENT |
     265                 :            :                                HDCP_TRANSB_SHA1_M0;
     266                 :            :                 case TRANSCODER_C:
     267                 :            :                         return HDCP_TRANSC_REP_PRESENT |
     268                 :            :                                HDCP_TRANSC_SHA1_M0;
     269                 :            :                 case TRANSCODER_D:
     270                 :            :                         return HDCP_TRANSD_REP_PRESENT |
     271                 :            :                                HDCP_TRANSD_SHA1_M0;
     272                 :            :                 default:
     273                 :            :                         DRM_ERROR("Unknown transcoder %d\n", cpu_transcoder);
     274                 :            :                         return -EINVAL;
     275                 :            :                 }
     276                 :            :         }
     277                 :            : 
     278                 :            :         switch (port) {
     279                 :            :         case PORT_A:
     280                 :            :                 return HDCP_DDIA_REP_PRESENT | HDCP_DDIA_SHA1_M0;
     281                 :            :         case PORT_B:
     282                 :            :                 return HDCP_DDIB_REP_PRESENT | HDCP_DDIB_SHA1_M0;
     283                 :            :         case PORT_C:
     284                 :            :                 return HDCP_DDIC_REP_PRESENT | HDCP_DDIC_SHA1_M0;
     285                 :            :         case PORT_D:
     286                 :            :                 return HDCP_DDID_REP_PRESENT | HDCP_DDID_SHA1_M0;
     287                 :            :         case PORT_E:
     288                 :            :                 return HDCP_DDIE_REP_PRESENT | HDCP_DDIE_SHA1_M0;
     289                 :            :         default:
     290                 :            :                 DRM_ERROR("Unknown port %d\n", port);
     291                 :            :                 return -EINVAL;
     292                 :            :         }
     293                 :            : }
     294                 :            : 
     295                 :            : static
     296                 :          0 : int intel_hdcp_validate_v_prime(struct intel_connector *connector,
     297                 :            :                                 const struct intel_hdcp_shim *shim,
     298                 :            :                                 u8 *ksv_fifo, u8 num_downstream, u8 *bstatus)
     299                 :            : {
     300         [ #  # ]:          0 :         struct intel_digital_port *intel_dig_port = conn_to_dig_port(connector);
     301                 :          0 :         struct drm_i915_private *dev_priv;
     302                 :          0 :         enum transcoder cpu_transcoder = connector->hdcp.cpu_transcoder;
     303                 :          0 :         enum port port = intel_dig_port->base.port;
     304                 :          0 :         u32 vprime, sha_text, sha_leftovers, rep_ctl;
     305                 :          0 :         int ret, i, j, sha_idx;
     306                 :            : 
     307                 :          0 :         dev_priv = intel_dig_port->base.base.dev->dev_private;
     308                 :            : 
     309                 :            :         /* Process V' values from the receiver */
     310         [ #  # ]:          0 :         for (i = 0; i < DRM_HDCP_V_PRIME_NUM_PARTS; i++) {
     311                 :          0 :                 ret = shim->read_v_prime_part(intel_dig_port, i, &vprime);
     312         [ #  # ]:          0 :                 if (ret)
     313                 :          0 :                         return ret;
     314                 :          0 :                 I915_WRITE(HDCP_SHA_V_PRIME(i), vprime);
     315                 :            :         }
     316                 :            : 
     317                 :            :         /*
     318                 :            :          * We need to write the concatenation of all device KSVs, BINFO (DP) ||
     319                 :            :          * BSTATUS (HDMI), and M0 (which is added via HDCP_REP_CTL). This byte
     320                 :            :          * stream is written via the HDCP_SHA_TEXT register in 32-bit
     321                 :            :          * increments. Every 64 bytes, we need to write HDCP_REP_CTL again. This
     322                 :            :          * index will keep track of our progress through the 64 bytes as well as
     323                 :            :          * helping us work the 40-bit KSVs through our 32-bit register.
     324                 :            :          *
     325                 :            :          * NOTE: data passed via HDCP_SHA_TEXT should be big-endian
     326                 :            :          */
     327                 :          0 :         sha_idx = 0;
     328                 :          0 :         sha_text = 0;
     329                 :          0 :         sha_leftovers = 0;
     330                 :          0 :         rep_ctl = intel_hdcp_get_repeater_ctl(dev_priv, cpu_transcoder, port);
     331                 :          0 :         I915_WRITE(HDCP_REP_CTL, rep_ctl | HDCP_SHA1_TEXT_32);
     332         [ #  # ]:          0 :         for (i = 0; i < num_downstream; i++) {
     333                 :          0 :                 unsigned int sha_empty;
     334                 :          0 :                 u8 *ksv = &ksv_fifo[i * DRM_HDCP_KSV_LEN];
     335                 :            : 
     336                 :            :                 /* Fill up the empty slots in sha_text and write it out */
     337                 :          0 :                 sha_empty = sizeof(sha_text) - sha_leftovers;
     338         [ #  # ]:          0 :                 for (j = 0; j < sha_empty; j++)
     339                 :          0 :                         sha_text |= ksv[j] << ((sizeof(sha_text) - j - 1) * 8);
     340                 :            : 
     341                 :          0 :                 ret = intel_write_sha_text(dev_priv, sha_text);
     342         [ #  # ]:          0 :                 if (ret < 0)
     343                 :          0 :                         return ret;
     344                 :            : 
     345                 :            :                 /* Programming guide writes this every 64 bytes */
     346                 :          0 :                 sha_idx += sizeof(sha_text);
     347         [ #  # ]:          0 :                 if (!(sha_idx % 64))
     348                 :          0 :                         I915_WRITE(HDCP_REP_CTL, rep_ctl | HDCP_SHA1_TEXT_32);
     349                 :            : 
     350                 :            :                 /* Store the leftover bytes from the ksv in sha_text */
     351                 :          0 :                 sha_leftovers = DRM_HDCP_KSV_LEN - sha_empty;
     352                 :          0 :                 sha_text = 0;
     353         [ #  # ]:          0 :                 for (j = 0; j < sha_leftovers; j++)
     354                 :          0 :                         sha_text |= ksv[sha_empty + j] <<
     355                 :          0 :                                         ((sizeof(sha_text) - j - 1) * 8);
     356                 :            : 
     357                 :            :                 /*
     358                 :            :                  * If we still have room in sha_text for more data, continue.
     359                 :            :                  * Otherwise, write it out immediately.
     360                 :            :                  */
     361         [ #  # ]:          0 :                 if (sizeof(sha_text) > sha_leftovers)
     362                 :          0 :                         continue;
     363                 :            : 
     364                 :          0 :                 ret = intel_write_sha_text(dev_priv, sha_text);
     365         [ #  # ]:          0 :                 if (ret < 0)
     366                 :          0 :                         return ret;
     367                 :          0 :                 sha_leftovers = 0;
     368                 :          0 :                 sha_text = 0;
     369                 :          0 :                 sha_idx += sizeof(sha_text);
     370                 :            :         }
     371                 :            : 
     372                 :            :         /*
     373                 :            :          * We need to write BINFO/BSTATUS, and M0 now. Depending on how many
     374                 :            :          * bytes are leftover from the last ksv, we might be able to fit them
     375                 :            :          * all in sha_text (first 2 cases), or we might need to split them up
     376                 :            :          * into 2 writes (last 2 cases).
     377                 :            :          */
     378         [ #  # ]:          0 :         if (sha_leftovers == 0) {
     379                 :            :                 /* Write 16 bits of text, 16 bits of M0 */
     380                 :          0 :                 I915_WRITE(HDCP_REP_CTL, rep_ctl | HDCP_SHA1_TEXT_16);
     381                 :          0 :                 ret = intel_write_sha_text(dev_priv,
     382                 :          0 :                                            bstatus[0] << 8 | bstatus[1]);
     383         [ #  # ]:          0 :                 if (ret < 0)
     384                 :            :                         return ret;
     385                 :          0 :                 sha_idx += sizeof(sha_text);
     386                 :            : 
     387                 :            :                 /* Write 32 bits of M0 */
     388                 :          0 :                 I915_WRITE(HDCP_REP_CTL, rep_ctl | HDCP_SHA1_TEXT_0);
     389                 :          0 :                 ret = intel_write_sha_text(dev_priv, 0);
     390         [ #  # ]:          0 :                 if (ret < 0)
     391                 :            :                         return ret;
     392                 :          0 :                 sha_idx += sizeof(sha_text);
     393                 :            : 
     394                 :            :                 /* Write 16 bits of M0 */
     395                 :          0 :                 I915_WRITE(HDCP_REP_CTL, rep_ctl | HDCP_SHA1_TEXT_16);
     396                 :          0 :                 ret = intel_write_sha_text(dev_priv, 0);
     397         [ #  # ]:          0 :                 if (ret < 0)
     398                 :            :                         return ret;
     399                 :          0 :                 sha_idx += sizeof(sha_text);
     400                 :            : 
     401         [ #  # ]:          0 :         } else if (sha_leftovers == 1) {
     402                 :            :                 /* Write 24 bits of text, 8 bits of M0 */
     403                 :          0 :                 I915_WRITE(HDCP_REP_CTL, rep_ctl | HDCP_SHA1_TEXT_24);
     404                 :          0 :                 sha_text |= bstatus[0] << 16 | bstatus[1] << 8;
     405                 :            :                 /* Only 24-bits of data, must be in the LSB */
     406                 :          0 :                 sha_text = (sha_text & 0xffffff00) >> 8;
     407                 :          0 :                 ret = intel_write_sha_text(dev_priv, sha_text);
     408         [ #  # ]:          0 :                 if (ret < 0)
     409                 :            :                         return ret;
     410                 :          0 :                 sha_idx += sizeof(sha_text);
     411                 :            : 
     412                 :            :                 /* Write 32 bits of M0 */
     413                 :          0 :                 I915_WRITE(HDCP_REP_CTL, rep_ctl | HDCP_SHA1_TEXT_0);
     414                 :          0 :                 ret = intel_write_sha_text(dev_priv, 0);
     415         [ #  # ]:          0 :                 if (ret < 0)
     416                 :            :                         return ret;
     417                 :          0 :                 sha_idx += sizeof(sha_text);
     418                 :            : 
     419                 :            :                 /* Write 24 bits of M0 */
     420                 :          0 :                 I915_WRITE(HDCP_REP_CTL, rep_ctl | HDCP_SHA1_TEXT_8);
     421                 :          0 :                 ret = intel_write_sha_text(dev_priv, 0);
     422         [ #  # ]:          0 :                 if (ret < 0)
     423                 :            :                         return ret;
     424                 :          0 :                 sha_idx += sizeof(sha_text);
     425                 :            : 
     426         [ #  # ]:          0 :         } else if (sha_leftovers == 2) {
     427                 :            :                 /* Write 32 bits of text */
     428                 :          0 :                 I915_WRITE(HDCP_REP_CTL, rep_ctl | HDCP_SHA1_TEXT_32);
     429                 :          0 :                 sha_text |= bstatus[0] << 24 | bstatus[1] << 16;
     430                 :          0 :                 ret = intel_write_sha_text(dev_priv, sha_text);
     431         [ #  # ]:          0 :                 if (ret < 0)
     432                 :            :                         return ret;
     433                 :          0 :                 sha_idx += sizeof(sha_text);
     434                 :            : 
     435                 :            :                 /* Write 64 bits of M0 */
     436                 :          0 :                 I915_WRITE(HDCP_REP_CTL, rep_ctl | HDCP_SHA1_TEXT_0);
     437         [ #  # ]:          0 :                 for (i = 0; i < 2; i++) {
     438                 :          0 :                         ret = intel_write_sha_text(dev_priv, 0);
     439         [ #  # ]:          0 :                         if (ret < 0)
     440                 :          0 :                                 return ret;
     441                 :          0 :                         sha_idx += sizeof(sha_text);
     442                 :            :                 }
     443         [ #  # ]:          0 :         } else if (sha_leftovers == 3) {
     444                 :            :                 /* Write 32 bits of text */
     445                 :          0 :                 I915_WRITE(HDCP_REP_CTL, rep_ctl | HDCP_SHA1_TEXT_32);
     446                 :          0 :                 sha_text |= bstatus[0] << 24;
     447                 :          0 :                 ret = intel_write_sha_text(dev_priv, sha_text);
     448         [ #  # ]:          0 :                 if (ret < 0)
     449                 :            :                         return ret;
     450                 :          0 :                 sha_idx += sizeof(sha_text);
     451                 :            : 
     452                 :            :                 /* Write 8 bits of text, 24 bits of M0 */
     453                 :          0 :                 I915_WRITE(HDCP_REP_CTL, rep_ctl | HDCP_SHA1_TEXT_8);
     454                 :          0 :                 ret = intel_write_sha_text(dev_priv, bstatus[1]);
     455         [ #  # ]:          0 :                 if (ret < 0)
     456                 :            :                         return ret;
     457                 :          0 :                 sha_idx += sizeof(sha_text);
     458                 :            : 
     459                 :            :                 /* Write 32 bits of M0 */
     460                 :          0 :                 I915_WRITE(HDCP_REP_CTL, rep_ctl | HDCP_SHA1_TEXT_0);
     461                 :          0 :                 ret = intel_write_sha_text(dev_priv, 0);
     462         [ #  # ]:          0 :                 if (ret < 0)
     463                 :            :                         return ret;
     464                 :          0 :                 sha_idx += sizeof(sha_text);
     465                 :            : 
     466                 :            :                 /* Write 8 bits of M0 */
     467                 :          0 :                 I915_WRITE(HDCP_REP_CTL, rep_ctl | HDCP_SHA1_TEXT_24);
     468                 :          0 :                 ret = intel_write_sha_text(dev_priv, 0);
     469         [ #  # ]:          0 :                 if (ret < 0)
     470                 :            :                         return ret;
     471                 :          0 :                 sha_idx += sizeof(sha_text);
     472                 :            :         } else {
     473                 :          0 :                 DRM_DEBUG_KMS("Invalid number of leftovers %d\n",
     474                 :            :                               sha_leftovers);
     475                 :          0 :                 return -EINVAL;
     476                 :            :         }
     477                 :            : 
     478                 :          0 :         I915_WRITE(HDCP_REP_CTL, rep_ctl | HDCP_SHA1_TEXT_32);
     479                 :            :         /* Fill up to 64-4 bytes with zeros (leave the last write for length) */
     480         [ #  # ]:          0 :         while ((sha_idx % 64) < (64 - sizeof(sha_text))) {
     481                 :          0 :                 ret = intel_write_sha_text(dev_priv, 0);
     482         [ #  # ]:          0 :                 if (ret < 0)
     483                 :          0 :                         return ret;
     484                 :          0 :                 sha_idx += sizeof(sha_text);
     485                 :            :         }
     486                 :            : 
     487                 :            :         /*
     488                 :            :          * Last write gets the length of the concatenation in bits. That is:
     489                 :            :          *  - 5 bytes per device
     490                 :            :          *  - 10 bytes for BINFO/BSTATUS(2), M0(8)
     491                 :            :          */
     492                 :          0 :         sha_text = (num_downstream * 5 + 10) * 8;
     493                 :          0 :         ret = intel_write_sha_text(dev_priv, sha_text);
     494         [ #  # ]:          0 :         if (ret < 0)
     495                 :            :                 return ret;
     496                 :            : 
     497                 :            :         /* Tell the HW we're done with the hash and wait for it to ACK */
     498                 :          0 :         I915_WRITE(HDCP_REP_CTL, rep_ctl | HDCP_SHA1_COMPLETE_HASH);
     499         [ #  # ]:          0 :         if (intel_de_wait_for_set(dev_priv, HDCP_REP_CTL,
     500                 :            :                                   HDCP_SHA1_COMPLETE, 1)) {
     501                 :          0 :                 DRM_ERROR("Timed out waiting for SHA1 complete\n");
     502                 :          0 :                 return -ETIMEDOUT;
     503                 :            :         }
     504         [ #  # ]:          0 :         if (!(I915_READ(HDCP_REP_CTL) & HDCP_SHA1_V_MATCH)) {
     505                 :          0 :                 DRM_DEBUG_KMS("SHA-1 mismatch, HDCP failed\n");
     506                 :          0 :                 return -ENXIO;
     507                 :            :         }
     508                 :            : 
     509                 :            :         return 0;
     510                 :            : }
     511                 :            : 
     512                 :            : /* Implements Part 2 of the HDCP authorization procedure */
     513                 :            : static
     514                 :          0 : int intel_hdcp_auth_downstream(struct intel_connector *connector)
     515                 :            : {
     516         [ #  # ]:          0 :         struct intel_digital_port *intel_dig_port = conn_to_dig_port(connector);
     517                 :          0 :         const struct intel_hdcp_shim *shim = connector->hdcp.shim;
     518                 :          0 :         struct drm_device *dev = connector->base.dev;
     519                 :          0 :         u8 bstatus[2], num_downstream, *ksv_fifo;
     520                 :          0 :         int ret, i, tries = 3;
     521                 :            : 
     522                 :          0 :         ret = intel_hdcp_poll_ksv_fifo(intel_dig_port, shim);
     523         [ #  # ]:          0 :         if (ret) {
     524                 :          0 :                 DRM_DEBUG_KMS("KSV list failed to become ready (%d)\n", ret);
     525                 :          0 :                 return ret;
     526                 :            :         }
     527                 :            : 
     528                 :          0 :         ret = shim->read_bstatus(intel_dig_port, bstatus);
     529         [ #  # ]:          0 :         if (ret)
     530                 :            :                 return ret;
     531                 :            : 
     532         [ #  # ]:          0 :         if (DRM_HDCP_MAX_DEVICE_EXCEEDED(bstatus[0]) ||
     533         [ #  # ]:          0 :             DRM_HDCP_MAX_CASCADE_EXCEEDED(bstatus[1])) {
     534                 :          0 :                 DRM_DEBUG_KMS("Max Topology Limit Exceeded\n");
     535                 :          0 :                 return -EPERM;
     536                 :            :         }
     537                 :            : 
     538                 :            :         /*
     539                 :            :          * When repeater reports 0 device count, HDCP1.4 spec allows disabling
     540                 :            :          * the HDCP encryption. That implies that repeater can't have its own
     541                 :            :          * display. As there is no consumption of encrypted content in the
     542                 :            :          * repeater with 0 downstream devices, we are failing the
     543                 :            :          * authentication.
     544                 :            :          */
     545                 :          0 :         num_downstream = DRM_HDCP_NUM_DOWNSTREAM(bstatus[0]);
     546         [ #  # ]:          0 :         if (num_downstream == 0) {
     547                 :          0 :                 DRM_DEBUG_KMS("Repeater with zero downstream devices\n");
     548                 :          0 :                 return -EINVAL;
     549                 :            :         }
     550                 :            : 
     551                 :          0 :         ksv_fifo = kcalloc(DRM_HDCP_KSV_LEN, num_downstream, GFP_KERNEL);
     552         [ #  # ]:          0 :         if (!ksv_fifo) {
     553                 :          0 :                 DRM_DEBUG_KMS("Out of mem: ksv_fifo\n");
     554                 :          0 :                 return -ENOMEM;
     555                 :            :         }
     556                 :            : 
     557                 :          0 :         ret = shim->read_ksv_fifo(intel_dig_port, num_downstream, ksv_fifo);
     558         [ #  # ]:          0 :         if (ret)
     559                 :          0 :                 goto err;
     560                 :            : 
     561         [ #  # ]:          0 :         if (drm_hdcp_check_ksvs_revoked(dev, ksv_fifo, num_downstream)) {
     562                 :          0 :                 DRM_ERROR("Revoked Ksv(s) in ksv_fifo\n");
     563                 :          0 :                 ret = -EPERM;
     564                 :          0 :                 goto err;
     565                 :            :         }
     566                 :            : 
     567                 :            :         /*
     568                 :            :          * When V prime mismatches, DP Spec mandates re-read of
     569                 :            :          * V prime atleast twice.
     570                 :            :          */
     571         [ #  # ]:          0 :         for (i = 0; i < tries; i++) {
     572                 :          0 :                 ret = intel_hdcp_validate_v_prime(connector, shim,
     573                 :            :                                                   ksv_fifo, num_downstream,
     574                 :            :                                                   bstatus);
     575         [ #  # ]:          0 :                 if (!ret)
     576                 :            :                         break;
     577                 :            :         }
     578                 :            : 
     579         [ #  # ]:          0 :         if (i == tries) {
     580                 :          0 :                 DRM_DEBUG_KMS("V Prime validation failed.(%d)\n", ret);
     581                 :          0 :                 goto err;
     582                 :            :         }
     583                 :            : 
     584                 :          0 :         DRM_DEBUG_KMS("HDCP is enabled (%d downstream devices)\n",
     585                 :            :                       num_downstream);
     586                 :          0 :         ret = 0;
     587                 :          0 : err:
     588                 :          0 :         kfree(ksv_fifo);
     589                 :          0 :         return ret;
     590                 :            : }
     591                 :            : 
     592                 :            : /* Implements Part 1 of the HDCP authorization procedure */
     593                 :          0 : static int intel_hdcp_auth(struct intel_connector *connector)
     594                 :            : {
     595         [ #  # ]:          0 :         struct intel_digital_port *intel_dig_port = conn_to_dig_port(connector);
     596                 :          0 :         struct intel_hdcp *hdcp = &connector->hdcp;
     597                 :          0 :         struct drm_device *dev = connector->base.dev;
     598                 :          0 :         const struct intel_hdcp_shim *shim = hdcp->shim;
     599                 :          0 :         struct drm_i915_private *dev_priv;
     600                 :          0 :         enum transcoder cpu_transcoder = connector->hdcp.cpu_transcoder;
     601                 :          0 :         enum port port;
     602                 :          0 :         unsigned long r0_prime_gen_start;
     603                 :          0 :         int ret, i, tries = 2;
     604                 :          0 :         union {
     605                 :            :                 u32 reg[2];
     606                 :            :                 u8 shim[DRM_HDCP_AN_LEN];
     607                 :            :         } an;
     608                 :          0 :         union {
     609                 :            :                 u32 reg[2];
     610                 :            :                 u8 shim[DRM_HDCP_KSV_LEN];
     611                 :            :         } bksv;
     612                 :          0 :         union {
     613                 :            :                 u32 reg;
     614                 :            :                 u8 shim[DRM_HDCP_RI_LEN];
     615                 :            :         } ri;
     616                 :          0 :         bool repeater_present, hdcp_capable;
     617                 :            : 
     618                 :          0 :         dev_priv = intel_dig_port->base.base.dev->dev_private;
     619                 :            : 
     620                 :          0 :         port = intel_dig_port->base.port;
     621                 :            : 
     622                 :            :         /*
     623                 :            :          * Detects whether the display is HDCP capable. Although we check for
     624                 :            :          * valid Bksv below, the HDCP over DP spec requires that we check
     625                 :            :          * whether the display supports HDCP before we write An. For HDMI
     626                 :            :          * displays, this is not necessary.
     627                 :            :          */
     628         [ #  # ]:          0 :         if (shim->hdcp_capable) {
     629                 :          0 :                 ret = shim->hdcp_capable(intel_dig_port, &hdcp_capable);
     630         [ #  # ]:          0 :                 if (ret)
     631                 :            :                         return ret;
     632         [ #  # ]:          0 :                 if (!hdcp_capable) {
     633                 :          0 :                         DRM_DEBUG_KMS("Panel is not HDCP capable\n");
     634                 :          0 :                         return -EINVAL;
     635                 :            :                 }
     636                 :            :         }
     637                 :            : 
     638                 :            :         /* Initialize An with 2 random values and acquire it */
     639         [ #  # ]:          0 :         for (i = 0; i < 2; i++)
     640         [ #  # ]:          0 :                 I915_WRITE(HDCP_ANINIT(dev_priv, cpu_transcoder, port),
     641                 :            :                            get_random_u32());
     642         [ #  # ]:          0 :         I915_WRITE(HDCP_CONF(dev_priv, cpu_transcoder, port),
     643                 :            :                    HDCP_CONF_CAPTURE_AN);
     644                 :            : 
     645                 :            :         /* Wait for An to be acquired */
     646   [ #  #  #  # ]:          0 :         if (intel_de_wait_for_set(dev_priv,
     647                 :            :                                   HDCP_STATUS(dev_priv, cpu_transcoder, port),
     648                 :            :                                   HDCP_STATUS_AN_READY, 1)) {
     649                 :          0 :                 DRM_ERROR("Timed out waiting for An\n");
     650                 :          0 :                 return -ETIMEDOUT;
     651                 :            :         }
     652                 :            : 
     653         [ #  # ]:          0 :         an.reg[0] = I915_READ(HDCP_ANLO(dev_priv, cpu_transcoder, port));
     654         [ #  # ]:          0 :         an.reg[1] = I915_READ(HDCP_ANHI(dev_priv, cpu_transcoder, port));
     655                 :          0 :         ret = shim->write_an_aksv(intel_dig_port, an.shim);
     656         [ #  # ]:          0 :         if (ret)
     657                 :            :                 return ret;
     658                 :            : 
     659                 :          0 :         r0_prime_gen_start = jiffies;
     660                 :            : 
     661                 :          0 :         memset(&bksv, 0, sizeof(bksv));
     662                 :            : 
     663                 :          0 :         ret = intel_hdcp_read_valid_bksv(intel_dig_port, shim, bksv.shim);
     664         [ #  # ]:          0 :         if (ret < 0)
     665                 :            :                 return ret;
     666                 :            : 
     667         [ #  # ]:          0 :         if (drm_hdcp_check_ksvs_revoked(dev, bksv.shim, 1)) {
     668                 :          0 :                 DRM_ERROR("BKSV is revoked\n");
     669                 :          0 :                 return -EPERM;
     670                 :            :         }
     671                 :            : 
     672         [ #  # ]:          0 :         I915_WRITE(HDCP_BKSVLO(dev_priv, cpu_transcoder, port), bksv.reg[0]);
     673         [ #  # ]:          0 :         I915_WRITE(HDCP_BKSVHI(dev_priv, cpu_transcoder, port), bksv.reg[1]);
     674                 :            : 
     675                 :          0 :         ret = shim->repeater_present(intel_dig_port, &repeater_present);
     676         [ #  # ]:          0 :         if (ret)
     677                 :            :                 return ret;
     678         [ #  # ]:          0 :         if (repeater_present)
     679                 :          0 :                 I915_WRITE(HDCP_REP_CTL,
     680                 :            :                            intel_hdcp_get_repeater_ctl(dev_priv, cpu_transcoder,
     681                 :            :                                                        port));
     682                 :            : 
     683                 :          0 :         ret = shim->toggle_signalling(intel_dig_port, true);
     684         [ #  # ]:          0 :         if (ret)
     685                 :            :                 return ret;
     686                 :            : 
     687         [ #  # ]:          0 :         I915_WRITE(HDCP_CONF(dev_priv, cpu_transcoder, port),
     688                 :            :                    HDCP_CONF_AUTH_AND_ENC);
     689                 :            : 
     690                 :            :         /* Wait for R0 ready */
     691   [ #  #  #  #  :          0 :         if (wait_for(I915_READ(HDCP_STATUS(dev_priv, cpu_transcoder, port)) &
          #  #  #  #  #  
                      # ]
     692                 :            :                      (HDCP_STATUS_R0_READY | HDCP_STATUS_ENC), 1)) {
     693                 :          0 :                 DRM_ERROR("Timed out waiting for R0 ready\n");
     694                 :          0 :                 return -ETIMEDOUT;
     695                 :            :         }
     696                 :            : 
     697                 :            :         /*
     698                 :            :          * Wait for R0' to become available. The spec says 100ms from Aksv, but
     699                 :            :          * some monitors can take longer than this. We'll set the timeout at
     700                 :            :          * 300ms just to be sure.
     701                 :            :          *
     702                 :            :          * On DP, there's an R0_READY bit available but no such bit
     703                 :            :          * exists on HDMI. Since the upper-bound is the same, we'll just do
     704                 :            :          * the stupid thing instead of polling on one and not the other.
     705                 :            :          */
     706                 :          0 :         wait_remaining_ms_from_jiffies(r0_prime_gen_start, 300);
     707                 :            : 
     708                 :          0 :         tries = 3;
     709                 :            : 
     710                 :            :         /*
     711                 :            :          * DP HDCP Spec mandates the two more reattempt to read R0, incase
     712                 :            :          * of R0 mismatch.
     713                 :            :          */
     714         [ #  # ]:          0 :         for (i = 0; i < tries; i++) {
     715                 :          0 :                 ri.reg = 0;
     716                 :          0 :                 ret = shim->read_ri_prime(intel_dig_port, ri.shim);
     717         [ #  # ]:          0 :                 if (ret)
     718                 :          0 :                         return ret;
     719         [ #  # ]:          0 :                 I915_WRITE(HDCP_RPRIME(dev_priv, cpu_transcoder, port), ri.reg);
     720                 :            : 
     721                 :            :                 /* Wait for Ri prime match */
     722   [ #  #  #  #  :          0 :                 if (!wait_for(I915_READ(HDCP_STATUS(dev_priv, cpu_transcoder,
          #  #  #  #  #  
                      # ]
     723                 :            :                                                     port)) &
     724                 :            :                     (HDCP_STATUS_RI_MATCH | HDCP_STATUS_ENC), 1))
     725                 :            :                         break;
     726                 :            :         }
     727                 :            : 
     728         [ #  # ]:          0 :         if (i == tries) {
     729         [ #  # ]:          0 :                 DRM_DEBUG_KMS("Timed out waiting for Ri prime match (%x)\n",
     730                 :            :                               I915_READ(HDCP_STATUS(dev_priv, cpu_transcoder,
     731                 :            :                                                     port)));
     732                 :          0 :                 return -ETIMEDOUT;
     733                 :            :         }
     734                 :            : 
     735                 :            :         /* Wait for encryption confirmation */
     736   [ #  #  #  # ]:          0 :         if (intel_de_wait_for_set(dev_priv,
     737                 :            :                                   HDCP_STATUS(dev_priv, cpu_transcoder, port),
     738                 :            :                                   HDCP_STATUS_ENC,
     739                 :            :                                   ENCRYPT_STATUS_CHANGE_TIMEOUT_MS)) {
     740                 :          0 :                 DRM_ERROR("Timed out waiting for encryption\n");
     741                 :          0 :                 return -ETIMEDOUT;
     742                 :            :         }
     743                 :            : 
     744                 :            :         /*
     745                 :            :          * XXX: If we have MST-connected devices, we need to enable encryption
     746                 :            :          * on those as well.
     747                 :            :          */
     748                 :            : 
     749         [ #  # ]:          0 :         if (repeater_present)
     750                 :          0 :                 return intel_hdcp_auth_downstream(connector);
     751                 :            : 
     752                 :          0 :         DRM_DEBUG_KMS("HDCP is enabled (no repeater present)\n");
     753                 :          0 :         return 0;
     754                 :            : }
     755                 :            : 
     756                 :          0 : static int _intel_hdcp_disable(struct intel_connector *connector)
     757                 :            : {
     758                 :          0 :         struct intel_hdcp *hdcp = &connector->hdcp;
     759                 :          0 :         struct drm_i915_private *dev_priv = connector->base.dev->dev_private;
     760         [ #  # ]:          0 :         struct intel_digital_port *intel_dig_port = conn_to_dig_port(connector);
     761                 :          0 :         enum port port = intel_dig_port->base.port;
     762                 :          0 :         enum transcoder cpu_transcoder = hdcp->cpu_transcoder;
     763                 :          0 :         int ret;
     764                 :            : 
     765                 :          0 :         DRM_DEBUG_KMS("[%s:%d] HDCP is being disabled...\n",
     766                 :            :                       connector->base.name, connector->base.base.id);
     767                 :            : 
     768                 :          0 :         hdcp->hdcp_encrypted = false;
     769         [ #  # ]:          0 :         I915_WRITE(HDCP_CONF(dev_priv, cpu_transcoder, port), 0);
     770   [ #  #  #  # ]:          0 :         if (intel_de_wait_for_clear(dev_priv,
     771                 :            :                                     HDCP_STATUS(dev_priv, cpu_transcoder, port),
     772                 :            :                                     ~0, ENCRYPT_STATUS_CHANGE_TIMEOUT_MS)) {
     773                 :          0 :                 DRM_ERROR("Failed to disable HDCP, timeout clearing status\n");
     774                 :          0 :                 return -ETIMEDOUT;
     775                 :            :         }
     776                 :            : 
     777                 :          0 :         ret = hdcp->shim->toggle_signalling(intel_dig_port, false);
     778         [ #  # ]:          0 :         if (ret) {
     779                 :          0 :                 DRM_ERROR("Failed to disable HDCP signalling\n");
     780                 :          0 :                 return ret;
     781                 :            :         }
     782                 :            : 
     783                 :          0 :         DRM_DEBUG_KMS("HDCP is disabled\n");
     784                 :          0 :         return 0;
     785                 :            : }
     786                 :            : 
     787                 :          0 : static int _intel_hdcp_enable(struct intel_connector *connector)
     788                 :            : {
     789                 :          0 :         struct intel_hdcp *hdcp = &connector->hdcp;
     790                 :          0 :         struct drm_i915_private *dev_priv = connector->base.dev->dev_private;
     791                 :          0 :         int i, ret, tries = 3;
     792                 :            : 
     793                 :          0 :         DRM_DEBUG_KMS("[%s:%d] HDCP is being enabled...\n",
     794                 :            :                       connector->base.name, connector->base.base.id);
     795                 :            : 
     796         [ #  # ]:          0 :         if (!hdcp_key_loadable(dev_priv)) {
     797                 :          0 :                 DRM_ERROR("HDCP key Load is not possible\n");
     798                 :          0 :                 return -ENXIO;
     799                 :            :         }
     800                 :            : 
     801         [ #  # ]:          0 :         for (i = 0; i < KEY_LOAD_TRIES; i++) {
     802                 :          0 :                 ret = intel_hdcp_load_keys(dev_priv);
     803         [ #  # ]:          0 :                 if (!ret)
     804                 :            :                         break;
     805                 :          0 :                 intel_hdcp_clear_keys(dev_priv);
     806                 :            :         }
     807         [ #  # ]:          0 :         if (ret) {
     808                 :          0 :                 DRM_ERROR("Could not load HDCP keys, (%d)\n", ret);
     809                 :          0 :                 return ret;
     810                 :            :         }
     811                 :            : 
     812                 :            :         /* Incase of authentication failures, HDCP spec expects reauth. */
     813         [ #  # ]:          0 :         for (i = 0; i < tries; i++) {
     814                 :          0 :                 ret = intel_hdcp_auth(connector);
     815         [ #  # ]:          0 :                 if (!ret) {
     816                 :          0 :                         hdcp->hdcp_encrypted = true;
     817                 :          0 :                         return 0;
     818                 :            :                 }
     819                 :            : 
     820                 :          0 :                 DRM_DEBUG_KMS("HDCP Auth failure (%d)\n", ret);
     821                 :            : 
     822                 :            :                 /* Ensuring HDCP encryption and signalling are stopped. */
     823                 :          0 :                 _intel_hdcp_disable(connector);
     824                 :            :         }
     825                 :            : 
     826                 :          0 :         DRM_DEBUG_KMS("HDCP authentication failed (%d tries/%d)\n", tries, ret);
     827                 :          0 :         return ret;
     828                 :            : }
     829                 :            : 
     830                 :            : static inline
     831                 :          0 : struct intel_connector *intel_hdcp_to_connector(struct intel_hdcp *hdcp)
     832                 :            : {
     833                 :          0 :         return container_of(hdcp, struct intel_connector, hdcp);
     834                 :            : }
     835                 :            : 
     836                 :            : /* Implements Part 3 of the HDCP authorization procedure */
     837                 :          0 : static int intel_hdcp_check_link(struct intel_connector *connector)
     838                 :            : {
     839                 :          0 :         struct intel_hdcp *hdcp = &connector->hdcp;
     840                 :          0 :         struct drm_i915_private *dev_priv = connector->base.dev->dev_private;
     841         [ #  # ]:          0 :         struct intel_digital_port *intel_dig_port = conn_to_dig_port(connector);
     842                 :          0 :         enum port port = intel_dig_port->base.port;
     843                 :          0 :         enum transcoder cpu_transcoder;
     844                 :          0 :         int ret = 0;
     845                 :            : 
     846                 :          0 :         mutex_lock(&hdcp->mutex);
     847                 :          0 :         cpu_transcoder = hdcp->cpu_transcoder;
     848                 :            : 
     849                 :            :         /* Check_link valid only when HDCP1.4 is enabled */
     850         [ #  # ]:          0 :         if (hdcp->value != DRM_MODE_CONTENT_PROTECTION_ENABLED ||
     851         [ #  # ]:          0 :             !hdcp->hdcp_encrypted) {
     852                 :          0 :                 ret = -EINVAL;
     853                 :          0 :                 goto out;
     854                 :            :         }
     855                 :            : 
     856   [ #  #  #  # ]:          0 :         if (WARN_ON(!intel_hdcp_in_use(dev_priv, cpu_transcoder, port))) {
     857         [ #  # ]:          0 :                 DRM_ERROR("%s:%d HDCP link stopped encryption,%x\n",
     858                 :            :                           connector->base.name, connector->base.base.id,
     859                 :            :                           I915_READ(HDCP_STATUS(dev_priv, cpu_transcoder,
     860                 :            :                                                 port)));
     861                 :          0 :                 ret = -ENXIO;
     862                 :          0 :                 hdcp->value = DRM_MODE_CONTENT_PROTECTION_DESIRED;
     863                 :          0 :                 schedule_work(&hdcp->prop_work);
     864                 :          0 :                 goto out;
     865                 :            :         }
     866                 :            : 
     867         [ #  # ]:          0 :         if (hdcp->shim->check_link(intel_dig_port)) {
     868         [ #  # ]:          0 :                 if (hdcp->value != DRM_MODE_CONTENT_PROTECTION_UNDESIRED) {
     869                 :          0 :                         hdcp->value = DRM_MODE_CONTENT_PROTECTION_ENABLED;
     870                 :          0 :                         schedule_work(&hdcp->prop_work);
     871                 :            :                 }
     872                 :          0 :                 goto out;
     873                 :            :         }
     874                 :            : 
     875                 :          0 :         DRM_DEBUG_KMS("[%s:%d] HDCP link failed, retrying authentication\n",
     876                 :            :                       connector->base.name, connector->base.base.id);
     877                 :            : 
     878                 :          0 :         ret = _intel_hdcp_disable(connector);
     879         [ #  # ]:          0 :         if (ret) {
     880                 :          0 :                 DRM_ERROR("Failed to disable hdcp (%d)\n", ret);
     881                 :          0 :                 hdcp->value = DRM_MODE_CONTENT_PROTECTION_DESIRED;
     882                 :          0 :                 schedule_work(&hdcp->prop_work);
     883                 :          0 :                 goto out;
     884                 :            :         }
     885                 :            : 
     886                 :          0 :         ret = _intel_hdcp_enable(connector);
     887         [ #  # ]:          0 :         if (ret) {
     888                 :          0 :                 DRM_ERROR("Failed to enable hdcp (%d)\n", ret);
     889                 :          0 :                 hdcp->value = DRM_MODE_CONTENT_PROTECTION_DESIRED;
     890                 :          0 :                 schedule_work(&hdcp->prop_work);
     891                 :          0 :                 goto out;
     892                 :            :         }
     893                 :            : 
     894                 :          0 : out:
     895                 :          0 :         mutex_unlock(&hdcp->mutex);
     896                 :          0 :         return ret;
     897                 :            : }
     898                 :            : 
     899                 :          0 : static void intel_hdcp_prop_work(struct work_struct *work)
     900                 :            : {
     901                 :          0 :         struct intel_hdcp *hdcp = container_of(work, struct intel_hdcp,
     902                 :            :                                                prop_work);
     903                 :          0 :         struct intel_connector *connector = intel_hdcp_to_connector(hdcp);
     904                 :          0 :         struct drm_device *dev = connector->base.dev;
     905                 :            : 
     906                 :          0 :         drm_modeset_lock(&dev->mode_config.connection_mutex, NULL);
     907                 :          0 :         mutex_lock(&hdcp->mutex);
     908                 :            : 
     909                 :            :         /*
     910                 :            :          * This worker is only used to flip between ENABLED/DESIRED. Either of
     911                 :            :          * those to UNDESIRED is handled by core. If value == UNDESIRED,
     912                 :            :          * we're running just after hdcp has been disabled, so just exit
     913                 :            :          */
     914         [ #  # ]:          0 :         if (hdcp->value != DRM_MODE_CONTENT_PROTECTION_UNDESIRED)
     915                 :          0 :                 drm_hdcp_update_content_protection(&connector->base,
     916                 :            :                                                    hdcp->value);
     917                 :            : 
     918                 :          0 :         mutex_unlock(&hdcp->mutex);
     919                 :          0 :         drm_modeset_unlock(&dev->mode_config.connection_mutex);
     920                 :          0 : }
     921                 :            : 
     922                 :          0 : bool is_hdcp_supported(struct drm_i915_private *dev_priv, enum port port)
     923                 :            : {
     924                 :            :         /* PORT E doesn't have HDCP, and PORT F is disabled */
     925   [ #  #  #  # ]:          0 :         return INTEL_INFO(dev_priv)->display.has_hdcp && port < PORT_E;
     926                 :            : }
     927                 :            : 
     928                 :            : static int
     929                 :          0 : hdcp2_prepare_ake_init(struct intel_connector *connector,
     930                 :            :                        struct hdcp2_ake_init *ake_data)
     931                 :            : {
     932                 :          0 :         struct hdcp_port_data *data = &connector->hdcp.port_data;
     933                 :          0 :         struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
     934                 :          0 :         struct i915_hdcp_comp_master *comp;
     935                 :          0 :         int ret;
     936                 :            : 
     937                 :          0 :         mutex_lock(&dev_priv->hdcp_comp_mutex);
     938                 :          0 :         comp = dev_priv->hdcp_master;
     939                 :            : 
     940   [ #  #  #  # ]:          0 :         if (!comp || !comp->ops) {
     941                 :          0 :                 mutex_unlock(&dev_priv->hdcp_comp_mutex);
     942                 :          0 :                 return -EINVAL;
     943                 :            :         }
     944                 :            : 
     945                 :          0 :         ret = comp->ops->initiate_hdcp2_session(comp->mei_dev, data, ake_data);
     946         [ #  # ]:          0 :         if (ret)
     947                 :          0 :                 DRM_DEBUG_KMS("Prepare_ake_init failed. %d\n", ret);
     948                 :          0 :         mutex_unlock(&dev_priv->hdcp_comp_mutex);
     949                 :            : 
     950                 :          0 :         return ret;
     951                 :            : }
     952                 :            : 
     953                 :            : static int
     954                 :          0 : hdcp2_verify_rx_cert_prepare_km(struct intel_connector *connector,
     955                 :            :                                 struct hdcp2_ake_send_cert *rx_cert,
     956                 :            :                                 bool *paired,
     957                 :            :                                 struct hdcp2_ake_no_stored_km *ek_pub_km,
     958                 :            :                                 size_t *msg_sz)
     959                 :            : {
     960                 :          0 :         struct hdcp_port_data *data = &connector->hdcp.port_data;
     961                 :          0 :         struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
     962                 :          0 :         struct i915_hdcp_comp_master *comp;
     963                 :          0 :         int ret;
     964                 :            : 
     965                 :          0 :         mutex_lock(&dev_priv->hdcp_comp_mutex);
     966                 :          0 :         comp = dev_priv->hdcp_master;
     967                 :            : 
     968   [ #  #  #  # ]:          0 :         if (!comp || !comp->ops) {
     969                 :          0 :                 mutex_unlock(&dev_priv->hdcp_comp_mutex);
     970                 :          0 :                 return -EINVAL;
     971                 :            :         }
     972                 :            : 
     973                 :          0 :         ret = comp->ops->verify_receiver_cert_prepare_km(comp->mei_dev, data,
     974                 :            :                                                          rx_cert, paired,
     975                 :            :                                                          ek_pub_km, msg_sz);
     976         [ #  # ]:          0 :         if (ret < 0)
     977                 :          0 :                 DRM_DEBUG_KMS("Verify rx_cert failed. %d\n", ret);
     978                 :          0 :         mutex_unlock(&dev_priv->hdcp_comp_mutex);
     979                 :            : 
     980                 :          0 :         return ret;
     981                 :            : }
     982                 :            : 
     983                 :          0 : static int hdcp2_verify_hprime(struct intel_connector *connector,
     984                 :            :                                struct hdcp2_ake_send_hprime *rx_hprime)
     985                 :            : {
     986                 :          0 :         struct hdcp_port_data *data = &connector->hdcp.port_data;
     987                 :          0 :         struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
     988                 :          0 :         struct i915_hdcp_comp_master *comp;
     989                 :          0 :         int ret;
     990                 :            : 
     991                 :          0 :         mutex_lock(&dev_priv->hdcp_comp_mutex);
     992                 :          0 :         comp = dev_priv->hdcp_master;
     993                 :            : 
     994   [ #  #  #  # ]:          0 :         if (!comp || !comp->ops) {
     995                 :          0 :                 mutex_unlock(&dev_priv->hdcp_comp_mutex);
     996                 :          0 :                 return -EINVAL;
     997                 :            :         }
     998                 :            : 
     999                 :          0 :         ret = comp->ops->verify_hprime(comp->mei_dev, data, rx_hprime);
    1000         [ #  # ]:          0 :         if (ret < 0)
    1001                 :          0 :                 DRM_DEBUG_KMS("Verify hprime failed. %d\n", ret);
    1002                 :          0 :         mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1003                 :            : 
    1004                 :          0 :         return ret;
    1005                 :            : }
    1006                 :            : 
    1007                 :            : static int
    1008                 :          0 : hdcp2_store_pairing_info(struct intel_connector *connector,
    1009                 :            :                          struct hdcp2_ake_send_pairing_info *pairing_info)
    1010                 :            : {
    1011                 :          0 :         struct hdcp_port_data *data = &connector->hdcp.port_data;
    1012                 :          0 :         struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
    1013                 :          0 :         struct i915_hdcp_comp_master *comp;
    1014                 :          0 :         int ret;
    1015                 :            : 
    1016                 :          0 :         mutex_lock(&dev_priv->hdcp_comp_mutex);
    1017                 :          0 :         comp = dev_priv->hdcp_master;
    1018                 :            : 
    1019   [ #  #  #  # ]:          0 :         if (!comp || !comp->ops) {
    1020                 :          0 :                 mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1021                 :          0 :                 return -EINVAL;
    1022                 :            :         }
    1023                 :            : 
    1024                 :          0 :         ret = comp->ops->store_pairing_info(comp->mei_dev, data, pairing_info);
    1025         [ #  # ]:          0 :         if (ret < 0)
    1026                 :          0 :                 DRM_DEBUG_KMS("Store pairing info failed. %d\n", ret);
    1027                 :          0 :         mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1028                 :            : 
    1029                 :          0 :         return ret;
    1030                 :            : }
    1031                 :            : 
    1032                 :            : static int
    1033                 :          0 : hdcp2_prepare_lc_init(struct intel_connector *connector,
    1034                 :            :                       struct hdcp2_lc_init *lc_init)
    1035                 :            : {
    1036                 :          0 :         struct hdcp_port_data *data = &connector->hdcp.port_data;
    1037                 :          0 :         struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
    1038                 :          0 :         struct i915_hdcp_comp_master *comp;
    1039                 :          0 :         int ret;
    1040                 :            : 
    1041                 :          0 :         mutex_lock(&dev_priv->hdcp_comp_mutex);
    1042                 :          0 :         comp = dev_priv->hdcp_master;
    1043                 :            : 
    1044   [ #  #  #  # ]:          0 :         if (!comp || !comp->ops) {
    1045                 :          0 :                 mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1046                 :          0 :                 return -EINVAL;
    1047                 :            :         }
    1048                 :            : 
    1049                 :          0 :         ret = comp->ops->initiate_locality_check(comp->mei_dev, data, lc_init);
    1050         [ #  # ]:          0 :         if (ret < 0)
    1051                 :          0 :                 DRM_DEBUG_KMS("Prepare lc_init failed. %d\n", ret);
    1052                 :          0 :         mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1053                 :            : 
    1054                 :          0 :         return ret;
    1055                 :            : }
    1056                 :            : 
    1057                 :            : static int
    1058                 :          0 : hdcp2_verify_lprime(struct intel_connector *connector,
    1059                 :            :                     struct hdcp2_lc_send_lprime *rx_lprime)
    1060                 :            : {
    1061                 :          0 :         struct hdcp_port_data *data = &connector->hdcp.port_data;
    1062                 :          0 :         struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
    1063                 :          0 :         struct i915_hdcp_comp_master *comp;
    1064                 :          0 :         int ret;
    1065                 :            : 
    1066                 :          0 :         mutex_lock(&dev_priv->hdcp_comp_mutex);
    1067                 :          0 :         comp = dev_priv->hdcp_master;
    1068                 :            : 
    1069   [ #  #  #  # ]:          0 :         if (!comp || !comp->ops) {
    1070                 :          0 :                 mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1071                 :          0 :                 return -EINVAL;
    1072                 :            :         }
    1073                 :            : 
    1074                 :          0 :         ret = comp->ops->verify_lprime(comp->mei_dev, data, rx_lprime);
    1075         [ #  # ]:          0 :         if (ret < 0)
    1076                 :          0 :                 DRM_DEBUG_KMS("Verify L_Prime failed. %d\n", ret);
    1077                 :          0 :         mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1078                 :            : 
    1079                 :          0 :         return ret;
    1080                 :            : }
    1081                 :            : 
    1082                 :          0 : static int hdcp2_prepare_skey(struct intel_connector *connector,
    1083                 :            :                               struct hdcp2_ske_send_eks *ske_data)
    1084                 :            : {
    1085                 :          0 :         struct hdcp_port_data *data = &connector->hdcp.port_data;
    1086                 :          0 :         struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
    1087                 :          0 :         struct i915_hdcp_comp_master *comp;
    1088                 :          0 :         int ret;
    1089                 :            : 
    1090                 :          0 :         mutex_lock(&dev_priv->hdcp_comp_mutex);
    1091                 :          0 :         comp = dev_priv->hdcp_master;
    1092                 :            : 
    1093   [ #  #  #  # ]:          0 :         if (!comp || !comp->ops) {
    1094                 :          0 :                 mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1095                 :          0 :                 return -EINVAL;
    1096                 :            :         }
    1097                 :            : 
    1098                 :          0 :         ret = comp->ops->get_session_key(comp->mei_dev, data, ske_data);
    1099         [ #  # ]:          0 :         if (ret < 0)
    1100                 :          0 :                 DRM_DEBUG_KMS("Get session key failed. %d\n", ret);
    1101                 :          0 :         mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1102                 :            : 
    1103                 :          0 :         return ret;
    1104                 :            : }
    1105                 :            : 
    1106                 :            : static int
    1107                 :          0 : hdcp2_verify_rep_topology_prepare_ack(struct intel_connector *connector,
    1108                 :            :                                       struct hdcp2_rep_send_receiverid_list
    1109                 :            :                                                                 *rep_topology,
    1110                 :            :                                       struct hdcp2_rep_send_ack *rep_send_ack)
    1111                 :            : {
    1112                 :          0 :         struct hdcp_port_data *data = &connector->hdcp.port_data;
    1113                 :          0 :         struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
    1114                 :          0 :         struct i915_hdcp_comp_master *comp;
    1115                 :          0 :         int ret;
    1116                 :            : 
    1117                 :          0 :         mutex_lock(&dev_priv->hdcp_comp_mutex);
    1118                 :          0 :         comp = dev_priv->hdcp_master;
    1119                 :            : 
    1120   [ #  #  #  # ]:          0 :         if (!comp || !comp->ops) {
    1121                 :          0 :                 mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1122                 :          0 :                 return -EINVAL;
    1123                 :            :         }
    1124                 :            : 
    1125                 :          0 :         ret = comp->ops->repeater_check_flow_prepare_ack(comp->mei_dev, data,
    1126                 :            :                                                          rep_topology,
    1127                 :            :                                                          rep_send_ack);
    1128         [ #  # ]:          0 :         if (ret < 0)
    1129                 :          0 :                 DRM_DEBUG_KMS("Verify rep topology failed. %d\n", ret);
    1130                 :          0 :         mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1131                 :            : 
    1132                 :          0 :         return ret;
    1133                 :            : }
    1134                 :            : 
    1135                 :            : static int
    1136                 :          0 : hdcp2_verify_mprime(struct intel_connector *connector,
    1137                 :            :                     struct hdcp2_rep_stream_ready *stream_ready)
    1138                 :            : {
    1139                 :          0 :         struct hdcp_port_data *data = &connector->hdcp.port_data;
    1140                 :          0 :         struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
    1141                 :          0 :         struct i915_hdcp_comp_master *comp;
    1142                 :          0 :         int ret;
    1143                 :            : 
    1144                 :          0 :         mutex_lock(&dev_priv->hdcp_comp_mutex);
    1145                 :          0 :         comp = dev_priv->hdcp_master;
    1146                 :            : 
    1147   [ #  #  #  # ]:          0 :         if (!comp || !comp->ops) {
    1148                 :          0 :                 mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1149                 :          0 :                 return -EINVAL;
    1150                 :            :         }
    1151                 :            : 
    1152                 :          0 :         ret = comp->ops->verify_mprime(comp->mei_dev, data, stream_ready);
    1153         [ #  # ]:          0 :         if (ret < 0)
    1154                 :          0 :                 DRM_DEBUG_KMS("Verify mprime failed. %d\n", ret);
    1155                 :          0 :         mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1156                 :            : 
    1157                 :          0 :         return ret;
    1158                 :            : }
    1159                 :            : 
    1160                 :          0 : static int hdcp2_authenticate_port(struct intel_connector *connector)
    1161                 :            : {
    1162                 :          0 :         struct hdcp_port_data *data = &connector->hdcp.port_data;
    1163                 :          0 :         struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
    1164                 :          0 :         struct i915_hdcp_comp_master *comp;
    1165                 :          0 :         int ret;
    1166                 :            : 
    1167                 :          0 :         mutex_lock(&dev_priv->hdcp_comp_mutex);
    1168                 :          0 :         comp = dev_priv->hdcp_master;
    1169                 :            : 
    1170   [ #  #  #  # ]:          0 :         if (!comp || !comp->ops) {
    1171                 :          0 :                 mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1172                 :          0 :                 return -EINVAL;
    1173                 :            :         }
    1174                 :            : 
    1175                 :          0 :         ret = comp->ops->enable_hdcp_authentication(comp->mei_dev, data);
    1176         [ #  # ]:          0 :         if (ret < 0)
    1177                 :          0 :                 DRM_DEBUG_KMS("Enable hdcp auth failed. %d\n", ret);
    1178                 :          0 :         mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1179                 :            : 
    1180                 :          0 :         return ret;
    1181                 :            : }
    1182                 :            : 
    1183                 :          0 : static int hdcp2_close_mei_session(struct intel_connector *connector)
    1184                 :            : {
    1185                 :          0 :         struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
    1186                 :          0 :         struct i915_hdcp_comp_master *comp;
    1187                 :          0 :         int ret;
    1188                 :            : 
    1189                 :          0 :         mutex_lock(&dev_priv->hdcp_comp_mutex);
    1190                 :          0 :         comp = dev_priv->hdcp_master;
    1191                 :            : 
    1192   [ #  #  #  # ]:          0 :         if (!comp || !comp->ops) {
    1193                 :          0 :                 mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1194                 :          0 :                 return -EINVAL;
    1195                 :            :         }
    1196                 :            : 
    1197                 :          0 :         ret = comp->ops->close_hdcp_session(comp->mei_dev,
    1198                 :            :                                              &connector->hdcp.port_data);
    1199                 :          0 :         mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1200                 :            : 
    1201                 :          0 :         return ret;
    1202                 :            : }
    1203                 :            : 
    1204                 :          0 : static int hdcp2_deauthenticate_port(struct intel_connector *connector)
    1205                 :            : {
    1206                 :          0 :         return hdcp2_close_mei_session(connector);
    1207                 :            : }
    1208                 :            : 
    1209                 :            : /* Authentication flow starts from here */
    1210                 :          0 : static int hdcp2_authentication_key_exchange(struct intel_connector *connector)
    1211                 :            : {
    1212         [ #  # ]:          0 :         struct intel_digital_port *intel_dig_port = conn_to_dig_port(connector);
    1213                 :          0 :         struct intel_hdcp *hdcp = &connector->hdcp;
    1214                 :          0 :         struct drm_device *dev = connector->base.dev;
    1215                 :          0 :         union {
    1216                 :            :                 struct hdcp2_ake_init ake_init;
    1217                 :            :                 struct hdcp2_ake_send_cert send_cert;
    1218                 :            :                 struct hdcp2_ake_no_stored_km no_stored_km;
    1219                 :            :                 struct hdcp2_ake_send_hprime send_hprime;
    1220                 :            :                 struct hdcp2_ake_send_pairing_info pairing_info;
    1221                 :            :         } msgs;
    1222                 :          0 :         const struct intel_hdcp_shim *shim = hdcp->shim;
    1223                 :          0 :         size_t size;
    1224                 :          0 :         int ret;
    1225                 :            : 
    1226                 :            :         /* Init for seq_num */
    1227                 :          0 :         hdcp->seq_num_v = 0;
    1228                 :          0 :         hdcp->seq_num_m = 0;
    1229                 :            : 
    1230                 :          0 :         ret = hdcp2_prepare_ake_init(connector, &msgs.ake_init);
    1231         [ #  # ]:          0 :         if (ret < 0)
    1232                 :            :                 return ret;
    1233                 :            : 
    1234                 :          0 :         ret = shim->write_2_2_msg(intel_dig_port, &msgs.ake_init,
    1235                 :            :                                   sizeof(msgs.ake_init));
    1236         [ #  # ]:          0 :         if (ret < 0)
    1237                 :            :                 return ret;
    1238                 :            : 
    1239                 :          0 :         ret = shim->read_2_2_msg(intel_dig_port, HDCP_2_2_AKE_SEND_CERT,
    1240                 :            :                                  &msgs.send_cert, sizeof(msgs.send_cert));
    1241         [ #  # ]:          0 :         if (ret < 0)
    1242                 :            :                 return ret;
    1243                 :            : 
    1244         [ #  # ]:          0 :         if (msgs.send_cert.rx_caps[0] != HDCP_2_2_RX_CAPS_VERSION_VAL) {
    1245                 :          0 :                 DRM_DEBUG_KMS("cert.rx_caps dont claim HDCP2.2\n");
    1246                 :          0 :                 return -EINVAL;
    1247                 :            :         }
    1248                 :            : 
    1249                 :          0 :         hdcp->is_repeater = HDCP_2_2_RX_REPEATER(msgs.send_cert.rx_caps[2]);
    1250                 :            : 
    1251         [ #  # ]:          0 :         if (drm_hdcp_check_ksvs_revoked(dev, msgs.send_cert.cert_rx.receiver_id,
    1252                 :            :                                         1)) {
    1253                 :          0 :                 DRM_ERROR("Receiver ID is revoked\n");
    1254                 :          0 :                 return -EPERM;
    1255                 :            :         }
    1256                 :            : 
    1257                 :            :         /*
    1258                 :            :          * Here msgs.no_stored_km will hold msgs corresponding to the km
    1259                 :            :          * stored also.
    1260                 :            :          */
    1261                 :          0 :         ret = hdcp2_verify_rx_cert_prepare_km(connector, &msgs.send_cert,
    1262                 :            :                                               &hdcp->is_paired,
    1263                 :            :                                               &msgs.no_stored_km, &size);
    1264         [ #  # ]:          0 :         if (ret < 0)
    1265                 :            :                 return ret;
    1266                 :            : 
    1267                 :          0 :         ret = shim->write_2_2_msg(intel_dig_port, &msgs.no_stored_km, size);
    1268         [ #  # ]:          0 :         if (ret < 0)
    1269                 :            :                 return ret;
    1270                 :            : 
    1271                 :          0 :         ret = shim->read_2_2_msg(intel_dig_port, HDCP_2_2_AKE_SEND_HPRIME,
    1272                 :            :                                  &msgs.send_hprime, sizeof(msgs.send_hprime));
    1273         [ #  # ]:          0 :         if (ret < 0)
    1274                 :            :                 return ret;
    1275                 :            : 
    1276                 :          0 :         ret = hdcp2_verify_hprime(connector, &msgs.send_hprime);
    1277         [ #  # ]:          0 :         if (ret < 0)
    1278                 :            :                 return ret;
    1279                 :            : 
    1280         [ #  # ]:          0 :         if (!hdcp->is_paired) {
    1281                 :            :                 /* Pairing is required */
    1282                 :          0 :                 ret = shim->read_2_2_msg(intel_dig_port,
    1283                 :            :                                          HDCP_2_2_AKE_SEND_PAIRING_INFO,
    1284                 :            :                                          &msgs.pairing_info,
    1285                 :            :                                          sizeof(msgs.pairing_info));
    1286         [ #  # ]:          0 :                 if (ret < 0)
    1287                 :            :                         return ret;
    1288                 :            : 
    1289                 :          0 :                 ret = hdcp2_store_pairing_info(connector, &msgs.pairing_info);
    1290         [ #  # ]:          0 :                 if (ret < 0)
    1291                 :            :                         return ret;
    1292                 :          0 :                 hdcp->is_paired = true;
    1293                 :            :         }
    1294                 :            : 
    1295                 :            :         return 0;
    1296                 :            : }
    1297                 :            : 
    1298                 :          0 : static int hdcp2_locality_check(struct intel_connector *connector)
    1299                 :            : {
    1300         [ #  # ]:          0 :         struct intel_digital_port *intel_dig_port = conn_to_dig_port(connector);
    1301                 :          0 :         struct intel_hdcp *hdcp = &connector->hdcp;
    1302                 :          0 :         union {
    1303                 :            :                 struct hdcp2_lc_init lc_init;
    1304                 :            :                 struct hdcp2_lc_send_lprime send_lprime;
    1305                 :            :         } msgs;
    1306                 :          0 :         const struct intel_hdcp_shim *shim = hdcp->shim;
    1307                 :          0 :         int tries = HDCP2_LC_RETRY_CNT, ret, i;
    1308                 :            : 
    1309         [ #  # ]:          0 :         for (i = 0; i < tries; i++) {
    1310                 :          0 :                 ret = hdcp2_prepare_lc_init(connector, &msgs.lc_init);
    1311         [ #  # ]:          0 :                 if (ret < 0)
    1312                 :          0 :                         continue;
    1313                 :            : 
    1314                 :          0 :                 ret = shim->write_2_2_msg(intel_dig_port, &msgs.lc_init,
    1315                 :            :                                       sizeof(msgs.lc_init));
    1316         [ #  # ]:          0 :                 if (ret < 0)
    1317                 :          0 :                         continue;
    1318                 :            : 
    1319                 :          0 :                 ret = shim->read_2_2_msg(intel_dig_port,
    1320                 :            :                                          HDCP_2_2_LC_SEND_LPRIME,
    1321                 :            :                                          &msgs.send_lprime,
    1322                 :            :                                          sizeof(msgs.send_lprime));
    1323         [ #  # ]:          0 :                 if (ret < 0)
    1324                 :          0 :                         continue;
    1325                 :            : 
    1326                 :          0 :                 ret = hdcp2_verify_lprime(connector, &msgs.send_lprime);
    1327         [ #  # ]:          0 :                 if (!ret)
    1328                 :            :                         break;
    1329                 :            :         }
    1330                 :            : 
    1331                 :          0 :         return ret;
    1332                 :            : }
    1333                 :            : 
    1334                 :          0 : static int hdcp2_session_key_exchange(struct intel_connector *connector)
    1335                 :            : {
    1336         [ #  # ]:          0 :         struct intel_digital_port *intel_dig_port = conn_to_dig_port(connector);
    1337                 :          0 :         struct intel_hdcp *hdcp = &connector->hdcp;
    1338                 :          0 :         struct hdcp2_ske_send_eks send_eks;
    1339                 :          0 :         int ret;
    1340                 :            : 
    1341                 :          0 :         ret = hdcp2_prepare_skey(connector, &send_eks);
    1342         [ #  # ]:          0 :         if (ret < 0)
    1343                 :            :                 return ret;
    1344                 :            : 
    1345                 :          0 :         ret = hdcp->shim->write_2_2_msg(intel_dig_port, &send_eks,
    1346                 :            :                                         sizeof(send_eks));
    1347                 :          0 :         if (ret < 0)
    1348                 :            :                 return ret;
    1349                 :            : 
    1350                 :            :         return 0;
    1351                 :            : }
    1352                 :            : 
    1353                 :            : static
    1354                 :          0 : int hdcp2_propagate_stream_management_info(struct intel_connector *connector)
    1355                 :            : {
    1356         [ #  # ]:          0 :         struct intel_digital_port *intel_dig_port = conn_to_dig_port(connector);
    1357                 :          0 :         struct intel_hdcp *hdcp = &connector->hdcp;
    1358                 :          0 :         union {
    1359                 :            :                 struct hdcp2_rep_stream_manage stream_manage;
    1360                 :            :                 struct hdcp2_rep_stream_ready stream_ready;
    1361                 :            :         } msgs;
    1362                 :          0 :         const struct intel_hdcp_shim *shim = hdcp->shim;
    1363                 :          0 :         int ret;
    1364                 :            : 
    1365                 :            :         /* Prepare RepeaterAuth_Stream_Manage msg */
    1366                 :          0 :         msgs.stream_manage.msg_id = HDCP_2_2_REP_STREAM_MANAGE;
    1367                 :          0 :         drm_hdcp_cpu_to_be24(msgs.stream_manage.seq_num_m, hdcp->seq_num_m);
    1368                 :            : 
    1369                 :            :         /* K no of streams is fixed as 1. Stored as big-endian. */
    1370                 :          0 :         msgs.stream_manage.k = cpu_to_be16(1);
    1371                 :            : 
    1372                 :            :         /* For HDMI this is forced to be 0x0. For DP SST also this is 0x0. */
    1373                 :          0 :         msgs.stream_manage.streams[0].stream_id = 0;
    1374                 :          0 :         msgs.stream_manage.streams[0].stream_type = hdcp->content_type;
    1375                 :            : 
    1376                 :            :         /* Send it to Repeater */
    1377                 :          0 :         ret = shim->write_2_2_msg(intel_dig_port, &msgs.stream_manage,
    1378                 :            :                                   sizeof(msgs.stream_manage));
    1379         [ #  # ]:          0 :         if (ret < 0)
    1380                 :            :                 return ret;
    1381                 :            : 
    1382                 :          0 :         ret = shim->read_2_2_msg(intel_dig_port, HDCP_2_2_REP_STREAM_READY,
    1383                 :            :                                  &msgs.stream_ready, sizeof(msgs.stream_ready));
    1384         [ #  # ]:          0 :         if (ret < 0)
    1385                 :            :                 return ret;
    1386                 :            : 
    1387                 :          0 :         hdcp->port_data.seq_num_m = hdcp->seq_num_m;
    1388                 :          0 :         hdcp->port_data.streams[0].stream_type = hdcp->content_type;
    1389                 :            : 
    1390                 :          0 :         ret = hdcp2_verify_mprime(connector, &msgs.stream_ready);
    1391         [ #  # ]:          0 :         if (ret < 0)
    1392                 :            :                 return ret;
    1393                 :            : 
    1394                 :          0 :         hdcp->seq_num_m++;
    1395                 :            : 
    1396         [ #  # ]:          0 :         if (hdcp->seq_num_m > HDCP_2_2_SEQ_NUM_MAX) {
    1397                 :          0 :                 DRM_DEBUG_KMS("seq_num_m roll over.\n");
    1398                 :          0 :                 return -1;
    1399                 :            :         }
    1400                 :            : 
    1401                 :            :         return 0;
    1402                 :            : }
    1403                 :            : 
    1404                 :            : static
    1405                 :          0 : int hdcp2_authenticate_repeater_topology(struct intel_connector *connector)
    1406                 :            : {
    1407         [ #  # ]:          0 :         struct intel_digital_port *intel_dig_port = conn_to_dig_port(connector);
    1408                 :          0 :         struct intel_hdcp *hdcp = &connector->hdcp;
    1409                 :          0 :         struct drm_device *dev = connector->base.dev;
    1410                 :          0 :         union {
    1411                 :            :                 struct hdcp2_rep_send_receiverid_list recvid_list;
    1412                 :            :                 struct hdcp2_rep_send_ack rep_ack;
    1413                 :            :         } msgs;
    1414                 :          0 :         const struct intel_hdcp_shim *shim = hdcp->shim;
    1415                 :          0 :         u32 seq_num_v, device_cnt;
    1416                 :          0 :         u8 *rx_info;
    1417                 :          0 :         int ret;
    1418                 :            : 
    1419                 :          0 :         ret = shim->read_2_2_msg(intel_dig_port, HDCP_2_2_REP_SEND_RECVID_LIST,
    1420                 :            :                                  &msgs.recvid_list, sizeof(msgs.recvid_list));
    1421         [ #  # ]:          0 :         if (ret < 0)
    1422                 :            :                 return ret;
    1423                 :            : 
    1424                 :          0 :         rx_info = msgs.recvid_list.rx_info;
    1425                 :            : 
    1426         [ #  # ]:          0 :         if (HDCP_2_2_MAX_CASCADE_EXCEEDED(rx_info[1]) ||
    1427                 :            :             HDCP_2_2_MAX_DEVS_EXCEEDED(rx_info[1])) {
    1428                 :          0 :                 DRM_DEBUG_KMS("Topology Max Size Exceeded\n");
    1429                 :          0 :                 return -EINVAL;
    1430                 :            :         }
    1431                 :            : 
    1432                 :            :         /* Converting and Storing the seq_num_v to local variable as DWORD */
    1433         [ #  # ]:          0 :         seq_num_v =
    1434                 :            :                 drm_hdcp_be24_to_cpu((const u8 *)msgs.recvid_list.seq_num_v);
    1435                 :            : 
    1436         [ #  # ]:          0 :         if (seq_num_v < hdcp->seq_num_v) {
    1437                 :            :                 /* Roll over of the seq_num_v from repeater. Reauthenticate. */
    1438                 :          0 :                 DRM_DEBUG_KMS("Seq_num_v roll over.\n");
    1439                 :          0 :                 return -EINVAL;
    1440                 :            :         }
    1441                 :            : 
    1442                 :          0 :         device_cnt = (HDCP_2_2_DEV_COUNT_HI(rx_info[0]) << 4 |
    1443                 :          0 :                       HDCP_2_2_DEV_COUNT_LO(rx_info[1]));
    1444         [ #  # ]:          0 :         if (drm_hdcp_check_ksvs_revoked(dev, msgs.recvid_list.receiver_ids,
    1445                 :            :                                         device_cnt)) {
    1446                 :          0 :                 DRM_ERROR("Revoked receiver ID(s) is in list\n");
    1447                 :          0 :                 return -EPERM;
    1448                 :            :         }
    1449                 :            : 
    1450                 :          0 :         ret = hdcp2_verify_rep_topology_prepare_ack(connector,
    1451                 :            :                                                     &msgs.recvid_list,
    1452                 :            :                                                     &msgs.rep_ack);
    1453         [ #  # ]:          0 :         if (ret < 0)
    1454                 :            :                 return ret;
    1455                 :            : 
    1456                 :          0 :         hdcp->seq_num_v = seq_num_v;
    1457                 :          0 :         ret = shim->write_2_2_msg(intel_dig_port, &msgs.rep_ack,
    1458                 :            :                                   sizeof(msgs.rep_ack));
    1459                 :          0 :         if (ret < 0)
    1460                 :            :                 return ret;
    1461                 :            : 
    1462                 :            :         return 0;
    1463                 :            : }
    1464                 :            : 
    1465                 :          0 : static int hdcp2_authenticate_repeater(struct intel_connector *connector)
    1466                 :            : {
    1467                 :          0 :         int ret;
    1468                 :            : 
    1469                 :          0 :         ret = hdcp2_authenticate_repeater_topology(connector);
    1470         [ #  # ]:          0 :         if (ret < 0)
    1471                 :            :                 return ret;
    1472                 :            : 
    1473                 :          0 :         return hdcp2_propagate_stream_management_info(connector);
    1474                 :            : }
    1475                 :            : 
    1476                 :          0 : static int hdcp2_authenticate_sink(struct intel_connector *connector)
    1477                 :            : {
    1478         [ #  # ]:          0 :         struct intel_digital_port *intel_dig_port = conn_to_dig_port(connector);
    1479                 :          0 :         struct intel_hdcp *hdcp = &connector->hdcp;
    1480                 :          0 :         const struct intel_hdcp_shim *shim = hdcp->shim;
    1481                 :          0 :         int ret;
    1482                 :            : 
    1483                 :          0 :         ret = hdcp2_authentication_key_exchange(connector);
    1484         [ #  # ]:          0 :         if (ret < 0) {
    1485                 :          0 :                 DRM_DEBUG_KMS("AKE Failed. Err : %d\n", ret);
    1486                 :          0 :                 return ret;
    1487                 :            :         }
    1488                 :            : 
    1489                 :          0 :         ret = hdcp2_locality_check(connector);
    1490         [ #  # ]:          0 :         if (ret < 0) {
    1491                 :          0 :                 DRM_DEBUG_KMS("Locality Check failed. Err : %d\n", ret);
    1492                 :          0 :                 return ret;
    1493                 :            :         }
    1494                 :            : 
    1495                 :          0 :         ret = hdcp2_session_key_exchange(connector);
    1496         [ #  # ]:          0 :         if (ret < 0) {
    1497                 :          0 :                 DRM_DEBUG_KMS("SKE Failed. Err : %d\n", ret);
    1498                 :          0 :                 return ret;
    1499                 :            :         }
    1500                 :            : 
    1501         [ #  # ]:          0 :         if (shim->config_stream_type) {
    1502                 :          0 :                 ret = shim->config_stream_type(intel_dig_port,
    1503                 :          0 :                                                hdcp->is_repeater,
    1504                 :          0 :                                                hdcp->content_type);
    1505         [ #  # ]:          0 :                 if (ret < 0)
    1506                 :            :                         return ret;
    1507                 :            :         }
    1508                 :            : 
    1509         [ #  # ]:          0 :         if (hdcp->is_repeater) {
    1510                 :          0 :                 ret = hdcp2_authenticate_repeater(connector);
    1511         [ #  # ]:          0 :                 if (ret < 0) {
    1512                 :          0 :                         DRM_DEBUG_KMS("Repeater Auth Failed. Err: %d\n", ret);
    1513                 :          0 :                         return ret;
    1514                 :            :                 }
    1515                 :            :         }
    1516                 :            : 
    1517                 :          0 :         hdcp->port_data.streams[0].stream_type = hdcp->content_type;
    1518                 :          0 :         ret = hdcp2_authenticate_port(connector);
    1519                 :          0 :         if (ret < 0)
    1520                 :            :                 return ret;
    1521                 :            : 
    1522                 :            :         return ret;
    1523                 :            : }
    1524                 :            : 
    1525                 :          0 : static int hdcp2_enable_encryption(struct intel_connector *connector)
    1526                 :            : {
    1527         [ #  # ]:          0 :         struct intel_digital_port *intel_dig_port = conn_to_dig_port(connector);
    1528         [ #  # ]:          0 :         struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
    1529                 :          0 :         struct intel_hdcp *hdcp = &connector->hdcp;
    1530                 :          0 :         enum port port = connector->encoder->port;
    1531                 :          0 :         enum transcoder cpu_transcoder = hdcp->cpu_transcoder;
    1532                 :          0 :         int ret;
    1533                 :            : 
    1534   [ #  #  #  # ]:          0 :         WARN_ON(I915_READ(HDCP2_STATUS(dev_priv, cpu_transcoder, port)) &
    1535                 :            :                 LINK_ENCRYPTION_STATUS);
    1536         [ #  # ]:          0 :         if (hdcp->shim->toggle_signalling) {
    1537                 :          0 :                 ret = hdcp->shim->toggle_signalling(intel_dig_port, true);
    1538         [ #  # ]:          0 :                 if (ret) {
    1539                 :          0 :                         DRM_ERROR("Failed to enable HDCP signalling. %d\n",
    1540                 :            :                                   ret);
    1541                 :          0 :                         return ret;
    1542                 :            :                 }
    1543                 :            :         }
    1544                 :            : 
    1545   [ #  #  #  # ]:          0 :         if (I915_READ(HDCP2_STATUS(dev_priv, cpu_transcoder, port)) &
    1546                 :            :             LINK_AUTH_STATUS) {
    1547                 :            :                 /* Link is Authenticated. Now set for Encryption */
    1548   [ #  #  #  # ]:          0 :                 I915_WRITE(HDCP2_CTL(dev_priv, cpu_transcoder, port),
    1549                 :            :                            I915_READ(HDCP2_CTL(dev_priv, cpu_transcoder,
    1550                 :            :                                                port)) |
    1551                 :            :                            CTL_LINK_ENCRYPTION_REQ);
    1552                 :            :         }
    1553                 :            : 
    1554         [ #  # ]:          0 :         ret = intel_de_wait_for_set(dev_priv,
    1555                 :            :                                     HDCP2_STATUS(dev_priv, cpu_transcoder,
    1556                 :            :                                                  port),
    1557                 :            :                                     LINK_ENCRYPTION_STATUS,
    1558                 :            :                                     ENCRYPT_STATUS_CHANGE_TIMEOUT_MS);
    1559                 :            : 
    1560                 :          0 :         return ret;
    1561                 :            : }
    1562                 :            : 
    1563                 :          0 : static int hdcp2_disable_encryption(struct intel_connector *connector)
    1564                 :            : {
    1565         [ #  # ]:          0 :         struct intel_digital_port *intel_dig_port = conn_to_dig_port(connector);
    1566         [ #  # ]:          0 :         struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
    1567                 :          0 :         struct intel_hdcp *hdcp = &connector->hdcp;
    1568                 :          0 :         enum port port = connector->encoder->port;
    1569                 :          0 :         enum transcoder cpu_transcoder = hdcp->cpu_transcoder;
    1570                 :          0 :         int ret;
    1571                 :            : 
    1572   [ #  #  #  # ]:          0 :         WARN_ON(!(I915_READ(HDCP2_STATUS(dev_priv, cpu_transcoder, port)) &
    1573                 :            :                             LINK_ENCRYPTION_STATUS));
    1574                 :            : 
    1575   [ #  #  #  # ]:          0 :         I915_WRITE(HDCP2_CTL(dev_priv, cpu_transcoder, port),
    1576                 :            :                    I915_READ(HDCP2_CTL(dev_priv, cpu_transcoder, port)) &
    1577                 :            :                    ~CTL_LINK_ENCRYPTION_REQ);
    1578                 :            : 
    1579         [ #  # ]:          0 :         ret = intel_de_wait_for_clear(dev_priv,
    1580                 :            :                                       HDCP2_STATUS(dev_priv, cpu_transcoder,
    1581                 :            :                                                    port),
    1582                 :            :                                       LINK_ENCRYPTION_STATUS,
    1583                 :            :                                       ENCRYPT_STATUS_CHANGE_TIMEOUT_MS);
    1584         [ #  # ]:          0 :         if (ret == -ETIMEDOUT)
    1585                 :          0 :                 DRM_DEBUG_KMS("Disable Encryption Timedout");
    1586                 :            : 
    1587         [ #  # ]:          0 :         if (hdcp->shim->toggle_signalling) {
    1588                 :          0 :                 ret = hdcp->shim->toggle_signalling(intel_dig_port, false);
    1589         [ #  # ]:          0 :                 if (ret) {
    1590                 :          0 :                         DRM_ERROR("Failed to disable HDCP signalling. %d\n",
    1591                 :            :                                   ret);
    1592                 :          0 :                         return ret;
    1593                 :            :                 }
    1594                 :            :         }
    1595                 :            : 
    1596                 :            :         return ret;
    1597                 :            : }
    1598                 :            : 
    1599                 :          0 : static int hdcp2_authenticate_and_encrypt(struct intel_connector *connector)
    1600                 :            : {
    1601                 :          0 :         int ret, i, tries = 3;
    1602                 :            : 
    1603         [ #  # ]:          0 :         for (i = 0; i < tries; i++) {
    1604                 :          0 :                 ret = hdcp2_authenticate_sink(connector);
    1605         [ #  # ]:          0 :                 if (!ret)
    1606                 :            :                         break;
    1607                 :            : 
    1608                 :            :                 /* Clearing the mei hdcp session */
    1609                 :          0 :                 DRM_DEBUG_KMS("HDCP2.2 Auth %d of %d Failed.(%d)\n",
    1610                 :            :                               i + 1, tries, ret);
    1611         [ #  # ]:          0 :                 if (hdcp2_deauthenticate_port(connector) < 0)
    1612                 :          0 :                         DRM_DEBUG_KMS("Port deauth failed.\n");
    1613                 :            :         }
    1614                 :            : 
    1615         [ #  # ]:          0 :         if (i != tries) {
    1616                 :            :                 /*
    1617                 :            :                  * Ensuring the required 200mSec min time interval between
    1618                 :            :                  * Session Key Exchange and encryption.
    1619                 :            :                  */
    1620                 :          0 :                 msleep(HDCP_2_2_DELAY_BEFORE_ENCRYPTION_EN);
    1621                 :          0 :                 ret = hdcp2_enable_encryption(connector);
    1622         [ #  # ]:          0 :                 if (ret < 0) {
    1623                 :          0 :                         DRM_DEBUG_KMS("Encryption Enable Failed.(%d)\n", ret);
    1624         [ #  # ]:          0 :                         if (hdcp2_deauthenticate_port(connector) < 0)
    1625                 :          0 :                                 DRM_DEBUG_KMS("Port deauth failed.\n");
    1626                 :            :                 }
    1627                 :            :         }
    1628                 :            : 
    1629                 :          0 :         return ret;
    1630                 :            : }
    1631                 :            : 
    1632                 :          0 : static int _intel_hdcp2_enable(struct intel_connector *connector)
    1633                 :            : {
    1634                 :          0 :         struct intel_hdcp *hdcp = &connector->hdcp;
    1635                 :          0 :         int ret;
    1636                 :            : 
    1637                 :          0 :         DRM_DEBUG_KMS("[%s:%d] HDCP2.2 is being enabled. Type: %d\n",
    1638                 :            :                       connector->base.name, connector->base.base.id,
    1639                 :            :                       hdcp->content_type);
    1640                 :            : 
    1641                 :          0 :         ret = hdcp2_authenticate_and_encrypt(connector);
    1642         [ #  # ]:          0 :         if (ret) {
    1643                 :          0 :                 DRM_DEBUG_KMS("HDCP2 Type%d  Enabling Failed. (%d)\n",
    1644                 :            :                               hdcp->content_type, ret);
    1645                 :          0 :                 return ret;
    1646                 :            :         }
    1647                 :            : 
    1648                 :          0 :         DRM_DEBUG_KMS("[%s:%d] HDCP2.2 is enabled. Type %d\n",
    1649                 :            :                       connector->base.name, connector->base.base.id,
    1650                 :            :                       hdcp->content_type);
    1651                 :            : 
    1652                 :          0 :         hdcp->hdcp2_encrypted = true;
    1653                 :          0 :         return 0;
    1654                 :            : }
    1655                 :            : 
    1656                 :          0 : static int _intel_hdcp2_disable(struct intel_connector *connector)
    1657                 :            : {
    1658                 :          0 :         int ret;
    1659                 :            : 
    1660                 :          0 :         DRM_DEBUG_KMS("[%s:%d] HDCP2.2 is being Disabled\n",
    1661                 :            :                       connector->base.name, connector->base.base.id);
    1662                 :            : 
    1663                 :          0 :         ret = hdcp2_disable_encryption(connector);
    1664                 :            : 
    1665         [ #  # ]:          0 :         if (hdcp2_deauthenticate_port(connector) < 0)
    1666                 :          0 :                 DRM_DEBUG_KMS("Port deauth failed.\n");
    1667                 :            : 
    1668                 :          0 :         connector->hdcp.hdcp2_encrypted = false;
    1669                 :            : 
    1670                 :          0 :         return ret;
    1671                 :            : }
    1672                 :            : 
    1673                 :            : /* Implements the Link Integrity Check for HDCP2.2 */
    1674                 :          0 : static int intel_hdcp2_check_link(struct intel_connector *connector)
    1675                 :            : {
    1676         [ #  # ]:          0 :         struct intel_digital_port *intel_dig_port = conn_to_dig_port(connector);
    1677                 :          0 :         struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
    1678                 :          0 :         struct intel_hdcp *hdcp = &connector->hdcp;
    1679                 :          0 :         enum port port = connector->encoder->port;
    1680                 :          0 :         enum transcoder cpu_transcoder;
    1681                 :          0 :         int ret = 0;
    1682                 :            : 
    1683                 :          0 :         mutex_lock(&hdcp->mutex);
    1684                 :          0 :         cpu_transcoder = hdcp->cpu_transcoder;
    1685                 :            : 
    1686                 :            :         /* hdcp2_check_link is expected only when HDCP2.2 is Enabled */
    1687         [ #  # ]:          0 :         if (hdcp->value != DRM_MODE_CONTENT_PROTECTION_ENABLED ||
    1688         [ #  # ]:          0 :             !hdcp->hdcp2_encrypted) {
    1689                 :          0 :                 ret = -EINVAL;
    1690                 :          0 :                 goto out;
    1691                 :            :         }
    1692                 :            : 
    1693   [ #  #  #  # ]:          0 :         if (WARN_ON(!intel_hdcp2_in_use(dev_priv, cpu_transcoder, port))) {
    1694         [ #  # ]:          0 :                 DRM_ERROR("HDCP2.2 link stopped the encryption, %x\n",
    1695                 :            :                           I915_READ(HDCP2_STATUS(dev_priv, cpu_transcoder,
    1696                 :            :                                                  port)));
    1697                 :          0 :                 ret = -ENXIO;
    1698                 :          0 :                 hdcp->value = DRM_MODE_CONTENT_PROTECTION_DESIRED;
    1699                 :          0 :                 schedule_work(&hdcp->prop_work);
    1700                 :          0 :                 goto out;
    1701                 :            :         }
    1702                 :            : 
    1703                 :          0 :         ret = hdcp->shim->check_2_2_link(intel_dig_port);
    1704         [ #  # ]:          0 :         if (ret == HDCP_LINK_PROTECTED) {
    1705         [ #  # ]:          0 :                 if (hdcp->value != DRM_MODE_CONTENT_PROTECTION_UNDESIRED) {
    1706                 :          0 :                         hdcp->value = DRM_MODE_CONTENT_PROTECTION_ENABLED;
    1707                 :          0 :                         schedule_work(&hdcp->prop_work);
    1708                 :            :                 }
    1709                 :          0 :                 goto out;
    1710                 :            :         }
    1711                 :            : 
    1712         [ #  # ]:          0 :         if (ret == HDCP_TOPOLOGY_CHANGE) {
    1713         [ #  # ]:          0 :                 if (hdcp->value == DRM_MODE_CONTENT_PROTECTION_UNDESIRED)
    1714                 :          0 :                         goto out;
    1715                 :            : 
    1716                 :          0 :                 DRM_DEBUG_KMS("HDCP2.2 Downstream topology change\n");
    1717                 :          0 :                 ret = hdcp2_authenticate_repeater_topology(connector);
    1718         [ #  # ]:          0 :                 if (!ret) {
    1719                 :          0 :                         hdcp->value = DRM_MODE_CONTENT_PROTECTION_ENABLED;
    1720                 :          0 :                         schedule_work(&hdcp->prop_work);
    1721                 :          0 :                         goto out;
    1722                 :            :                 }
    1723                 :          0 :                 DRM_DEBUG_KMS("[%s:%d] Repeater topology auth failed.(%d)\n",
    1724                 :            :                               connector->base.name, connector->base.base.id,
    1725                 :            :                               ret);
    1726                 :            :         } else {
    1727                 :          0 :                 DRM_DEBUG_KMS("[%s:%d] HDCP2.2 link failed, retrying auth\n",
    1728                 :            :                               connector->base.name, connector->base.base.id);
    1729                 :            :         }
    1730                 :            : 
    1731                 :          0 :         ret = _intel_hdcp2_disable(connector);
    1732         [ #  # ]:          0 :         if (ret) {
    1733                 :          0 :                 DRM_ERROR("[%s:%d] Failed to disable hdcp2.2 (%d)\n",
    1734                 :            :                           connector->base.name, connector->base.base.id, ret);
    1735                 :          0 :                 hdcp->value = DRM_MODE_CONTENT_PROTECTION_DESIRED;
    1736                 :          0 :                 schedule_work(&hdcp->prop_work);
    1737                 :          0 :                 goto out;
    1738                 :            :         }
    1739                 :            : 
    1740                 :          0 :         ret = _intel_hdcp2_enable(connector);
    1741         [ #  # ]:          0 :         if (ret) {
    1742                 :          0 :                 DRM_DEBUG_KMS("[%s:%d] Failed to enable hdcp2.2 (%d)\n",
    1743                 :            :                               connector->base.name, connector->base.base.id,
    1744                 :            :                               ret);
    1745                 :          0 :                 hdcp->value = DRM_MODE_CONTENT_PROTECTION_DESIRED;
    1746                 :          0 :                 schedule_work(&hdcp->prop_work);
    1747                 :          0 :                 goto out;
    1748                 :            :         }
    1749                 :            : 
    1750                 :          0 : out:
    1751                 :          0 :         mutex_unlock(&hdcp->mutex);
    1752                 :          0 :         return ret;
    1753                 :            : }
    1754                 :            : 
    1755                 :          0 : static void intel_hdcp_check_work(struct work_struct *work)
    1756                 :            : {
    1757                 :          0 :         struct intel_hdcp *hdcp = container_of(to_delayed_work(work),
    1758                 :            :                                                struct intel_hdcp,
    1759                 :            :                                                check_work);
    1760                 :          0 :         struct intel_connector *connector = intel_hdcp_to_connector(hdcp);
    1761                 :            : 
    1762         [ #  # ]:          0 :         if (!intel_hdcp2_check_link(connector))
    1763                 :          0 :                 schedule_delayed_work(&hdcp->check_work,
    1764                 :            :                                       DRM_HDCP2_CHECK_PERIOD_MS);
    1765         [ #  # ]:          0 :         else if (!intel_hdcp_check_link(connector))
    1766                 :          0 :                 schedule_delayed_work(&hdcp->check_work,
    1767                 :            :                                       DRM_HDCP_CHECK_PERIOD_MS);
    1768                 :          0 : }
    1769                 :            : 
    1770                 :          0 : static int i915_hdcp_component_bind(struct device *i915_kdev,
    1771                 :            :                                     struct device *mei_kdev, void *data)
    1772                 :            : {
    1773                 :          0 :         struct drm_i915_private *dev_priv = kdev_to_i915(i915_kdev);
    1774                 :            : 
    1775                 :          0 :         DRM_DEBUG("I915 HDCP comp bind\n");
    1776                 :          0 :         mutex_lock(&dev_priv->hdcp_comp_mutex);
    1777                 :          0 :         dev_priv->hdcp_master = (struct i915_hdcp_comp_master *)data;
    1778                 :          0 :         dev_priv->hdcp_master->mei_dev = mei_kdev;
    1779                 :          0 :         mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1780                 :            : 
    1781                 :          0 :         return 0;
    1782                 :            : }
    1783                 :            : 
    1784                 :          0 : static void i915_hdcp_component_unbind(struct device *i915_kdev,
    1785                 :            :                                        struct device *mei_kdev, void *data)
    1786                 :            : {
    1787                 :          0 :         struct drm_i915_private *dev_priv = kdev_to_i915(i915_kdev);
    1788                 :            : 
    1789                 :          0 :         DRM_DEBUG("I915 HDCP comp unbind\n");
    1790                 :          0 :         mutex_lock(&dev_priv->hdcp_comp_mutex);
    1791                 :          0 :         dev_priv->hdcp_master = NULL;
    1792                 :          0 :         mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1793                 :          0 : }
    1794                 :            : 
    1795                 :            : static const struct component_ops i915_hdcp_component_ops = {
    1796                 :            :         .bind   = i915_hdcp_component_bind,
    1797                 :            :         .unbind = i915_hdcp_component_unbind,
    1798                 :            : };
    1799                 :            : 
    1800                 :            : static inline
    1801                 :            : enum mei_fw_ddi intel_get_mei_fw_ddi_index(enum port port)
    1802                 :            : {
    1803                 :            :         switch (port) {
    1804                 :            :         case PORT_A:
    1805                 :            :                 return MEI_DDI_A;
    1806                 :            :         case PORT_B ... PORT_F:
    1807                 :            :                 return (enum mei_fw_ddi)port;
    1808                 :            :         default:
    1809                 :            :                 return MEI_DDI_INVALID_PORT;
    1810                 :            :         }
    1811                 :            : }
    1812                 :            : 
    1813                 :            : static inline
    1814                 :          0 : enum mei_fw_tc intel_get_mei_fw_tc(enum transcoder cpu_transcoder)
    1815                 :            : {
    1816                 :          0 :         switch (cpu_transcoder) {
    1817                 :          0 :         case TRANSCODER_A ... TRANSCODER_D:
    1818                 :          0 :                 return (enum mei_fw_tc)(cpu_transcoder | 0x10);
    1819                 :            :         default: /* eDP, DSI TRANSCODERS are non HDCP capable */
    1820                 :            :                 return MEI_INVALID_TRANSCODER;
    1821                 :            :         }
    1822                 :            : }
    1823                 :            : 
    1824                 :            : static inline int initialize_hdcp_port_data(struct intel_connector *connector,
    1825                 :            :                                             const struct intel_hdcp_shim *shim)
    1826                 :            : {
    1827                 :            :         struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
    1828                 :            :         struct intel_hdcp *hdcp = &connector->hdcp;
    1829                 :            :         struct hdcp_port_data *data = &hdcp->port_data;
    1830                 :            : 
    1831                 :            :         if (INTEL_GEN(dev_priv) < 12)
    1832                 :            :                 data->fw_ddi =
    1833                 :            :                         intel_get_mei_fw_ddi_index(connector->encoder->port);
    1834                 :            :         else
    1835                 :            :                 /*
    1836                 :            :                  * As per ME FW API expectation, for GEN 12+, fw_ddi is filled
    1837                 :            :                  * with zero(INVALID PORT index).
    1838                 :            :                  */
    1839                 :            :                 data->fw_ddi = MEI_DDI_INVALID_PORT;
    1840                 :            : 
    1841                 :            :         /*
    1842                 :            :          * As associated transcoder is set and modified at modeset, here fw_tc
    1843                 :            :          * is initialized to zero (invalid transcoder index). This will be
    1844                 :            :          * retained for <Gen12 forever.
    1845                 :            :          */
    1846                 :            :         data->fw_tc = MEI_INVALID_TRANSCODER;
    1847                 :            : 
    1848                 :            :         data->port_type = (u8)HDCP_PORT_TYPE_INTEGRATED;
    1849                 :            :         data->protocol = (u8)shim->protocol;
    1850                 :            : 
    1851                 :            :         data->k = 1;
    1852                 :            :         if (!data->streams)
    1853                 :            :                 data->streams = kcalloc(data->k,
    1854                 :            :                                         sizeof(struct hdcp2_streamid_type),
    1855                 :            :                                         GFP_KERNEL);
    1856                 :            :         if (!data->streams) {
    1857                 :            :                 DRM_ERROR("Out of Memory\n");
    1858                 :            :                 return -ENOMEM;
    1859                 :            :         }
    1860                 :            : 
    1861                 :            :         data->streams[0].stream_id = 0;
    1862                 :            :         data->streams[0].stream_type = hdcp->content_type;
    1863                 :            : 
    1864                 :            :         return 0;
    1865                 :            : }
    1866                 :            : 
    1867                 :          0 : static bool is_hdcp2_supported(struct drm_i915_private *dev_priv)
    1868                 :            : {
    1869                 :          0 :         if (!IS_ENABLED(CONFIG_INTEL_MEI_HDCP))
    1870                 :          0 :                 return false;
    1871                 :            : 
    1872                 :            :         return (INTEL_GEN(dev_priv) >= 10 || IS_GEMINILAKE(dev_priv) ||
    1873                 :            :                 IS_KABYLAKE(dev_priv) || IS_COFFEELAKE(dev_priv));
    1874                 :            : }
    1875                 :            : 
    1876                 :          0 : void intel_hdcp_component_init(struct drm_i915_private *dev_priv)
    1877                 :            : {
    1878                 :          0 :         int ret;
    1879                 :            : 
    1880                 :          0 :         if (!is_hdcp2_supported(dev_priv))
    1881                 :          0 :                 return;
    1882                 :            : 
    1883                 :            :         mutex_lock(&dev_priv->hdcp_comp_mutex);
    1884                 :            :         WARN_ON(dev_priv->hdcp_comp_added);
    1885                 :            : 
    1886                 :            :         dev_priv->hdcp_comp_added = true;
    1887                 :            :         mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1888                 :            :         ret = component_add_typed(dev_priv->drm.dev, &i915_hdcp_component_ops,
    1889                 :            :                                   I915_COMPONENT_HDCP);
    1890                 :            :         if (ret < 0) {
    1891                 :            :                 DRM_DEBUG_KMS("Failed at component add(%d)\n", ret);
    1892                 :            :                 mutex_lock(&dev_priv->hdcp_comp_mutex);
    1893                 :            :                 dev_priv->hdcp_comp_added = false;
    1894                 :            :                 mutex_unlock(&dev_priv->hdcp_comp_mutex);
    1895                 :            :                 return;
    1896                 :            :         }
    1897                 :            : }
    1898                 :            : 
    1899                 :            : static void intel_hdcp2_init(struct intel_connector *connector,
    1900                 :            :                              const struct intel_hdcp_shim *shim)
    1901                 :            : {
    1902                 :            :         struct intel_hdcp *hdcp = &connector->hdcp;
    1903                 :            :         int ret;
    1904                 :            : 
    1905                 :            :         ret = initialize_hdcp_port_data(connector, shim);
    1906                 :            :         if (ret) {
    1907                 :            :                 DRM_DEBUG_KMS("Mei hdcp data init failed\n");
    1908                 :            :                 return;
    1909                 :            :         }
    1910                 :            : 
    1911                 :            :         hdcp->hdcp2_supported = true;
    1912                 :            : }
    1913                 :            : 
    1914                 :          0 : int intel_hdcp_init(struct intel_connector *connector,
    1915                 :            :                     const struct intel_hdcp_shim *shim)
    1916                 :            : {
    1917         [ #  # ]:          0 :         struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
    1918                 :          0 :         struct intel_hdcp *hdcp = &connector->hdcp;
    1919                 :          0 :         int ret;
    1920                 :            : 
    1921         [ #  # ]:          0 :         if (!shim)
    1922                 :            :                 return -EINVAL;
    1923                 :            : 
    1924                 :          0 :         if (is_hdcp2_supported(dev_priv))
    1925                 :            :                 intel_hdcp2_init(connector, shim);
    1926                 :            : 
    1927                 :          0 :         ret =
    1928                 :          0 :         drm_connector_attach_content_protection_property(&connector->base,
    1929                 :          0 :                                                          hdcp->hdcp2_supported);
    1930         [ #  # ]:          0 :         if (ret) {
    1931                 :          0 :                 hdcp->hdcp2_supported = false;
    1932                 :          0 :                 kfree(hdcp->port_data.streams);
    1933                 :          0 :                 return ret;
    1934                 :            :         }
    1935                 :            : 
    1936                 :          0 :         hdcp->shim = shim;
    1937                 :          0 :         mutex_init(&hdcp->mutex);
    1938                 :          0 :         INIT_DELAYED_WORK(&hdcp->check_work, intel_hdcp_check_work);
    1939                 :          0 :         INIT_WORK(&hdcp->prop_work, intel_hdcp_prop_work);
    1940                 :          0 :         init_waitqueue_head(&hdcp->cp_irq_queue);
    1941                 :            : 
    1942                 :          0 :         return 0;
    1943                 :            : }
    1944                 :            : 
    1945                 :          0 : int intel_hdcp_enable(struct intel_connector *connector,
    1946                 :            :                       enum transcoder cpu_transcoder, u8 content_type)
    1947                 :            : {
    1948         [ #  # ]:          0 :         struct drm_i915_private *dev_priv = to_i915(connector->base.dev);
    1949                 :          0 :         struct intel_hdcp *hdcp = &connector->hdcp;
    1950                 :          0 :         unsigned long check_link_interval = DRM_HDCP_CHECK_PERIOD_MS;
    1951                 :          0 :         int ret = -EINVAL;
    1952                 :            : 
    1953         [ #  # ]:          0 :         if (!hdcp->shim)
    1954                 :            :                 return -ENOENT;
    1955                 :            : 
    1956                 :          0 :         mutex_lock(&hdcp->mutex);
    1957         [ #  # ]:          0 :         WARN_ON(hdcp->value == DRM_MODE_CONTENT_PROTECTION_ENABLED);
    1958                 :          0 :         hdcp->content_type = content_type;
    1959                 :            : 
    1960         [ #  # ]:          0 :         if (INTEL_GEN(dev_priv) >= 12) {
    1961                 :          0 :                 hdcp->cpu_transcoder = cpu_transcoder;
    1962         [ #  # ]:          0 :                 hdcp->port_data.fw_tc = intel_get_mei_fw_tc(cpu_transcoder);
    1963                 :            :         }
    1964                 :            : 
    1965                 :            :         /*
    1966                 :            :          * Considering that HDCP2.2 is more secure than HDCP1.4, If the setup
    1967                 :            :          * is capable of HDCP2.2, it is preferred to use HDCP2.2.
    1968                 :            :          */
    1969         [ #  # ]:          0 :         if (intel_hdcp2_capable(connector)) {
    1970                 :          0 :                 ret = _intel_hdcp2_enable(connector);
    1971         [ #  # ]:          0 :                 if (!ret)
    1972                 :          0 :                         check_link_interval = DRM_HDCP2_CHECK_PERIOD_MS;
    1973                 :            :         }
    1974                 :            : 
    1975                 :            :         /*
    1976                 :            :          * When HDCP2.2 fails and Content Type is not Type1, HDCP1.4 will
    1977                 :            :          * be attempted.
    1978                 :            :          */
    1979   [ #  #  #  # ]:          0 :         if (ret && intel_hdcp_capable(connector) &&
    1980         [ #  # ]:          0 :             hdcp->content_type != DRM_MODE_HDCP_CONTENT_TYPE1) {
    1981                 :          0 :                 ret = _intel_hdcp_enable(connector);
    1982                 :            :         }
    1983                 :            : 
    1984         [ #  # ]:          0 :         if (!ret) {
    1985                 :          0 :                 schedule_delayed_work(&hdcp->check_work, check_link_interval);
    1986                 :          0 :                 hdcp->value = DRM_MODE_CONTENT_PROTECTION_ENABLED;
    1987                 :          0 :                 schedule_work(&hdcp->prop_work);
    1988                 :            :         }
    1989                 :            : 
    1990                 :          0 :         mutex_unlock(&hdcp->mutex);
    1991                 :          0 :         return ret;
    1992                 :            : }
    1993                 :            : 
    1994                 :          0 : int intel_hdcp_disable(struct intel_connector *connector)
    1995                 :            : {
    1996                 :          0 :         struct intel_hdcp *hdcp = &connector->hdcp;
    1997                 :          0 :         int ret = 0;
    1998                 :            : 
    1999         [ #  # ]:          0 :         if (!hdcp->shim)
    2000                 :            :                 return -ENOENT;
    2001                 :            : 
    2002                 :          0 :         mutex_lock(&hdcp->mutex);
    2003                 :            : 
    2004         [ #  # ]:          0 :         if (hdcp->value != DRM_MODE_CONTENT_PROTECTION_UNDESIRED) {
    2005                 :          0 :                 hdcp->value = DRM_MODE_CONTENT_PROTECTION_UNDESIRED;
    2006         [ #  # ]:          0 :                 if (hdcp->hdcp2_encrypted)
    2007                 :          0 :                         ret = _intel_hdcp2_disable(connector);
    2008         [ #  # ]:          0 :                 else if (hdcp->hdcp_encrypted)
    2009                 :          0 :                         ret = _intel_hdcp_disable(connector);
    2010                 :            :         }
    2011                 :            : 
    2012                 :          0 :         mutex_unlock(&hdcp->mutex);
    2013                 :          0 :         cancel_delayed_work_sync(&hdcp->check_work);
    2014                 :          0 :         return ret;
    2015                 :            : }
    2016                 :            : 
    2017                 :          0 : void intel_hdcp_component_fini(struct drm_i915_private *dev_priv)
    2018                 :            : {
    2019                 :          0 :         mutex_lock(&dev_priv->hdcp_comp_mutex);
    2020         [ #  # ]:          0 :         if (!dev_priv->hdcp_comp_added) {
    2021                 :          0 :                 mutex_unlock(&dev_priv->hdcp_comp_mutex);
    2022                 :          0 :                 return;
    2023                 :            :         }
    2024                 :            : 
    2025                 :          0 :         dev_priv->hdcp_comp_added = false;
    2026                 :          0 :         mutex_unlock(&dev_priv->hdcp_comp_mutex);
    2027                 :            : 
    2028                 :          0 :         component_del(dev_priv->drm.dev, &i915_hdcp_component_ops);
    2029                 :            : }
    2030                 :            : 
    2031                 :          0 : void intel_hdcp_cleanup(struct intel_connector *connector)
    2032                 :            : {
    2033         [ #  # ]:          0 :         if (!connector->hdcp.shim)
    2034                 :            :                 return;
    2035                 :            : 
    2036                 :          0 :         mutex_lock(&connector->hdcp.mutex);
    2037                 :          0 :         kfree(connector->hdcp.port_data.streams);
    2038                 :          0 :         mutex_unlock(&connector->hdcp.mutex);
    2039                 :            : }
    2040                 :            : 
    2041                 :          0 : void intel_hdcp_atomic_check(struct drm_connector *connector,
    2042                 :            :                              struct drm_connector_state *old_state,
    2043                 :            :                              struct drm_connector_state *new_state)
    2044                 :            : {
    2045                 :          0 :         u64 old_cp = old_state->content_protection;
    2046                 :          0 :         u64 new_cp = new_state->content_protection;
    2047                 :          0 :         struct drm_crtc_state *crtc_state;
    2048                 :            : 
    2049         [ #  # ]:          0 :         if (!new_state->crtc) {
    2050                 :            :                 /*
    2051                 :            :                  * If the connector is being disabled with CP enabled, mark it
    2052                 :            :                  * desired so it's re-enabled when the connector is brought back
    2053                 :            :                  */
    2054         [ #  # ]:          0 :                 if (old_cp == DRM_MODE_CONTENT_PROTECTION_ENABLED)
    2055                 :          0 :                         new_state->content_protection =
    2056                 :            :                                 DRM_MODE_CONTENT_PROTECTION_DESIRED;
    2057                 :          0 :                 return;
    2058                 :            :         }
    2059                 :            : 
    2060                 :            :         /*
    2061                 :            :          * Nothing to do if the state didn't change, or HDCP was activated since
    2062                 :            :          * the last commit. And also no change in hdcp content type.
    2063                 :            :          */
    2064         [ #  # ]:          0 :         if (old_cp == new_cp ||
    2065                 :          0 :             (old_cp == DRM_MODE_CONTENT_PROTECTION_DESIRED &&
    2066         [ #  # ]:          0 :              new_cp == DRM_MODE_CONTENT_PROTECTION_ENABLED)) {
    2067                 :          0 :                 if (old_state->hdcp_content_type ==
    2068         [ #  # ]:          0 :                                 new_state->hdcp_content_type)
    2069                 :            :                         return;
    2070                 :            :         }
    2071                 :            : 
    2072                 :          0 :         crtc_state = drm_atomic_get_new_crtc_state(new_state->state,
    2073                 :            :                                                    new_state->crtc);
    2074                 :          0 :         crtc_state->mode_changed = true;
    2075                 :            : }
    2076                 :            : 
    2077                 :            : /* Handles the CP_IRQ raised from the DP HDCP sink */
    2078                 :          0 : void intel_hdcp_handle_cp_irq(struct intel_connector *connector)
    2079                 :            : {
    2080                 :          0 :         struct intel_hdcp *hdcp = &connector->hdcp;
    2081                 :            : 
    2082         [ #  # ]:          0 :         if (!hdcp->shim)
    2083                 :            :                 return;
    2084                 :            : 
    2085                 :          0 :         atomic_inc(&connector->hdcp.cp_irq_count);
    2086                 :          0 :         wake_up_all(&connector->hdcp.cp_irq_queue);
    2087                 :            : 
    2088                 :          0 :         schedule_delayed_work(&hdcp->check_work, 0);
    2089                 :            : }

Generated by: LCOV version 1.14