diff mbox series

xen/compiler: Fix the position of the visibility pragma

Message ID 20250318133947.607492-1-andrew.cooper3@citrix.com (mailing list archive)
State New
Headers show
Series xen/compiler: Fix the position of the visibility pragma | expand

Commit Message

Andrew Cooper March 18, 2025, 1:39 p.m. UTC
This needs to be ahead of everything.  Right now, it is after xen/init.h being
included for -DINIT_SECTIONS_ONLY

  # 1 "./include/xen/compiler.h" 1
  # 83 "./include/xen/compiler.h"
  # 1 "./include/xen/init.h" 1
  # 62 "./include/xen/init.h"
  typedef int (*initcall_t)(void);
  typedef void (*exitcall_t)(void);
  # 72 "./include/xen/init.h"
  void do_presmp_initcalls(void);
  void do_initcalls(void);
  # 84 "./include/xen/compiler.h" 2
  # 122 "./include/xen/compiler.h"
  #pragma GCC visibility push(hidden)

Fixes: 84c4461b7d3a ("Force out-of-line instances of inline functions into .init.text in init-only code")
Signed-off-by: Andrew Cooper <andrew.cooper3@citrix.com>
---
CC: Anthony PERARD <anthony.perard@vates.tech>
CC: Michal Orzel <michal.orzel@amd.com>
CC: Jan Beulich <jbeulich@suse.com>
CC: Julien Grall <julien@xen.org>
CC: Roger Pau Monné <roger.pau@citrix.com>
CC: Stefano Stabellini <sstabellini@kernel.org>
---
 xen/include/xen/compiler.h | 10 +++++-----
 1 file changed, 5 insertions(+), 5 deletions(-)


base-commit: 77be740e8182fa6b31291a8ae983d253187e9b50

Comments

Jan Beulich March 18, 2025, 2:21 p.m. UTC | #1
On 18.03.2025 14:39, Andrew Cooper wrote:
> This needs to be ahead of everything.  Right now, it is after xen/init.h being
> included for -DINIT_SECTIONS_ONLY
> 
>   # 1 "./include/xen/compiler.h" 1
>   # 83 "./include/xen/compiler.h"
>   # 1 "./include/xen/init.h" 1
>   # 62 "./include/xen/init.h"
>   typedef int (*initcall_t)(void);
>   typedef void (*exitcall_t)(void);
>   # 72 "./include/xen/init.h"
>   void do_presmp_initcalls(void);
>   void do_initcalls(void);
>   # 84 "./include/xen/compiler.h" 2
>   # 122 "./include/xen/compiler.h"
>   #pragma GCC visibility push(hidden)
> 
> Fixes: 84c4461b7d3a ("Force out-of-line instances of inline functions into .init.text in init-only code")
> Signed-off-by: Andrew Cooper <andrew.cooper3@citrix.com>

Reviewed-by: Jan Beulich <jbeulich@suse.com>
diff mbox series

Patch

diff --git a/xen/include/xen/compiler.h b/xen/include/xen/compiler.h
index b118e4ba62eb..636a85bc417d 100644
--- a/xen/include/xen/compiler.h
+++ b/xen/include/xen/compiler.h
@@ -15,6 +15,11 @@ 
 # endif
 #endif
 
+#ifdef CONFIG_CC_HAS_VISIBILITY_ATTRIBUTE
+/* Results in more efficient PIC code (no indirections through GOT or PLT). */
+#pragma GCC visibility push(hidden)
+#endif
+
 #define barrier()     __asm__ __volatile__("": : :"memory")
 
 #define likely(x)     __builtin_expect(!!(x),1)
@@ -118,11 +123,6 @@ 
 #define __must_be_array(a) \
   BUILD_BUG_ON_ZERO(__builtin_types_compatible_p(typeof(a), typeof(&(a)[0])))
 
-#ifdef CONFIG_CC_HAS_VISIBILITY_ATTRIBUTE
-/* Results in more efficient PIC code (no indirections through GOT or PLT). */
-#pragma GCC visibility push(hidden)
-#endif
-
 /* Make the optimizer believe the variable can be manipulated arbitrarily. */
 #define OPTIMIZER_HIDE_VAR(var) __asm__ ( "" : "+g" (var) )