lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [day] [month] [year] [list]
Message-ID: <20180904152709.GA17047@intel.com>
Date:   Tue, 4 Sep 2018 23:27:09 +0800
From:   kbuild test robot <lkp@...el.com>
To:     Juergen Gross <jgross@...e.com>
Cc:     kbuild-all@...org, linux-kernel@...r.kernel.org,
        tipbuild@...or.com, Thomas Gleixner <tglx@...utronix.de>
Subject: [tip:x86/paravirt 13/15] arch/x86/entry/entry_64.S:624: Error:
 invalid operands (*UND* and *ABS* sections) for `/'

tree:   https://git.kernel.org/pub/scm/linux/kernel/git/tip/tip.git x86/paravirt
head:   495310e4f2dd857c4d5a62806a04cb8ba53855c1
commit: 6da63eb241a05b0e676d68975e793c0521387141 [13/15] x86/paravirt: Move the pv_irq_ops under the PARAVIRT_XXL umbrella
config: x86_64-randconfig-g0-09032303 (attached as .config)
compiler: gcc-4.9 (Debian 4.9.4-2) 4.9.4
reproduce:
        git checkout 6da63eb241a05b0e676d68975e793c0521387141
        # save the attached .config to linux build tree
        make ARCH=x86_64 
:::::: branch date: 71 minutes ago
:::::: commit date: 71 minutes ago

All error/warnings (new ones prefixed by >>):

   In file included from arch/x86/entry/entry_64.S:33:0:
>> arch/x86/include/asm/paravirt.h:938:0: warning: "SAVE_FLAGS" redefined
    #define SAVE_FLAGS(clobbers)                                        \
    ^
   In file included from arch/x86/entry/entry_64.S:32:0:
   arch/x86/include/asm/irqflags.h:127:0: note: this is the location of the previous definition
    #define SAVE_FLAGS(x)  pushfq; popq %rax
    ^
   arch/x86/entry/entry_64.S: Assembler messages:
>> arch/x86/entry/entry_64.S:624: Error: invalid operands (*UND* and *UND* sections) for `+'
   arch/x86/entry/entry_64.S:649: Error: invalid operands (*UND* and *UND* sections) for `+'
   arch/x86/entry/entry_64.S:1046: Error: invalid operands (*UND* and *UND* sections) for `+'
   arch/x86/entry/entry_64.S:1048: Error: invalid operands (*UND* and *UND* sections) for `+'
>> arch/x86/entry/entry_64.S:624: Error: invalid operands (*UND* and *ABS* sections) for `/'
   arch/x86/entry/entry_64.S:649: Error: invalid operands (*UND* and *ABS* sections) for `/'
   arch/x86/entry/entry_64.S:1046: Error: invalid operands (*UND* and *ABS* sections) for `/'
   arch/x86/entry/entry_64.S:1048: Error: invalid operands (*UND* and *ABS* sections) for `/'

# https://git.kernel.org/pub/scm/linux/kernel/git/tip/tip.git/commit/?id=6da63eb241a05b0e676d68975e793c0521387141
git remote add tip https://git.kernel.org/pub/scm/linux/kernel/git/tip/tip.git
git remote update tip
git checkout 6da63eb241a05b0e676d68975e793c0521387141
vim +624 arch/x86/entry/entry_64.S

1d3e53e86 arch/x86/entry/entry_64.S  Andy Lutomirski   2017-07-11  546  
939b78713 arch/x86/kernel/entry_64.S H. Peter Anvin    2008-11-11  547  /*
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  548   * Interrupt entry helper function.
^1da177e4 arch/x86_64/kernel/entry.S Linus Torvalds    2005-04-16  549   *
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  550   * Entry runs with interrupts off. Stack layout at entry:
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  551   * +----------------------------------------------------+
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  552   * | regs->ss						|
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  553   * | regs->rsp						|
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  554   * | regs->eflags					|
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  555   * | regs->cs						|
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  556   * | regs->ip						|
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  557   * +----------------------------------------------------+
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  558   * | regs->orig_ax = ~(interrupt number)		|
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  559   * +----------------------------------------------------+
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  560   * | return address					|
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  561   * +----------------------------------------------------+
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  562   */
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  563  ENTRY(interrupt_entry)
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  564  	UNWIND_HINT_FUNC
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  565  	ASM_CLAC
f6f64681d arch/x86/kernel/entry_64.S Denys Vlasenko    2015-01-08  566  	cld
7f2590a11 arch/x86/entry/entry_64.S  Andy Lutomirski   2017-12-04  567  
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  568  	testb	$3, CS-ORIG_RAX+8(%rsp)
7f2590a11 arch/x86/entry/entry_64.S  Andy Lutomirski   2017-12-04  569  	jz	1f
7f2590a11 arch/x86/entry/entry_64.S  Andy Lutomirski   2017-12-04  570  	SWAPGS
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  571  
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  572  	/*
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  573  	 * Switch to the thread stack. The IRET frame and orig_ax are
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  574  	 * on the stack, as well as the return address. RDI..R12 are
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  575  	 * not (yet) on the stack and space has not (yet) been
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  576  	 * allocated for them.
90a6acc4e arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  577  	 */
90a6acc4e arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  578  	pushq	%rdi
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  579  
90a6acc4e arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  580  	/* Need to switch before accessing the thread stack. */
90a6acc4e arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  581  	SWITCH_TO_KERNEL_CR3 scratch_reg=%rdi
90a6acc4e arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  582  	movq	%rsp, %rdi
90a6acc4e arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  583  	movq	PER_CPU_VAR(cpu_current_top_of_stack), %rsp
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  584  
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  585  	 /*
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  586  	  * We have RDI, return address, and orig_ax on the stack on
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  587  	  * top of the IRET frame. That means offset=24
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  588  	  */
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  589  	UNWIND_HINT_IRET_REGS base=%rdi offset=24
90a6acc4e arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  590  
90a6acc4e arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  591  	pushq	7*8(%rdi)		/* regs->ss */
90a6acc4e arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  592  	pushq	6*8(%rdi)		/* regs->rsp */
90a6acc4e arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  593  	pushq	5*8(%rdi)		/* regs->eflags */
90a6acc4e arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  594  	pushq	4*8(%rdi)		/* regs->cs */
90a6acc4e arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  595  	pushq	3*8(%rdi)		/* regs->ip */
90a6acc4e arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  596  	pushq	2*8(%rdi)		/* regs->orig_ax */
90a6acc4e arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  597  	pushq	8(%rdi)			/* return address */
90a6acc4e arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  598  	UNWIND_HINT_FUNC
90a6acc4e arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  599  
90a6acc4e arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  600  	movq	(%rdi), %rdi
7f2590a11 arch/x86/entry/entry_64.S  Andy Lutomirski   2017-12-04  601  1:
7f2590a11 arch/x86/entry/entry_64.S  Andy Lutomirski   2017-12-04  602  
0e34d2263 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  603  	PUSH_AND_CLEAR_REGS save_ret=1
0e34d2263 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  604  	ENCODE_FRAME_POINTER 8
76f5df43c arch/x86/kernel/entry_64.S Denys Vlasenko    2015-02-26  605  
2ba647410 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  606  	testb	$3, CS+8(%rsp)
dde74f2e4 arch/x86/kernel/entry_64.S Denys Vlasenko    2015-04-27  607  	jz	1f
02bc7768f arch/x86/entry/entry_64.S  Andy Lutomirski   2015-07-03  608  
02bc7768f arch/x86/entry/entry_64.S  Andy Lutomirski   2015-07-03  609  	/*
7f2590a11 arch/x86/entry/entry_64.S  Andy Lutomirski   2017-12-04  610  	 * IRQ from user mode.
7f2590a11 arch/x86/entry/entry_64.S  Andy Lutomirski   2017-12-04  611  	 *
f10750536 arch/x86/entry/entry_64.S  Andy Lutomirski   2015-11-12  612  	 * We need to tell lockdep that IRQs are off.  We can't do this until
f10750536 arch/x86/entry/entry_64.S  Andy Lutomirski   2015-11-12  613  	 * we fix gsbase, and we should do it before enter_from_user_mode
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  614  	 * (which can take locks).  Since TRACE_IRQS_OFF is idempotent,
f10750536 arch/x86/entry/entry_64.S  Andy Lutomirski   2015-11-12  615  	 * the simplest way to handle it is to just call it twice if
f10750536 arch/x86/entry/entry_64.S  Andy Lutomirski   2015-11-12  616  	 * we enter from user mode.  There's no reason to optimize this since
f10750536 arch/x86/entry/entry_64.S  Andy Lutomirski   2015-11-12  617  	 * TRACE_IRQS_OFF is a no-op if lockdep is off.
f10750536 arch/x86/entry/entry_64.S  Andy Lutomirski   2015-11-12  618  	 */
f10750536 arch/x86/entry/entry_64.S  Andy Lutomirski   2015-11-12  619  	TRACE_IRQS_OFF
f10750536 arch/x86/entry/entry_64.S  Andy Lutomirski   2015-11-12  620  
478dc89cf arch/x86/entry/entry_64.S  Andy Lutomirski   2015-11-12  621  	CALL_enter_from_user_mode
02bc7768f arch/x86/entry/entry_64.S  Andy Lutomirski   2015-07-03  622  
76f5df43c arch/x86/kernel/entry_64.S Denys Vlasenko    2015-02-26  623  1:
2ba647410 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20 @624  	ENTER_IRQ_STACK old_rsp=%rdi save_ret=1
f6f64681d arch/x86/kernel/entry_64.S Denys Vlasenko    2015-01-08  625  	/* We entered an interrupt context - irqs are off: */
f6f64681d arch/x86/kernel/entry_64.S Denys Vlasenko    2015-01-08  626  	TRACE_IRQS_OFF
f6f64681d arch/x86/kernel/entry_64.S Denys Vlasenko    2015-01-08  627  
2ba647410 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  628  	ret
2ba647410 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  629  END(interrupt_entry)
2ba647410 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  630  
f3d415ea4 arch/x86/entry/entry_64.S  Dominik Brodowski 2018-02-20  631  

:::::: The code at line 624 was first introduced by commit
:::::: 2ba6474104a1132c4af9f6dc42c6bfe3ca71f8c7 x86/entry/64: Move ENTER_IRQ_STACK from interrupt macro to interrupt_entry

:::::: TO: Dominik Brodowski <linux@...inikbrodowski.net>
:::::: CC: Ingo Molnar <mingo@...nel.org>

---
0-DAY kernel test infrastructure                Open Source Technology Center
https://lists.01.org/pipermail/kbuild-all                   Intel Corporation

Download attachment ".config.gz" of type "application/gzip" (28423 bytes)

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ