>>> On 26.09.12 at 10:28, Tao Guo <glorious...@gmail.com> wrote:
> gas in binutils(2.16.91) could not parse parentheses within macro
> parameters unless fully parenthesized, 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>

This looks okay now to me, but I'm somewhat reluctant to formally
ack it given that we know how broken those particular gas
versions are.

Jan

> ---
>  arch/x86/include/asm/calling.h |   48 +++++++++++++++++++--------------------
>  arch/x86/kernel/entry_64.S     |   20 ++++++++--------
>  2 files changed, 33 insertions(+), 35 deletions(-)
> 
> diff --git a/arch/x86/include/asm/calling.h b/arch/x86/include/asm/calling.h
> index a9e3a74..7f8422a 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
> diff --git a/arch/x86/kernel/entry_64.S b/arch/x86/kernel/entry_64.S
> index 69babd8..bf77e70 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
> @@ -384,7 +384,7 @@ ENDPROC(native_usergs_sysret64)
>       .endm
>  
>  ENTRY(save_rest)
> -     PARTIAL_FRAME 1 REST_SKIP+8
> +     PARTIAL_FRAME 1 (REST_SKIP+8)
>       movq 5*8+16(%rsp), %r11 /* save return address */
>       movq_cfi rbx, RBX+16
>       movq_cfi rbp, RBP+16
> -- 
> 1.7.7.6


--
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/

Reply via email to