mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-16 13:34:30 +00:00
s390/sthyi: enforce 4k alignment of vmalloc'ed area
vmalloc() does not guarantee any alignment, unless it is explicitly requested with e.g. __vmalloc_node(). Using diag204() with subcode 7 requires a 4k aligned virtual buffer. Therefore switch to __vmalloc_node(). Note: with the current vmalloc() implementation callers would still get a 4k aligned area, even though this is quite non-obvious looking at the code. So changing this in sthyi doesn't fix a real bug. It is just to make sure the code will not suffer from some obscure options, like it happened in the past with kmalloc() where debug options changed the assumed alignment of allocated memory areas. Acked-by: Alexander Gordeev <agordeev@linux.ibm.com> Signed-off-by: Heiko Carstens <hca@linux.ibm.com>
This commit is contained in:
parent
c83cd4fe31
commit
86e74965bb
@ -317,7 +317,9 @@ static void fill_diag(struct sthyi_sctns *sctns)
|
||||
if (pages <= 0)
|
||||
return;
|
||||
|
||||
diag204_buf = vmalloc(array_size(pages, PAGE_SIZE));
|
||||
diag204_buf = __vmalloc_node(array_size(pages, PAGE_SIZE),
|
||||
PAGE_SIZE, GFP_KERNEL, NUMA_NO_NODE,
|
||||
__builtin_return_address(0));
|
||||
if (!diag204_buf)
|
||||
return;
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user