Bug 217175
Summary: | arch/x86/kernel/smp.o: warning: objtool: sysvec_reboot()+0x4e: unreachable instruction | ||
---|---|---|---|
Product: | Other | Reporter: | Ray (ray) |
Component: | Other | Assignee: | other_other |
Status: | NEW --- | ||
Severity: | normal | CC: | regressions |
Priority: | P1 | ||
Hardware: | All | ||
OS: | Linux | ||
Kernel Version: | Subsystem: | ||
Regression: | No | Bisected commit-id: |
Description
Ray
2023-03-11 08:13:52 UTC
Could you please bisect? https://docs.kernel.org/admin-guide/bug-bisect.html (In reply to Artem S. Tashkinov from comment #1) > Could you please bisect? No need to, this afaics was reported and bisected here already: https://lore.kernel.org/all/4ce8fe57-53eb-4a83-a468-ebfc98fed496@linaro.org/ root@14.2 kernel $ cp -dlR linux-5.15.98.16r2 linux-5.15.99.16r2 root@14.2 linux-5.15.98.16r2 $ make -s clean && make -s -j 32 all root@14.2 linux-5.15.98.16r2 $ ## Clean no warnings, current working kernel root@14.2 linux-5.15.99.16r2 $ wget https://cdn.kernel.org/pub/linux/kernel/v5.x/incr/patch-5.15.98-99.xz root@14.2 linux-5.15.99.16r2 $ xz -d patch-5.15.98-99.xz root@14.2 linux-5.15.99.16r2 $ patch -p1 -s < patch-5.15.98-99 root@14.2 linux-5.15.99.16r2 $ make menuconfig ( Do nothing except save .config and exit ) root@14.2 linux-5.15.99.16r2 $ make -s clean && make -s -j 32 all arch/x86/kernel/smp.o: warning: objtool: sysvec_reboot()+0x4e: unreachable instruction root@14.2 linux-5.15.99.16r2 $ cp .config ../.config.5.15.99 root@14.2 linux-5.15.99.16r2 $ make distclean root@14.2 linux-5.15.99.16r2 $ grep -Rls sysvec_reboot * arch/x86/include/asm/idtentry.h arch/x86/kernel/smp.c arch/x86/kernel/idt.c patch-5.15.98-99 ## so sysvec_reboot referenced smp.c idt.c and the patch file idtentry.h refs are declarations, don't think prob could be there. idtentry.h 5.15.98 #ifdef CONFIG_SMP DECLARE_IDTENTRY(RESCHEDULE_VECTOR, sysvec_reschedule_ipi); DECLARE_IDTENTRY_SYSVEC(IRQ_MOVE_CLEANUP_VECTOR, sysvec_irq_move_cleanup); DECLARE_IDTENTRY_SYSVEC(REBOOT_VECTOR, sysvec_reboot); DECLARE_IDTENTRY_SYSVEC(CALL_FUNCTION_SINGLE_VECTOR, sysvec_call_function_single); DECLARE_IDTENTRY_SYSVEC(CALL_FUNCTION_VECTOR, sysvec_call_function); #endif 5.15.99 #ifdef CONFIG_SMP DECLARE_IDTENTRY(RESCHEDULE_VECTOR, sysvec_reschedule_ipi); DECLARE_IDTENTRY_SYSVEC(IRQ_MOVE_CLEANUP_VECTOR, sysvec_irq_move_cleanup); DECLARE_IDTENTRY_SYSVEC(REBOOT_VECTOR, sysvec_reboot); DECLARE_IDTENTRY_SYSVEC(CALL_FUNCTION_SINGLE_VECTOR, sysvec_call_function_single); DECLARE_IDTENTRY_SYSVEC(CALL_FUNCTION_VECTOR, sysvec_call_function); #endif ------------------------------------------ * The APIC and SMP idt entries - idt.c \\\\ 5.15.98 = 99 identical, no change static const __initconst struct idt_data apic_idts[] = { #ifdef CONFIG_SMP INTG(RESCHEDULE_VECTOR, asm_sysvec_reschedule_ipi), INTG(CALL_FUNCTION_VECTOR, asm_sysvec_call_function), INTG(CALL_FUNCTION_SINGLE_VECTOR, asm_sysvec_call_function_single), INTG(IRQ_MOVE_CLEANUP_VECTOR, asm_sysvec_irq_move_cleanup), INTG(REBOOT_VECTOR, asm_sysvec_reboot), #endif -------------------------------------------- smp.c - - - 5.15.98 * this function calls the 'stop' function on all other CPUs in the system. */ DEFINE_IDTENTRY_SYSVEC(sysvec_reboot) { ack_APIC_irq(); cpu_emergency_vmxoff(); stop_this_cpu(NULL); } - - - - - 5.15.99 * this function calls the 'stop' function on all other CPUs in the system. */ DEFINE_IDTENTRY_SYSVEC(sysvec_reboot) { ack_APIC_irq(); cpu_emergency_disable_virtualization(); stop_this_cpu(NULL); } ------------------------------------------------------ root@14.2 linux-5.15.99.16r2 $ grep -Rls cpu_emergency_disable_virtualization * arch/x86/include/asm/reboot.h arch/x86/kernel/smp.c arch/x86/kernel/reboot.c arch/x86/kernel/crash.c patch-5.15.98-99 root@14.2 linux-5.15.99.16r2 $ refs to that new function are not in things that would be missing from any classical kernel cfg . ( i think ) . Only coding ive ever done is Z80 assy back in 1978-1982 and dont know what binutils is complaining about, unreachable address ? missing symbol during link ? root@14.2 linux-5.15.99.16r2 $ make -s clean && make -s -j 32 all Makefile:669: include/config/auto.conf: No such file or directory Makefile:724: include/config/auto.conf.cmd: No such file or directory arch/x86/kernel/smp.o: warning: objtool: sysvec_reboot()+0x4e: unreachable instruction looks like the make distclean dorked the kernel tree . . i replaced the .config and ran make menuconfig before hand . . looks like ill need to remove those binary arifacts distclean leaves behind again so rm tools/objtool/fixdep rm tools/objtool/objtool rm scripts/basic/fixdep root@14.2 linux-5.15.99.16r2 $ make distclean root@14.2 linux-5.15.99.16r2 $ cp ../config.5.15.99 .config root@14.2 linux-5.15.99.16r2 $ make menuconfig root@14.2 linux-5.15.99.16r2 $ make -s -j 32 all Makefile:669: include/config/auto.conf: No such file or directory Makefile:724: include/config/auto.conf.cmd: No such file or directory I didnt touch those . . make distclean did that . . This kernel tree had old things that worked, ( sorta, distclean should not leave behind fixdep 2 places or that objtool binary, they break the tree when shared with multiple distributions, mrproper / distclean should make that possible yes? ) things broken that should not be broken on a LTS kernel . . I wish i knew enough that i could be more helpful in fixing it. Have been compiling my own kernels and running only my own compiled kernels since 1995, Am at least familiar with doing that. Willing to try many things in the hope that i will learn something during my feeble attempt to be helpful. root@14.2 kernel $ rm -r linux-5.15.99.16r2 root@14.2 kernel $ cp -dlR linux-5.15.98.16r2 linux-5.15.99.16r2 root@14.2 kernel $ cd linux-5.15.99.16r2 root@14.2 linux-5.15.99.16r2 $ patch -s -p1 < ../patch-5.15.98-99 root@14.2 linux-5.15.99.16r2 $ cp ../config.5.15.99 .config root@14.2 linux-5.15.99.16r2 $ make menuconfig root@14.2 linux-5.15.99.16r2 $ make -s -j 32 all arch/x86/kernel/smp.o: warning: objtool: sysvec_reboot()+0x4e: unreachable instruction In the early days screens full of warnings was a normal thing . Hope we arn't going back to that ;=) unreachable instructions can be interpreted as serious as a null pointer, hope that don't happen during a diskcache flush. Perhaps that error is restricted to KVM virtual machines, looks like it might. Im not competent enough, nor have ny proper brain-map of kernel internals. Old 340-108 Nvidia driver went nuts against the new ABI in newer Xorg and ruined one of my KGPE-D16 numa server boards. Wish there was a target for my ire on that one. Cheers ! Raymond (In reply to The Linux kernel's regression tracker (Thorsten Leemhuis) from comment #2) > (In reply to Artem S. Tashkinov from comment #1) > > Could you please bisect? > > No need to, this afaics was reported and bisected here already: > https://lore.kernel.org/all/4ce8fe57-53eb-4a83-a468-ebfc98fed496@linaro.org/ fix not in 100 or 101 patch, but looks like it may come soon. Thx Now if we can just find a fix for nvidia 340-108 hard locking and burning 16x slots in our fancy numa server boards Yeah i know,, don't make it hurt any less . ;=) Cheers! Raymond root@14.2 linux-5.15.101.16r2 $ patch -p1 -s < ../patch-5.15.99-100 root@14.2 linux-5.15.101.16r2 $ patch -p1 -s < ../patch-5.15.100-101 root@14.2 linux-5.15.101.16r2 $ make menuconfig root@14.2 linux-5.15.101.16r2 $ make -s -j 32 all arch/x86/kernel/smp.o: warning: objtool: sysvec_reboot()+0x4e: unreachable instruction Nope . . not yet . . In https://lore.kernel.org/all/20220412062945.857488242@linuxfoundation.org/ " Both cases are due to a call_on_stack() calling a __noreturn function. Since that's an inline asm, GCC can't do anything about the instructions after the CALL. Therefore put in an explicit ASM_REACHABLE annotation to make sure objtool and gcc are consistently confused about control flow. " diff --git a/arch/x86/include/asm/irq_stack.h b/arch/x86/include/asm/irq_stack.h index 8d55bd11848c..e087cd7837c3 100644 --- a/arch/x86/include/asm/irq_stack.h +++ b/arch/x86/include/asm/irq_stack.h @@ -99,7 +99,8 @@ } #define ASM_CALL_ARG0 \ - "call %P[__func] \n" + "call %P[__func] \n" \ + ASM_REACHABLE #define ASM_CALL_ARG1 \ "movq %[arg1], %%rdi \n" \ -- 2.35.1 Not suggesting anyone apply this patch, might be incomplete But useful explanation as to why. Already the state of irq_stack.h md Sep 21 #define ASM_CALL_ARG0 \ "call %P[__func] \n" \ ASM_REACHABLE arch/x86/kernel/reboot.c void cpu_emergency_disable_virtualization(void) { cpu_emergency_vmxoff(); cpu_emergency_svm_disable(); } root@14.2 linux-5.15.101.16r2 $ grep -Rls cpu_emergency_vmxoff * arch/x86/include/asm/virtext.h arch/x86/kernel/reboot.c root@14.2 linux-5.15.101.16r2 $ grep -Rls cpu_emergency_svm_disable * arch/x86/include/asm/virtext.h arch/x86/kernel/reboot.c root@14.2 linux-5.15.101.16r2 $ Turning off KVM et al. in cfg doesn't make it go away I notice this kind of glitch has a special case hack in tools/objtool/check.c Perhaps list has to grow another loc. * Unfortunately these have to be hard coded because the noreturn * attribute isn't provided in ELF data. */ static const char * const global_noreturns[] = { "__stack_chk_fail", "panic", "do_exit", "do_task_dead", "make_task_dead", "__module_put_and_exit", "complete_and_exit", "__reiserfs_panic", "lbug_with_loc", "fortify_panic", "usercopy_abort", "machine_real_restart", "rewind_stack_and_make_dead", "kunit_try_catch_throw", "xen_start_kernel", "cpu_bringup_and_idle", "stop_this_cpu", }; So here am I showing off my incompetence to the planet, I must have no shame at all. .. Ohh wait . . rm scripts/basic/fixdep rm tools/objtool/objtool rm scripts/basic/fixdep How would objtool get the update if it never gets remade ? that causes problems in other contexts Should get remade, if check.c got an update eh ? stop_this_cpu, was added to tools/objtool/check.c static const char * const global_noreturns with the 5.15.99 patch root@14.2 linux-5.15.101.16r2 $ make distclean root@14.2 linux-5.15.101.16r2 $ cp ../config.5.15.99 .config root@14.2 linux-5.15.101.16r2 $ make menuconfig root@14.2 linux-5.15.101.16r2 $ time make -s -j 32 all Makefile:669: include/config/auto.conf: No such file or directory Makefile:724: include/config/auto.conf.cmd: No such file or directory make distclean dorked the kernel tree again didn't it . you fellas should fix that, shouldn't leave those 3 files above behind either, they often cause problems out here in the dirt where things are not so tidy. root@14.2 kernel $ rm -r linux-5.15.101.16r2 root@14.2 kernel $ cp -dlR linux-5.15.99.16r2 linux-5.15.101.16r2 root@14.2 kernel $ cd linux-5.15.101.16r2 root@14.2 linux-5.15.101.16r2 $ rm tools/objtool/fixdep root@14.2 linux-5.15.101.16r2 $ rm tools/objtool/objtool root@14.2 linux-5.15.101.16r2 $ rm scripts/basic/fixdep root@14.2 linux-5.15.101.16r2 $ patch -p1 -s < patch-5.15.99-100 root@14.2 linux-5.15.101.16r2 $ patch -p1 -s < patch-5.15.100-101 root@14.2 linux-5.15.101.16r2 $ cp ../config.5.15.99 .config root@14.2 linux-5.15.101.16r2 $ make menuconfig ( remind me to do a diff on the before/after .config files, new stuff showed up perhaps ?, wouldn't it be nice to know what these were without running a diff on them ? ( or searching thru 10,000 items in menuconfig ) because by default it turns those on, and sometimes, not helpful. ) no guts, no glory. root@14.2 linux-5.15.101.16r2 $ time make -s -j 32 all # powersave mode, but 1.4g X 32 cores is still purty quick. Me showing off, while i wait . . . root@14.2 ~ $ ibstatus | grep link link_layer: Ethernet link_layer: InfiniBand link_layer: InfiniBand root@14.2 ~ $ numactl -H | grep cpus node 0 cpus: 0 1 2 3 4 5 6 7 node 1 cpus: 8 9 10 11 12 13 14 15 node 2 cpus: 16 17 18 19 20 21 22 23 node 3 cpus: 24 25 26 27 28 29 30 31 root@14.2 ~ $ numactl -H | grep size node 0 size: 64350 MB node 1 size: 64510 MB node 2 size: 64510 MB node 3 size: 64491 MB root@14.2 ~ $ arch/x86/kernel/smp.o: warning: objtool: sysvec_reboot()+0x4e: unreachable instruction real 6m54.220s user 160m14.187s sys 17m13.788s root@14.2 linux-5.15.101.16r2 $ Well this is so way above my paygrade, but perhaps I was some use, most likely as an object of laughter. Cheers!! Raymond root@14.2 kernel $ diff linux-5.15.96.16r2/.config \ > linux-5.15.101.16r2/.config 3c3 < # Linux/x86 5.15.98 Kernel Configuration --- > # Linux/x86 5.15.101 Kernel Configuration 383c383 < # CONFIG_MICROCODE_OLD_INTERFACE is not set --- > # CONFIG_MICROCODE_LATE_LOADING is not set root@14.2 kernel $ Nuttin dere Just for grins, I have a new -current slack running in chroot ( incompatible with nvidia, will melt server board slots !! ) ( now i understand why so many hate that outfit ) Lets try with more modern tool chain root@14.2 kernel $ cp -dlR linux-5.15.101.16r2 linux-5.15.101.xxx 16r4[root@15.0+:/kernel/linux-5.15.101.xxx]# rm tools/objtool/fixdep 16r4[root@15.0+:/kernel/linux-5.15.101.xxx]# rm tools/objtool/objtool 16r4[root@15.0+:/kernel/linux-5.15.101.xxx]# rm scripts/basic/fixdep This is the exact context where those files cause problems, distclean is also broken so . . 16r4[root@15.0+:/kernel/linux-5.15.101.xxx]# PS1="16r4 \u@$dist: \W \$ " 16r4 root@15.0+: linux-5.15.101.xxx $ make clean ; make menuconfig 16r4 root@15.0+: kernel $ diff linux-5.15.101.16r2/.config \ linux-5.15.101.xxx/.config | less Plenty new stuff but nothing problematic so 16r4 root@15.0+: linux-5.15.101.xxx $ time make -s -j32 all Love these old monster boards tho, run 18 other distros in chroot "containers" these old things carry loads like a freight train . keep them away from nvidia. arch/x86/kernel/smp.o: warning: objtool: sysvec_reboot()+0x4e: unreachable instruction Ohh the hell you say . . . In file included from arch/x86/boot/a20.c:14: In function 'rdfs32', inlined from 'a20_test' at arch/x86/boot/a20.c:62:16: arch/x86/boot/boot.h:126:9: warning: array subscript 0 is outside array bounds of 'u32[0]' {aka 'unsigned int[]'} [-Warray-bounds] 126 | asm volatile("movl %%fs:%1,%0" : "=r" (v) : "m" (*(u32 *)addr)); | ^~~ In function 'wrfs32', inlined from 'a20_test' at arch/x86/boot/a20.c:65:3: arch/x86/boot/boot.h:140:9: warning: array subscript 0 is outside array bounds of 'u32[0]' {aka 'unsigned int[]'} [-Warray-bounds] 140 | asm volatile("movl %1,%%fs:%0" : "+m" (*(u32 *)addr) : "ri" (v)); | ^~~ arch/x86/boot/boot.h:140:9: warning: array subscript 0 is outside array bounds of 'u32[0]' {aka 'unsigned int[]'} [-Warray-bounds] In function 'rdgs32', inlined from 'a20_test' at arch/x86/boot/a20.c:67:8: arch/x86/boot/boot.h:158:9: warning: array subscript 0 is outside array bounds of 'u32[0]' {aka 'unsigned int[]'} [-Warray-bounds] 158 | asm volatile("movl %%gs:%1,%0" : "=r" (v) : "m" (*(u32 *)addr)); | ^~~ In function 'wrfs32', inlined from 'a20_test' at arch/x86/boot/a20.c:72:2: arch/x86/boot/boot.h:140:9: warning: array subscript 0 is outside array bounds of 'u32[0]' {aka 'unsigned int[]'} [-Warray-bounds] 140 | asm volatile("movl %1,%%fs:%0" : "+m" (*(u32 *)addr) : "ri" (v)); | ^~~ arch/x86/boot/boot.h:140:9: warning: array subscript 0 is outside array bounds of 'u32[0]' {aka 'unsigned int[]'} [-Warray-bounds] In function 'copy_boot_params', inlined from 'main' at arch/x86/boot/main.c:137:2: arch/x86/boot/main.c:42:19: warning: array subscript 0 is outside array bounds of 'const struct old_cmdline[0]' [-Warray-bounds] 42 | oldcmd->cl_magic == OLD_CL_MAGIC) { | ~~~~~~^~~~~~~~~~ arch/x86/boot/main.c:49:27: warning: array subscript 0 is outside array bounds of 'const struct old_cmdline[0]' [-Warray-bounds] 49 | if (oldcmd->cl_offset < boot_params.hdr.setup_move_size) | ~~~~~~^~~~~~~~~~~ In file included from arch/x86/boot/video-bios.c:16: In function 'rdfs16', inlined from 'bios_probe' at arch/x86/boot/video-bios.c:108:11: arch/x86/boot/boot.h:120:9: warning: array subscript 0 is outside array bounds of 'u16[0]' {aka 'short unsigned int[]'} [-Warray-bounds] 120 | asm volatile("movw %%fs:%1,%0" : "=r" (v) : "m" (*(u16 *)addr)); | ^~~ In function 'rdfs8', inlined from 'bios_probe' at arch/x86/boot/video-bios.c:109:11: arch/x86/boot/boot.h:114:9: warning: array subscript 0 is outside array bounds of 'u8[0]' {aka 'unsigned char[]'} [-Warray-bounds] 114 | asm volatile("movb %%fs:%1,%0" : "=q" (v) : "m" (*(u8 *)addr)); | ^~~ In file included from arch/x86/boot/video.c:16: In function 'rdfs16', inlined from 'store_mode_params.part.0' at arch/x86/boot/video.c:83:14: arch/x86/boot/boot.h:120:9: warning: array subscript 0 is outside array bounds of 'u16[0]' {aka 'short unsigned int[]'} [-Warray-bounds] 120 | asm volatile("movw %%fs:%1,%0" : "=r" (v) : "m" (*(u16 *)addr)); | ^~~ In function 'rdfs16', inlined from 'store_mode_params.part.0' at arch/x86/boot/video.c:86:6: arch/x86/boot/boot.h:120:9: warning: array subscript 0 is outside array bounds of 'u16[0]' {aka 'short unsigned int[]'} [-Warray-bounds] 120 | asm volatile("movw %%fs:%1,%0" : "=r" (v) : "m" (*(u16 *)addr)); | ^~~ In function 'rdfs8', inlined from 'store_mode_params.part.0' at arch/x86/boot/video.c:87:38: arch/x86/boot/boot.h:114:9: warning: array subscript 0 is outside array bounds of 'u8[0]' {aka 'unsigned char[]'} [-Warray-bounds] 114 | asm volatile("movb %%fs:%1,%0" : "=q" (v) : "m" (*(u8 *)addr)); | ^~~ In file included from arch/x86/boot/video-mode.c:16: In function 'rdfs8', inlined from 'vga_recalc_vertical' at arch/x86/boot/video-mode.c:123:14, inlined from 'set_mode' at arch/x86/boot/video-mode.c:163:3: arch/x86/boot/boot.h:114:9: warning: array subscript 0 is outside array bounds of 'u8[0]' {aka 'unsigned char[]'} [-Warray-bounds] 114 | asm volatile("movb %%fs:%1,%0" : "=q" (v) : "m" (*(u8 *)addr)); | ^~~ In function 'rdfs8', inlined from 'vga_recalc_vertical' at arch/x86/boot/video-mode.c:124:29, inlined from 'set_mode' at arch/x86/boot/video-mode.c:163:3: arch/x86/boot/boot.h:114:9: warning: array subscript 0 is outside array bounds of 'u8[0]' {aka 'unsigned char[]'} [-Warray-bounds] 114 | asm volatile("movb %%fs:%1,%0" : "=q" (v) : "m" (*(u8 *)addr)); | ^~~ real 8m12.117s user 200m22.615s sys 19m4.485s 16r4 root@15.0+: linux-5.15.101.xxx $ 16r4 root@15.0+: linux-5.15.101.xxx $ gcc --version gcc (GCC) 12.2.0 16r4 root@15.0+: linux-6.1.15.16r4 $ ls /var/log/packages/ | grep binut binutils-2.40-x86_64-1 Because we need a "control group" of some kind . . 16r4 root@15.0+: linux-6.1.15.16r4 $ make -s clean ; time make -s -j 32 all real 9m10.703s user 225m27.176s sys 22m2.039s 16r4 root@15.0+: linux-6.1.15.16r4 $ Clean pass Could something more than the pair of fixdep's and objtool be lurking in that tree ? distclean is broken so . . Otherwise, someone drank too much last night, and pissed the bed. Let us try the same thing with a hard link tree of 5.15.96 Another control group . . same pre-prep for the change in libraries and tool chain 16r4 root@15.0+: linux-6.1.15.16r4 $ make clean 16r4 root@15.0+: linux-6.1.15.16r4 $ cd .. 16r4 root@15.0+: kernel $ cp -dlR linux-5.15.96.16r2 linux-5.15.96.xxx 16r4 root@15.0+: linux-5.15.96.xxx $ rm scripts/basic/fixdep 16r4 root@15.0+: linux-5.15.96.xxx $ rm tools/objtool/objtool 16r4 root@15.0+: linux-5.15.96.xxx $ rm tools/objtool/fixdep 16r4 root@15.0+: linux-5.15.96.xxx $ make clean ; make menuconfig 16r4 root@15.0+: linux-5.15.96.xxx $ time make -s -j 32 all Ohh wow . . In function 'copy_boot_params', inlined from 'main' at arch/x86/boot/main.c:137:2: arch/x86/boot/main.c:42:19: warning: array subscript 0 is outside array bounds of 'const struct old_cmdline[0]' [-Warray-bounds] 42 | oldcmd->cl_magic == OLD_CL_MAGIC) { | ~~~~~~^~~~~~~~~~ arch/x86/boot/main.c:49:27: warning: array subscript 0 is outside array bounds of 'const struct old_cmdline[0]' [-Warray-bounds] 49 | if (oldcmd->cl_offset < boot_params.hdr.setup_move_size) | ~~~~~~^~~~~~~~~~~ In file included from arch/x86/boot/a20.c:14: In function 'rdfs32', inlined from 'a20_test' at arch/x86/boot/a20.c:62:16: arch/x86/boot/boot.h:126:9: warning: array subscript 0 is outside array bounds of 'u32[0]' {aka 'unsigned int[]'} [-Warray-bounds] 126 | asm volatile("movl %%fs:%1,%0" : "=r" (v) : "m" (*(u32 *)addr)); | ^~~ In function 'wrfs32', inlined from 'a20_test' at arch/x86/boot/a20.c:65:3: arch/x86/boot/boot.h:140:9: warning: array subscript 0 is outside array bounds of 'u32[0]' {aka 'unsigned int[]'} [-Warray-bounds] 140 | asm volatile("movl %1,%%fs:%0" : "+m" (*(u32 *)addr) : "ri" (v)); | ^~~ arch/x86/boot/boot.h:140:9: warning: array subscript 0 is outside array bounds of 'u32[0]' {aka 'unsigned int[]'} [-Warray-bounds] In function 'rdgs32', inlined from 'a20_test' at arch/x86/boot/a20.c:67:8: arch/x86/boot/boot.h:158:9: warning: array subscript 0 is outside array bounds of 'u32[0]' {aka 'unsigned int[]'} [-Warray-bounds] 158 | asm volatile("movl %%gs:%1,%0" : "=r" (v) : "m" (*(u32 *)addr)); | ^~~ In function 'wrfs32', inlined from 'a20_test' at arch/x86/boot/a20.c:72:2: arch/x86/boot/boot.h:140:9: warning: array subscript 0 is outside array bounds of 'u32[0]' {aka 'unsigned int[]'} [-Warray-bounds] 140 | asm volatile("movl %1,%%fs:%0" : "+m" (*(u32 *)addr) : "ri" (v)); | ^~~ arch/x86/boot/boot.h:140:9: warning: array subscript 0 is outside array bounds of 'u32[0]' {aka 'unsigned int[]'} [-Warray-bounds] In file included from arch/x86/boot/video-bios.c:16: In function 'rdfs16', inlined from 'bios_probe' at arch/x86/boot/video-bios.c:108:11: arch/x86/boot/boot.h:120:9: warning: array subscript 0 is outside array bounds of 'u16[0]' {aka 'short unsigned int[]'} [-Warray-bounds] 120 | asm volatile("movw %%fs:%1,%0" : "=r" (v) : "m" (*(u16 *)addr)); | ^~~ In function 'rdfs8', inlined from 'bios_probe' at arch/x86/boot/video-bios.c:109:11: arch/x86/boot/boot.h:114:9: warning: array subscript 0 is outside array bounds of 'u8[0]' {aka 'unsigned char[]'} [-Warray-bounds] 114 | asm volatile("movb %%fs:%1,%0" : "=q" (v) : "m" (*(u8 *)addr)); | ^~~ In file included from arch/x86/boot/video.c:16: In function 'rdfs16', inlined from 'store_mode_params.part.0' at arch/x86/boot/video.c:83:14: arch/x86/boot/boot.h:120:9: warning: array subscript 0 is outside array bounds of 'u16[0]' {aka 'short unsigned int[]'} [-Warray-bounds] 120 | asm volatile("movw %%fs:%1,%0" : "=r" (v) : "m" (*(u16 *)addr)); | ^~~ In function 'rdfs16', inlined from 'store_mode_params.part.0' at arch/x86/boot/video.c:86:6: arch/x86/boot/boot.h:120:9: warning: array subscript 0 is outside array bounds of 'u16[0]' {aka 'short unsigned int[]'} [-Warray-bounds] 120 | asm volatile("movw %%fs:%1,%0" : "=r" (v) : "m" (*(u16 *)addr)); | ^~~ In function 'rdfs8', inlined from 'store_mode_params.part.0' at arch/x86/boot/video.c:87:38: arch/x86/boot/boot.h:114:9: warning: array subscript 0 is outside array bounds of 'u8[0]' {aka 'unsigned char[]'} [-Warray-bounds] 114 | asm volatile("movb %%fs:%1,%0" : "=q" (v) : "m" (*(u8 *)addr)); | ^~~ In file included from arch/x86/boot/video-mode.c:16: In function 'rdfs8', inlined from 'vga_recalc_vertical' at arch/x86/boot/video-mode.c:123:14, inlined from 'set_mode' at arch/x86/boot/video-mode.c:163:3: arch/x86/boot/boot.h:114:9: warning: array subscript 0 is outside array bounds of 'u8[0]' {aka 'unsigned char[]'} [-Warray-bounds] 114 | asm volatile("movb %%fs:%1,%0" : "=q" (v) : "m" (*(u8 *)addr)); | ^~~ In function 'rdfs8', inlined from 'vga_recalc_vertical' at arch/x86/boot/video-mode.c:124:29, inlined from 'set_mode' at arch/x86/boot/video-mode.c:163:3: arch/x86/boot/boot.h:114:9: warning: array subscript 0 is outside array bounds of 'u8[0]' {aka 'unsigned char[]'} [-Warray-bounds] 114 | asm volatile("movb %%fs:%1,%0" : "=q" (v) : "m" (*(u8 *)addr)); | ^~~ real 8m20.581s user 200m23.398s sys 19m15.431s 16r4 root@15.0+: linux-5.15.96.xxx $ Slack 15.0 16r3[root@:/kernel/linux-5.15.96.xxx]# gcc --version gcc (GCC) 11.2.0 16r3[root@:/kernel/linux-5.15.96.xxx]# ls /var/log/packages/ | grep binut binutils-2.37-x86_64-1 16r3[root@:/kernel/linux-5.15.96.xxx]# make clean 16r3[root@:/kernel/linux-5.15.96.xxx]# rm tools/objtool/fixdep 16r3[root@:/kernel/linux-5.15.96.xxx]# rm tools/objtool/objtool 16r3[root@:/kernel/linux-5.15.96.xxx]# rm scripts/basic/fixdep 16r3[root@:/kernel/linux-5.15.96.xxx]# make menuconfig 16r3[root@:/kernel/linux-5.15.96.xxx]# time make -s -j 32 all real 8m16.291s user 197m44.858s sys 22m18.752s 16r3[root@:/kernel/linux-5.15.96.xxx]# Clean pass,, same tree that barfed with gcc 12.2 Ok new compiler no bueno 5.15.xx (slack-current compiler used to work, but) since way back august 22 eh ? Yeah, that compiler used to be fine with 5.15 This has happened fairly recently. /home/data2/slackware/slackware64-current Sun Aug 21 18:58:29 UTC 2022 d/gcc-12.2.0-x86_64-1.txz: Upgraded. Sat Jun 11 01:56:19 UTC 2022 d/gcc-12.1.0-x86_64-1.txz: Upgraded. Wed Apr 27 21:43:51 UTC 2022 d/gcc-11.3.0-x86_64-1.txz: Upgraded. I make hard link trees for each os so i dont need to deal with fixdep and objtool,,, that distclean wont clean when you share them. I used to run nvidia 340-108 with kernel 6.1.x & slack-current -- still works with root@14.2 ~ $ uname -a Linux n64 5.15.96.16r2 #12 SMP Mon Feb 27 00:13:09 -00 2023 x86_64 AMD Opteron(tm) Processor 6380 -- and an older Xorg server I would also apply patches for the kernels for the other bootable root systems that otherwise run as chroot containers. For illustration root@14.2 ~ $ lilo Added 5.15.101.16r2 * Added 5.15.98.16r2 Added 5.15.96.16r2 Added 4710.16r2r Added 4.9.337.16r7 Added 4710.16r7d Added 6.1.15.16r4 Added 6.1.11.16r4 Added 6.1.14.16r3 Added 5.15.96.16r3 root@14.2 ~ $ Then the slot melting nuke (many hard locks backing up on kernel versions before the final melt ) I ended up on my old slack 14.1 root volume and kernel 4.7.10 before i found a working rather than hard locking (and slot melting) root volume apparently because the nvidia bomb had been backported down stream into the LTS kernels. the old 4.7.10 didnt get any of those, so it was still working combo of Xorg ABI change, latest kernel backport fixes, abandoned nvidia driver will melt your motherboards . . beware. Anyhow . . looks like you fellas have your own mess to clean up. Cheers! . No , not going to risk my remaining numa serverboards to find when the slot melting nvidia nuke arrived. I have enough nvs 290' 300' dual monitor cards in operation to fill up a bucket, for us otherwise poor folk we will be using them quite a while longer . . It means we wont be updating upgrading anything except nonbootable containers, because otherwise kernel.org is full of slot melting nukes where nvidia in concerned. good idea, stay away from that company. go with whats supported in kernel, and don't march close to the front of the column either, stay at the back, its safer back there. root@14.2 boot $ lilo Added 5.15.96.16r2 * Added 4710.16r2r Added 4710.16r7d Added 6.1.11.16r4 Added 5.15.96.16r3 root@14.2 boot $ Shorter safer list me thinks . . ref https://nvidia.if-not-true-then-false.com/patcher/ 70165522 Dec 19 2019 NVIDIA-Linux-x86_64-340.108.run 101937099 Nov 10 03:23 NVIDIA-x86_64-340.108-kernel-5.15.run 101937664 May 7 2022 NVIDIA-x86_64-340.108-kernel-5.17.run 101938042 Jul 6 2022 NVIDIA-x86_64-340.108-kernel-5.18.run 101939210 Oct 27 23:04 NVIDIA-x86_64-340.108-kernel-6.0.run Those all worked before the nvidia nuke arrived N5LAX-Ray — 03/03/2023 9:45 PM new kernel binab Ahh nuke arrival day . . 11131760 Mar 3 20:08 v6.1.15.16r4 nuke kernel . . 11134608 Feb 10 04:33 v6.1.11.16r4 11106160 Feb 27 00:32 v6.1.14.16r3 Was prob an update from 6.1.11, many kernels get built only to be replaced with newer patch before they ever get used. so 6.1.11. might be safe, but cant risk it anyway. so we done wit all dat aint we. root@14.2 linux-5.15.103.16r2 $ time ../mk arch/x86/kernel/smp.o: warning: objtool: sysvec_reboot()+0x4e: unreachable instruction Still there in patch 5 15 103 I get the impresion this warning is basically harmless Look at all the others on their plate . . The nvidia nuke bomb that was backported melts pcie slots .. not quite so harmless . . Beware nvidia . . |