1bf215546Sopenharmony_ci/* 2bf215546Sopenharmony_ci * Copyright 2012 Advanced Micro Devices, Inc. 3bf215546Sopenharmony_ci * All Rights Reserved. 4bf215546Sopenharmony_ci * 5bf215546Sopenharmony_ci * Permission is hereby granted, free of charge, to any person obtaining a 6bf215546Sopenharmony_ci * copy of this software and associated documentation files (the "Software"), 7bf215546Sopenharmony_ci * to deal in the Software without restriction, including without limitation 8bf215546Sopenharmony_ci * on the rights to use, copy, modify, merge, publish, distribute, sub 9bf215546Sopenharmony_ci * license, and/or sell copies of the Software, and to permit persons to whom 10bf215546Sopenharmony_ci * the Software is furnished to do so, subject to the following conditions: 11bf215546Sopenharmony_ci * 12bf215546Sopenharmony_ci * The above copyright notice and this permission notice (including the next 13bf215546Sopenharmony_ci * paragraph) shall be included in all copies or substantial portions of the 14bf215546Sopenharmony_ci * Software. 15bf215546Sopenharmony_ci * 16bf215546Sopenharmony_ci * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 17bf215546Sopenharmony_ci * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 18bf215546Sopenharmony_ci * FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. IN NO EVENT SHALL 19bf215546Sopenharmony_ci * THE AUTHOR(S) AND/OR THEIR SUPPLIERS BE LIABLE FOR ANY CLAIM, 20bf215546Sopenharmony_ci * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR 21bf215546Sopenharmony_ci * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE 22bf215546Sopenharmony_ci * USE OR OTHER DEALINGS IN THE SOFTWARE. 23bf215546Sopenharmony_ci */ 24bf215546Sopenharmony_ci 25bf215546Sopenharmony_ci#ifndef SI_PM4_H 26bf215546Sopenharmony_ci#define SI_PM4_H 27bf215546Sopenharmony_ci 28bf215546Sopenharmony_ci#include "winsys/radeon_winsys.h" 29bf215546Sopenharmony_ci 30bf215546Sopenharmony_ci#ifdef __cplusplus 31bf215546Sopenharmony_ciextern "C" { 32bf215546Sopenharmony_ci#endif 33bf215546Sopenharmony_ci 34bf215546Sopenharmony_ci// forward defines 35bf215546Sopenharmony_cistruct si_context; 36bf215546Sopenharmony_ci 37bf215546Sopenharmony_ci/* State atoms are callbacks which write a sequence of packets into a GPU 38bf215546Sopenharmony_ci * command buffer (AKA indirect buffer, AKA IB, AKA command stream, AKA CS). 39bf215546Sopenharmony_ci */ 40bf215546Sopenharmony_cistruct si_atom { 41bf215546Sopenharmony_ci void (*emit)(struct si_context *ctx); 42bf215546Sopenharmony_ci}; 43bf215546Sopenharmony_ci 44bf215546Sopenharmony_cistruct si_pm4_state { 45bf215546Sopenharmony_ci /* PKT3_SET_*_REG handling */ 46bf215546Sopenharmony_ci uint16_t last_reg; /* register offset in dwords */ 47bf215546Sopenharmony_ci uint16_t last_pm4; 48bf215546Sopenharmony_ci uint16_t ndw; /* number of dwords in pm4 */ 49bf215546Sopenharmony_ci uint8_t last_opcode; 50bf215546Sopenharmony_ci 51bf215546Sopenharmony_ci /* For shader states only */ 52bf215546Sopenharmony_ci bool is_shader; 53bf215546Sopenharmony_ci struct si_atom atom; 54bf215546Sopenharmony_ci 55bf215546Sopenharmony_ci /* commands for the DE */ 56bf215546Sopenharmony_ci uint16_t max_dw; 57bf215546Sopenharmony_ci 58bf215546Sopenharmony_ci /* This must be the last field because the array can continue after the structure. */ 59bf215546Sopenharmony_ci uint32_t pm4[64]; 60bf215546Sopenharmony_ci}; 61bf215546Sopenharmony_ci 62bf215546Sopenharmony_civoid si_pm4_cmd_add(struct si_pm4_state *state, uint32_t dw); 63bf215546Sopenharmony_civoid si_pm4_set_reg(struct si_pm4_state *state, unsigned reg, uint32_t val); 64bf215546Sopenharmony_civoid si_pm4_set_reg_idx3(struct si_pm4_state *state, unsigned reg, uint32_t val); 65bf215546Sopenharmony_ci 66bf215546Sopenharmony_civoid si_pm4_clear_state(struct si_pm4_state *state); 67bf215546Sopenharmony_civoid si_pm4_free_state(struct si_context *sctx, struct si_pm4_state *state, unsigned idx); 68bf215546Sopenharmony_ci 69bf215546Sopenharmony_civoid si_pm4_emit(struct si_context *sctx, struct si_pm4_state *state); 70bf215546Sopenharmony_civoid si_pm4_reset_emitted(struct si_context *sctx, bool first_cs); 71bf215546Sopenharmony_ci 72bf215546Sopenharmony_ci#ifdef __cplusplus 73bf215546Sopenharmony_ci} 74bf215546Sopenharmony_ci#endif 75bf215546Sopenharmony_ci 76bf215546Sopenharmony_ci#endif 77