Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

drm/amdgpu: Implement the pciconfig callbacks for CGS

This implements the pciconfig register accessors.

Reviewed-by: Jammy Zhou <Jammy.Zhou@amd.com>
Signed-off-by: Chunming Zhou <David1.Zhou@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>

authored by

Chunming Zhou and committed by
Alex Deucher
97cb7f6e aba684d8

+28 -12
+28 -12
drivers/gpu/drm/amd/amdgpu/amdgpu_cgs.c
··· 21 21 * 22 22 * 23 23 */ 24 + #include <linux/pci.h> 24 25 #include "amdgpu.h" 25 26 #include "cgs_linux.h" 26 27 ··· 164 163 165 164 static uint8_t amdgpu_cgs_read_pci_config_byte(void *cgs_device, unsigned addr) 166 165 { 167 - /* TODO */ 168 - return 0; 166 + CGS_FUNC_ADEV; 167 + uint8_t val; 168 + int ret = pci_read_config_byte(adev->pdev, addr, &val); 169 + if (WARN(ret, "pci_read_config_byte error")) 170 + return 0; 171 + return val; 169 172 } 170 173 171 174 static uint16_t amdgpu_cgs_read_pci_config_word(void *cgs_device, unsigned addr) 172 175 { 173 - /* TODO */ 174 - return 0; 176 + CGS_FUNC_ADEV; 177 + uint16_t val; 178 + int ret = pci_read_config_word(adev->pdev, addr, &val); 179 + if (WARN(ret, "pci_read_config_word error")) 180 + return 0; 181 + return val; 175 182 } 176 183 177 184 static uint32_t amdgpu_cgs_read_pci_config_dword(void *cgs_device, 178 185 unsigned addr) 179 186 { 180 - /* TODO */ 181 - return 0; 187 + CGS_FUNC_ADEV; 188 + uint32_t val; 189 + int ret = pci_read_config_dword(adev->pdev, addr, &val); 190 + if (WARN(ret, "pci_read_config_dword error")) 191 + return 0; 192 + return val; 182 193 } 183 194 184 195 static void amdgpu_cgs_write_pci_config_byte(void *cgs_device, unsigned addr, 185 196 uint8_t value) 186 197 { 187 - /* TODO */ 188 - return; 198 + CGS_FUNC_ADEV; 199 + int ret = pci_write_config_byte(adev->pdev, addr, value); 200 + WARN(ret, "pci_write_config_byte error"); 189 201 } 190 202 191 203 static void amdgpu_cgs_write_pci_config_word(void *cgs_device, unsigned addr, 192 204 uint16_t value) 193 205 { 194 - /* TODO */ 195 - return; 206 + CGS_FUNC_ADEV; 207 + int ret = pci_write_config_word(adev->pdev, addr, value); 208 + WARN(ret, "pci_write_config_word error"); 196 209 } 197 210 198 211 static void amdgpu_cgs_write_pci_config_dword(void *cgs_device, unsigned addr, 199 212 uint32_t value) 200 213 { 201 - /* TODO */ 202 - return; 214 + CGS_FUNC_ADEV; 215 + int ret = pci_write_config_dword(adev->pdev, addr, value); 216 + WARN(ret, "pci_write_config_dword error"); 203 217 } 204 218 205 219 static const void *amdgpu_cgs_atom_get_data_table(void *cgs_device,