| /* SPDX-License-Identifier: GPL-2.0 OR MIT */ |
| /* |
| * Copyright 2014-2022 Advanced Micro Devices, Inc. |
| * |
| * Permission is hereby granted, free of charge, to any person obtaining a |
| * copy of this software and associated documentation files (the "Software"), |
| * to deal in the Software without restriction, including without limitation |
| * the rights to use, copy, modify, merge, publish, distribute, sublicense, |
| * and/or sell copies of the Software, and to permit persons to whom the |
| * Software is furnished to do so, subject to the following conditions: |
| * |
| * The above copyright notice and this permission notice shall be included in |
| * all copies or substantial portions of the Software. |
| * |
| * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
| * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
| * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL |
| * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR |
| * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, |
| * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR |
| * OTHER DEALINGS IN THE SOFTWARE. |
| * |
| */ |
| |
| #ifndef KFD_PM4_HEADERS_DIQ_H_ |
| #define KFD_PM4_HEADERS_DIQ_H_ |
| |
| /*--------------------_INDIRECT_BUFFER-------------------- */ |
| |
| #ifndef _PM4__INDIRECT_BUFFER_DEFINED |
| #define _PM4__INDIRECT_BUFFER_DEFINED |
| enum _INDIRECT_BUFFER_cache_policy_enum { |
| cache_policy___indirect_buffer__lru = 0, |
| cache_policy___indirect_buffer__stream = 1, |
| cache_policy___indirect_buffer__bypass = 2 |
| }; |
| |
| enum { |
| IT_INDIRECT_BUFFER_PASID = 0x5C |
| }; |
| |
| struct pm4__indirect_buffer_pasid { |
| union { |
| union PM4_MES_TYPE_3_HEADER header; /* header */ |
| unsigned int ordinal1; |
| }; |
| |
| union { |
| struct { |
| unsigned int reserved1:2; |
| unsigned int ib_base_lo:30; |
| } bitfields2; |
| unsigned int ordinal2; |
| }; |
| |
| union { |
| struct { |
| unsigned int ib_base_hi:16; |
| unsigned int reserved2:16; |
| } bitfields3; |
| unsigned int ordinal3; |
| }; |
| |
| union { |
| unsigned int control; |
| unsigned int ordinal4; |
| }; |
| |
| union { |
| struct { |
| unsigned int pasid:10; |
| unsigned int reserved4:22; |
| } bitfields5; |
| unsigned int ordinal5; |
| }; |
| |
| }; |
| |
| #endif |
| |
| /*--------------------_RELEASE_MEM-------------------- */ |
| |
| #ifndef _PM4__RELEASE_MEM_DEFINED |
| #define _PM4__RELEASE_MEM_DEFINED |
| enum _RELEASE_MEM_event_index_enum { |
| event_index___release_mem__end_of_pipe = 5, |
| event_index___release_mem__shader_done = 6 |
| }; |
| |
| enum _RELEASE_MEM_cache_policy_enum { |
| cache_policy___release_mem__lru = 0, |
| cache_policy___release_mem__stream = 1, |
| cache_policy___release_mem__bypass = 2 |
| }; |
| |
| enum _RELEASE_MEM_dst_sel_enum { |
| dst_sel___release_mem__memory_controller = 0, |
| dst_sel___release_mem__tc_l2 = 1, |
| dst_sel___release_mem__queue_write_pointer_register = 2, |
| dst_sel___release_mem__queue_write_pointer_poll_mask_bit = 3 |
| }; |
| |
| enum _RELEASE_MEM_int_sel_enum { |
| int_sel___release_mem__none = 0, |
| int_sel___release_mem__send_interrupt_only = 1, |
| int_sel___release_mem__send_interrupt_after_write_confirm = 2, |
| int_sel___release_mem__send_data_after_write_confirm = 3 |
| }; |
| |
| enum _RELEASE_MEM_data_sel_enum { |
| data_sel___release_mem__none = 0, |
| data_sel___release_mem__send_32_bit_low = 1, |
| data_sel___release_mem__send_64_bit_data = 2, |
| data_sel___release_mem__send_gpu_clock_counter = 3, |
| data_sel___release_mem__send_cp_perfcounter_hi_lo = 4, |
| data_sel___release_mem__store_gds_data_to_memory = 5 |
| }; |
| |
| struct pm4__release_mem { |
| union { |
| union PM4_MES_TYPE_3_HEADER header; /*header */ |
| unsigned int ordinal1; |
| }; |
| |
| union { |
| struct { |
| unsigned int event_type:6; |
| unsigned int reserved1:2; |
| enum _RELEASE_MEM_event_index_enum event_index:4; |
| unsigned int tcl1_vol_action_ena:1; |
| unsigned int tc_vol_action_ena:1; |
| unsigned int reserved2:1; |
| unsigned int tc_wb_action_ena:1; |
| unsigned int tcl1_action_ena:1; |
| unsigned int tc_action_ena:1; |
| unsigned int reserved3:6; |
| unsigned int atc:1; |
| enum _RELEASE_MEM_cache_policy_enum cache_policy:2; |
| unsigned int reserved4:5; |
| } bitfields2; |
| unsigned int ordinal2; |
| }; |
| |
| union { |
| struct { |
| unsigned int reserved5:16; |
| enum _RELEASE_MEM_dst_sel_enum dst_sel:2; |
| unsigned int reserved6:6; |
| enum _RELEASE_MEM_int_sel_enum int_sel:3; |
| unsigned int reserved7:2; |
| enum _RELEASE_MEM_data_sel_enum data_sel:3; |
| } bitfields3; |
| unsigned int ordinal3; |
| }; |
| |
| union { |
| struct { |
| unsigned int reserved8:2; |
| unsigned int address_lo_32b:30; |
| } bitfields4; |
| struct { |
| unsigned int reserved9:3; |
| unsigned int address_lo_64b:29; |
| } bitfields5; |
| unsigned int ordinal4; |
| }; |
| |
| unsigned int address_hi; |
| |
| unsigned int data_lo; |
| |
| unsigned int data_hi; |
| |
| }; |
| #endif |
| |
| |
| /*--------------------_SET_CONFIG_REG-------------------- */ |
| |
| #ifndef _PM4__SET_CONFIG_REG_DEFINED |
| #define _PM4__SET_CONFIG_REG_DEFINED |
| |
| struct pm4__set_config_reg { |
| union { |
| union PM4_MES_TYPE_3_HEADER header; /*header */ |
| unsigned int ordinal1; |
| }; |
| |
| union { |
| struct { |
| unsigned int reg_offset:16; |
| unsigned int reserved1:7; |
| unsigned int vmid_shift:5; |
| unsigned int insert_vmid:1; |
| unsigned int reserved2:3; |
| } bitfields2; |
| unsigned int ordinal2; |
| }; |
| |
| unsigned int reg_data[1]; /*1..N of these fields */ |
| |
| }; |
| #endif |
| |
| /*--------------------_WAIT_REG_MEM-------------------- */ |
| |
| #ifndef _PM4__WAIT_REG_MEM_DEFINED |
| #define _PM4__WAIT_REG_MEM_DEFINED |
| enum _WAIT_REG_MEM_function_enum { |
| function___wait_reg_mem__always_pass = 0, |
| function___wait_reg_mem__less_than_ref_value = 1, |
| function___wait_reg_mem__less_than_equal_to_the_ref_value = 2, |
| function___wait_reg_mem__equal_to_the_reference_value = 3, |
| function___wait_reg_mem__not_equal_reference_value = 4, |
| function___wait_reg_mem__greater_than_or_equal_reference_value = 5, |
| function___wait_reg_mem__greater_than_reference_value = 6, |
| function___wait_reg_mem__reserved = 7 |
| }; |
| |
| enum _WAIT_REG_MEM_mem_space_enum { |
| mem_space___wait_reg_mem__register_space = 0, |
| mem_space___wait_reg_mem__memory_space = 1 |
| }; |
| |
| enum _WAIT_REG_MEM_operation_enum { |
| operation___wait_reg_mem__wait_reg_mem = 0, |
| operation___wait_reg_mem__wr_wait_wr_reg = 1 |
| }; |
| |
| struct pm4__wait_reg_mem { |
| union { |
| union PM4_MES_TYPE_3_HEADER header; /*header */ |
| unsigned int ordinal1; |
| }; |
| |
| union { |
| struct { |
| enum _WAIT_REG_MEM_function_enum function:3; |
| unsigned int reserved1:1; |
| enum _WAIT_REG_MEM_mem_space_enum mem_space:2; |
| enum _WAIT_REG_MEM_operation_enum operation:2; |
| unsigned int reserved2:24; |
| } bitfields2; |
| unsigned int ordinal2; |
| }; |
| |
| union { |
| struct { |
| unsigned int reserved3:2; |
| unsigned int memory_poll_addr_lo:30; |
| } bitfields3; |
| struct { |
| unsigned int register_poll_addr:16; |
| unsigned int reserved4:16; |
| } bitfields4; |
| struct { |
| unsigned int register_write_addr:16; |
| unsigned int reserved5:16; |
| } bitfields5; |
| unsigned int ordinal3; |
| }; |
| |
| union { |
| struct { |
| unsigned int poll_address_hi:16; |
| unsigned int reserved6:16; |
| } bitfields6; |
| struct { |
| unsigned int register_write_addr:16; |
| unsigned int reserved7:16; |
| } bitfields7; |
| unsigned int ordinal4; |
| }; |
| |
| unsigned int reference; |
| |
| unsigned int mask; |
| |
| union { |
| struct { |
| unsigned int poll_interval:16; |
| unsigned int reserved8:16; |
| } bitfields8; |
| unsigned int ordinal7; |
| }; |
| |
| }; |
| #endif |
| |
| |
| #endif /* KFD_PM4_HEADERS_DIQ_H_ */ |