mirror of
https://github.com/torvalds/linux.git
synced 2026-05-31 10:33:41 +02:00
drm/amdgpu: Fix SHMEM alignment mode for GFX 12.1.0
Alignment mode in SHMEM config register is only a single bit value on GFX 12.1.0 instead of 2 bits in previous asics. Add a new enum and use the correct value of SHMEM alignment mode when programming the SHMEM config register. Signed-off-by: Mukul Joshi <mukul.joshi@amd.com> Reviewed-by: Hawking Zhang <Hawking.Zhang@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
3849efdc78
commit
e3b8d8cc8c
|
|
@ -52,9 +52,10 @@
|
|||
MODULE_FIRMWARE("amdgpu/gc_12_1_0_mec.bin");
|
||||
MODULE_FIRMWARE("amdgpu/gc_12_1_0_rlc.bin");
|
||||
|
||||
#define SH_MEM_ALIGNMENT_MODE_UNALIGNED_GFX12_1_0 0x00000001
|
||||
#define DEFAULT_SH_MEM_CONFIG \
|
||||
((SH_MEM_ADDRESS_MODE_64 << SH_MEM_CONFIG__ADDRESS_MODE__SHIFT) | \
|
||||
(SH_MEM_ALIGNMENT_MODE_UNALIGNED << SH_MEM_CONFIG__ALIGNMENT_MODE__SHIFT) | \
|
||||
(SH_MEM_ALIGNMENT_MODE_UNALIGNED_GFX12_1_0 << SH_MEM_CONFIG__ALIGNMENT_MODE__SHIFT) | \
|
||||
(3 << SH_MEM_CONFIG__INITIAL_INST_PREFETCH__SHIFT))
|
||||
|
||||
static void gfx_v12_1_xcc_disable_gpa_mode(struct amdgpu_device *adev, int xcc_id);
|
||||
|
|
|
|||
|
|
@ -24,7 +24,7 @@
|
|||
|
||||
#include "kfd_device_queue_manager.h"
|
||||
#include "gc/gc_12_1_0_sh_mask.h"
|
||||
#include "soc24_enum.h"
|
||||
#include "soc_v1_0_enum.h"
|
||||
|
||||
static int update_qpd_v12_1(struct device_queue_manager *dqm,
|
||||
struct qcm_process_device *qpd);
|
||||
|
|
|
|||
|
|
@ -30,4 +30,9 @@ typedef enum MTYPE {
|
|||
MTYPE_UC = 0x00000003,
|
||||
} MTYPE;
|
||||
|
||||
typedef enum SH_MEM_ALIGNMENT_MODE {
|
||||
SH_MEM_ALIGNMENT_MODE_DWORD = 0x00000000,
|
||||
SH_MEM_ALIGNMENT_MODE_UNALIGNED = 0x00000001,
|
||||
} SH_MEM_ALIGNMENT_MODE;
|
||||
|
||||
#endif
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user