1 // SPDX-License-Identifier: GPL-2.0-only 2 /* 3 * Copyright (c) 2012-2016, The Linux Foundation. All rights reserved. 4 * Copyright (C) 2017 Linaro Ltd. 5 */ 6 #include <linux/overflow.h> 7 #include <linux/errno.h> 8 #include <linux/hash.h> 9 10 #include "hfi_cmds.h" 11 12 static enum hfi_version hfi_ver; 13 14 void pkt_sys_init(struct hfi_sys_init_pkt *pkt, u32 arch_type) 15 { 16 pkt->hdr.size = sizeof(*pkt); 17 pkt->hdr.pkt_type = HFI_CMD_SYS_INIT; 18 pkt->arch_type = arch_type; 19 } 20 21 void pkt_sys_pc_prep(struct hfi_sys_pc_prep_pkt *pkt) 22 { 23 pkt->hdr.size = sizeof(*pkt); 24 pkt->hdr.pkt_type = HFI_CMD_SYS_PC_PREP; 25 } 26 27 void pkt_sys_idle_indicator(struct hfi_sys_set_property_pkt *pkt, u32 enable) 28 { 29 struct hfi_enable *hfi = (struct hfi_enable *)&pkt->data[1]; 30 31 pkt->hdr.size = struct_size(pkt, data, 1) + sizeof(*hfi); 32 pkt->hdr.pkt_type = HFI_CMD_SYS_SET_PROPERTY; 33 pkt->num_properties = 1; 34 pkt->data[0] = HFI_PROPERTY_SYS_IDLE_INDICATOR; 35 hfi->enable = enable; 36 } 37 38 void pkt_sys_debug_config(struct hfi_sys_set_property_pkt *pkt, u32 mode, 39 u32 config) 40 { 41 struct hfi_debug_config *hfi; 42 43 pkt->hdr.size = struct_size(pkt, data, 1) + sizeof(*hfi); 44 pkt->hdr.pkt_type = HFI_CMD_SYS_SET_PROPERTY; 45 pkt->num_properties = 1; 46 pkt->data[0] = HFI_PROPERTY_SYS_DEBUG_CONFIG; 47 hfi = (struct hfi_debug_config *)&pkt->data[1]; 48 hfi->config = config; 49 hfi->mode = mode; 50 } 51 52 void pkt_sys_coverage_config(struct hfi_sys_set_property_pkt *pkt, u32 mode) 53 { 54 pkt->hdr.size = struct_size(pkt, data, 2); 55 pkt->hdr.pkt_type = HFI_CMD_SYS_SET_PROPERTY; 56 pkt->num_properties = 1; 57 pkt->data[0] = HFI_PROPERTY_SYS_CONFIG_COVERAGE; 58 pkt->data[1] = mode; 59 } 60 61 void pkt_sys_ubwc_config(struct hfi_sys_set_property_pkt *pkt, const struct hfi_ubwc_config *hfi) 62 { 63 pkt->hdr.size = struct_size(pkt, data, 1) + sizeof(*hfi); 64 pkt->hdr.pkt_type = HFI_CMD_SYS_SET_PROPERTY; 65 pkt->num_properties = 1; 66 pkt->data[0] = HFI_PROPERTY_SYS_UBWC_CONFIG; 67 memcpy(&pkt->data[1], hfi, sizeof(*hfi)); 68 } 69 70 int pkt_sys_set_resource(struct hfi_sys_set_resource_pkt *pkt, u32 id, u32 size, 71 u32 addr, void *cookie) 72 { 73 pkt->hdr.size = sizeof(*pkt); 74 pkt->hdr.pkt_type = HFI_CMD_SYS_SET_RESOURCE; 75 pkt->resource_handle = hash32_ptr(cookie); 76 77 switch (id) { 78 case VIDC_RESOURCE_OCMEM: 79 case VIDC_RESOURCE_VMEM: { 80 struct hfi_resource_ocmem *res = 81 (struct hfi_resource_ocmem *)&pkt->resource_data[0]; 82 83 res->size = size; 84 res->mem = addr; 85 pkt->resource_type = HFI_RESOURCE_OCMEM; 86 pkt->hdr.size += sizeof(*res); 87 break; 88 } 89 case VIDC_RESOURCE_NONE: 90 default: 91 return -ENOTSUPP; 92 } 93 94 return 0; 95 } 96 97 int pkt_sys_unset_resource(struct hfi_sys_release_resource_pkt *pkt, u32 id, 98 u32 size, void *cookie) 99 { 100 pkt->hdr.size = sizeof(*pkt); 101 pkt->hdr.pkt_type = HFI_CMD_SYS_RELEASE_RESOURCE; 102 pkt->resource_handle = hash32_ptr(cookie); 103 104 switch (id) { 105 case VIDC_RESOURCE_OCMEM: 106 case VIDC_RESOURCE_VMEM: 107 pkt->resource_type = HFI_RESOURCE_OCMEM; 108 break; 109 case VIDC_RESOURCE_NONE: 110 break; 111 default: 112 return -ENOTSUPP; 113 } 114 115 return 0; 116 } 117 118 void pkt_sys_ping(struct hfi_sys_ping_pkt *pkt, u32 cookie) 119 { 120 pkt->hdr.size = sizeof(*pkt); 121 pkt->hdr.pkt_type = HFI_CMD_SYS_PING; 122 pkt->client_data = cookie; 123 } 124 125 void pkt_sys_power_control(struct hfi_sys_set_property_pkt *pkt, u32 enable) 126 { 127 struct hfi_enable *hfi = (struct hfi_enable *)&pkt->data[1]; 128 129 pkt->hdr.size = struct_size(pkt, data, 1) + sizeof(*hfi); 130 pkt->hdr.pkt_type = HFI_CMD_SYS_SET_PROPERTY; 131 pkt->num_properties = 1; 132 pkt->data[0] = HFI_PROPERTY_SYS_CODEC_POWER_PLANE_CTRL; 133 hfi->enable = enable; 134 } 135 136 int pkt_sys_ssr_cmd(struct hfi_sys_test_ssr_pkt *pkt, u32 trigger_type) 137 { 138 switch (trigger_type) { 139 case HFI_TEST_SSR_SW_ERR_FATAL: 140 case HFI_TEST_SSR_SW_DIV_BY_ZERO: 141 case HFI_TEST_SSR_HW_WDOG_IRQ: 142 break; 143 default: 144 return -EINVAL; 145 } 146 147 pkt->hdr.size = sizeof(*pkt); 148 pkt->hdr.pkt_type = HFI_CMD_SYS_TEST_SSR; 149 pkt->trigger_type = trigger_type; 150 151 return 0; 152 } 153 154 void pkt_sys_image_version(struct hfi_sys_get_property_pkt *pkt) 155 { 156 pkt->hdr.size = sizeof(*pkt); 157 pkt->hdr.pkt_type = HFI_CMD_SYS_GET_PROPERTY; 158 pkt->num_properties = 1; 159 pkt->data[0] = HFI_PROPERTY_SYS_IMAGE_VERSION; 160 } 161 162 int pkt_session_init(struct hfi_session_init_pkt *pkt, void *cookie, 163 u32 session_type, u32 codec) 164 { 165 if (!pkt || !cookie || !codec) 166 return -EINVAL; 167 168 pkt->shdr.hdr.size = sizeof(*pkt); 169 pkt->shdr.hdr.pkt_type = HFI_CMD_SYS_SESSION_INIT; 170 pkt->shdr.session_id = hash32_ptr(cookie); 171 pkt->session_domain = session_type; 172 pkt->session_codec = codec; 173 174 return 0; 175 } 176 177 void pkt_session_cmd(struct hfi_session_pkt *pkt, u32 pkt_type, void *cookie) 178 { 179 pkt->shdr.hdr.size = sizeof(*pkt); 180 pkt->shdr.hdr.pkt_type = pkt_type; 181 pkt->shdr.session_id = hash32_ptr(cookie); 182 } 183 184 int pkt_session_set_buffers(struct hfi_session_set_buffers_pkt *pkt, 185 void *cookie, struct hfi_buffer_desc *bd) 186 { 187 unsigned int i; 188 189 if (!cookie || !pkt || !bd) 190 return -EINVAL; 191 192 pkt->shdr.hdr.pkt_type = HFI_CMD_SESSION_SET_BUFFERS; 193 pkt->shdr.session_id = hash32_ptr(cookie); 194 pkt->buffer_size = bd->buffer_size; 195 pkt->min_buffer_size = bd->buffer_size; 196 pkt->num_buffers = bd->num_buffers; 197 198 if (bd->buffer_type == HFI_BUFFER_OUTPUT || 199 bd->buffer_type == HFI_BUFFER_OUTPUT2) { 200 struct hfi_buffer_info *bi; 201 202 pkt->extradata_size = bd->extradata_size; 203 pkt->shdr.hdr.size = sizeof(*pkt) + 204 bd->num_buffers * sizeof(*bi); 205 bi = (struct hfi_buffer_info *)pkt->buffer_info; 206 for (i = 0; i < pkt->num_buffers; i++) { 207 bi->buffer_addr = bd->device_addr; 208 bi->extradata_addr = bd->extradata_addr; 209 } 210 } else { 211 pkt->extradata_size = 0; 212 pkt->shdr.hdr.size = struct_size(pkt, buffer_info, 213 bd->num_buffers); 214 for (i = 0; i < pkt->num_buffers; i++) 215 pkt->buffer_info[i] = bd->device_addr; 216 } 217 218 pkt->buffer_type = bd->buffer_type; 219 220 return 0; 221 } 222 223 int pkt_session_unset_buffers(struct hfi_session_release_buffer_pkt *pkt, 224 void *cookie, struct hfi_buffer_desc *bd) 225 { 226 unsigned int i; 227 228 if (!cookie || !pkt || !bd) 229 return -EINVAL; 230 231 pkt->shdr.hdr.pkt_type = HFI_CMD_SESSION_RELEASE_BUFFERS; 232 pkt->shdr.session_id = hash32_ptr(cookie); 233 pkt->buffer_size = bd->buffer_size; 234 pkt->num_buffers = bd->num_buffers; 235 236 if (bd->buffer_type == HFI_BUFFER_OUTPUT || 237 bd->buffer_type == HFI_BUFFER_OUTPUT2) { 238 struct hfi_buffer_info *bi; 239 240 bi = (struct hfi_buffer_info *)pkt->buffer_info; 241 for (i = 0; i < pkt->num_buffers; i++) { 242 bi->buffer_addr = bd->device_addr; 243 bi->extradata_addr = bd->extradata_addr; 244 } 245 pkt->shdr.hdr.size = 246 sizeof(struct hfi_session_set_buffers_pkt) + 247 bd->num_buffers * sizeof(*bi); 248 } else { 249 for (i = 0; i < pkt->num_buffers; i++) 250 pkt->buffer_info[i] = bd->device_addr; 251 252 pkt->extradata_size = 0; 253 pkt->shdr.hdr.size = 254 struct_size_t(struct hfi_session_set_buffers_pkt, 255 buffer_info, bd->num_buffers); 256 } 257 258 pkt->response_req = bd->response_required; 259 pkt->buffer_type = bd->buffer_type; 260 261 return 0; 262 } 263 264 int pkt_session_etb_decoder(struct hfi_session_empty_buffer_compressed_pkt *pkt, 265 void *cookie, struct hfi_frame_data *in_frame) 266 { 267 if (!cookie) 268 return -EINVAL; 269 270 pkt->shdr.hdr.size = sizeof(*pkt); 271 pkt->shdr.hdr.pkt_type = HFI_CMD_SESSION_EMPTY_BUFFER; 272 pkt->shdr.session_id = hash32_ptr(cookie); 273 pkt->time_stamp_hi = upper_32_bits(in_frame->timestamp); 274 pkt->time_stamp_lo = lower_32_bits(in_frame->timestamp); 275 pkt->flags = in_frame->flags; 276 pkt->mark_target = in_frame->mark_target; 277 pkt->mark_data = in_frame->mark_data; 278 pkt->offset = in_frame->offset; 279 pkt->alloc_len = in_frame->alloc_len; 280 pkt->filled_len = in_frame->filled_len; 281 pkt->input_tag = in_frame->clnt_data; 282 pkt->packet_buffer = in_frame->device_addr; 283 284 return 0; 285 } 286 287 int pkt_session_etb_encoder( 288 struct hfi_session_empty_buffer_uncompressed_plane0_pkt *pkt, 289 void *cookie, struct hfi_frame_data *in_frame) 290 { 291 if (!cookie || !in_frame->device_addr) 292 return -EINVAL; 293 294 pkt->shdr.hdr.size = sizeof(*pkt); 295 pkt->shdr.hdr.pkt_type = HFI_CMD_SESSION_EMPTY_BUFFER; 296 pkt->shdr.session_id = hash32_ptr(cookie); 297 pkt->view_id = 0; 298 pkt->time_stamp_hi = upper_32_bits(in_frame->timestamp); 299 pkt->time_stamp_lo = lower_32_bits(in_frame->timestamp); 300 pkt->flags = in_frame->flags; 301 pkt->mark_target = in_frame->mark_target; 302 pkt->mark_data = in_frame->mark_data; 303 pkt->offset = in_frame->offset; 304 pkt->alloc_len = in_frame->alloc_len; 305 pkt->filled_len = in_frame->filled_len; 306 pkt->input_tag = in_frame->clnt_data; 307 pkt->packet_buffer = in_frame->device_addr; 308 pkt->extradata_buffer = in_frame->extradata_addr; 309 310 return 0; 311 } 312 313 int pkt_session_ftb(struct hfi_session_fill_buffer_pkt *pkt, void *cookie, 314 struct hfi_frame_data *out_frame) 315 { 316 if (!cookie || !out_frame || !out_frame->device_addr) 317 return -EINVAL; 318 319 pkt->shdr.hdr.size = sizeof(*pkt); 320 pkt->shdr.hdr.pkt_type = HFI_CMD_SESSION_FILL_BUFFER; 321 pkt->shdr.session_id = hash32_ptr(cookie); 322 323 if (out_frame->buffer_type == HFI_BUFFER_OUTPUT) 324 pkt->stream_id = 0; 325 else if (out_frame->buffer_type == HFI_BUFFER_OUTPUT2) 326 pkt->stream_id = 1; 327 328 pkt->output_tag = out_frame->clnt_data; 329 pkt->packet_buffer = out_frame->device_addr; 330 pkt->extradata_buffer = out_frame->extradata_addr; 331 pkt->alloc_len = out_frame->alloc_len; 332 pkt->filled_len = out_frame->filled_len; 333 pkt->offset = out_frame->offset; 334 pkt->data[0] = out_frame->extradata_size; 335 336 return 0; 337 } 338 339 int pkt_session_parse_seq_header( 340 struct hfi_session_parse_sequence_header_pkt *pkt, 341 void *cookie, u32 seq_hdr, u32 seq_hdr_len) 342 { 343 if (!cookie || !seq_hdr || !seq_hdr_len) 344 return -EINVAL; 345 346 pkt->shdr.hdr.size = sizeof(*pkt); 347 pkt->shdr.hdr.pkt_type = HFI_CMD_SESSION_PARSE_SEQUENCE_HEADER; 348 pkt->shdr.session_id = hash32_ptr(cookie); 349 pkt->header_len = seq_hdr_len; 350 pkt->packet_buffer = seq_hdr; 351 352 return 0; 353 } 354 355 int pkt_session_get_seq_hdr(struct hfi_session_get_sequence_header_pkt *pkt, 356 void *cookie, u32 seq_hdr, u32 seq_hdr_len) 357 { 358 if (!cookie || !seq_hdr || !seq_hdr_len) 359 return -EINVAL; 360 361 pkt->shdr.hdr.size = sizeof(*pkt); 362 pkt->shdr.hdr.pkt_type = HFI_CMD_SESSION_GET_SEQUENCE_HEADER; 363 pkt->shdr.session_id = hash32_ptr(cookie); 364 pkt->buffer_len = seq_hdr_len; 365 pkt->packet_buffer = seq_hdr; 366 367 return 0; 368 } 369 370 int pkt_session_flush(struct hfi_session_flush_pkt *pkt, void *cookie, u32 type) 371 { 372 switch (type) { 373 case HFI_FLUSH_INPUT: 374 case HFI_FLUSH_OUTPUT: 375 case HFI_FLUSH_OUTPUT2: 376 case HFI_FLUSH_ALL: 377 break; 378 default: 379 return -EINVAL; 380 } 381 382 pkt->shdr.hdr.size = sizeof(*pkt); 383 pkt->shdr.hdr.pkt_type = HFI_CMD_SESSION_FLUSH; 384 pkt->shdr.session_id = hash32_ptr(cookie); 385 pkt->flush_type = type; 386 387 return 0; 388 } 389 390 static int pkt_session_get_property_1x(struct hfi_session_get_property_pkt *pkt, 391 void *cookie, u32 ptype) 392 { 393 switch (ptype) { 394 case HFI_PROPERTY_PARAM_PROFILE_LEVEL_CURRENT: 395 case HFI_PROPERTY_CONFIG_BUFFER_REQUIREMENTS: 396 break; 397 default: 398 return -EINVAL; 399 } 400 401 pkt->shdr.hdr.size = sizeof(*pkt); 402 pkt->shdr.hdr.pkt_type = HFI_CMD_SESSION_GET_PROPERTY; 403 pkt->shdr.session_id = hash32_ptr(cookie); 404 pkt->num_properties = 1; 405 pkt->data[0] = ptype; 406 407 return 0; 408 } 409 410 static int pkt_session_set_property_1x(struct hfi_session_set_property_pkt *pkt, 411 void *cookie, u32 ptype, void *pdata) 412 { 413 void *prop_data; 414 int ret = 0; 415 416 if (!pkt || !cookie || !pdata) 417 return -EINVAL; 418 419 prop_data = &pkt->data[1]; 420 421 pkt->shdr.hdr.size = sizeof(*pkt); 422 pkt->shdr.hdr.pkt_type = HFI_CMD_SESSION_SET_PROPERTY; 423 pkt->shdr.session_id = hash32_ptr(cookie); 424 pkt->num_properties = 1; 425 pkt->data[0] = ptype; 426 427 switch (ptype) { 428 case HFI_PROPERTY_CONFIG_FRAME_RATE: { 429 struct hfi_framerate *in = pdata, *frate = prop_data; 430 431 frate->buffer_type = in->buffer_type; 432 frate->framerate = in->framerate; 433 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*frate); 434 break; 435 } 436 case HFI_PROPERTY_PARAM_UNCOMPRESSED_FORMAT_SELECT: { 437 struct hfi_uncompressed_format_select *in = pdata; 438 struct hfi_uncompressed_format_select *hfi = prop_data; 439 440 hfi->buffer_type = in->buffer_type; 441 hfi->format = in->format; 442 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*hfi); 443 break; 444 } 445 case HFI_PROPERTY_PARAM_FRAME_SIZE: { 446 struct hfi_framesize *in = pdata, *fsize = prop_data; 447 448 fsize->buffer_type = in->buffer_type; 449 fsize->height = in->height; 450 fsize->width = in->width; 451 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*fsize); 452 break; 453 } 454 case HFI_PROPERTY_CONFIG_REALTIME: { 455 struct hfi_enable *in = pdata, *en = prop_data; 456 457 en->enable = in->enable; 458 pkt->shdr.hdr.size += sizeof(u32) * 2; 459 break; 460 } 461 case HFI_PROPERTY_PARAM_BUFFER_COUNT_ACTUAL: { 462 struct hfi_buffer_count_actual *in = pdata, *count = prop_data; 463 464 count->count_actual = in->count_actual; 465 count->type = in->type; 466 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*count); 467 break; 468 } 469 case HFI_PROPERTY_PARAM_BUFFER_SIZE_ACTUAL: { 470 struct hfi_buffer_size_actual *in = pdata, *sz = prop_data; 471 472 sz->size = in->size; 473 sz->type = in->type; 474 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*sz); 475 break; 476 } 477 case HFI_PROPERTY_PARAM_BUFFER_DISPLAY_HOLD_COUNT_ACTUAL: { 478 struct hfi_buffer_display_hold_count_actual *in = pdata; 479 struct hfi_buffer_display_hold_count_actual *count = prop_data; 480 481 count->hold_count = in->hold_count; 482 count->type = in->type; 483 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*count); 484 break; 485 } 486 case HFI_PROPERTY_PARAM_NAL_STREAM_FORMAT_SELECT: { 487 struct hfi_nal_stream_format_select *in = pdata; 488 struct hfi_nal_stream_format_select *fmt = prop_data; 489 490 fmt->format = in->format; 491 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*fmt); 492 break; 493 } 494 case HFI_PROPERTY_PARAM_VDEC_OUTPUT_ORDER: { 495 u32 *in = pdata; 496 497 switch (*in) { 498 case HFI_OUTPUT_ORDER_DECODE: 499 case HFI_OUTPUT_ORDER_DISPLAY: 500 break; 501 default: 502 ret = -EINVAL; 503 break; 504 } 505 506 pkt->data[1] = *in; 507 pkt->shdr.hdr.size += sizeof(u32) * 2; 508 break; 509 } 510 case HFI_PROPERTY_PARAM_VDEC_PICTURE_TYPE_DECODE: { 511 struct hfi_enable_picture *in = pdata, *en = prop_data; 512 513 en->picture_type = in->picture_type; 514 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*en); 515 break; 516 } 517 case HFI_PROPERTY_PARAM_VDEC_OUTPUT2_KEEP_ASPECT_RATIO: { 518 struct hfi_enable *in = pdata, *en = prop_data; 519 520 en->enable = in->enable; 521 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*en); 522 break; 523 } 524 case HFI_PROPERTY_PARAM_VDEC_ENABLE_SUFFICIENT_SEQCHANGE_EVENT: 525 case HFI_PROPERTY_CONFIG_VDEC_POST_LOOP_DEBLOCKER: { 526 struct hfi_enable *in = pdata; 527 struct hfi_enable *en = prop_data; 528 529 en->enable = in->enable; 530 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*en); 531 break; 532 } 533 case HFI_PROPERTY_PARAM_VDEC_MULTI_STREAM: { 534 struct hfi_multi_stream *in = pdata, *multi = prop_data; 535 536 multi->buffer_type = in->buffer_type; 537 multi->enable = in->enable; 538 multi->width = in->width; 539 multi->height = in->height; 540 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*multi); 541 break; 542 } 543 case HFI_PROPERTY_PARAM_VDEC_DISPLAY_PICTURE_BUFFER_COUNT: { 544 struct hfi_display_picture_buffer_count *in = pdata; 545 struct hfi_display_picture_buffer_count *count = prop_data; 546 547 count->count = in->count; 548 count->enable = in->enable; 549 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*count); 550 break; 551 } 552 case HFI_PROPERTY_PARAM_DIVX_FORMAT: { 553 u32 *in = pdata; 554 555 switch (*in) { 556 case HFI_DIVX_FORMAT_4: 557 case HFI_DIVX_FORMAT_5: 558 case HFI_DIVX_FORMAT_6: 559 break; 560 default: 561 ret = -EINVAL; 562 break; 563 } 564 565 pkt->data[1] = *in; 566 pkt->shdr.hdr.size += sizeof(u32) * 2; 567 break; 568 } 569 case HFI_PROPERTY_CONFIG_VDEC_MB_ERROR_MAP_REPORTING: { 570 struct hfi_enable *in = pdata, *en = prop_data; 571 572 en->enable = in->enable; 573 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*en); 574 break; 575 } 576 case HFI_PROPERTY_PARAM_VDEC_CONTINUE_DATA_TRANSFER: { 577 struct hfi_enable *in = pdata, *en = prop_data; 578 579 en->enable = in->enable; 580 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*en); 581 break; 582 } 583 case HFI_PROPERTY_PARAM_VDEC_THUMBNAIL_MODE: { 584 struct hfi_enable *in = pdata, *en = prop_data; 585 586 en->enable = in->enable; 587 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*en); 588 break; 589 } 590 case HFI_PROPERTY_CONFIG_VENC_SYNC_FRAME_SEQUENCE_HEADER: { 591 struct hfi_enable *in = pdata, *en = prop_data; 592 593 en->enable = in->enable; 594 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*en); 595 break; 596 } 597 case HFI_PROPERTY_CONFIG_VENC_REQUEST_SYNC_FRAME: 598 pkt->shdr.hdr.size += sizeof(u32); 599 break; 600 case HFI_PROPERTY_PARAM_VENC_MPEG4_SHORT_HEADER: 601 break; 602 case HFI_PROPERTY_PARAM_VENC_MPEG4_AC_PREDICTION: 603 break; 604 case HFI_PROPERTY_CONFIG_VENC_TARGET_BITRATE: { 605 struct hfi_bitrate *in = pdata, *brate = prop_data; 606 607 brate->bitrate = in->bitrate; 608 brate->layer_id = in->layer_id; 609 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*brate); 610 break; 611 } 612 case HFI_PROPERTY_CONFIG_VENC_MAX_BITRATE: { 613 struct hfi_bitrate *in = pdata, *hfi = prop_data; 614 615 hfi->bitrate = in->bitrate; 616 hfi->layer_id = in->layer_id; 617 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*hfi); 618 break; 619 } 620 case HFI_PROPERTY_PARAM_PROFILE_LEVEL_CURRENT: { 621 struct hfi_profile_level *in = pdata, *pl = prop_data; 622 623 pl->level = in->level; 624 pl->profile = in->profile; 625 if (pl->profile <= 0) 626 /* Profile not supported, falling back to high */ 627 pl->profile = HFI_H264_PROFILE_HIGH; 628 629 if (!pl->level) 630 /* Level not supported, falling back to 1 */ 631 pl->level = 1; 632 633 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*pl); 634 break; 635 } 636 case HFI_PROPERTY_PARAM_VENC_H264_ENTROPY_CONTROL: { 637 struct hfi_h264_entropy_control *in = pdata, *hfi = prop_data; 638 639 hfi->entropy_mode = in->entropy_mode; 640 if (hfi->entropy_mode == HFI_H264_ENTROPY_CABAC) 641 hfi->cabac_model = in->cabac_model; 642 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*hfi); 643 break; 644 } 645 case HFI_PROPERTY_PARAM_VENC_RATE_CONTROL: { 646 u32 *in = pdata; 647 648 switch (*in) { 649 case HFI_RATE_CONTROL_OFF: 650 case HFI_RATE_CONTROL_CBR_CFR: 651 case HFI_RATE_CONTROL_CBR_VFR: 652 case HFI_RATE_CONTROL_VBR_CFR: 653 case HFI_RATE_CONTROL_VBR_VFR: 654 case HFI_RATE_CONTROL_CQ: 655 break; 656 default: 657 ret = -EINVAL; 658 break; 659 } 660 661 pkt->data[1] = *in; 662 pkt->shdr.hdr.size += sizeof(u32) * 2; 663 break; 664 } 665 case HFI_PROPERTY_PARAM_VENC_MPEG4_TIME_RESOLUTION: { 666 struct hfi_mpeg4_time_resolution *in = pdata, *res = prop_data; 667 668 res->time_increment_resolution = in->time_increment_resolution; 669 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*res); 670 break; 671 } 672 case HFI_PROPERTY_PARAM_VENC_MPEG4_HEADER_EXTENSION: { 673 struct hfi_mpeg4_header_extension *in = pdata, *ext = prop_data; 674 675 ext->header_extension = in->header_extension; 676 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*ext); 677 break; 678 } 679 case HFI_PROPERTY_PARAM_VENC_H264_DEBLOCK_CONTROL: { 680 struct hfi_h264_db_control *in = pdata, *db = prop_data; 681 682 switch (in->mode) { 683 case HFI_H264_DB_MODE_DISABLE: 684 case HFI_H264_DB_MODE_SKIP_SLICE_BOUNDARY: 685 case HFI_H264_DB_MODE_ALL_BOUNDARY: 686 break; 687 default: 688 ret = -EINVAL; 689 break; 690 } 691 692 db->mode = in->mode; 693 db->slice_alpha_offset = in->slice_alpha_offset; 694 db->slice_beta_offset = in->slice_beta_offset; 695 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*db); 696 break; 697 } 698 case HFI_PROPERTY_PARAM_VENC_SESSION_QP: { 699 struct hfi_quantization *in = pdata, *quant = prop_data; 700 701 quant->qp_i = in->qp_i; 702 quant->qp_p = in->qp_p; 703 quant->qp_b = in->qp_b; 704 quant->layer_id = in->layer_id; 705 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*quant); 706 break; 707 } 708 case HFI_PROPERTY_PARAM_VENC_SESSION_QP_RANGE: { 709 struct hfi_quantization_range *in = pdata, *range = prop_data; 710 u32 min_qp, max_qp; 711 712 min_qp = in->min_qp; 713 max_qp = in->max_qp; 714 715 /* We'll be packing in the qp, so make sure we 716 * won't be losing data when masking 717 */ 718 if (min_qp > 0xff || max_qp > 0xff) { 719 ret = -ERANGE; 720 break; 721 } 722 723 /* When creating the packet, pack the qp value as 724 * 0xiippbb, where ii = qp range for I-frames, 725 * pp = qp range for P-frames, etc. 726 */ 727 range->min_qp = min_qp | min_qp << 8 | min_qp << 16; 728 range->max_qp = max_qp | max_qp << 8 | max_qp << 16; 729 range->layer_id = in->layer_id; 730 731 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*range); 732 break; 733 } 734 case HFI_PROPERTY_PARAM_VENC_VC1_PERF_CFG: { 735 struct hfi_vc1e_perf_cfg_type *in = pdata, *perf = prop_data; 736 737 memcpy(perf->search_range_x_subsampled, 738 in->search_range_x_subsampled, 739 sizeof(perf->search_range_x_subsampled)); 740 memcpy(perf->search_range_y_subsampled, 741 in->search_range_y_subsampled, 742 sizeof(perf->search_range_y_subsampled)); 743 744 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*perf); 745 break; 746 } 747 case HFI_PROPERTY_PARAM_VENC_MAX_NUM_B_FRAMES: { 748 struct hfi_max_num_b_frames *bframes = prop_data; 749 u32 *in = pdata; 750 751 bframes->max_num_b_frames = *in; 752 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*bframes); 753 break; 754 } 755 case HFI_PROPERTY_CONFIG_VENC_INTRA_PERIOD: { 756 struct hfi_intra_period *in = pdata, *intra = prop_data; 757 758 intra->pframes = in->pframes; 759 intra->bframes = in->bframes; 760 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*intra); 761 break; 762 } 763 case HFI_PROPERTY_CONFIG_VENC_IDR_PERIOD: { 764 struct hfi_idr_period *in = pdata, *idr = prop_data; 765 766 idr->idr_period = in->idr_period; 767 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*idr); 768 break; 769 } 770 case HFI_PROPERTY_PARAM_VDEC_CONCEAL_COLOR: { 771 struct hfi_conceal_color *color = prop_data; 772 u32 *in = pdata; 773 774 color->conceal_color = *in & 0xff; 775 color->conceal_color |= ((*in >> 10) & 0xff) << 8; 776 color->conceal_color |= ((*in >> 20) & 0xff) << 16; 777 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*color); 778 break; 779 } 780 case HFI_PROPERTY_CONFIG_VPE_OPERATIONS: { 781 struct hfi_operations_type *in = pdata, *ops = prop_data; 782 783 switch (in->rotation) { 784 case HFI_ROTATE_NONE: 785 case HFI_ROTATE_90: 786 case HFI_ROTATE_180: 787 case HFI_ROTATE_270: 788 break; 789 default: 790 ret = -EINVAL; 791 break; 792 } 793 794 switch (in->flip) { 795 case HFI_FLIP_NONE: 796 case HFI_FLIP_HORIZONTAL: 797 case HFI_FLIP_VERTICAL: 798 break; 799 default: 800 ret = -EINVAL; 801 break; 802 } 803 804 ops->rotation = in->rotation; 805 ops->flip = in->flip; 806 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*ops); 807 break; 808 } 809 case HFI_PROPERTY_PARAM_VENC_INTRA_REFRESH: { 810 struct hfi_intra_refresh *in = pdata, *intra = prop_data; 811 812 switch (in->mode) { 813 case HFI_INTRA_REFRESH_NONE: 814 case HFI_INTRA_REFRESH_ADAPTIVE: 815 case HFI_INTRA_REFRESH_CYCLIC: 816 case HFI_INTRA_REFRESH_CYCLIC_ADAPTIVE: 817 case HFI_INTRA_REFRESH_RANDOM: 818 break; 819 default: 820 ret = -EINVAL; 821 break; 822 } 823 824 intra->mode = in->mode; 825 intra->air_mbs = in->air_mbs; 826 intra->air_ref = in->air_ref; 827 intra->cir_mbs = in->cir_mbs; 828 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*intra); 829 break; 830 } 831 case HFI_PROPERTY_PARAM_VENC_MULTI_SLICE_CONTROL: { 832 struct hfi_multi_slice_control *in = pdata, *multi = prop_data; 833 834 switch (in->multi_slice) { 835 case HFI_MULTI_SLICE_OFF: 836 case HFI_MULTI_SLICE_GOB: 837 case HFI_MULTI_SLICE_BY_MB_COUNT: 838 case HFI_MULTI_SLICE_BY_BYTE_COUNT: 839 break; 840 default: 841 ret = -EINVAL; 842 break; 843 } 844 845 multi->multi_slice = in->multi_slice; 846 multi->slice_size = in->slice_size; 847 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*multi); 848 break; 849 } 850 case HFI_PROPERTY_PARAM_VENC_SLICE_DELIVERY_MODE: { 851 struct hfi_enable *in = pdata, *en = prop_data; 852 853 en->enable = in->enable; 854 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*en); 855 break; 856 } 857 case HFI_PROPERTY_PARAM_VENC_H264_VUI_TIMING_INFO: { 858 struct hfi_h264_vui_timing_info *in = pdata, *vui = prop_data; 859 860 vui->enable = in->enable; 861 vui->fixed_framerate = in->fixed_framerate; 862 vui->time_scale = in->time_scale; 863 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*vui); 864 break; 865 } 866 case HFI_PROPERTY_CONFIG_VPE_DEINTERLACE: { 867 struct hfi_enable *in = pdata, *en = prop_data; 868 869 en->enable = in->enable; 870 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*en); 871 break; 872 } 873 case HFI_PROPERTY_PARAM_VENC_H264_GENERATE_AUDNAL: { 874 struct hfi_enable *in = pdata, *en = prop_data; 875 876 en->enable = in->enable; 877 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*en); 878 break; 879 } 880 case HFI_PROPERTY_PARAM_BUFFER_ALLOC_MODE: { 881 struct hfi_buffer_alloc_mode *in = pdata, *mode = prop_data; 882 883 mode->type = in->type; 884 mode->mode = in->mode; 885 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*mode); 886 break; 887 } 888 case HFI_PROPERTY_PARAM_VDEC_FRAME_ASSEMBLY: { 889 struct hfi_enable *in = pdata, *en = prop_data; 890 891 en->enable = in->enable; 892 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*en); 893 break; 894 } 895 case HFI_PROPERTY_PARAM_VENC_H264_VUI_BITSTREAM_RESTRC: { 896 struct hfi_enable *in = pdata, *en = prop_data; 897 898 en->enable = in->enable; 899 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*en); 900 break; 901 } 902 case HFI_PROPERTY_PARAM_VENC_PRESERVE_TEXT_QUALITY: { 903 struct hfi_enable *in = pdata, *en = prop_data; 904 905 en->enable = in->enable; 906 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*en); 907 break; 908 } 909 case HFI_PROPERTY_PARAM_VDEC_SCS_THRESHOLD: { 910 struct hfi_scs_threshold *thres = prop_data; 911 u32 *in = pdata; 912 913 thres->threshold_value = *in; 914 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*thres); 915 break; 916 } 917 case HFI_PROPERTY_PARAM_MVC_BUFFER_LAYOUT: { 918 struct hfi_mvc_buffer_layout_descp_type *in = pdata; 919 struct hfi_mvc_buffer_layout_descp_type *mvc = prop_data; 920 921 switch (in->layout_type) { 922 case HFI_MVC_BUFFER_LAYOUT_TOP_BOTTOM: 923 case HFI_MVC_BUFFER_LAYOUT_SEQ: 924 break; 925 default: 926 ret = -EINVAL; 927 break; 928 } 929 930 mvc->layout_type = in->layout_type; 931 mvc->bright_view_first = in->bright_view_first; 932 mvc->ngap = in->ngap; 933 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*mvc); 934 break; 935 } 936 case HFI_PROPERTY_PARAM_VENC_LTRMODE: { 937 struct hfi_ltr_mode *in = pdata, *ltr = prop_data; 938 939 switch (in->ltr_mode) { 940 case HFI_LTR_MODE_DISABLE: 941 case HFI_LTR_MODE_MANUAL: 942 case HFI_LTR_MODE_PERIODIC: 943 break; 944 default: 945 ret = -EINVAL; 946 break; 947 } 948 949 ltr->ltr_mode = in->ltr_mode; 950 ltr->ltr_count = in->ltr_count; 951 ltr->trust_mode = in->trust_mode; 952 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*ltr); 953 break; 954 } 955 case HFI_PROPERTY_CONFIG_VENC_USELTRFRAME: { 956 struct hfi_ltr_use *in = pdata, *ltr_use = prop_data; 957 958 ltr_use->frames = in->frames; 959 ltr_use->ref_ltr = in->ref_ltr; 960 ltr_use->use_constrnt = in->use_constrnt; 961 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*ltr_use); 962 break; 963 } 964 case HFI_PROPERTY_CONFIG_VENC_MARKLTRFRAME: { 965 struct hfi_ltr_mark *in = pdata, *ltr_mark = prop_data; 966 967 ltr_mark->mark_frame = in->mark_frame; 968 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*ltr_mark); 969 break; 970 } 971 case HFI_PROPERTY_PARAM_VENC_HIER_P_MAX_NUM_ENH_LAYER: { 972 u32 *in = pdata; 973 974 pkt->data[1] = *in; 975 pkt->shdr.hdr.size += sizeof(u32) * 2; 976 break; 977 } 978 case HFI_PROPERTY_CONFIG_VENC_HIER_P_ENH_LAYER: { 979 u32 *in = pdata; 980 981 pkt->data[1] = *in; 982 pkt->shdr.hdr.size += sizeof(u32) * 2; 983 break; 984 } 985 case HFI_PROPERTY_PARAM_VENC_DISABLE_RC_TIMESTAMP: { 986 struct hfi_enable *in = pdata, *en = prop_data; 987 988 en->enable = in->enable; 989 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*en); 990 break; 991 } 992 case HFI_PROPERTY_PARAM_VENC_INITIAL_QP: { 993 struct hfi_initial_quantization *in = pdata, *quant = prop_data; 994 995 quant->init_qp_enable = in->init_qp_enable; 996 quant->qp_i = in->qp_i; 997 quant->qp_p = in->qp_p; 998 quant->qp_b = in->qp_b; 999 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*quant); 1000 break; 1001 } 1002 case HFI_PROPERTY_PARAM_VPE_COLOR_SPACE_CONVERSION: { 1003 struct hfi_vpe_color_space_conversion *in = pdata; 1004 struct hfi_vpe_color_space_conversion *csc = prop_data; 1005 1006 memcpy(csc->csc_matrix, in->csc_matrix, 1007 sizeof(csc->csc_matrix)); 1008 memcpy(csc->csc_bias, in->csc_bias, sizeof(csc->csc_bias)); 1009 memcpy(csc->csc_limit, in->csc_limit, sizeof(csc->csc_limit)); 1010 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*csc); 1011 break; 1012 } 1013 case HFI_PROPERTY_PARAM_VENC_VPX_ERROR_RESILIENCE_MODE: { 1014 struct hfi_enable *in = pdata, *en = prop_data; 1015 1016 en->enable = in->enable; 1017 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*en); 1018 break; 1019 } 1020 case HFI_PROPERTY_PARAM_VENC_H264_NAL_SVC_EXT: { 1021 struct hfi_enable *in = pdata, *en = prop_data; 1022 1023 en->enable = in->enable; 1024 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*en); 1025 break; 1026 } 1027 case HFI_PROPERTY_CONFIG_VENC_PERF_MODE: { 1028 u32 *in = pdata; 1029 1030 pkt->data[1] = *in; 1031 pkt->shdr.hdr.size += sizeof(u32) * 2; 1032 break; 1033 } 1034 case HFI_PROPERTY_PARAM_VENC_HIER_B_MAX_NUM_ENH_LAYER: { 1035 u32 *in = pdata; 1036 1037 pkt->data[1] = *in; 1038 pkt->shdr.hdr.size += sizeof(u32) * 2; 1039 break; 1040 } 1041 case HFI_PROPERTY_PARAM_VDEC_NONCP_OUTPUT2: { 1042 struct hfi_enable *in = pdata, *en = prop_data; 1043 1044 en->enable = in->enable; 1045 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*en); 1046 break; 1047 } 1048 case HFI_PROPERTY_PARAM_VENC_HIER_P_HYBRID_MODE: { 1049 struct hfi_hybrid_hierp *in = pdata, *hierp = prop_data; 1050 1051 hierp->layers = in->layers; 1052 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*hierp); 1053 break; 1054 } 1055 case HFI_PROPERTY_PARAM_UNCOMPRESSED_PLANE_ACTUAL_INFO: { 1056 struct hfi_uncompressed_plane_actual_info *in = pdata; 1057 struct hfi_uncompressed_plane_actual_info *info = prop_data; 1058 1059 info->buffer_type = in->buffer_type; 1060 info->num_planes = in->num_planes; 1061 info->plane_format[0] = in->plane_format[0]; 1062 if (in->num_planes > 1) 1063 info->plane_format[1] = in->plane_format[1]; 1064 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*info); 1065 break; 1066 } 1067 case HFI_PROPERTY_PARAM_VENC_HDR10_PQ_SEI: 1068 return -ENOTSUPP; 1069 1070 /* FOLLOWING PROPERTIES ARE NOT IMPLEMENTED IN CORE YET */ 1071 case HFI_PROPERTY_CONFIG_BUFFER_REQUIREMENTS: 1072 case HFI_PROPERTY_CONFIG_PRIORITY: 1073 case HFI_PROPERTY_CONFIG_BATCH_INFO: 1074 case HFI_PROPERTY_SYS_IDLE_INDICATOR: 1075 case HFI_PROPERTY_PARAM_UNCOMPRESSED_FORMAT_SUPPORTED: 1076 case HFI_PROPERTY_PARAM_INTERLACE_FORMAT_SUPPORTED: 1077 case HFI_PROPERTY_PARAM_CHROMA_SITE: 1078 case HFI_PROPERTY_PARAM_PROPERTIES_SUPPORTED: 1079 case HFI_PROPERTY_PARAM_PROFILE_LEVEL_SUPPORTED: 1080 case HFI_PROPERTY_PARAM_CAPABILITY_SUPPORTED: 1081 case HFI_PROPERTY_PARAM_NAL_STREAM_FORMAT_SUPPORTED: 1082 case HFI_PROPERTY_PARAM_MULTI_VIEW_FORMAT: 1083 case HFI_PROPERTY_PARAM_MAX_SEQUENCE_HEADER_SIZE: 1084 case HFI_PROPERTY_PARAM_CODEC_SUPPORTED: 1085 case HFI_PROPERTY_PARAM_VDEC_MULTI_VIEW_SELECT: 1086 case HFI_PROPERTY_PARAM_VDEC_MB_QUANTIZATION: 1087 case HFI_PROPERTY_PARAM_VDEC_NUM_CONCEALED_MB: 1088 case HFI_PROPERTY_PARAM_VDEC_H264_ENTROPY_SWITCHING: 1089 case HFI_PROPERTY_PARAM_VENC_MULTI_SLICE_INFO: 1090 default: 1091 return -EINVAL; 1092 } 1093 1094 return ret; 1095 } 1096 1097 static int 1098 pkt_session_get_property_3xx(struct hfi_session_get_property_pkt *pkt, 1099 void *cookie, u32 ptype) 1100 { 1101 int ret = 0; 1102 1103 if (!pkt || !cookie) 1104 return -EINVAL; 1105 1106 pkt->shdr.hdr.size = sizeof(struct hfi_session_get_property_pkt); 1107 pkt->shdr.hdr.pkt_type = HFI_CMD_SESSION_GET_PROPERTY; 1108 pkt->shdr.session_id = hash32_ptr(cookie); 1109 pkt->num_properties = 1; 1110 1111 switch (ptype) { 1112 case HFI_PROPERTY_CONFIG_VDEC_ENTROPY: 1113 pkt->data[0] = HFI_PROPERTY_CONFIG_VDEC_ENTROPY; 1114 break; 1115 default: 1116 ret = pkt_session_get_property_1x(pkt, cookie, ptype); 1117 break; 1118 } 1119 1120 return ret; 1121 } 1122 1123 static int 1124 pkt_session_set_property_3xx(struct hfi_session_set_property_pkt *pkt, 1125 void *cookie, u32 ptype, void *pdata) 1126 { 1127 void *prop_data; 1128 int ret = 0; 1129 1130 if (!pkt || !cookie || !pdata) 1131 return -EINVAL; 1132 1133 prop_data = &pkt->data[1]; 1134 1135 pkt->shdr.hdr.size = sizeof(*pkt); 1136 pkt->shdr.hdr.pkt_type = HFI_CMD_SESSION_SET_PROPERTY; 1137 pkt->shdr.session_id = hash32_ptr(cookie); 1138 pkt->num_properties = 1; 1139 pkt->data[0] = ptype; 1140 1141 /* 1142 * Any session set property which is different in 3XX packetization 1143 * should be added as a new case below. All unchanged session set 1144 * properties will be handled in the default case. 1145 */ 1146 switch (ptype) { 1147 case HFI_PROPERTY_PARAM_VDEC_MULTI_STREAM: { 1148 struct hfi_multi_stream *in = pdata; 1149 struct hfi_multi_stream_3x *multi = prop_data; 1150 1151 multi->buffer_type = in->buffer_type; 1152 multi->enable = in->enable; 1153 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*multi); 1154 break; 1155 } 1156 case HFI_PROPERTY_PARAM_VENC_INTRA_REFRESH: { 1157 struct hfi_intra_refresh *in = pdata; 1158 struct hfi_intra_refresh_3x *intra = prop_data; 1159 1160 switch (in->mode) { 1161 case HFI_INTRA_REFRESH_NONE: 1162 case HFI_INTRA_REFRESH_ADAPTIVE: 1163 case HFI_INTRA_REFRESH_CYCLIC: 1164 case HFI_INTRA_REFRESH_CYCLIC_ADAPTIVE: 1165 case HFI_INTRA_REFRESH_RANDOM: 1166 break; 1167 default: 1168 ret = -EINVAL; 1169 break; 1170 } 1171 1172 intra->mode = in->mode; 1173 intra->mbs = in->cir_mbs; 1174 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*intra); 1175 break; 1176 } 1177 case HFI_PROPERTY_PARAM_VDEC_CONTINUE_DATA_TRANSFER: 1178 /* for 3xx fw version session_continue is used */ 1179 break; 1180 default: 1181 ret = pkt_session_set_property_1x(pkt, cookie, ptype, pdata); 1182 break; 1183 } 1184 1185 return ret; 1186 } 1187 1188 static int 1189 pkt_session_set_property_4xx(struct hfi_session_set_property_pkt *pkt, 1190 void *cookie, u32 ptype, void *pdata) 1191 { 1192 void *prop_data; 1193 1194 if (!pkt || !cookie || !pdata) 1195 return -EINVAL; 1196 1197 prop_data = &pkt->data[1]; 1198 1199 pkt->shdr.hdr.size = sizeof(*pkt); 1200 pkt->shdr.hdr.pkt_type = HFI_CMD_SESSION_SET_PROPERTY; 1201 pkt->shdr.session_id = hash32_ptr(cookie); 1202 pkt->num_properties = 1; 1203 pkt->data[0] = ptype; 1204 1205 /* 1206 * Any session set property which is different in 3XX packetization 1207 * should be added as a new case below. All unchanged session set 1208 * properties will be handled in the default case. 1209 */ 1210 switch (ptype) { 1211 case HFI_PROPERTY_PARAM_BUFFER_COUNT_ACTUAL: { 1212 struct hfi_buffer_count_actual *in = pdata; 1213 struct hfi_buffer_count_actual_4xx *count = prop_data; 1214 1215 count->count_actual = in->count_actual; 1216 count->type = in->type; 1217 count->count_min_host = in->count_actual; 1218 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*count); 1219 break; 1220 } 1221 case HFI_PROPERTY_PARAM_WORK_MODE: { 1222 struct hfi_video_work_mode *in = pdata, *wm = prop_data; 1223 1224 wm->video_work_mode = in->video_work_mode; 1225 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*wm); 1226 break; 1227 } 1228 case HFI_PROPERTY_CONFIG_VIDEOCORES_USAGE: { 1229 struct hfi_videocores_usage_type *in = pdata, *cu = prop_data; 1230 1231 cu->video_core_enable_mask = in->video_core_enable_mask; 1232 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*cu); 1233 break; 1234 } 1235 case HFI_PROPERTY_PARAM_VENC_HDR10_PQ_SEI: { 1236 struct hfi_hdr10_pq_sei *in = pdata, *hdr10 = prop_data; 1237 1238 memcpy(hdr10, in, sizeof(*hdr10)); 1239 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*hdr10); 1240 break; 1241 } 1242 case HFI_PROPERTY_PARAM_VDEC_CONCEAL_COLOR: { 1243 struct hfi_conceal_color_v4 *color = prop_data; 1244 u32 *in = pdata; 1245 1246 color->conceal_color_8bit = *in & 0xff; 1247 color->conceal_color_8bit |= ((*in >> 10) & 0xff) << 8; 1248 color->conceal_color_8bit |= ((*in >> 20) & 0xff) << 16; 1249 color->conceal_color_10bit = *in; 1250 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*color); 1251 break; 1252 } 1253 1254 case HFI_PROPERTY_PARAM_VENC_H264_TRANSFORM_8X8: { 1255 struct hfi_h264_8x8_transform *in = pdata, *tm = prop_data; 1256 1257 tm->enable_type = in->enable_type; 1258 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*tm); 1259 break; 1260 } 1261 case HFI_PROPERTY_PARAM_VENC_SESSION_QP_RANGE_V2: { 1262 struct hfi_quantization_range_v2 *in = pdata, *range = prop_data; 1263 u32 min_qp, max_qp; 1264 1265 min_qp = in->min_qp.qp_packed; 1266 max_qp = in->max_qp.qp_packed; 1267 1268 /* We'll be packing in the qp, so make sure we 1269 * won't be losing data when masking 1270 */ 1271 if (min_qp > 0xff || max_qp > 0xff) 1272 return -ERANGE; 1273 1274 range->min_qp.layer_id = 0xFF; 1275 range->max_qp.layer_id = 0xFF; 1276 range->min_qp.qp_packed = (min_qp & 0xFF) | ((min_qp & 0xFF) << 8) | 1277 ((min_qp & 0xFF) << 16); 1278 range->max_qp.qp_packed = (max_qp & 0xFF) | ((max_qp & 0xFF) << 8) | 1279 ((max_qp & 0xFF) << 16); 1280 range->min_qp.enable = 7; 1281 range->max_qp.enable = 7; 1282 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*range); 1283 break; 1284 } 1285 case HFI_PROPERTY_CONFIG_VENC_MAX_BITRATE: 1286 case HFI_PROPERTY_CONFIG_VDEC_POST_LOOP_DEBLOCKER: 1287 case HFI_PROPERTY_PARAM_BUFFER_ALLOC_MODE: 1288 case HFI_PROPERTY_PARAM_VENC_SESSION_QP: 1289 case HFI_PROPERTY_PARAM_VENC_SESSION_QP_RANGE: 1290 /* not implemented on Venus 4xx */ 1291 return -ENOTSUPP; 1292 default: 1293 return pkt_session_set_property_3xx(pkt, cookie, ptype, pdata); 1294 } 1295 1296 return 0; 1297 } 1298 1299 static int 1300 pkt_session_set_property_6xx(struct hfi_session_set_property_pkt *pkt, 1301 void *cookie, u32 ptype, void *pdata) 1302 { 1303 void *prop_data; 1304 1305 if (!pkt || !cookie || !pdata) 1306 return -EINVAL; 1307 1308 prop_data = &pkt->data[1]; 1309 1310 pkt->shdr.hdr.size = sizeof(*pkt); 1311 pkt->shdr.hdr.pkt_type = HFI_CMD_SESSION_SET_PROPERTY; 1312 pkt->shdr.session_id = hash32_ptr(cookie); 1313 pkt->num_properties = 1; 1314 pkt->data[0] = ptype; 1315 1316 switch (ptype) { 1317 case HFI_PROPERTY_PARAM_UNCOMPRESSED_PLANE_ACTUAL_CONSTRAINTS_INFO: { 1318 struct hfi_uncompressed_plane_actual_constraints_info *in = pdata; 1319 struct hfi_uncompressed_plane_actual_constraints_info *info = prop_data; 1320 1321 info->buffer_type = in->buffer_type; 1322 info->num_planes = in->num_planes; 1323 info->plane_format[0] = in->plane_format[0]; 1324 if (in->num_planes > 1) 1325 info->plane_format[1] = in->plane_format[1]; 1326 1327 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*info); 1328 break; 1329 } 1330 case HFI_PROPERTY_CONFIG_HEIC_FRAME_QUALITY: { 1331 struct hfi_heic_frame_quality *in = pdata, *cq = prop_data; 1332 1333 cq->frame_quality = in->frame_quality; 1334 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*cq); 1335 break; 1336 } 1337 case HFI_PROPERTY_PARAM_WORK_ROUTE: { 1338 struct hfi_video_work_route *in = pdata, *wr = prop_data; 1339 1340 wr->video_work_route = in->video_work_route; 1341 pkt->shdr.hdr.size += sizeof(u32) + sizeof(*wr); 1342 break; 1343 } 1344 default: 1345 return pkt_session_set_property_4xx(pkt, cookie, ptype, pdata); 1346 } 1347 1348 return 0; 1349 } 1350 1351 int pkt_session_get_property(struct hfi_session_get_property_pkt *pkt, 1352 void *cookie, u32 ptype) 1353 { 1354 if (hfi_ver == HFI_VERSION_1XX) 1355 return pkt_session_get_property_1x(pkt, cookie, ptype); 1356 1357 return pkt_session_get_property_3xx(pkt, cookie, ptype); 1358 } 1359 1360 int pkt_session_set_property(struct hfi_session_set_property_pkt *pkt, 1361 void *cookie, u32 ptype, void *pdata) 1362 { 1363 if (hfi_ver == HFI_VERSION_1XX) 1364 return pkt_session_set_property_1x(pkt, cookie, ptype, pdata); 1365 1366 if (hfi_ver == HFI_VERSION_3XX) 1367 return pkt_session_set_property_3xx(pkt, cookie, ptype, pdata); 1368 1369 if (hfi_ver == HFI_VERSION_4XX) 1370 return pkt_session_set_property_4xx(pkt, cookie, ptype, pdata); 1371 1372 return pkt_session_set_property_6xx(pkt, cookie, ptype, pdata); 1373 } 1374 1375 void pkt_set_version(enum hfi_version version) 1376 { 1377 hfi_ver = version; 1378 } 1379