1bf215546Sopenharmony_ci/* 2bf215546Sopenharmony_ci * Copyright © 2016-2018 Broadcom 3bf215546Sopenharmony_ci * 4bf215546Sopenharmony_ci * Permission is hereby granted, free of charge, to any person obtaining a 5bf215546Sopenharmony_ci * copy of this software and associated documentation files (the "Software"), 6bf215546Sopenharmony_ci * to deal in the Software without restriction, including without limitation 7bf215546Sopenharmony_ci * the rights to use, copy, modify, merge, publish, distribute, sublicense, 8bf215546Sopenharmony_ci * and/or sell copies of the Software, and to permit persons to whom the 9bf215546Sopenharmony_ci * Software is furnished to do so, subject to the following conditions: 10bf215546Sopenharmony_ci * 11bf215546Sopenharmony_ci * The above copyright notice and this permission notice (including the next 12bf215546Sopenharmony_ci * paragraph) shall be included in all copies or substantial portions of the 13bf215546Sopenharmony_ci * Software. 14bf215546Sopenharmony_ci * 15bf215546Sopenharmony_ci * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16bf215546Sopenharmony_ci * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17bf215546Sopenharmony_ci * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 18bf215546Sopenharmony_ci * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19bf215546Sopenharmony_ci * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 20bf215546Sopenharmony_ci * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS 21bf215546Sopenharmony_ci * IN THE SOFTWARE. 22bf215546Sopenharmony_ci */ 23bf215546Sopenharmony_ci 24bf215546Sopenharmony_ci#include "v3d_compiler.h" 25bf215546Sopenharmony_ci 26bf215546Sopenharmony_ci/* We don't do any address packing. */ 27bf215546Sopenharmony_ci#define __gen_user_data void 28bf215546Sopenharmony_ci#define __gen_address_type uint32_t 29bf215546Sopenharmony_ci#define __gen_address_offset(reloc) (*reloc) 30bf215546Sopenharmony_ci#define __gen_emit_reloc(cl, reloc) 31bf215546Sopenharmony_ci#include "broadcom/cle/v3d_packet_v33_pack.h" 32bf215546Sopenharmony_ci 33bf215546Sopenharmony_civoid 34bf215546Sopenharmony_civ3d33_vir_vpm_read_setup(struct v3d_compile *c, int num_components) 35bf215546Sopenharmony_ci{ 36bf215546Sopenharmony_ci struct V3D33_VPM_GENERIC_BLOCK_READ_SETUP unpacked = { 37bf215546Sopenharmony_ci V3D33_VPM_GENERIC_BLOCK_READ_SETUP_header, 38bf215546Sopenharmony_ci 39bf215546Sopenharmony_ci .horiz = true, 40bf215546Sopenharmony_ci .laned = false, 41bf215546Sopenharmony_ci /* If the field is 0, that means a read count of 32. */ 42bf215546Sopenharmony_ci .num = num_components & 31, 43bf215546Sopenharmony_ci .segs = true, 44bf215546Sopenharmony_ci .stride = 1, 45bf215546Sopenharmony_ci .size = VPM_SETUP_SIZE_32_BIT, 46bf215546Sopenharmony_ci .addr = c->num_inputs, 47bf215546Sopenharmony_ci }; 48bf215546Sopenharmony_ci 49bf215546Sopenharmony_ci uint32_t packed; 50bf215546Sopenharmony_ci V3D33_VPM_GENERIC_BLOCK_READ_SETUP_pack(NULL, 51bf215546Sopenharmony_ci (uint8_t *)&packed, 52bf215546Sopenharmony_ci &unpacked); 53bf215546Sopenharmony_ci vir_VPMSETUP(c, vir_uniform_ui(c, packed)); 54bf215546Sopenharmony_ci} 55bf215546Sopenharmony_ci 56bf215546Sopenharmony_civoid 57bf215546Sopenharmony_civ3d33_vir_vpm_write_setup(struct v3d_compile *c) 58bf215546Sopenharmony_ci{ 59bf215546Sopenharmony_ci uint32_t packed; 60bf215546Sopenharmony_ci struct V3D33_VPM_GENERIC_BLOCK_WRITE_SETUP unpacked = { 61bf215546Sopenharmony_ci V3D33_VPM_GENERIC_BLOCK_WRITE_SETUP_header, 62bf215546Sopenharmony_ci 63bf215546Sopenharmony_ci .horiz = true, 64bf215546Sopenharmony_ci .laned = false, 65bf215546Sopenharmony_ci .segs = true, 66bf215546Sopenharmony_ci .stride = 1, 67bf215546Sopenharmony_ci .size = VPM_SETUP_SIZE_32_BIT, 68bf215546Sopenharmony_ci .addr = 0, 69bf215546Sopenharmony_ci }; 70bf215546Sopenharmony_ci 71bf215546Sopenharmony_ci V3D33_VPM_GENERIC_BLOCK_WRITE_SETUP_pack(NULL, 72bf215546Sopenharmony_ci (uint8_t *)&packed, 73bf215546Sopenharmony_ci &unpacked); 74bf215546Sopenharmony_ci vir_VPMSETUP(c, vir_uniform_ui(c, packed)); 75bf215546Sopenharmony_ci} 76