On 05/08/2018 05:16 AM, Alexander Potapenko wrote: > Similarly to commit 187e91fe5e91 > ("x86/boot/64/clang: Use fixup_pointer() to access 'next_early_pgt'"), > '__supported_pte_mask' must be also accessed using fixup_pointer() to > avoid position-dependent relocations. > > Signed-off-by: Alexander Potapenko <glider@xxxxxxxxxx> > Fixes: fb43d6cb91ef ("x86/mm: Do not auto-massage page protections") In the interests of standalone changelogs, I'd really appreciate an actual explanation of what's going on here. Your patch makes the code uglier and doesn't fix anything functional from what I can see. The other commit has some explanation, so it seems like the rules for accessing globals in head64.c are different than other files because... something. The functional problem here is that it causes insta-reboots? Do we have anything we can do to keep us from recreating these kinds of regressions all the time?