]> Git Repo - linux.git/blob - drivers/gpu/drm/amd/include/amdgpu_reg_state.h
Merge tag 'soundwire-6.14-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/vkoul...
[linux.git] / drivers / gpu / drm / amd / include / amdgpu_reg_state.h
1 /* SPDX-License-Identifier: MIT */
2 /*
3  * Copyright 2023 Advanced Micro Devices, Inc.
4  *
5  * Permission is hereby granted, free of charge, to any person obtaining a
6  * copy of this software and associated documentation files (the "Software"),
7  * to deal in the Software without restriction, including without limitation
8  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9  * and/or sell copies of the Software, and to permit persons to whom the
10  * Software is furnished to do so, subject to the following conditions:
11  *
12  * The above copyright notice and this permission notice shall be included in
13  * all copies or substantial portions of the Software.
14  *
15  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18  * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
19  * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
20  * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
21  * OTHER DEALINGS IN THE SOFTWARE.
22  *
23  */
24
25 #ifndef __AMDGPU_REG_STATE_H__
26 #define __AMDGPU_REG_STATE_H__
27
28 enum amdgpu_reg_state {
29         AMDGPU_REG_STATE_TYPE_INVALID   = 0,
30         AMDGPU_REG_STATE_TYPE_XGMI      = 1,
31         AMDGPU_REG_STATE_TYPE_WAFL      = 2,
32         AMDGPU_REG_STATE_TYPE_PCIE      = 3,
33         AMDGPU_REG_STATE_TYPE_USR       = 4,
34         AMDGPU_REG_STATE_TYPE_USR_1     = 5
35 };
36
37 enum amdgpu_sysfs_reg_offset {
38         AMDGPU_SYS_REG_STATE_XGMI       = 0x0000,
39         AMDGPU_SYS_REG_STATE_WAFL       = 0x1000,
40         AMDGPU_SYS_REG_STATE_PCIE       = 0x2000,
41         AMDGPU_SYS_REG_STATE_USR        = 0x3000,
42         AMDGPU_SYS_REG_STATE_USR_1      = 0x4000,
43         AMDGPU_SYS_REG_STATE_END        = 0x5000,
44 };
45
46 struct amdgpu_reg_state_header {
47         uint16_t                structure_size;
48         uint8_t                 format_revision;
49         uint8_t                 content_revision;
50         uint8_t                 state_type;
51         uint8_t                 num_instances;
52         uint16_t                pad;
53 };
54
55 enum amdgpu_reg_inst_state {
56         AMDGPU_INST_S_OK,
57         AMDGPU_INST_S_EDISABLED,
58         AMDGPU_INST_S_EACCESS,
59 };
60
61 struct amdgpu_smn_reg_data {
62         uint64_t addr;
63         uint32_t value;
64         uint32_t pad;
65 };
66
67 struct amdgpu_reg_inst_header {
68         uint16_t        instance;
69         uint16_t        state;
70         uint16_t        num_smn_regs;
71         uint16_t        pad;
72 };
73
74
75 struct amdgpu_regs_xgmi_v1_0 {
76         struct amdgpu_reg_inst_header   inst_header;
77
78         struct amdgpu_smn_reg_data      smn_reg_values[];
79 };
80
81 struct amdgpu_reg_state_xgmi_v1_0 {
82         /* common_header.state_type must be AMDGPU_REG_STATE_TYPE_XGMI */
83         struct amdgpu_reg_state_header  common_header;
84
85         struct amdgpu_regs_xgmi_v1_0    xgmi_state_regs[];
86 };
87
88 struct amdgpu_regs_wafl_v1_0 {
89         struct amdgpu_reg_inst_header   inst_header;
90
91         struct amdgpu_smn_reg_data      smn_reg_values[];
92 };
93
94 struct amdgpu_reg_state_wafl_v1_0 {
95         /* common_header.state_type must be AMDGPU_REG_STATE_TYPE_WAFL */
96         struct amdgpu_reg_state_header  common_header;
97
98         struct amdgpu_regs_wafl_v1_0    wafl_state_regs[];
99 };
100
101 struct amdgpu_regs_pcie_v1_0 {
102         struct amdgpu_reg_inst_header   inst_header;
103
104         uint16_t                        device_status;
105         uint16_t                        link_status;
106         uint32_t                        sub_bus_number_latency;
107         uint32_t                        pcie_corr_err_status;
108         uint32_t                        pcie_uncorr_err_status;
109
110         struct amdgpu_smn_reg_data      smn_reg_values[];
111 };
112
113 struct amdgpu_reg_state_pcie_v1_0 {
114         /* common_header.state_type must be AMDGPU_REG_STATE_TYPE_PCIE */
115         struct amdgpu_reg_state_header  common_header;
116
117         struct amdgpu_regs_pcie_v1_0    pci_state_regs[];
118 };
119
120 struct amdgpu_regs_usr_v1_0 {
121         struct amdgpu_reg_inst_header   inst_header;
122
123         struct amdgpu_smn_reg_data      smn_reg_values[];
124 };
125
126 struct amdgpu_reg_state_usr_v1_0 {
127         /* common_header.state_type must be AMDGPU_REG_STATE_TYPE_USR */
128         struct amdgpu_reg_state_header  common_header;
129
130         struct amdgpu_regs_usr_v1_0     usr_state_regs[];
131 };
132
133 static inline size_t amdgpu_reginst_size(uint16_t num_inst, size_t inst_size,
134                                          uint16_t num_regs)
135 {
136         return num_inst *
137                (inst_size + num_regs * sizeof(struct amdgpu_smn_reg_data));
138 }
139
140 #define amdgpu_asic_get_reg_state_supported(adev) \
141         (((adev)->asic_funcs && (adev)->asic_funcs->get_reg_state) ? 1 : 0)
142
143 #define amdgpu_asic_get_reg_state(adev, state, buf, size)                  \
144         ((adev)->asic_funcs->get_reg_state ?                               \
145                  (adev)->asic_funcs->get_reg_state((adev), (state), (buf), \
146                                                    (size)) :               \
147                  0)
148
149
150 int amdgpu_reg_state_sysfs_init(struct amdgpu_device *adev);
151 void amdgpu_reg_state_sysfs_fini(struct amdgpu_device *adev);
152
153 #endif
This page took 0.035732 seconds and 4 git commands to generate.