Merge tag 'drm-intel-next-2021-05-19-1' of git://anongit.freedesktop.org/drm/drm...
[sfrench/cifs-2.6.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
33         memcpy(&n, hdcp->auth.msg.hdcp1.bksv, sizeof(uint64_t));
34
35         while (n) {
36                 count++;
37                 n &= (n - 1);
38         }
39         return (count == 20) ? MOD_HDCP_STATUS_SUCCESS :
40                         MOD_HDCP_STATUS_HDCP1_INVALID_BKSV;
41 }
42
43 static inline enum mod_hdcp_status check_ksv_ready(struct mod_hdcp *hdcp)
44 {
45         if (is_dp_hdcp(hdcp))
46                 return (hdcp->auth.msg.hdcp1.bstatus & DP_BSTATUS_READY) ?
47                                 MOD_HDCP_STATUS_SUCCESS :
48                                 MOD_HDCP_STATUS_HDCP1_KSV_LIST_NOT_READY;
49         return (hdcp->auth.msg.hdcp1.bcaps & DRM_HDCP_DDC_BCAPS_KSV_FIFO_READY) ?
50                         MOD_HDCP_STATUS_SUCCESS :
51                         MOD_HDCP_STATUS_HDCP1_KSV_LIST_NOT_READY;
52 }
53
54 static inline enum mod_hdcp_status check_hdcp_capable_dp(struct mod_hdcp *hdcp)
55 {
56         return (hdcp->auth.msg.hdcp1.bcaps & DP_BCAPS_HDCP_CAPABLE) ?
57                         MOD_HDCP_STATUS_SUCCESS :
58                         MOD_HDCP_STATUS_HDCP1_NOT_CAPABLE;
59 }
60
61 static inline enum mod_hdcp_status check_r0p_available_dp(struct mod_hdcp *hdcp)
62 {
63         enum mod_hdcp_status status;
64         if (is_dp_hdcp(hdcp)) {
65                 status = (hdcp->auth.msg.hdcp1.bstatus &
66                                 DP_BSTATUS_R0_PRIME_READY) ?
67                         MOD_HDCP_STATUS_SUCCESS :
68                         MOD_HDCP_STATUS_HDCP1_R0_PRIME_PENDING;
69         } else {
70                 status = MOD_HDCP_STATUS_INVALID_OPERATION;
71         }
72         return status;
73 }
74
75 static inline enum mod_hdcp_status check_link_integrity_dp(
76                 struct mod_hdcp *hdcp)
77 {
78         return (hdcp->auth.msg.hdcp1.bstatus &
79                         DP_BSTATUS_LINK_FAILURE) ?
80                         MOD_HDCP_STATUS_HDCP1_LINK_INTEGRITY_FAILURE :
81                         MOD_HDCP_STATUS_SUCCESS;
82 }
83
84 static inline enum mod_hdcp_status check_no_reauthentication_request_dp(
85                 struct mod_hdcp *hdcp)
86 {
87         return (hdcp->auth.msg.hdcp1.bstatus & DP_BSTATUS_REAUTH_REQ) ?
88                         MOD_HDCP_STATUS_HDCP1_REAUTH_REQUEST_ISSUED :
89                         MOD_HDCP_STATUS_SUCCESS;
90 }
91
92 static inline enum mod_hdcp_status check_no_max_cascade(struct mod_hdcp *hdcp)
93 {
94         enum mod_hdcp_status status;
95
96         if (is_dp_hdcp(hdcp))
97                 status = DRM_HDCP_MAX_CASCADE_EXCEEDED(hdcp->auth.msg.hdcp1.binfo_dp >> 8)
98                                  ? MOD_HDCP_STATUS_HDCP1_MAX_CASCADE_EXCEEDED_FAILURE
99                                  : MOD_HDCP_STATUS_SUCCESS;
100         else
101                 status = DRM_HDCP_MAX_CASCADE_EXCEEDED(hdcp->auth.msg.hdcp1.bstatus >> 8)
102                                  ? MOD_HDCP_STATUS_HDCP1_MAX_CASCADE_EXCEEDED_FAILURE
103                                  : MOD_HDCP_STATUS_SUCCESS;
104         return status;
105 }
106
107 static inline enum mod_hdcp_status check_no_max_devs(struct mod_hdcp *hdcp)
108 {
109         enum mod_hdcp_status status;
110
111         if (is_dp_hdcp(hdcp))
112                 status = DRM_HDCP_MAX_DEVICE_EXCEEDED(hdcp->auth.msg.hdcp1.binfo_dp) ?
113                                 MOD_HDCP_STATUS_HDCP1_MAX_DEVS_EXCEEDED_FAILURE :
114                                 MOD_HDCP_STATUS_SUCCESS;
115         else
116                 status = DRM_HDCP_MAX_DEVICE_EXCEEDED(hdcp->auth.msg.hdcp1.bstatus) ?
117                                 MOD_HDCP_STATUS_HDCP1_MAX_DEVS_EXCEEDED_FAILURE :
118                                 MOD_HDCP_STATUS_SUCCESS;
119         return status;
120 }
121
122 static inline uint8_t get_device_count(struct mod_hdcp *hdcp)
123 {
124         return is_dp_hdcp(hdcp) ?
125                         DRM_HDCP_NUM_DOWNSTREAM(hdcp->auth.msg.hdcp1.binfo_dp) :
126                         DRM_HDCP_NUM_DOWNSTREAM(hdcp->auth.msg.hdcp1.bstatus);
127 }
128
129 static inline enum mod_hdcp_status check_device_count(struct mod_hdcp *hdcp)
130 {
131         /* Some MST display may choose to report the internal panel as an HDCP RX.
132          * To update this condition with 1(because the immediate repeater's internal
133          * panel is possibly not included in DEVICE_COUNT) + get_device_count(hdcp).
134          * Device count must be greater than or equal to tracked hdcp displays.
135          */
136         return ((1 + get_device_count(hdcp)) < get_active_display_count(hdcp)) ?
137                         MOD_HDCP_STATUS_HDCP1_DEVICE_COUNT_MISMATCH_FAILURE :
138                         MOD_HDCP_STATUS_SUCCESS;
139 }
140
141 static enum mod_hdcp_status wait_for_active_rx(struct mod_hdcp *hdcp,
142                 struct mod_hdcp_event_context *event_ctx,
143                 struct mod_hdcp_transition_input_hdcp1 *input)
144 {
145         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
146
147         if (event_ctx->event != MOD_HDCP_EVENT_CALLBACK) {
148                 event_ctx->unexpected_event = 1;
149                 goto out;
150         }
151
152         if (!mod_hdcp_execute_and_set(mod_hdcp_read_bksv,
153                         &input->bksv_read, &status,
154                         hdcp, "bksv_read"))
155                 goto out;
156         if (!mod_hdcp_execute_and_set(mod_hdcp_read_bcaps,
157                         &input->bcaps_read, &status,
158                         hdcp, "bcaps_read"))
159                 goto out;
160 out:
161         return status;
162 }
163
164 static enum mod_hdcp_status exchange_ksvs(struct mod_hdcp *hdcp,
165                 struct mod_hdcp_event_context *event_ctx,
166                 struct mod_hdcp_transition_input_hdcp1 *input)
167 {
168         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
169
170         if (event_ctx->event != MOD_HDCP_EVENT_CALLBACK) {
171                 event_ctx->unexpected_event = 1;
172                 goto out;
173         }
174
175         if (!mod_hdcp_execute_and_set(mod_hdcp_hdcp1_create_session,
176                         &input->create_session, &status,
177                         hdcp, "create_session"))
178                 goto out;
179         if (!mod_hdcp_execute_and_set(mod_hdcp_write_an,
180                         &input->an_write, &status,
181                         hdcp, "an_write"))
182                 goto out;
183         if (!mod_hdcp_execute_and_set(mod_hdcp_write_aksv,
184                         &input->aksv_write, &status,
185                         hdcp, "aksv_write"))
186                 goto out;
187         if (!mod_hdcp_execute_and_set(mod_hdcp_read_bksv,
188                         &input->bksv_read, &status,
189                         hdcp, "bksv_read"))
190                 goto out;
191         if (!mod_hdcp_execute_and_set(validate_bksv,
192                         &input->bksv_validation, &status,
193                         hdcp, "bksv_validation"))
194                 goto out;
195         if (hdcp->auth.msg.hdcp1.ainfo) {
196                 if (!mod_hdcp_execute_and_set(mod_hdcp_write_ainfo,
197                                 &input->ainfo_write, &status,
198                                 hdcp, "ainfo_write"))
199                         goto out;
200         }
201 out:
202         return status;
203 }
204
205 static enum mod_hdcp_status computations_validate_rx_test_for_repeater(
206                 struct mod_hdcp *hdcp,
207                 struct mod_hdcp_event_context *event_ctx,
208                 struct mod_hdcp_transition_input_hdcp1 *input)
209 {
210         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
211
212         if (event_ctx->event != MOD_HDCP_EVENT_CALLBACK) {
213                 event_ctx->unexpected_event = 1;
214                 goto out;
215         }
216
217         if (!mod_hdcp_execute_and_set(mod_hdcp_read_r0p,
218                         &input->r0p_read, &status,
219                         hdcp, "r0p_read"))
220                 goto out;
221         if (!mod_hdcp_execute_and_set(mod_hdcp_hdcp1_validate_rx,
222                         &input->rx_validation, &status,
223                         hdcp, "rx_validation"))
224                 goto out;
225         if (hdcp->connection.is_repeater) {
226                 if (!hdcp->connection.link.adjust.hdcp1.postpone_encryption)
227                         if (!mod_hdcp_execute_and_set(
228                                         mod_hdcp_hdcp1_enable_encryption,
229                                         &input->encryption, &status,
230                                         hdcp, "encryption"))
231                                 goto out;
232         } else {
233                 if (!mod_hdcp_execute_and_set(mod_hdcp_hdcp1_enable_encryption,
234                                 &input->encryption, &status,
235                                 hdcp, "encryption"))
236                         goto out;
237                 if (is_dp_mst_hdcp(hdcp))
238                         if (!mod_hdcp_execute_and_set(
239                                         mod_hdcp_hdcp1_enable_dp_stream_encryption,
240                                         &input->stream_encryption_dp, &status,
241                                         hdcp, "stream_encryption_dp"))
242                                 goto out;
243         }
244 out:
245         return status;
246 }
247
248 static enum mod_hdcp_status authenticated(struct mod_hdcp *hdcp,
249                 struct mod_hdcp_event_context *event_ctx,
250                 struct mod_hdcp_transition_input_hdcp1 *input)
251 {
252         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
253
254         if (event_ctx->event != MOD_HDCP_EVENT_CALLBACK) {
255                 event_ctx->unexpected_event = 1;
256                 goto out;
257         }
258
259         mod_hdcp_execute_and_set(mod_hdcp_hdcp1_link_maintenance,
260                         &input->link_maintenance, &status,
261                         hdcp, "link_maintenance");
262
263         if (status != MOD_HDCP_STATUS_SUCCESS)
264                 mod_hdcp_save_current_encryption_states(hdcp);
265 out:
266         return status;
267 }
268
269 static enum mod_hdcp_status wait_for_ready(struct mod_hdcp *hdcp,
270                 struct mod_hdcp_event_context *event_ctx,
271                 struct mod_hdcp_transition_input_hdcp1 *input)
272 {
273         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
274
275         if (event_ctx->event != MOD_HDCP_EVENT_CALLBACK &&
276                         event_ctx->event != MOD_HDCP_EVENT_CPIRQ &&
277                         event_ctx->event != MOD_HDCP_EVENT_WATCHDOG_TIMEOUT) {
278                 event_ctx->unexpected_event = 1;
279                 goto out;
280         }
281
282         if (is_dp_hdcp(hdcp)) {
283                 if (!mod_hdcp_execute_and_set(mod_hdcp_read_bstatus,
284                                 &input->bstatus_read, &status,
285                                 hdcp, "bstatus_read"))
286                         goto out;
287                 if (!mod_hdcp_execute_and_set(check_link_integrity_dp,
288                                 &input->link_integrity_check, &status,
289                                 hdcp, "link_integrity_check"))
290                         goto out;
291                 if (!mod_hdcp_execute_and_set(check_no_reauthentication_request_dp,
292                                 &input->reauth_request_check, &status,
293                                 hdcp, "reauth_request_check"))
294                         goto out;
295         } else {
296                 if (!mod_hdcp_execute_and_set(mod_hdcp_read_bcaps,
297                                 &input->bcaps_read, &status,
298                                 hdcp, "bcaps_read"))
299                         goto out;
300         }
301         if (!mod_hdcp_execute_and_set(check_ksv_ready,
302                         &input->ready_check, &status,
303                         hdcp, "ready_check"))
304                 goto out;
305 out:
306         return status;
307 }
308
309 static enum mod_hdcp_status read_ksv_list(struct mod_hdcp *hdcp,
310                 struct mod_hdcp_event_context *event_ctx,
311                 struct mod_hdcp_transition_input_hdcp1 *input)
312 {
313         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
314         uint8_t device_count;
315
316         if (event_ctx->event != MOD_HDCP_EVENT_CALLBACK) {
317                 event_ctx->unexpected_event = 1;
318                 goto out;
319         }
320
321         if (is_dp_hdcp(hdcp)) {
322                 if (!mod_hdcp_execute_and_set(mod_hdcp_read_binfo,
323                                 &input->binfo_read_dp, &status,
324                                 hdcp, "binfo_read_dp"))
325                         goto out;
326         } else {
327                 if (!mod_hdcp_execute_and_set(mod_hdcp_read_bstatus,
328                                 &input->bstatus_read, &status,
329                                 hdcp, "bstatus_read"))
330                         goto out;
331         }
332         if (!mod_hdcp_execute_and_set(check_no_max_cascade,
333                         &input->max_cascade_check, &status,
334                         hdcp, "max_cascade_check"))
335                 goto out;
336         if (!mod_hdcp_execute_and_set(check_no_max_devs,
337                         &input->max_devs_check, &status,
338                         hdcp, "max_devs_check"))
339                 goto out;
340         if (!mod_hdcp_execute_and_set(check_device_count,
341                         &input->device_count_check, &status,
342                         hdcp, "device_count_check"))
343                 goto out;
344         device_count = get_device_count(hdcp);
345         hdcp->auth.msg.hdcp1.ksvlist_size = device_count*5;
346         if (!mod_hdcp_execute_and_set(mod_hdcp_read_ksvlist,
347                         &input->ksvlist_read, &status,
348                         hdcp, "ksvlist_read"))
349                 goto out;
350         if (!mod_hdcp_execute_and_set(mod_hdcp_read_vp,
351                         &input->vp_read, &status,
352                         hdcp, "vp_read"))
353                 goto out;
354         if (!mod_hdcp_execute_and_set(mod_hdcp_hdcp1_validate_ksvlist_vp,
355                         &input->ksvlist_vp_validation, &status,
356                         hdcp, "ksvlist_vp_validation"))
357                 goto out;
358         if (input->encryption != PASS)
359                 if (!mod_hdcp_execute_and_set(mod_hdcp_hdcp1_enable_encryption,
360                                 &input->encryption, &status,
361                                 hdcp, "encryption"))
362                         goto out;
363         if (is_dp_mst_hdcp(hdcp))
364                 if (!mod_hdcp_execute_and_set(
365                                 mod_hdcp_hdcp1_enable_dp_stream_encryption,
366                                 &input->stream_encryption_dp, &status,
367                                 hdcp, "stream_encryption_dp"))
368                         goto out;
369 out:
370         return status;
371 }
372
373 static enum mod_hdcp_status determine_rx_hdcp_capable_dp(struct mod_hdcp *hdcp,
374                 struct mod_hdcp_event_context *event_ctx,
375                 struct mod_hdcp_transition_input_hdcp1 *input)
376 {
377         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
378
379         if (event_ctx->event != MOD_HDCP_EVENT_CALLBACK) {
380                 event_ctx->unexpected_event = 1;
381                 goto out;
382         }
383
384         if (!mod_hdcp_execute_and_set(mod_hdcp_read_bcaps,
385                         &input->bcaps_read, &status,
386                         hdcp, "bcaps_read"))
387                 goto out;
388         if (!mod_hdcp_execute_and_set(check_hdcp_capable_dp,
389                         &input->hdcp_capable_dp, &status,
390                         hdcp, "hdcp_capable_dp"))
391                 goto out;
392 out:
393         return status;
394 }
395
396 static enum mod_hdcp_status wait_for_r0_prime_dp(struct mod_hdcp *hdcp,
397                 struct mod_hdcp_event_context *event_ctx,
398                 struct mod_hdcp_transition_input_hdcp1 *input)
399 {
400         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
401
402         if (event_ctx->event != MOD_HDCP_EVENT_CPIRQ &&
403                         event_ctx->event != MOD_HDCP_EVENT_WATCHDOG_TIMEOUT) {
404                 event_ctx->unexpected_event = 1;
405                 goto out;
406         }
407
408         if (!mod_hdcp_execute_and_set(mod_hdcp_read_bstatus,
409                         &input->bstatus_read, &status,
410                         hdcp, "bstatus_read"))
411                 goto out;
412         if (!mod_hdcp_execute_and_set(check_r0p_available_dp,
413                         &input->r0p_available_dp, &status,
414                         hdcp, "r0p_available_dp"))
415                 goto out;
416 out:
417         return status;
418 }
419
420 static enum mod_hdcp_status authenticated_dp(struct mod_hdcp *hdcp,
421                 struct mod_hdcp_event_context *event_ctx,
422                 struct mod_hdcp_transition_input_hdcp1 *input)
423 {
424         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
425
426         if (event_ctx->event != MOD_HDCP_EVENT_CPIRQ) {
427                 event_ctx->unexpected_event = 1;
428                 goto out;
429         }
430
431         if (status == MOD_HDCP_STATUS_SUCCESS)
432                 mod_hdcp_execute_and_set(mod_hdcp_read_bstatus,
433                                 &input->bstatus_read, &status,
434                                 hdcp, "bstatus_read");
435         if (status == MOD_HDCP_STATUS_SUCCESS)
436                 mod_hdcp_execute_and_set(check_link_integrity_dp,
437                                 &input->link_integrity_check, &status,
438                                 hdcp, "link_integrity_check");
439         if (status == MOD_HDCP_STATUS_SUCCESS)
440                 mod_hdcp_execute_and_set(check_no_reauthentication_request_dp,
441                                 &input->reauth_request_check, &status,
442                                 hdcp, "reauth_request_check");
443
444         if (status != MOD_HDCP_STATUS_SUCCESS)
445                 mod_hdcp_save_current_encryption_states(hdcp);
446 out:
447         return status;
448 }
449
450 uint8_t mod_hdcp_execute_and_set(
451                 mod_hdcp_action func, uint8_t *flag,
452                 enum mod_hdcp_status *status, struct mod_hdcp *hdcp, char *str)
453 {
454         *status = func(hdcp);
455         if (*status == MOD_HDCP_STATUS_SUCCESS && *flag != PASS) {
456                 HDCP_INPUT_PASS_TRACE(hdcp, str);
457                 *flag = PASS;
458         } else if (*status != MOD_HDCP_STATUS_SUCCESS && *flag != FAIL) {
459                 HDCP_INPUT_FAIL_TRACE(hdcp, str);
460                 *flag = FAIL;
461         }
462         return (*status == MOD_HDCP_STATUS_SUCCESS);
463 }
464
465 enum mod_hdcp_status mod_hdcp_hdcp1_execution(struct mod_hdcp *hdcp,
466                 struct mod_hdcp_event_context *event_ctx,
467                 struct mod_hdcp_transition_input_hdcp1 *input)
468 {
469         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
470
471         switch (current_state(hdcp)) {
472         case H1_A0_WAIT_FOR_ACTIVE_RX:
473                 status = wait_for_active_rx(hdcp, event_ctx, input);
474                 break;
475         case H1_A1_EXCHANGE_KSVS:
476                 status = exchange_ksvs(hdcp, event_ctx, input);
477                 break;
478         case H1_A2_COMPUTATIONS_A3_VALIDATE_RX_A6_TEST_FOR_REPEATER:
479                 status = computations_validate_rx_test_for_repeater(hdcp,
480                                 event_ctx, input);
481                 break;
482         case H1_A45_AUTHENTICATED:
483                 status = authenticated(hdcp, event_ctx, input);
484                 break;
485         case H1_A8_WAIT_FOR_READY:
486                 status = wait_for_ready(hdcp, event_ctx, input);
487                 break;
488         case H1_A9_READ_KSV_LIST:
489                 status = read_ksv_list(hdcp, event_ctx, input);
490                 break;
491         default:
492                 status = MOD_HDCP_STATUS_INVALID_STATE;
493                 break;
494         }
495
496         return status;
497 }
498
499 extern enum mod_hdcp_status mod_hdcp_hdcp1_dp_execution(struct mod_hdcp *hdcp,
500                 struct mod_hdcp_event_context *event_ctx,
501                 struct mod_hdcp_transition_input_hdcp1 *input)
502 {
503         enum mod_hdcp_status status = MOD_HDCP_STATUS_SUCCESS;
504
505         switch (current_state(hdcp)) {
506         case D1_A0_DETERMINE_RX_HDCP_CAPABLE:
507                 status = determine_rx_hdcp_capable_dp(hdcp, event_ctx, input);
508                 break;
509         case D1_A1_EXCHANGE_KSVS:
510                 status = exchange_ksvs(hdcp, event_ctx, input);
511                 break;
512         case D1_A23_WAIT_FOR_R0_PRIME:
513                 status = wait_for_r0_prime_dp(hdcp, event_ctx, input);
514                 break;
515         case D1_A2_COMPUTATIONS_A3_VALIDATE_RX_A5_TEST_FOR_REPEATER:
516                 status = computations_validate_rx_test_for_repeater(
517                                 hdcp, event_ctx, input);
518                 break;
519         case D1_A4_AUTHENTICATED:
520                 status = authenticated_dp(hdcp, event_ctx, input);
521                 break;
522         case D1_A6_WAIT_FOR_READY:
523                 status = wait_for_ready(hdcp, event_ctx, input);
524                 break;
525         case D1_A7_READ_KSV_LIST:
526                 status = read_ksv_list(hdcp, event_ctx, input);
527                 break;
528         default:
529                 status = MOD_HDCP_STATUS_INVALID_STATE;
530                 break;
531         }
532
533         return status;
534 }