1bf215546Sopenharmony_ci/* 2bf215546Sopenharmony_ci * Copyright © 2022 Advanced Micro Devices, Inc. 3bf215546Sopenharmony_ci * 4bf215546Sopenharmony_ci * Permission is hereby granted, free of charge, to any person obtaining 5bf215546Sopenharmony_ci * a copy of this software and associated documentation files (the 6bf215546Sopenharmony_ci * "Software"), to deal in the Software without restriction, including 7bf215546Sopenharmony_ci * without limitation the rights to use, copy, modify, merge, publish, 8bf215546Sopenharmony_ci * distribute, sub license, and/or sell copies of the Software, and to 9bf215546Sopenharmony_ci * permit persons to whom the Software is furnished to do so, subject to 10bf215546Sopenharmony_ci * the following conditions: 11bf215546Sopenharmony_ci * 12bf215546Sopenharmony_ci * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 13bf215546Sopenharmony_ci * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES 14bf215546Sopenharmony_ci * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 15bf215546Sopenharmony_ci * NON-INFRINGEMENT. IN NO EVENT SHALL THE COPYRIGHT HOLDERS, AUTHORS 16bf215546Sopenharmony_ci * AND/OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 17bf215546Sopenharmony_ci * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, 18bf215546Sopenharmony_ci * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE 19bf215546Sopenharmony_ci * USE OR OTHER DEALINGS IN THE SOFTWARE. 20bf215546Sopenharmony_ci * 21bf215546Sopenharmony_ci * The above copyright notice and this permission notice (including the 22bf215546Sopenharmony_ci * next paragraph) shall be included in all copies or substantial portions 23bf215546Sopenharmony_ci * of the Software. 24bf215546Sopenharmony_ci */ 25bf215546Sopenharmony_ci 26bf215546Sopenharmony_ci#include "radeon_vcn.h" 27bf215546Sopenharmony_ci 28bf215546Sopenharmony_ci/* vcn unified queue (sq) ib header */ 29bf215546Sopenharmony_civoid rvcn_sq_header(struct radeon_cmdbuf *cs, 30bf215546Sopenharmony_ci struct rvcn_sq_var *sq, 31bf215546Sopenharmony_ci bool enc) 32bf215546Sopenharmony_ci{ 33bf215546Sopenharmony_ci /* vcn ib signature */ 34bf215546Sopenharmony_ci radeon_emit(cs, RADEON_VCN_SIGNATURE_SIZE); 35bf215546Sopenharmony_ci radeon_emit(cs, RADEON_VCN_SIGNATURE); 36bf215546Sopenharmony_ci sq->ib_checksum = &cs->current.buf[cs->current.cdw]; 37bf215546Sopenharmony_ci radeon_emit(cs, 0); 38bf215546Sopenharmony_ci sq->ib_total_size_in_dw = &cs->current.buf[cs->current.cdw]; 39bf215546Sopenharmony_ci radeon_emit(cs, 0); 40bf215546Sopenharmony_ci 41bf215546Sopenharmony_ci /* vcn ib engine info */ 42bf215546Sopenharmony_ci radeon_emit(cs, RADEON_VCN_ENGINE_INFO_SIZE); 43bf215546Sopenharmony_ci radeon_emit(cs, RADEON_VCN_ENGINE_INFO); 44bf215546Sopenharmony_ci radeon_emit(cs, enc ? RADEON_VCN_ENGINE_TYPE_ENCODE 45bf215546Sopenharmony_ci : RADEON_VCN_ENGINE_TYPE_DECODE); 46bf215546Sopenharmony_ci radeon_emit(cs, 0); 47bf215546Sopenharmony_ci} 48bf215546Sopenharmony_ci 49bf215546Sopenharmony_civoid rvcn_sq_tail(struct radeon_cmdbuf *cs, 50bf215546Sopenharmony_ci struct rvcn_sq_var *sq) 51bf215546Sopenharmony_ci{ 52bf215546Sopenharmony_ci uint32_t *end; 53bf215546Sopenharmony_ci uint32_t size_in_dw; 54bf215546Sopenharmony_ci uint32_t checksum = 0; 55bf215546Sopenharmony_ci 56bf215546Sopenharmony_ci if (sq->ib_checksum == NULL || sq->ib_total_size_in_dw == NULL) 57bf215546Sopenharmony_ci return; 58bf215546Sopenharmony_ci 59bf215546Sopenharmony_ci end = &cs->current.buf[cs->current.cdw]; 60bf215546Sopenharmony_ci size_in_dw = end - sq->ib_total_size_in_dw - 1; 61bf215546Sopenharmony_ci *sq->ib_total_size_in_dw = size_in_dw; 62bf215546Sopenharmony_ci *(sq->ib_total_size_in_dw + 4) = size_in_dw * sizeof(uint32_t); 63bf215546Sopenharmony_ci 64bf215546Sopenharmony_ci for (int i = 0; i < size_in_dw; i++) 65bf215546Sopenharmony_ci checksum += *(sq->ib_checksum + 2 + i); 66bf215546Sopenharmony_ci 67bf215546Sopenharmony_ci *sq->ib_checksum = checksum; 68bf215546Sopenharmony_ci} 69