]> Git Repo - linux.git/blob - drivers/gpu/drm/amd/display/modules/hdcp/hdcp1_execution.c
Merge remote-tracking branch 'spi/for-5.14' into spi-linus
[linux.git] / drivers / gpu / drm / amd / display / modules / hdcp / hdcp1_execution.c
1 /*
2  * Copyright 2019 Advanced Micro Devices, Inc.
3  *
4  * Permission is hereby granted, free of charge, to any person obtaining a
5  * copy of this software and associated documentation files (the "Software"),
6  * to deal in the Software without restriction, including without limitation
7  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8  * and/or sell copies of the Software, and to permit persons to whom the
9  * Software is furnished to do so, subject to the following conditions:
10  *
11  * The above copyright notice and this permission notice shall be included in
12  * all copies or substantial portions of the Software.
13  *
14  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
17  * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
18  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
19  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
20  * OTHER DEALINGS IN THE SOFTWARE.
21  *
22  * Authors: AMD
23  *
24  */
25
26 #include "hdcp.h"
27
28 static inline enum mod_hdcp_status validate_bksv(struct mod_hdcp *hdcp)
29 {
30         uint64_t n = 0;
31         uint8_t count = 0;
32         u8 bksv[sizeof(n)] = { };
33
34         memcpy(bksv, hdcp->auth.msg.hdcp1.bksv, sizeof(hdcp->auth.msg.hdcp1.bksv));
35         n = *(uint64_t *)bksv;
36
37         while (n) {
38                 count++;
39                 n &= (n - 1);
40         }
41         return (count == 20) ? MOD_HDCP_STATUS_SUCCESS :
42                         MOD_HDCP_STATUS_HDCP1_INVALID_BKSV;
43 }
44
45 static inline enum mod_hdcp_status check_ksv_ready(struct mod_hdcp *hdcp)
46 {
47         if (is_dp_hdcp(hdcp))
48                 return (hdcp->auth.msg.hdcp1.bstatus & DP_BSTATUS_READY) ?
49                                 MOD_HDCP_STATUS_SUCCESS :
50                                 MOD_HDCP_STATUS_HDCP1_KSV_LIST_NOT_READY;
51         return (hdcp->auth.msg.hdcp1.bcaps & DRM_HDCP_DDC_BCAPS_KSV_FIFO_READY) ?
52                         MOD_HDCP_STATUS_SUCCESS :
53                         MOD_HDCP_STATUS_HDCP1_KSV_LIST_NOT_READY;
54 }
55
56 static inline enum mod_hdcp_status check_hdcp_capable_dp(struct mod_hdcp *hdcp)
57 {
58         return (hdcp->auth.msg.hdcp1.bcaps & DP_BCAPS_HDCP_CAPABLE) ?
59                         MOD_HDCP_STATUS_SUCCESS :
60                         MOD_HDCP_STATUS_HDCP1_NOT_CAPABLE;
61 }
62
63 static inline enum mod_hdcp_status check_r0p_available_dp(struct mod_hdcp *hdcp)
64 {
65         enum mod_hdcp_status status;
66         if (is_dp_hdcp(hdcp)) {
67                 status = (hdcp->auth.msg.hdcp1.bstatus &
68                                 DP_BSTATUS_R0_PRIME_READY) ?
69                         MOD_HDCP_STATUS_SUCCESS :
70                         MOD_HDCP_STATUS_HDCP1_R0_PRIME_PENDING;
71         } else {
72                 status = MOD_HDCP_STATUS_INVALID_OPERATION;
73         }
74         return status;
75 }
76
77 static inline enum mod_hdcp_status check_link_integrity_dp(
78                 struct mod_hdcp *hdcp)
79 {
80         return (hdcp->auth.msg.hdcp1.bstatus &
81                         DP_BSTATUS_LINK_FAILURE) ?
82                         MOD_HDCP_STATUS_HDCP1_LINK_INTEGRITY_FAILURE :
83                         MOD_HDCP_STATUS_SUCCESS;
84 }
85
86 static inline enum mod_hdcp_status check_no_reauthentication_request_dp(
87                 struct mod_hdcp *hdcp)
88 {
89         return (hdcp->auth.msg.hdcp1.bstatus & DP_BSTATUS_REAUTH_REQ) ?
90                         MOD_HDCP_STATUS_HDCP1_REAUTH_REQUEST_ISSUED :
91                         MOD_HDCP_STATUS_SUCCESS;
92 }
93
94 static inline enum mod_hdcp_status check_no_max_cascade(struct mod_hdcp *hdcp)
95 {
96         enum mod_hdcp_status status;
97
98         if (is_dp_hdcp(hdcp))
99                 status = DRM_HDCP_MAX_CASCADE_EXCEEDED(hdcp->auth.msg.hdcp1.binfo_dp >> 8)
100                                  ? MOD_HDCP_STATUS_HDCP1_MAX_CASCADE_EXCEEDED_FAILURE
101                                  : MOD_HDCP_STATUS_SUCCESS;
102         else
103                 status = DRM_HDCP_MAX_CASCADE_EXCEEDED(hdcp->auth.msg.hdcp1.bstatus >> 8)
104                                  ? MOD_HDCP_STATUS_HDCP1_MAX_CASCADE_EXCEEDED_FAILURE
105                                  : MOD_HDCP_STATUS_SUCCESS;
106         return status;
107 }
108
109 static inline enum mod_hdcp_status check_no_max_devs(struct mod_hdcp *hdcp)
110 {
111         enum mod_hdcp_status status;
112
113         if (is_dp_hdcp(hdcp))
114                 status = DRM_HDCP_MAX_DEVICE_EXCEEDED(hdcp->auth.msg.hdcp1.binfo_dp) ?
115                                 MOD_HDCP_STATUS_HDCP1_MAX_DEVS_EXCEEDED_FAILURE :
116                                 MOD_HDCP_STATUS_SUCCESS;
117         else
118                 status = DRM_HDCP_MAX_DEVICE_EXCEEDED(hdcp->auth.msg.hdcp1.bstatus) ?
119                                 MOD_HDCP_STATUS_HDCP1_MAX_DEVS_EXCEEDED_FAILURE :
120                                 MOD_HDCP_STATUS_SUCCESS;
121         return status;
122 }
123
124 static inline uint8_t get_device_count(struct mod_hdcp *hdcp)
125 {
126         return is_dp_hdcp(hdcp) ?
127                         DRM_HDCP_NUM_DOWNSTREAM(hdcp->auth.msg.hdcp1.binfo_dp) :
128                         DRM_HDCP_NUM_DOWNSTREAM(hdcp->auth.msg.hdcp1.bstatus);
129 }
130
131 static inline enum mod_hdcp_status check_device_count(struct mod_hdcp *hdcp)
132 {
133         /* Avoid device count == 0 to do authentication */
134         if (0 == get_device_count(hdcp)) {
135                 return MOD_HDCP_STATUS_HDCP1_DEVICE_COUNT_MISMATCH_FAILURE;
136         }
137
138         /* Some MST display may choose to report the internal panel as an HDCP RX.
139          * To update this condition with 1(because the immediate repeater's internal
140          * panel is possibly not included in DEVICE_COUNT) + get_device_count(hdcp).
141          * Device count must be greater than or equal to tracked hdcp displays.
142          */
143         return ((1 + get_device_count(hdcp)) < get_active_display_count(hdcp)) ?
144                         MOD_HDCP_STATUS_HDCP1_DEVICE_COUNT_MISMATCH_FAILURE :
145                         MOD_HDCP_STATUS_SUCCESS;
146 }
147
148 static enum mod_hdcp_status wait_for_active_rx(struct mod_hdcp *hdcp,
149                 struct mod_hdcp_event_context *event_ctx,
150                 struct mod_hdcp_transition_input_hdcp1 *input)
151 {
152         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
153
154         if (event_ctx->event != MOD_HDCP_EVENT_CALLBACK) {
155                 event_ctx->unexpected_event = 1;
156                 goto out;
157         }
158
159         if (!mod_hdcp_execute_and_set(mod_hdcp_read_bksv,
160                         &input->bksv_read, &status,
161                         hdcp, "bksv_read"))
162                 goto out;
163         if (!mod_hdcp_execute_and_set(mod_hdcp_read_bcaps,
164                         &input->bcaps_read, &status,
165                         hdcp, "bcaps_read"))
166                 goto out;
167 out:
168         return status;
169 }
170
171 static enum mod_hdcp_status exchange_ksvs(struct mod_hdcp *hdcp,
172                 struct mod_hdcp_event_context *event_ctx,
173                 struct mod_hdcp_transition_input_hdcp1 *input)
174 {
175         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
176
177         if (event_ctx->event != MOD_HDCP_EVENT_CALLBACK) {
178                 event_ctx->unexpected_event = 1;
179                 goto out;
180         }
181
182         if (!mod_hdcp_execute_and_set(mod_hdcp_hdcp1_create_session,
183                         &input->create_session, &status,
184                         hdcp, "create_session"))
185                 goto out;
186         if (!mod_hdcp_execute_and_set(mod_hdcp_write_an,
187                         &input->an_write, &status,
188                         hdcp, "an_write"))
189                 goto out;
190         if (!mod_hdcp_execute_and_set(mod_hdcp_write_aksv,
191                         &input->aksv_write, &status,
192                         hdcp, "aksv_write"))
193                 goto out;
194         if (!mod_hdcp_execute_and_set(mod_hdcp_read_bksv,
195                         &input->bksv_read, &status,
196                         hdcp, "bksv_read"))
197                 goto out;
198         if (!mod_hdcp_execute_and_set(validate_bksv,
199                         &input->bksv_validation, &status,
200                         hdcp, "bksv_validation"))
201                 goto out;
202         if (hdcp->auth.msg.hdcp1.ainfo) {
203                 if (!mod_hdcp_execute_and_set(mod_hdcp_write_ainfo,
204                                 &input->ainfo_write, &status,
205                                 hdcp, "ainfo_write"))
206                         goto out;
207         }
208 out:
209         return status;
210 }
211
212 static enum mod_hdcp_status computations_validate_rx_test_for_repeater(
213                 struct mod_hdcp *hdcp,
214                 struct mod_hdcp_event_context *event_ctx,
215                 struct mod_hdcp_transition_input_hdcp1 *input)
216 {
217         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
218
219         if (event_ctx->event != MOD_HDCP_EVENT_CALLBACK) {
220                 event_ctx->unexpected_event = 1;
221                 goto out;
222         }
223
224         if (!mod_hdcp_execute_and_set(mod_hdcp_read_r0p,
225                         &input->r0p_read, &status,
226                         hdcp, "r0p_read"))
227                 goto out;
228         if (!mod_hdcp_execute_and_set(mod_hdcp_hdcp1_validate_rx,
229                         &input->rx_validation, &status,
230                         hdcp, "rx_validation"))
231                 goto out;
232         if (hdcp->connection.is_repeater) {
233                 if (!hdcp->connection.link.adjust.hdcp1.postpone_encryption)
234                         if (!mod_hdcp_execute_and_set(
235                                         mod_hdcp_hdcp1_enable_encryption,
236                                         &input->encryption, &status,
237                                         hdcp, "encryption"))
238                                 goto out;
239         } else {
240                 if (!mod_hdcp_execute_and_set(mod_hdcp_hdcp1_enable_encryption,
241                                 &input->encryption, &status,
242                                 hdcp, "encryption"))
243                         goto out;
244                 if (is_dp_mst_hdcp(hdcp))
245                         if (!mod_hdcp_execute_and_set(
246                                         mod_hdcp_hdcp1_enable_dp_stream_encryption,
247                                         &input->stream_encryption_dp, &status,
248                                         hdcp, "stream_encryption_dp"))
249                                 goto out;
250         }
251 out:
252         return status;
253 }
254
255 static enum mod_hdcp_status authenticated(struct mod_hdcp *hdcp,
256                 struct mod_hdcp_event_context *event_ctx,
257                 struct mod_hdcp_transition_input_hdcp1 *input)
258 {
259         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
260
261         if (event_ctx->event != MOD_HDCP_EVENT_CALLBACK) {
262                 event_ctx->unexpected_event = 1;
263                 goto out;
264         }
265
266         mod_hdcp_execute_and_set(mod_hdcp_hdcp1_link_maintenance,
267                         &input->link_maintenance, &status,
268                         hdcp, "link_maintenance");
269
270         if (status != MOD_HDCP_STATUS_SUCCESS)
271                 mod_hdcp_save_current_encryption_states(hdcp);
272 out:
273         return status;
274 }
275
276 static enum mod_hdcp_status wait_for_ready(struct mod_hdcp *hdcp,
277                 struct mod_hdcp_event_context *event_ctx,
278                 struct mod_hdcp_transition_input_hdcp1 *input)
279 {
280         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
281
282         if (event_ctx->event != MOD_HDCP_EVENT_CALLBACK &&
283                         event_ctx->event != MOD_HDCP_EVENT_CPIRQ &&
284                         event_ctx->event != MOD_HDCP_EVENT_WATCHDOG_TIMEOUT) {
285                 event_ctx->unexpected_event = 1;
286                 goto out;
287         }
288
289         if (is_dp_hdcp(hdcp)) {
290                 if (!mod_hdcp_execute_and_set(mod_hdcp_read_bstatus,
291                                 &input->bstatus_read, &status,
292                                 hdcp, "bstatus_read"))
293                         goto out;
294                 if (!mod_hdcp_execute_and_set(check_link_integrity_dp,
295                                 &input->link_integrity_check, &status,
296                                 hdcp, "link_integrity_check"))
297                         goto out;
298                 if (!mod_hdcp_execute_and_set(check_no_reauthentication_request_dp,
299                                 &input->reauth_request_check, &status,
300                                 hdcp, "reauth_request_check"))
301                         goto out;
302         } else {
303                 if (!mod_hdcp_execute_and_set(mod_hdcp_read_bcaps,
304                                 &input->bcaps_read, &status,
305                                 hdcp, "bcaps_read"))
306                         goto out;
307         }
308         if (!mod_hdcp_execute_and_set(check_ksv_ready,
309                         &input->ready_check, &status,
310                         hdcp, "ready_check"))
311                 goto out;
312 out:
313         return status;
314 }
315
316 static enum mod_hdcp_status read_ksv_list(struct mod_hdcp *hdcp,
317                 struct mod_hdcp_event_context *event_ctx,
318                 struct mod_hdcp_transition_input_hdcp1 *input)
319 {
320         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
321         uint8_t device_count;
322
323         if (event_ctx->event != MOD_HDCP_EVENT_CALLBACK) {
324                 event_ctx->unexpected_event = 1;
325                 goto out;
326         }
327
328         if (is_dp_hdcp(hdcp)) {
329                 if (!mod_hdcp_execute_and_set(mod_hdcp_read_binfo,
330                                 &input->binfo_read_dp, &status,
331                                 hdcp, "binfo_read_dp"))
332                         goto out;
333         } else {
334                 if (!mod_hdcp_execute_and_set(mod_hdcp_read_bstatus,
335                                 &input->bstatus_read, &status,
336                                 hdcp, "bstatus_read"))
337                         goto out;
338         }
339         if (!mod_hdcp_execute_and_set(check_no_max_cascade,
340                         &input->max_cascade_check, &status,
341                         hdcp, "max_cascade_check"))
342                 goto out;
343         if (!mod_hdcp_execute_and_set(check_no_max_devs,
344                         &input->max_devs_check, &status,
345                         hdcp, "max_devs_check"))
346                 goto out;
347         if (!mod_hdcp_execute_and_set(check_device_count,
348                         &input->device_count_check, &status,
349                         hdcp, "device_count_check"))
350                 goto out;
351         device_count = get_device_count(hdcp);
352         hdcp->auth.msg.hdcp1.ksvlist_size = device_count*5;
353         if (!mod_hdcp_execute_and_set(mod_hdcp_read_ksvlist,
354                         &input->ksvlist_read, &status,
355                         hdcp, "ksvlist_read"))
356                 goto out;
357         if (!mod_hdcp_execute_and_set(mod_hdcp_read_vp,
358                         &input->vp_read, &status,
359                         hdcp, "vp_read"))
360                 goto out;
361         if (!mod_hdcp_execute_and_set(mod_hdcp_hdcp1_validate_ksvlist_vp,
362                         &input->ksvlist_vp_validation, &status,
363                         hdcp, "ksvlist_vp_validation"))
364                 goto out;
365         if (input->encryption != PASS)
366                 if (!mod_hdcp_execute_and_set(mod_hdcp_hdcp1_enable_encryption,
367                                 &input->encryption, &status,
368                                 hdcp, "encryption"))
369                         goto out;
370         if (is_dp_mst_hdcp(hdcp))
371                 if (!mod_hdcp_execute_and_set(
372                                 mod_hdcp_hdcp1_enable_dp_stream_encryption,
373                                 &input->stream_encryption_dp, &status,
374                                 hdcp, "stream_encryption_dp"))
375                         goto out;
376 out:
377         return status;
378 }
379
380 static enum mod_hdcp_status determine_rx_hdcp_capable_dp(struct mod_hdcp *hdcp,
381                 struct mod_hdcp_event_context *event_ctx,
382                 struct mod_hdcp_transition_input_hdcp1 *input)
383 {
384         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
385
386         if (event_ctx->event != MOD_HDCP_EVENT_CALLBACK) {
387                 event_ctx->unexpected_event = 1;
388                 goto out;
389         }
390
391         if (!mod_hdcp_execute_and_set(mod_hdcp_read_bcaps,
392                         &input->bcaps_read, &status,
393                         hdcp, "bcaps_read"))
394                 goto out;
395         if (!mod_hdcp_execute_and_set(check_hdcp_capable_dp,
396                         &input->hdcp_capable_dp, &status,
397                         hdcp, "hdcp_capable_dp"))
398                 goto out;
399 out:
400         return status;
401 }
402
403 static enum mod_hdcp_status wait_for_r0_prime_dp(struct mod_hdcp *hdcp,
404                 struct mod_hdcp_event_context *event_ctx,
405                 struct mod_hdcp_transition_input_hdcp1 *input)
406 {
407         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
408
409         if (event_ctx->event != MOD_HDCP_EVENT_CPIRQ &&
410                         event_ctx->event != MOD_HDCP_EVENT_WATCHDOG_TIMEOUT) {
411                 event_ctx->unexpected_event = 1;
412                 goto out;
413         }
414
415         if (!mod_hdcp_execute_and_set(mod_hdcp_read_bstatus,
416                         &input->bstatus_read, &status,
417                         hdcp, "bstatus_read"))
418                 goto out;
419         if (!mod_hdcp_execute_and_set(check_r0p_available_dp,
420                         &input->r0p_available_dp, &status,
421                         hdcp, "r0p_available_dp"))
422                 goto out;
423 out:
424         return status;
425 }
426
427 static enum mod_hdcp_status authenticated_dp(struct mod_hdcp *hdcp,
428                 struct mod_hdcp_event_context *event_ctx,
429                 struct mod_hdcp_transition_input_hdcp1 *input)
430 {
431         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
432
433         if (event_ctx->event != MOD_HDCP_EVENT_CPIRQ) {
434                 event_ctx->unexpected_event = 1;
435                 goto out;
436         }
437
438         if (status == MOD_HDCP_STATUS_SUCCESS)
439                 mod_hdcp_execute_and_set(mod_hdcp_read_bstatus,
440                                 &input->bstatus_read, &status,
441                                 hdcp, "bstatus_read");
442         if (status == MOD_HDCP_STATUS_SUCCESS)
443                 mod_hdcp_execute_and_set(check_link_integrity_dp,
444                                 &input->link_integrity_check, &status,
445                                 hdcp, "link_integrity_check");
446         if (status == MOD_HDCP_STATUS_SUCCESS)
447                 mod_hdcp_execute_and_set(check_no_reauthentication_request_dp,
448                                 &input->reauth_request_check, &status,
449                                 hdcp, "reauth_request_check");
450
451         if (status != MOD_HDCP_STATUS_SUCCESS)
452                 mod_hdcp_save_current_encryption_states(hdcp);
453 out:
454         return status;
455 }
456
457 uint8_t mod_hdcp_execute_and_set(
458                 mod_hdcp_action func, uint8_t *flag,
459                 enum mod_hdcp_status *status, struct mod_hdcp *hdcp, char *str)
460 {
461         *status = func(hdcp);
462         if (*status == MOD_HDCP_STATUS_SUCCESS && *flag != PASS) {
463                 HDCP_INPUT_PASS_TRACE(hdcp, str);
464                 *flag = PASS;
465         } else if (*status != MOD_HDCP_STATUS_SUCCESS && *flag != FAIL) {
466                 HDCP_INPUT_FAIL_TRACE(hdcp, str);
467                 *flag = FAIL;
468         }
469         return (*status == MOD_HDCP_STATUS_SUCCESS);
470 }
471
472 enum mod_hdcp_status mod_hdcp_hdcp1_execution(struct mod_hdcp *hdcp,
473                 struct mod_hdcp_event_context *event_ctx,
474                 struct mod_hdcp_transition_input_hdcp1 *input)
475 {
476         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
477
478         switch (current_state(hdcp)) {
479         case H1_A0_WAIT_FOR_ACTIVE_RX:
480                 status = wait_for_active_rx(hdcp, event_ctx, input);
481                 break;
482         case H1_A1_EXCHANGE_KSVS:
483                 status = exchange_ksvs(hdcp, event_ctx, input);
484                 break;
485         case H1_A2_COMPUTATIONS_A3_VALIDATE_RX_A6_TEST_FOR_REPEATER:
486                 status = computations_validate_rx_test_for_repeater(hdcp,
487                                 event_ctx, input);
488                 break;
489         case H1_A45_AUTHENTICATED:
490                 status = authenticated(hdcp, event_ctx, input);
491                 break;
492         case H1_A8_WAIT_FOR_READY:
493                 status = wait_for_ready(hdcp, event_ctx, input);
494                 break;
495         case H1_A9_READ_KSV_LIST:
496                 status = read_ksv_list(hdcp, event_ctx, input);
497                 break;
498         default:
499                 status = MOD_HDCP_STATUS_INVALID_STATE;
500                 break;
501         }
502
503         return status;
504 }
505
506 extern enum mod_hdcp_status mod_hdcp_hdcp1_dp_execution(struct mod_hdcp *hdcp,
507                 struct mod_hdcp_event_context *event_ctx,
508                 struct mod_hdcp_transition_input_hdcp1 *input)
509 {
510         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
511
512         switch (current_state(hdcp)) {
513         case D1_A0_DETERMINE_RX_HDCP_CAPABLE:
514                 status = determine_rx_hdcp_capable_dp(hdcp, event_ctx, input);
515                 break;
516         case D1_A1_EXCHANGE_KSVS:
517                 status = exchange_ksvs(hdcp, event_ctx, input);
518                 break;
519         case D1_A23_WAIT_FOR_R0_PRIME:
520                 status = wait_for_r0_prime_dp(hdcp, event_ctx, input);
521                 break;
522         case D1_A2_COMPUTATIONS_A3_VALIDATE_RX_A5_TEST_FOR_REPEATER:
523                 status = computations_validate_rx_test_for_repeater(
524                                 hdcp, event_ctx, input);
525                 break;
526         case D1_A4_AUTHENTICATED:
527                 status = authenticated_dp(hdcp, event_ctx, input);
528                 break;
529         case D1_A6_WAIT_FOR_READY:
530                 status = wait_for_ready(hdcp, event_ctx, input);
531                 break;
532         case D1_A7_READ_KSV_LIST:
533                 status = read_ksv_list(hdcp, event_ctx, input);
534                 break;
535         default:
536                 status = MOD_HDCP_STATUS_INVALID_STATE;
537                 break;
538         }
539
540         return status;
541 }
This page took 0.065797 seconds and 4 git commands to generate.