Sorry, please ignore this patch. I missed to send 2nd patch...

On Fri, 28 Jul 2017 21:20:22 +0900
Masami Hiramatsu <mhira...@kernel.org> wrote:

> Generate irqentry and softirqentry text sections without
> any configs. This will add above extra sections, but
> no performace impact.
> 
> Signed-off-by: Masami Hiramatsu <mhira...@kernel.org>
> Suggested-by: Ingo Molnar <mi...@kernel.org>
> ---
>  arch/arm/include/asm/traps.h      |    7 -------
>  arch/arm64/include/asm/traps.h    |    7 -------
>  arch/x86/entry/entry_64.S         |    9 ++-------
>  include/asm-generic/sections.h    |    4 ++++
>  include/asm-generic/vmlinux.lds.h |    8 --------
>  include/linux/interrupt.h         |   14 +-------------
>  6 files changed, 7 insertions(+), 42 deletions(-)
> 
> diff --git a/arch/arm/include/asm/traps.h b/arch/arm/include/asm/traps.h
> index f555bb3664dc..683d9230984a 100644
> --- a/arch/arm/include/asm/traps.h
> +++ b/arch/arm/include/asm/traps.h
> @@ -18,7 +18,6 @@ struct undef_hook {
>  void register_undef_hook(struct undef_hook *hook);
>  void unregister_undef_hook(struct undef_hook *hook);
>  
> -#ifdef CONFIG_FUNCTION_GRAPH_TRACER
>  static inline int __in_irqentry_text(unsigned long ptr)
>  {
>       extern char __irqentry_text_start[];
> @@ -27,12 +26,6 @@ static inline int __in_irqentry_text(unsigned long ptr)
>       return ptr >= (unsigned long)&__irqentry_text_start &&
>              ptr < (unsigned long)&__irqentry_text_end;
>  }
> -#else
> -static inline int __in_irqentry_text(unsigned long ptr)
> -{
> -     return 0;
> -}
> -#endif
>  
>  static inline int in_exception_text(unsigned long ptr)
>  {
> diff --git a/arch/arm64/include/asm/traps.h b/arch/arm64/include/asm/traps.h
> index 02e9035b0685..47a9066f7c86 100644
> --- a/arch/arm64/include/asm/traps.h
> +++ b/arch/arm64/include/asm/traps.h
> @@ -37,18 +37,11 @@ void unregister_undef_hook(struct undef_hook *hook);
>  
>  void arm64_notify_segfault(struct pt_regs *regs, unsigned long addr);
>  
> -#ifdef CONFIG_FUNCTION_GRAPH_TRACER
>  static inline int __in_irqentry_text(unsigned long ptr)
>  {
>       return ptr >= (unsigned long)&__irqentry_text_start &&
>              ptr < (unsigned long)&__irqentry_text_end;
>  }
> -#else
> -static inline int __in_irqentry_text(unsigned long ptr)
> -{
> -     return 0;
> -}
> -#endif
>  
>  static inline int in_exception_text(unsigned long ptr)
>  {
> diff --git a/arch/x86/entry/entry_64.S b/arch/x86/entry/entry_64.S
> index aa58155187c5..5e41396efbbf 100644
> --- a/arch/x86/entry/entry_64.S
> +++ b/arch/x86/entry/entry_64.S
> @@ -766,13 +766,8 @@ apicinterrupt3 \num trace(\sym) smp_trace(\sym)
>  #endif
>  
>  /* Make sure APIC interrupt handlers end up in the irqentry section: */
> -#if defined(CONFIG_FUNCTION_GRAPH_TRACER) || defined(CONFIG_KASAN)
> -# define PUSH_SECTION_IRQENTRY       .pushsection .irqentry.text, "ax"
> -# define POP_SECTION_IRQENTRY        .popsection
> -#else
> -# define PUSH_SECTION_IRQENTRY
> -# define POP_SECTION_IRQENTRY
> -#endif
> +#define PUSH_SECTION_IRQENTRY        .pushsection .irqentry.text, "ax"
> +#define POP_SECTION_IRQENTRY .popsection
>  
>  .macro apicinterrupt num sym do_sym
>  PUSH_SECTION_IRQENTRY
> diff --git a/include/asm-generic/sections.h b/include/asm-generic/sections.h
> index 532372c6cf15..e5da44eddd2f 100644
> --- a/include/asm-generic/sections.h
> +++ b/include/asm-generic/sections.h
> @@ -27,6 +27,8 @@
>   *   __kprobes_text_start, __kprobes_text_end
>   *   __entry_text_start, __entry_text_end
>   *   __ctors_start, __ctors_end
> + *   __irqentry_text_start, __irqentry_text_end
> + *   __softirqentry_text_start, __softirqentry_text_end
>   */
>  extern char _text[], _stext[], _etext[];
>  extern char _data[], _sdata[], _edata[];
> @@ -39,6 +41,8 @@ extern char __per_cpu_load[], __per_cpu_start[], 
> __per_cpu_end[];
>  extern char __kprobes_text_start[], __kprobes_text_end[];
>  extern char __entry_text_start[], __entry_text_end[];
>  extern char __start_rodata[], __end_rodata[];
> +extern char __irqentry_text_start[], __irqentry_text_end[];
> +extern char __softirqentry_text_start[], __softirqentry_text_end[];
>  
>  /* Start and end of .ctors section - used for constructor calls. */
>  extern char __ctors_start[], __ctors_end[];
> diff --git a/include/asm-generic/vmlinux.lds.h 
> b/include/asm-generic/vmlinux.lds.h
> index fffc9bdae025..438b014c192f 100644
> --- a/include/asm-generic/vmlinux.lds.h
> +++ b/include/asm-generic/vmlinux.lds.h
> @@ -483,25 +483,17 @@
>               *(.entry.text)                                          \
>               VMLINUX_SYMBOL(__entry_text_end) = .;
>  
> -#if defined(CONFIG_FUNCTION_GRAPH_TRACER) || defined(CONFIG_KASAN)
>  #define IRQENTRY_TEXT                                                        
> \
>               ALIGN_FUNCTION();                                       \
>               VMLINUX_SYMBOL(__irqentry_text_start) = .;              \
>               *(.irqentry.text)                                       \
>               VMLINUX_SYMBOL(__irqentry_text_end) = .;
> -#else
> -#define IRQENTRY_TEXT
> -#endif
>  
> -#if defined(CONFIG_FUNCTION_GRAPH_TRACER) || defined(CONFIG_KASAN)
>  #define SOFTIRQENTRY_TEXT                                            \
>               ALIGN_FUNCTION();                                       \
>               VMLINUX_SYMBOL(__softirqentry_text_start) = .;          \
>               *(.softirqentry.text)                                   \
>               VMLINUX_SYMBOL(__softirqentry_text_end) = .;
> -#else
> -#define SOFTIRQENTRY_TEXT
> -#endif
>  
>  /* Section used for early init (in .S files) */
>  #define HEAD_TEXT  *(.head.text)
> diff --git a/include/linux/interrupt.h b/include/linux/interrupt.h
> index a2fddddb0d60..59ba11661b6e 100644
> --- a/include/linux/interrupt.h
> +++ b/include/linux/interrupt.h
> @@ -18,6 +18,7 @@
>  #include <linux/atomic.h>
>  #include <asm/ptrace.h>
>  #include <asm/irq.h>
> +#include <asm/sections.h>
>  
>  /*
>   * These correspond to the IORESOURCE_IRQ_* defines in
> @@ -726,7 +727,6 @@ extern int early_irq_init(void);
>  extern int arch_probe_nr_irqs(void);
>  extern int arch_early_irq_init(void);
>  
> -#if defined(CONFIG_FUNCTION_GRAPH_TRACER) || defined(CONFIG_KASAN)
>  /*
>   * We want to know which function is an entrypoint of a hardirq or a softirq.
>   */
> @@ -734,16 +734,4 @@ extern int arch_early_irq_init(void);
>  #define __softirq_entry  \
>       __attribute__((__section__(".softirqentry.text")))
>  
> -/* Limits of hardirq entrypoints */
> -extern char __irqentry_text_start[];
> -extern char __irqentry_text_end[];
> -/* Limits of softirq entrypoints */
> -extern char __softirqentry_text_start[];
> -extern char __softirqentry_text_end[];
> -
> -#else
> -#define __irq_entry
> -#define __softirq_entry
> -#endif
> -
>  #endif
> 


-- 
Masami Hiramatsu <mhira...@kernel.org>

Reply via email to