On 9/26/12, Jan Beulich <jbeul...@suse.com> wrote: >>>> On 26.09.12 at 08:15, Tao Guo <glorious...@gmail.com> wrote: >> gas in binutils(2.16.91) could not parse parentheses within macro >> parameters, > > This description of yours contradicts the last hunk of the patch - > iirc the requirement for macro parameters in those old gas > versions is to be fully parenthesized if there's any blank inside > (which could possibly not even be present in source code, but > get inserted by the C preprocessor). Yes, the description is a little misleading and I have corrected in the new patch. > >> and this is a workaround to make old gas work without >> generating below errors: >> arch/x86/kernel/entry_64.S: Assembler messages: >> arch/x86/kernel/entry_64.S:387: Error: too many positional arguments >> arch/x86/kernel/entry_64.S:389: Error: too many positional arguments >> arch/x86/kernel/entry_64.S:390: Error: too many positional arguments >> arch/x86/kernel/entry_64.S:391: Error: too many positional arguments >> arch/x86/kernel/entry_64.S:392: Error: too many positional arguments >> arch/x86/kernel/entry_64.S:393: Error: too many positional arguments >> arch/x86/kernel/entry_64.S:394: Error: too many positional arguments >> >> Signed-off-by: Tao Guo <glorious...@gmail.com> >> --- >> arch/x86/include/asm/calling.h | 52 >> +++++++++++++++++++-------------------- >> arch/x86/kernel/entry_64.S | 18 +++++++------- >> 2 files changed, 34 insertions(+), 36 deletions(-) >> >> diff --git a/arch/x86/include/asm/calling.h >> b/arch/x86/include/asm/calling.h >> index a9e3a74..7627e26 100644 >> --- a/arch/x86/include/asm/calling.h >> +++ b/arch/x86/include/asm/calling.h >> @@ -49,38 +49,36 @@ For 32-bit we have the following conventions - kernel >> is >> built with >> #include "dwarf2.h" >> >> /* >> - * 64-bit system call stack frame layout defines and helpers, for >> - * assembly code (note that the seemingly unnecessary parentheses >> - * are to prevent cpp from inserting spaces in expressions that get >> - * passed to macros): >> + * 64-bit system call stack frame layout defines and helpers, >> + * for assembly code: >> */ >> >> -#define R15 (0) >> -#define R14 (8) >> -#define R13 (16) >> -#define R12 (24) >> -#define RBP (32) >> -#define RBX (40) >> +#define R15 0 >> +#define R14 8 >> +#define R13 16 >> +#define R12 24 >> +#define RBP 32 >> +#define RBX 40 >> >> /* arguments: interrupts/non tracing syscalls only save up to here: */ >> -#define R11 (48) >> -#define R10 (56) >> -#define R9 (64) >> -#define R8 (72) >> -#define RAX (80) >> -#define RCX (88) >> -#define RDX (96) >> -#define RSI (104) >> -#define RDI (112) >> -#define ORIG_RAX (120) /* + error_code */ >> +#define R11 48 >> +#define R10 56 >> +#define R9 64 >> +#define R8 72 >> +#define RAX 80 >> +#define RCX 88 >> +#define RDX 96 >> +#define RSI 104 >> +#define RDI 112 >> +#define ORIG_RAX 120 /* + error_code */ >> /* end of arguments */ >> >> /* cpu exception frame or undefined in case of fast syscall: */ >> -#define RIP (128) >> -#define CS (136) >> -#define EFLAGS (144) >> -#define RSP (152) >> -#define SS (160) >> +#define RIP 128 >> +#define CS 136 >> +#define EFLAGS 144 >> +#define RSP 152 >> +#define SS 160 >> >> #define ARGOFFSET R11 >> #define SWFRAME ORIG_RAX > > While up the here the changes are certainly acceptable, ... > >> @@ -107,7 +105,7 @@ For 32-bit we have the following conventions - kernel >> is >> built with >> >> .endm >> >> -#define ARG_SKIP (9*8) >> +#define ARG_SKIP 9*8 >> >> .macro RESTORE_ARGS rstor_rax=1, addskip=0, rstor_rcx=1, rstor_r11=1, \ >> rstor_r8910=1, rstor_rdx=1 >> @@ -157,7 +155,7 @@ For 32-bit we have the following conventions - kernel >> is >> built with >> .endif >> .endm >> >> -#define REST_SKIP (6*8) >> +#define REST_SKIP 6*8 >> >> .macro SAVE_REST >> subq $REST_SKIP, %rsp > > ... these two ones aren't - you can't simply remove parentheses > from expressions without causing (potentially future) problems, > up to and including someone re-introducing the parentheses to > address such problems. You ought to parenthesize the macro > parameters where needed instead, as you did below. Thanks for the suggestion and I will correct it in the new patch. > > But that's all leaving aside that in the past it was already > suggested (by hpa iirc) to simply declare these 2.16-based > assemblers non-suitable for building the kernel. Yes, that's another way to solve such compiling problems; People can at least get some instructions to solve their problems.
Thanks, -Tao > > Jan > >> diff --git a/arch/x86/kernel/entry_64.S b/arch/x86/kernel/entry_64.S >> index 69babd8..784a5b6 100644 >> --- a/arch/x86/kernel/entry_64.S >> +++ b/arch/x86/kernel/entry_64.S >> @@ -342,15 +342,15 @@ ENDPROC(native_usergs_sysret64) >> .macro SAVE_ARGS_IRQ >> cld >> /* start from rbp in pt_regs and jump over */ >> - movq_cfi rdi, RDI-RBP >> - movq_cfi rsi, RSI-RBP >> - movq_cfi rdx, RDX-RBP >> - movq_cfi rcx, RCX-RBP >> - movq_cfi rax, RAX-RBP >> - movq_cfi r8, R8-RBP >> - movq_cfi r9, R9-RBP >> - movq_cfi r10, R10-RBP >> - movq_cfi r11, R11-RBP >> + movq_cfi rdi, (RDI-RBP) >> + movq_cfi rsi, (RSI-RBP) >> + movq_cfi rdx, (RDX-RBP) >> + movq_cfi rcx, (RCX-RBP) >> + movq_cfi rax, (RAX-RBP) >> + movq_cfi r8, (R8-RBP) >> + movq_cfi r9, (R9-RBP) >> + movq_cfi r10, (R10-RBP) >> + movq_cfi r11, (R11-RBP) >> >> /* Save rbp so that we can unwind from get_irq_regs() */ >> movq_cfi rbp, 0 >> -- >> 1.7.7 > > > -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/