aboutsummaryrefslogtreecommitdiff
path: root/drivers/gpu/drm/amd/amdgpu/amdgpu_vram_mgr.c
diff options
context:
space:
mode:
authorPavel Tatashin <[email protected]>2017-02-16 15:13:54 -0500
committerDavid S. Miller <[email protected]>2017-02-23 08:33:23 -0800
commitcd429ce2d095041d249ec85feaed608bbf72154f (patch)
tree32f0637f630d31722523530ae4c52a470b95c765 /drivers/gpu/drm/amd/amdgpu/amdgpu_vram_mgr.c
parent1537b26dab1c1dfd92a116a933143f52b1112a22 (diff)
sparc64: memblock resizes are not handled properly
In add_node_ranges() when memblock resize happens, the iterator keeps using the previous freed array. This bug cause hangs on machine where there are over 128 memory blocks during boot. For example, on machines where memory interleaving is small. The problem is seen on T4-4 because it cant have 2T of memory, and memory is interleaved at 8G. So we have 2T/8G = 256 regions to set node IDs. The starting size of regions array is 128. Thus, we have to double at least one time (actually we have to double twice because some memory is already reserved and thus we need more than 256 regions). We start using an incorrect pointer to the array after the first doubling. Signed-off-by: Pavel Tatashin <[email protected]> Signed-off-by: Babu Moger <[email protected]> Reviewed-by: Babu Moger <[email protected]> Signed-off-by: David S. Miller <[email protected]>
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_vram_mgr.c')
0 files changed, 0 insertions, 0 deletions