diff options
author | Thomas Gleixner <tglx@linutronix.de> | 2022-09-15 13:10:40 +0200 |
---|---|---|
committer | Borislav Petkov <bp@suse.de> | 2022-09-21 12:30:16 +0200 |
commit | f92ff8f5dca2acfa475842c71212657b0703c3be (patch) | |
tree | eef0269eafb93b7cebb66724d3e4dea26eda930d /lib/test_bits.c | |
parent | 521a547ced6477c54b4b0cc206000406c221b4d6 (diff) |
x86/paravirt: Ensure proper alignment
The entries in the .parainstructions sections are 8 byte aligned and the
corresponding C struct paravirt_patch_site makes the array offset 16
bytes.
Though the pushed entries are only using 12 bytes, __parainstructions_end
is therefore 4 bytes short.
That works by chance because it's only used in a loop:
for (p = start; p < end; p++)
But this falls flat when calculating the number of elements:
n = end - start
That's obviously off by one.
Ensure that the gap is filled and the last entry is occupying 16 bytes.
[ bp: Add the proper struct and section names. ]
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Signed-off-by: Borislav Petkov <bp@suse.de>
Reviewed-by: Juergen Gross <jgross@suse.com>
Link: https://lore.kernel.org/r/20220915111142.992398801@infradead.org
Diffstat (limited to 'lib/test_bits.c')
0 files changed, 0 insertions, 0 deletions