]> git.ipfire.org Git - thirdparty/glibc.git/blame - include/libc-symbols.h
Update copyright dates with scripts/update-copyrights
[thirdparty/glibc.git] / include / libc-symbols.h
CommitLineData
28f540f4
RM
1/* Support macros for making weak and strong aliases for symbols,
2 and for using symbol sets and linker warnings with GNU ld.
6d7e8eda 3 Copyright (C) 1995-2023 Free Software Foundation, Inc.
5290baf0 4 This file is part of the GNU C Library.
28f540f4 5
5290baf0 6 The GNU C Library is free software; you can redistribute it and/or
41bdb6e2
AJ
7 modify it under the terms of the GNU Lesser General Public
8 License as published by the Free Software Foundation; either
9 version 2.1 of the License, or (at your option) any later version.
28f540f4 10
5290baf0
UD
11 The GNU C Library is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
41bdb6e2 14 Lesser General Public License for more details.
28f540f4 15
41bdb6e2 16 You should have received a copy of the GNU Lesser General Public
59ba27a6 17 License along with the GNU C Library; if not, see
5a82c748 18 <https://www.gnu.org/licenses/>. */
28f540f4
RM
19
20#ifndef _LIBC_SYMBOLS_H
5290baf0 21#define _LIBC_SYMBOLS_H 1
28f540f4 22
7c3018f9
ZW
23/* This file is included implicitly in the compilation of every source file,
24 using -include. It includes config.h. */
9cd47470 25
7c3018f9
ZW
26/* Enable declarations of GNU extensions, since we are compiling them. */
27#define _GNU_SOURCE 1
28
29#ifdef MODULE_NAME
30
31/* Use `#if IS_IN (module)` to detect what component is being compiled. */
32#define PASTE_NAME1(a,b) a##b
33#define PASTE_NAME(a,b) PASTE_NAME1 (a,b)
34#define IN_MODULE PASTE_NAME (MODULE_, MODULE_NAME)
35#define IS_IN(lib) (IN_MODULE == MODULE_##lib)
36
37/* True if the current module is a versioned library. Versioned
38 library names culled from shlib-versions files are assigned a
39 MODULE_* value greater than MODULE_LIBS_BEGIN. */
40#define IS_IN_LIB (IN_MODULE > MODULE_LIBS_BEGIN)
41
42/* The testsuite, and some other ancillary code, should be compiled against
43 as close an approximation to the installed headers as possible.
44 Defining this symbol disables most internal-use-only declarations
45 provided by this header, and all those provided by other internal
46 wrapper headers. */
47#if IS_IN (testsuite) || defined IS_IN_build || defined __cplusplus
48# define _ISOMAC 1
49#endif
28f540f4 50
7c3018f9
ZW
51#else
52/* The generation process for a few files created very early in the
53 build (notably libc-modules.h itself) involves preprocessing this
54 header without defining MODULE_NAME. Under these conditions,
55 internal declarations (especially from config.h) must be visible,
56 but IS_IN should always evaluate as false. */
57# define IS_IN(lib) 0
58# define IS_IN_LIB 0
59# define IN_MODULE (-1)
60#endif
28f540f4 61
7c3018f9 62#ifndef _ISOMAC
28f540f4 63
92777700
RM
64/* This is defined for the compilation of all C library code. features.h
65 tests this to avoid inclusion of stubs.h while compiling the library,
66 before stubs.h has been generated. Some library code that is shared
67 with other packages also tests this symbol to see if it is being
68 compiled as part of the C library. We must define this before including
69 config.h, because it makes some definitions conditional on whether libc
70 itself is being compiled, or just some generator program. */
c709e372 71#define _LIBC 1
92777700 72
7c3018f9
ZW
73/* Some files must be compiled with optimization on. */
74#if !defined __ASSEMBLER__ && !defined __OPTIMIZE__
75# error "glibc cannot be compiled without optimization"
76#endif
77
78/* -ffast-math cannot be applied to the C library, as it alters the ABI.
79 Some test components that use -ffast-math are currently not part of
80 IS_IN (testsuite) for technical reasons, so we have a secondary override. */
81#if defined __FAST_MATH__ && !defined TEST_FAST_MATH
82# error "glibc must not be compiled with -ffast-math"
83#endif
d3669add 84
92777700 85#include <config.h>
28f540f4 86
3a24ddea
FW
87/* Obtain the definition of symbol_version_reference. */
88#include <libc-symver.h>
89
086df229
L
90/* When PIC is defined and SHARED isn't defined, we are building PIE
91 by default. */
92#if defined PIC && !defined SHARED
93# define BUILD_PIE_DEFAULT 1
94#else
95# define BUILD_PIE_DEFAULT 0
96#endif
97
26ffd5e6
RM
98/* Define this for the benefit of portable GNU code that wants to check it.
99 Code that checks with #if will not #include <config.h> again, since we've
100 already done it (and this file is implicitly included in every compile,
101 via -include). Code that checks with #ifdef will #include <config.h>,
102 but that file should always be idempotent (i.e., it's just #define/#undef
103 and nothing else anywhere should be changing the macro state it touches),
104 so it's harmless. */
105#define HAVE_CONFIG_H 0
106
3f3dd810
SP
107/* Define these macros for the benefit of portable GNU code that wants to check
108 them. Of course, STDC_HEADERS is never false when building libc! */
26ffd5e6 109#define STDC_HEADERS 1
3f3dd810
SP
110#define HAVE_MBSTATE_T 1
111#define HAVE_MBSRTOWCS 1
a476ac4b
SP
112#define HAVE_LIBINTL_H 1
113#define HAVE_WCTYPE_H 1
114#define HAVE_ISWCTYPE 1
115#define ENABLE_NLS 1
26ffd5e6 116
0269750c 117/* The symbols in all the user (non-_) macros are C symbols. */
28f540f4 118
28f540f4 119#ifndef __SYMBOL_PREFIX
a0da5fe1 120# define __SYMBOL_PREFIX
28f540f4
RM
121#endif
122
123#ifndef C_SYMBOL_NAME
a0da5fe1 124# define C_SYMBOL_NAME(name) name
28f540f4
RM
125#endif
126
b15cb495
UD
127#ifndef ASM_LINE_SEP
128# define ASM_LINE_SEP ;
129#endif
130
1626a1cf
MS
131#ifndef __attribute_copy__
132/* Provide an empty definition when cdefs.h is not included. */
133# define __attribute_copy__(arg)
134#endif
135
428383e8
UD
136#ifndef __ASSEMBLER__
137/* GCC understands weak symbols and aliases; use its interface where
138 possible, instead of embedded assembly language. */
d02907df 139
428383e8 140/* Define ALIASNAME as a strong alias for NAME. */
c62f5cab
GM
141# define strong_alias(name, aliasname) _strong_alias(name, aliasname)
142# define _strong_alias(name, aliasname) \
1626a1cf
MS
143 extern __typeof (name) aliasname __attribute__ ((alias (#name))) \
144 __attribute_copy__ (name);
428383e8
UD
145
146/* This comes between the return type and function name in
147 a function definition to make that definition weak. */
148# define weak_function __attribute__ ((weak))
149# define weak_const_function __attribute__ ((weak, __const__))
150
428383e8
UD
151/* Define ALIASNAME as a weak alias for NAME.
152 If weak aliases are not available, this defines a strong alias. */
a0da5fe1
UD
153# define weak_alias(name, aliasname) _weak_alias (name, aliasname)
154# define _weak_alias(name, aliasname) \
1626a1cf
MS
155 extern __typeof (name) aliasname __attribute__ ((weak, alias (#name))) \
156 __attribute_copy__ (name);
428383e8
UD
157
158/* Declare SYMBOL as weak undefined symbol (resolved to 0 if not defined). */
a0da5fe1
UD
159# define weak_extern(symbol) _weak_extern (weak symbol)
160# define _weak_extern(expr) _Pragma (#expr)
428383e8 161
ef4f9764
FW
162/* In shared builds, the expression call_function_static_weak
163 (FUNCTION-SYMBOL, ARGUMENTS) invokes FUNCTION-SYMBOL (an
164 identifier) unconditionally, with the (potentially empty) argument
165 list ARGUMENTS. In static builds, if FUNCTION-SYMBOL has a
166 definition, the function is invoked as before; if FUNCTION-SYMBOL
167 is NULL, no call is performed. */
168# ifdef SHARED
169# define call_function_static_weak(func, ...) func (__VA_ARGS__)
170# else /* !SHARED */
171# define call_function_static_weak(func, ...) \
172 ({ \
173 extern __typeof__ (func) func weak_function; \
174 (func != NULL ? func (__VA_ARGS__) : (void)0); \
175 })
176# endif
428383e8
UD
177
178#else /* __ASSEMBLER__ */
179
180# ifdef HAVE_ASM_SET_DIRECTIVE
5ca10a0c 181# define strong_alias(original, alias) \
7b8e0d49 182 .globl C_SYMBOL_NAME (alias) ASM_LINE_SEP \
c843e065 183 .set C_SYMBOL_NAME (alias),C_SYMBOL_NAME (original)
5ca10a0c 184# define strong_data_alias(original, alias) strong_alias(original, alias)
dfd2257a 185# else
5ca10a0c 186# define strong_alias(original, alias) \
7b8e0d49 187 .globl C_SYMBOL_NAME (alias) ASM_LINE_SEP \
c843e065 188 C_SYMBOL_NAME (alias) = C_SYMBOL_NAME (original)
5ca10a0c 189# define strong_data_alias(original, alias) strong_alias(original, alias)
dfd2257a 190# endif
d02907df 191
210dd782 192# define weak_alias(original, alias) \
c843e065 193 .weak C_SYMBOL_NAME (alias) ASM_LINE_SEP \
28f540f4 194 C_SYMBOL_NAME (alias) = C_SYMBOL_NAME (original)
e6964dd4 195
210dd782 196# define weak_extern(symbol) \
af5b3bc3 197 .weak C_SYMBOL_NAME (symbol)
d02907df 198
428383e8 199#endif /* __ASSEMBLER__ */
958f803f 200
e862aada
UD
201/* Determine the return address. */
202#define RETURN_ADDRESS(nr) \
203 __builtin_extract_return_addr (__builtin_return_address (nr))
204
44c8d1a2
RM
205/* When a reference to SYMBOL is encountered, the linker will emit a
206 warning message MSG. */
fd26970f 207/* We want the .gnu.warning.SYMBOL section to be unallocated. */
75b0964b 208#define __make_section_unallocated(section_string) \
b15cb495 209 asm (".section " section_string "\n\t.previous");
fd26970f 210
b15cb495
UD
211/* Tacking on "\n\t#" to the section name makes gcc put it's bogus
212 section attributes on what looks like a comment to the assembler. */
0269750c
UD
213#ifdef HAVE_SECTION_QUOTES
214# define __sec_comment "\"\n\t#\""
215#else
216# define __sec_comment "\n\t#"
217#endif
218#define link_warning(symbol, msg) \
e26dd47f 219 __make_section_unallocated (".gnu.warning." #symbol) \
44c8d1a2 220 static const char __evoke_link_warning_##symbol[] \
6c5775c3 221 __attribute__ ((used, section (".gnu.warning." #symbol __sec_comment))) \
c877418f 222 = msg;
28f540f4
RM
223
224/* A canned warning for sysdeps/stub functions. */
225#define stub_warning(name) \
561bcb80 226 __make_section_unallocated (".gnu.glibc-stub." #name) \
cd525923 227 link_warning (name, #name " is not implemented and will always fail")
5f9e57ba 228
2f7f7bc6
UD
229/* Warning for linking functions calling dlopen into static binaries. */
230#ifdef SHARED
231#define static_link_warning(name)
232#else
233#define static_link_warning(name) static_link_warning1(name)
234#define static_link_warning1(name) \
235 link_warning(name, "Using '" #name "' in statically linked applications \
236requires at runtime the shared libraries from the glibc version used \
237for linking")
238#endif
b88ac073 239
2827ab99
CD
240/* Resource Freeing Hooks:
241
242 Normally a process exits and the OS cleans up any allocated
243 memory. However, when tooling like mtrace or valgrind is monitoring
244 the process we need to free all resources that are part of the
245 process in order to provide the consistency required to track
246 memory leaks.
247
248 A single public API exists and is __libc_freeres(), and this is used
249 by applications like valgrind to freee resouces.
250
251 There are 3 cases:
252
253 (a) __libc_freeres
254
255 In this case all you need to do is define the freeing routine:
256
257 foo.c:
258 libfoo_freeres_fn (foo_freeres)
259 {
260 complex_free (mem);
261 }
262
263 This ensures the function is called at the right point to free
264 resources.
265
266 (b) __libc_freeres_ptr
267
268 The framework for (a) iterates over the list of pointers-to-free
269 in (b) and frees them.
270
271 foo.c:
272 libc_freeres_ptr (static char *foo_buffer);
273
274 Freeing these resources alaways happens last and is equivalent
275 to registering a function that does 'free (foo_buffer)'.
276
277 (c) Explicit lists of free routines to call or objects to free.
278
279 It is the intended goal to remove (a) and (b) which have some
280 non-determinism based on link order, and instead use explicit
281 lists of functions and frees to resolve cleanup ordering issues
282 and make it easy to debug and maintain.
283
284 As of today the following subsystems use (c):
285
286 Per-thread cleanup:
287 * malloc/thread-freeres.c
288
289 libdl cleanup:
290 * dlfcn/dlfreeres.c
291
292 libpthread cleanup:
293 * nptl/nptlfreeres.c
294
295 So if you need any shutdown routines to run you should add them
296 directly to the appropriate subsystem's shutdown list. */
297
298/* Resource pointers to free in libc.so. */
299#define libc_freeres_ptr(decl) \
300 __make_section_unallocated ("__libc_freeres_ptrs, \"aw\", %nobits") \
301 decl __attribute__ ((section ("__libc_freeres_ptrs" __sec_comment)))
302
303/* Resource freeing functions from libc.so go in this section. */
304#define __libc_freeres_fn_section \
3c1fe20a 305 __attribute__ ((__used__, section ("__libc_freeres_fn")))
2827ab99
CD
306
307/* Resource freeing functions for libc.so. */
308#define libc_freeres_fn(name) \
309 static void name (void) __attribute_used__ __libc_freeres_fn_section; \
310 text_set_element (__libc_subfreeres, name); \
311 static void name (void)
312
11bf311e
UD
313/* Declare SYMBOL to be TYPE (`function' or `object') of SIZE bytes
314 alias to ORIGINAL, when the assembler supports such declarations
315 (such as in ELF).
b88ac073
RM
316 This is only necessary when defining something in assembly, or playing
317 funny alias games where the size should be other than what the compiler
318 thinks it is. */
b67e9372 319#ifdef __ASSEMBLER__
111254f3
L
320# define declare_object_symbol_alias(symbol, original, size) \
321 declare_object_symbol_alias_1 (symbol, original, size)
322# define declare_object_symbol_alias_1(symbol, original, s_size) \
323 strong_alias (original, symbol) ASM_LINE_SEP \
324 .type C_SYMBOL_NAME (symbol), %object ASM_LINE_SEP \
325 .size C_SYMBOL_NAME (symbol), s_size ASM_LINE_SEP
b67e9372 326#else /* Not __ASSEMBLER__. */
b67e9372
MP
327# ifdef HAVE_ASM_SET_DIRECTIVE
328# define declare_symbol_alias_1_alias(symbol, original) \
329 ".set " __SYMBOL_PREFIX #symbol ", " __SYMBOL_PREFIX #original
330# else
331# define declare_symbol_alias_1_alias(symbol, original) \
332 __SYMBOL_PREFIX #symbol " = " __SYMBOL_PREFIX #original
333# endif /* HAVE_ASM_SET_DIRECTIVE */
334#endif /* __ASSEMBLER__ */
b88ac073
RM
335
336
5f9e57ba 337/*
28f540f4 338\f
5f9e57ba
RM
339*/
340
cd6ae7ea
FS
341#ifdef HAVE_GNU_RETAIN
342# define attribute_used_retain __attribute__ ((__used__, __retain__))
343#else
344# define attribute_used_retain __attribute__ ((__used__))
345#endif
346
28f540f4
RM
347/* Symbol set support macros. */
348
28f540f4 349/* Make SYMBOL, which is in the text segment, an element of SET. */
0269750c 350#define text_set_element(set, symbol) _elf_set_element(set, symbol)
28f540f4 351/* Make SYMBOL, which is in the data segment, an element of SET. */
0269750c 352#define data_set_element(set, symbol) _elf_set_element(set, symbol)
28f540f4 353/* Make SYMBOL, which is in the bss segment, an element of SET. */
0269750c 354#define bss_set_element(set, symbol) _elf_set_element(set, symbol)
28f540f4
RM
355
356/* These are all done the same way in ELF.
357 There is a new section created for each set. */
0269750c 358#ifdef SHARED
53afa8d9
RM
359/* When building a shared library, make the set section writable,
360 because it will need to be relocated at run time anyway. */
0269750c 361# define _elf_set_element(set, symbol) \
cd6ae7ea
FS
362 static const void *__elf_set_##set##_element_##symbol##__ \
363 attribute_used_retain __attribute__ ((section (#set))) = &(symbol)
0269750c
UD
364#else
365# define _elf_set_element(set, symbol) \
cd6ae7ea
FS
366 static const void *const __elf_set_##set##_element_##symbol##__ \
367 attribute_used_retain __attribute__ ((section (#set))) = &(symbol)
0269750c 368#endif
28f540f4
RM
369
370/* Define SET as a symbol set. This may be required (it is in a.out) to
371 be able to use the set's contents. */
0269750c 372#define symbol_set_define(set) symbol_set_declare(set)
28f540f4 373
20792f99
RM
374/* Declare SET for use in this module, if defined in another module.
375 In a shared library, this is always local to that shared object.
376 For static linking, the set might be wholly absent and so we use
377 weak references. */
0269750c 378#define symbol_set_declare(set) \
6f1e513d
RH
379 extern char const __start_##set[] __symbol_set_attribute; \
380 extern char const __stop_##set[] __symbol_set_attribute;
0269750c
UD
381#ifdef SHARED
382# define __symbol_set_attribute attribute_hidden
383#else
384# define __symbol_set_attribute __attribute__ ((weak))
385#endif
28f540f4
RM
386
387/* Return a pointer (void *const *) to the first element of SET. */
0269750c 388#define symbol_set_first_element(set) ((void *const *) (&__start_##set))
28f540f4
RM
389
390/* Return true iff PTR (a void *const *) has been incremented
391 past the last element in SET. */
0269750c 392#define symbol_set_end_p(set, ptr) ((ptr) >= (void *const *) &__stop_##set)
28f540f4 393
3f2e46a4 394#ifdef SHARED
ebdf53a7 395# define symbol_version(real, name, version) \
968dc26d 396 symbol_version_reference(real, name, version)
ebdf53a7
GM
397# define default_symbol_version(real, name, version) \
398 _default_symbol_version(real, name, version)
0923f74a 399/* See <libc-symver.h>. */
ebdf53a7 400# ifdef __ASSEMBLER__
5ca10a0c 401# define _default_symbol_version(real, name, version) \
0923f74a 402 _set_symbol_version (real, name@@version)
da2d1bc5 403# else
5ca10a0c 404# define _default_symbol_version(real, name, version) \
0923f74a 405 _set_symbol_version (real, #name "@@" #version)
da2d1bc5 406# endif
3a0ecccb
FW
407
408/* Evalutes to a string literal for VERSION in LIB. */
409# define symbol_version_string(lib, version) \
410 _symbol_version_stringify_1 (VERSION_##lib##_##version)
411# define _symbol_version_stringify_1(arg) _symbol_version_stringify_2 (arg)
412# define _symbol_version_stringify_2(arg) #arg
413
414#else /* !SHARED */
1ea89a40 415# define symbol_version(real, name, version)
da2d1bc5
UD
416# define default_symbol_version(real, name, version) \
417 strong_alias(real, name)
1ea89a40
UD
418#endif
419
df359a25
SN
420#if defined SHARED || defined LIBC_NONSHARED \
421 || (BUILD_PIE_DEFAULT && IS_IN (libc))
e6caf4e1
UD
422# define attribute_hidden __attribute__ ((visibility ("hidden")))
423#else
424# define attribute_hidden
425#endif
426
3ce1f295 427#define attribute_tls_model_ie __attribute__ ((tls_model ("initial-exec")))
9b21e6bc 428
11bf311e 429#define attribute_relro __attribute__ ((section (".data.rel.ro")))
392a6b52 430
de659123
NA
431
432/* Used to disable stack protection in sensitive places, like ifunc
433 resolvers and early static TLS init. */
434#ifdef HAVE_CC_NO_STACK_PROTECTOR
435# define inhibit_stack_protector \
436 __attribute__ ((__optimize__ ("-fno-stack-protector")))
437#else
438# define inhibit_stack_protector
439#endif
440
37ba7d66
UD
441/* The following macros are used for PLT bypassing within libc.so
442 (and if needed other libraries similarly).
443 First of all, you need to have the function prototyped somewhere,
444 say in foo/foo.h:
445
446 int foo (int __bar);
447
448 If calls to foo within libc.so should always go to foo defined in libc.so,
449 then in include/foo.h you add:
450
451 libc_hidden_proto (foo)
452
453 line and after the foo function definition:
454
455 int foo (int __bar)
456 {
457 return __bar;
458 }
459 libc_hidden_def (foo)
460
461 or
462
463 int foo (int __bar)
464 {
465 return __bar;
466 }
467 libc_hidden_weak (foo)
468
5536dfcb 469 Similarly for global data. If references to foo within libc.so should
c843e065
RM
470 always go to foo defined in libc.so, then in include/foo.h you add:
471
472 libc_hidden_proto (foo)
473
474 line and after foo's definition:
475
476 int foo = INITIAL_FOO_VALUE;
477 libc_hidden_data_def (foo)
478
479 or
480
481 int foo = INITIAL_FOO_VALUE;
482 libc_hidden_data_weak (foo)
483
5536dfcb 484 If foo is normally just an alias (strong or weak) to some other function,
37ba7d66
UD
485 you should use the normal strong_alias first, then add libc_hidden_def
486 or libc_hidden_weak:
487
488 int baz (int __bar)
489 {
490 return __bar;
491 }
492 strong_alias (baz, foo)
493 libc_hidden_weak (foo)
494
495 If the function should be internal to multiple objects, say ld.so and
496 libc.so, the best way is to use:
497
9cd47470 498 #if IS_IN (libc) || IS_IN (rtld)
37ba7d66
UD
499 hidden_proto (foo)
500 #endif
501
502 in include/foo.h and the normal macros at all function definitions
503 depending on what DSO they belong to.
504
505 If versioned_symbol macro is used to define foo,
506 libc_hidden_ver macro should be used, as in:
507
508 int __real_foo (int __bar)
509 {
510 return __bar;
511 }
512 versioned_symbol (libc, __real_foo, foo, GLIBC_2_1);
513 libc_hidden_ver (__real_foo, foo) */
514
3f2e46a4 515#if defined SHARED && !defined NO_HIDDEN
37ba7d66 516# ifndef __ASSEMBLER__
11bf311e 517# define __hidden_proto_hiddenattr(attrs...) \
81cb0d82 518 __attribute__ ((visibility ("hidden"), ##attrs))
81cb0d82 519# define hidden_proto(name, attrs...) \
699df45b 520 __hidden_proto (name, , __GI_##name, ##attrs)
baf2a265
AZ
521# define hidden_proto_alias(name, alias, attrs...) \
522 __hidden_proto_alias (name, , alias, ##attrs)
699df45b
JM
523# define hidden_tls_proto(name, attrs...) \
524 __hidden_proto (name, __thread, __GI_##name, ##attrs)
525# define __hidden_proto(name, thread, internal, attrs...) \
526 extern thread __typeof (name) name __asm__ (__hidden_asmname (#internal)) \
81cb0d82 527 __hidden_proto_hiddenattr (attrs);
baf2a265
AZ
528# define __hidden_proto_alias(name, thread, internal, attrs...) \
529 extern thread __typeof (name) internal __hidden_proto_hiddenattr (attrs);
37ba7d66
UD
530# define __hidden_asmname(name) \
531 __hidden_asmname1 (__USER_LABEL_PREFIX__, name)
532# define __hidden_asmname1(prefix, name) __hidden_asmname2(prefix, name)
533# define __hidden_asmname2(prefix, name) #prefix name
61995d3e 534# define __hidden_ver1(local, internal, name) \
9c4b457e
JM
535 __hidden_ver2 (, local, internal, name)
536# define __hidden_ver2(thread, local, internal, name) \
537 extern thread __typeof (name) __EI_##name \
538 __asm__(__hidden_asmname (#internal)); \
539 extern thread __typeof (name) __EI_##name \
1626a1cf
MS
540 __attribute__((alias (__hidden_asmname (#local)))) \
541 __attribute_copy__ (name)
61995d3e 542# define hidden_ver(local, name) __hidden_ver1(local, __GI_##name, name);
61995d3e 543# define hidden_def(name) __hidden_ver1(__GI_##name, name, name);
baf2a265
AZ
544# define hidden_def_alias(name, internal) \
545 strong_alias (name, internal)
61995d3e 546# define hidden_data_def(name) hidden_def(name)
baf2a265 547# define hidden_data_def_alias(name, alias) hidden_def_alias(name, alias)
9c4b457e
JM
548# define hidden_tls_def(name) \
549 __hidden_ver2 (__thread, __GI_##name, name, name);
61995d3e
RM
550# define hidden_weak(name) \
551 __hidden_ver1(__GI_##name, name, name) __attribute__((weak));
552# define hidden_data_weak(name) hidden_weak(name)
7b57bfe5
UD
553# define hidden_nolink(name, lib, version) \
554 __hidden_nolink1 (__GI_##name, __EI_##name, name, VERSION_##lib##_##version)
555# define __hidden_nolink1(local, internal, name, version) \
556 __hidden_nolink2 (local, internal, name, version)
557# define __hidden_nolink2(local, internal, name, version) \
1626a1cf
MS
558 extern __typeof (name) internal __attribute__ ((alias (#local))) \
559 __attribute_copy__ (name); \
7b57bfe5
UD
560 __hidden_nolink3 (local, internal, #name "@" #version)
561# define __hidden_nolink3(local, internal, vername) \
562 __asm__ (".symver " #internal ", " vername);
37ba7d66
UD
563# else
564/* For assembly, we need to do the opposite of what we do in C:
565 in assembly gcc __REDIRECT stuff is not in place, so functions
566 are defined by its normal name and we need to create the
567 __GI_* alias to it, in C __REDIRECT causes the function definition
568 to use __GI_* name and we need to add alias to the real name.
4547dee3
RM
569 There is no reason to use hidden_weak over hidden_def in assembly,
570 but we provide it for consistency with the C usage.
571 hidden_proto doesn't make sense for assembly but the equivalent
dce8f2b6 572 is to call via the HIDDEN_JUMPTARGET macro instead of JUMPTARGET. */
4547dee3 573# define hidden_def(name) strong_alias (name, __GI_##name)
baf2a265 574# define hidden_def_alias(name, alias) strong_alias (name, alias)
4547dee3 575# define hidden_weak(name) hidden_def (name)
37ba7d66 576# define hidden_ver(local, name) strong_alias (local, __GI_##name)
c843e065 577# define hidden_data_def(name) strong_data_alias (name, __GI_##name)
baf2a265 578# define hidden_data_def_alias(name, alias) strong_data_alias (name, alias)
9c4b457e 579# define hidden_tls_def(name) hidden_data_def (name)
c843e065 580# define hidden_data_weak(name) hidden_data_def (name)
5ca10a0c 581# define HIDDEN_JUMPTARGET(name) __GI_##name
37ba7d66
UD
582# endif
583#else
4547dee3 584# ifndef __ASSEMBLER__
8d2ec553 585# if !defined SHARED && IS_IN (libc) && !defined LIBC_NONSHARED \
ee417882 586 && (!defined PIC || !defined NO_HIDDEN_EXTERN_FUNC_IN_PIE) \
8d2ec553
L
587 && !defined NO_HIDDEN
588# define __hidden_proto_hiddenattr(attrs...) \
589 __attribute__ ((visibility ("hidden"), ##attrs))
590# define hidden_proto(name, attrs...) \
591 __hidden_proto (name, , name, ##attrs)
baf2a265
AZ
592# define hidden_proto_alias(name, alias, attrs...) \
593 __hidden_proto_alias (name, , alias, ##attrs)
8d2ec553
L
594# define hidden_tls_proto(name, attrs...) \
595 __hidden_proto (name, __thread, name, ##attrs)
596# define __hidden_proto(name, thread, internal, attrs...) \
597 extern thread __typeof (name) name __hidden_proto_hiddenattr (attrs);
baf2a265
AZ
598# define __hidden_proto_alias(name, thread, internal, attrs...) \
599 extern thread __typeof (name) internal __hidden_proto_hiddenattr (attrs);
8d2ec553
L
600# else
601# define hidden_proto(name, attrs...)
baf2a265 602# define hidden_proto_alias(name, alias, attrs...)
8d2ec553
L
603# define hidden_tls_proto(name, attrs...)
604# endif
4547dee3
RM
605# else
606# define HIDDEN_JUMPTARGET(name) JUMPTARGET(name)
607# endif /* Not __ASSEMBLER__ */
608# define hidden_weak(name)
37ba7d66 609# define hidden_def(name)
baf2a265 610# define hidden_def_alias(name, alias)
37ba7d66 611# define hidden_ver(local, name)
c843e065
RM
612# define hidden_data_weak(name)
613# define hidden_data_def(name)
baf2a265 614# define hidden_data_def_alias(name, alias)
9c4b457e 615# define hidden_tls_def(name)
1792c087 616# define hidden_nolink(name, lib, version)
37ba7d66
UD
617#endif
618
4f41c682 619#if IS_IN (libc)
81cb0d82 620# define libc_hidden_proto(name, attrs...) hidden_proto (name, ##attrs)
baf2a265
AZ
621# define libc_hidden_proto_alias(name, alias, attrs...) \
622 hidden_proto_alias (name, alias, ##attrs)
699df45b 623# define libc_hidden_tls_proto(name, attrs...) hidden_tls_proto (name, ##attrs)
37ba7d66
UD
624# define libc_hidden_def(name) hidden_def (name)
625# define libc_hidden_weak(name) hidden_weak (name)
5500cdba 626# define libc_hidden_nolink_sunrpc(name, version) hidden_nolink (name, libc, version)
37ba7d66 627# define libc_hidden_ver(local, name) hidden_ver (local, name)
c843e065 628# define libc_hidden_data_def(name) hidden_data_def (name)
baf2a265 629# define libc_hidden_data_def_alias(name, alias) hidden_data_def_alias (name, alias)
9c4b457e 630# define libc_hidden_tls_def(name) hidden_tls_def (name)
c843e065 631# define libc_hidden_data_weak(name) hidden_data_weak (name)
37ba7d66 632#else
81cb0d82 633# define libc_hidden_proto(name, attrs...)
baf2a265 634# define libc_hidden_proto_alias(name, alias, attrs...)
699df45b 635# define libc_hidden_tls_proto(name, attrs...)
37ba7d66
UD
636# define libc_hidden_def(name)
637# define libc_hidden_weak(name)
638# define libc_hidden_ver(local, name)
c843e065 639# define libc_hidden_data_def(name)
baf2a265 640# define libc_hidden_data_def_alias(name, alias)
9c4b457e 641# define libc_hidden_tls_def(name)
c843e065 642# define libc_hidden_data_weak(name)
37ba7d66
UD
643#endif
644
3d3316b1 645#if IS_IN (rtld)
81cb0d82 646# define rtld_hidden_proto(name, attrs...) hidden_proto (name, ##attrs)
37ba7d66
UD
647# define rtld_hidden_def(name) hidden_def (name)
648# define rtld_hidden_weak(name) hidden_weak (name)
c843e065 649# define rtld_hidden_data_def(name) hidden_data_def (name)
37ba7d66 650#else
81cb0d82 651# define rtld_hidden_proto(name, attrs...)
37ba7d66
UD
652# define rtld_hidden_def(name)
653# define rtld_hidden_weak(name)
c843e065 654# define rtld_hidden_data_def(name)
37ba7d66
UD
655#endif
656
9cd47470 657#if IS_IN (libm)
81cb0d82 658# define libm_hidden_proto(name, attrs...) hidden_proto (name, ##attrs)
37ba7d66
UD
659# define libm_hidden_def(name) hidden_def (name)
660# define libm_hidden_weak(name) hidden_weak (name)
661# define libm_hidden_ver(local, name) hidden_ver (local, name)
662#else
81cb0d82 663# define libm_hidden_proto(name, attrs...)
37ba7d66
UD
664# define libm_hidden_def(name)
665# define libm_hidden_weak(name)
666# define libm_hidden_ver(local, name)
667#endif
668
829a679f 669#if IS_IN (libmvec)
829a679f 670# define libmvec_hidden_def(name) hidden_def (name)
829a679f 671#else
829a679f 672# define libmvec_hidden_def(name)
829a679f
AS
673#endif
674
9cd47470 675#if IS_IN (libresolv)
6f9d8e68
UD
676# define libresolv_hidden_proto(name, attrs...) hidden_proto (name, ##attrs)
677# define libresolv_hidden_def(name) hidden_def (name)
6f9d8e68 678# define libresolv_hidden_data_def(name) hidden_data_def (name)
6f9d8e68
UD
679#else
680# define libresolv_hidden_proto(name, attrs...)
681# define libresolv_hidden_def(name)
6f9d8e68 682# define libresolv_hidden_data_def(name)
6f9d8e68
UD
683#endif
684
e3022f4b
FW
685#if IS_IN (libpthread)
686# define libpthread_hidden_proto(name, attrs...) hidden_proto (name, ##attrs)
e3022f4b 687# define libpthread_hidden_def(name) hidden_def (name)
e3022f4b
FW
688#else
689# define libpthread_hidden_proto(name, attrs...)
e3022f4b 690# define libpthread_hidden_def(name)
e3022f4b
FW
691#endif
692
9cd47470 693#if IS_IN (librt)
a9564ae9 694# define librt_hidden_proto(name, attrs...) hidden_proto (name, ##attrs)
a9564ae9 695# define librt_hidden_ver(local, name) hidden_ver (local, name)
a9564ae9
UD
696#else
697# define librt_hidden_proto(name, attrs...)
a9564ae9 698# define librt_hidden_ver(local, name)
5f21997b
UD
699#endif
700
9cd47470 701#if IS_IN (libnsl)
1d5cee23 702# define libnsl_hidden_proto(name, attrs...) hidden_proto (name, ##attrs)
ae7a94e5 703# define libnsl_hidden_nolink_def(name, version) hidden_nolink (name, libnsl, version)
1d5cee23
UD
704#else
705# define libnsl_hidden_proto(name, attrs...)
1d5cee23
UD
706#endif
707
3ce1f295
UD
708#define libc_hidden_builtin_proto(name, attrs...) libc_hidden_proto (name, ##attrs)
709#define libc_hidden_builtin_def(name) libc_hidden_def (name)
45ae17dd
PM
710
711#define libc_hidden_ldbl_proto(name, attrs...) libc_hidden_proto (name, ##attrs)
3ce1f295
UD
712#ifdef __ASSEMBLER__
713# define HIDDEN_BUILTIN_JUMPTARGET(name) HIDDEN_JUMPTARGET(name)
85dd1003
UD
714#endif
715
94551be9
LM
716#if IS_IN (libanl)
717# define libanl_hidden_proto(name, attrs...) hidden_proto (name, ##attrs)
94551be9
LM
718#else
719# define libanl_hidden_proto(name, attrs...)
94551be9
LM
720#endif
721
b30542fb
UD
722/* Get some dirty hacks. */
723#include <symbol-hacks.h>
724
4a381a81
UD
725/* Move compatibility symbols out of the way by placing them all in a
726 special section. */
d3a4a571
UD
727#ifndef __ASSEMBLER__
728# define attribute_compat_text_section \
4a381a81 729 __attribute__ ((section (".text.compat")))
d3a4a571
UD
730#else
731# define compat_text_section .section ".text.compat", "ax";
d3a4a571 732#endif
4a381a81 733
00980d84
SL
734/* Helper / base macros for indirect function symbols. */
735#define __ifunc_resolver(type_name, name, expr, arg, init, classifier) \
ee4e992e
MS
736 classifier inhibit_stack_protector \
737 __typeof (type_name) *name##_ifunc (arg) \
425ce2ed 738 { \
00980d84
SL
739 init (); \
740 __typeof (type_name) *res = expr; \
425ce2ed 741 return res; \
00980d84
SL
742 }
743
744#ifdef HAVE_GCC_IFUNC
745# define __ifunc(type_name, name, expr, arg, init) \
746 extern __typeof (type_name) name __attribute__ \
747 ((ifunc (#name "_ifunc"))); \
748 __ifunc_resolver (type_name, name, expr, arg, init, static)
749
750# define __ifunc_hidden(type_name, name, expr, arg, init) \
751 __ifunc (type_name, name, expr, arg, init)
752#else
753/* Gcc does not support __attribute__ ((ifunc (...))). Use the old behaviour
754 as fallback. But keep in mind that the debug information for the ifunc
755 resolver functions is not correct. It contains the ifunc'ed function as
756 DW_AT_linkage_name. E.g. lldb uses this field and an inferior function
757 call of the ifunc'ed function will fail due to "no matching function for
758 call to ..." because the ifunc'ed function and the resolver function have
759 different signatures. (Gcc support is disabled at least on a ppc64le
760 Ubuntu 14.04 system.) */
761
762# define __ifunc(type_name, name, expr, arg, init) \
763 extern __typeof (type_name) name; \
b513da7e 764 __typeof (type_name) *name##_ifunc (arg) __asm__ (#name); \
00980d84
SL
765 __ifunc_resolver (type_name, name, expr, arg, init,) \
766 __asm__ (".type " #name ", %gnu_indirect_function");
767
768# define __ifunc_hidden(type_name, name, expr, arg, init) \
769 extern __typeof (type_name) __libc_##name; \
770 __ifunc (type_name, __libc_##name, expr, arg, init) \
771 strong_alias (__libc_##name, name);
772#endif /* !HAVE_GCC_IFUNC */
773
774/* The following macros are used for indirect function symbols in libc.so.
775 First of all, you need to have the function prototyped somewhere,
776 say in foo.h:
777
778 int foo (int __bar);
779
780 If you have an implementation for foo which e.g. uses a special hardware
781 feature which isn't available on all machines where this libc.so will be
782 used but decideable if available at runtime e.g. via hwcaps, you can provide
783 two or multiple implementations of foo:
784
785 int __foo_default (int __bar)
786 {
787 return __bar;
788 }
789
790 int __foo_special (int __bar)
791 {
792 return __bar;
793 }
794
795 If your function foo has no libc_hidden_proto (foo) defined for PLT
796 bypassing, you can use:
797
798 #define INIT_ARCH() unsigned long int hwcap = __GLRO(dl_hwcap);
799
800 libc_ifunc (foo, (hwcap & HWCAP_SPECIAL) ? __foo_special : __foo_default);
801
802 This will define a resolver function for foo which returns __foo_special or
803 __foo_default depending on your specified expression. Please note that you
804 have to define a macro function INIT_ARCH before using libc_ifunc macro as
805 it is called by the resolver function before evaluating the specified
806 expression. In this example it is used to prepare the hwcap variable.
807 The resolver function is assigned to an ifunc'ed symbol foo. Calls to foo
808 from inside or outside of libc.so will be indirected by a PLT call.
809
810 If your function foo has a libc_hidden_proto (foo) defined for PLT bypassing
811 and calls to foo within libc.so should always go to one specific
812 implementation of foo e.g. __foo_default then you have to add:
813
814 __hidden_ver1 (__foo_default, __GI_foo, __foo_default);
815
816 or a tweaked definition of libc_hidden_def macro after the __foo_default
817 function definition. Calls to foo within libc.so will always go directly to
818 __foo_default. Calls to foo from outside libc.so will be indirected by a
819 PLT call to ifunc'ed symbol foo which you have to define in a separate
820 compile unit:
821
822 #define foo __redirect_foo
823 #include <foo.h>
824 #undef foo
825
826 extern __typeof (__redirect_foo) __foo_default attribute_hidden;
827 extern __typeof (__redirect_foo) __foo_special attribute_hidden;
828
829 libc_ifunc_redirected (__redirect_foo, foo,
830 (hwcap & HWCAP_SPECIAL)
831 ? __foo_special
832 : __foo_default);
833
834 This will define the ifunc'ed symbol foo like above. The redirection of foo
835 in header file is needed to omit an additional defintion of __GI_foo which
836 would end in a linker error while linking libc.so. You have to specify
837 __redirect_foo as first parameter which is used within libc_ifunc_redirected
838 macro in conjunction with typeof to define the ifunc'ed symbol foo.
839
840 If your function foo has a libc_hidden_proto (foo) defined and calls to foo
841 within or from outside libc.so should go via ifunc'ed symbol, then you have
842 to use:
843
844 libc_ifunc_hidden (foo, foo,
845 (hwcap & HWCAP_SPECIAL)
846 ? __foo_special
847 : __foo_default);
848 libc_hidden_def (foo)
849
850 The first parameter foo of libc_ifunc_hidden macro is used in the same way
851 as for libc_ifunc_redirected macro. */
852
853#define libc_ifunc(name, expr) __ifunc (name, name, expr, void, INIT_ARCH)
854
855#define libc_ifunc_redirected(redirected_name, name, expr) \
856 __ifunc (redirected_name, name, expr, void, INIT_ARCH)
857
858#define libc_ifunc_hidden(redirected_name, name, expr) \
859 __ifunc_hidden (redirected_name, name, expr, void, INIT_ARCH)
425ce2ed 860
9a1d2d45
UD
861/* The body of the function is supposed to use __get_cpu_features
862 which will, if necessary, initialize the data first. */
00980d84
SL
863#define libm_ifunc_init()
864#define libm_ifunc(name, expr) \
865 __ifunc (name, name, expr, void, libm_ifunc_init)
9a1d2d45 866
85c2e611
AZ
867/* Add the compiler optimization to inhibit loop transformation to library
868 calls. This is used to avoid recursive calls in memset and memmove
869 default implementations. */
870#ifdef HAVE_CC_INHIBIT_LOOP_TO_LIBCALL
871# define inhibit_loop_to_libcall \
872 __attribute__ ((__optimize__ ("-fno-tree-loop-distribute-patterns")))
873#else
874# define inhibit_loop_to_libcall
875#endif
0f3be872
ZW
876\f
877/* These macros facilitate sharing source files with gnulib.
878
879 They are here instead of sys/cdefs.h because they should not be
880 used in public header files.
881
882 Their definitions should be kept consistent with the definitions in
883 gnulib-common.m4, but it is not necessary to cater to old non-GCC
884 compilers, since they will only be used while building glibc itself.
885 (Note that _GNUC_PREREQ cannot be used in this file.) */
886
887/* Define as a marker that can be attached to declarations that might not
888 be used. This helps to reduce warnings, such as from
889 GCC -Wunused-parameter. */
890#if __GNUC__ >= 3 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 7)
891# define _GL_UNUSED __attribute__ ((__unused__))
892#else
893# define _GL_UNUSED
894#endif
895
896/* gcc supports the "unused" attribute on possibly unused labels, and
897 g++ has since version 4.5. Note to support C++ as well as C,
898 _GL_UNUSED_LABEL should be used with a trailing ; */
899#if !defined __cplusplus || __GNUC__ > 4 \
900 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 5)
901# define _GL_UNUSED_LABEL _GL_UNUSED
902#else
903# define _GL_UNUSED_LABEL
904#endif
905
906/* The __pure__ attribute was added in gcc 2.96. */
907#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 96)
908# define _GL_ATTRIBUTE_PURE __attribute__ ((__pure__))
909#else
910# define _GL_ATTRIBUTE_PURE /* empty */
911#endif
912
913/* The __const__ attribute was added in gcc 2.95. */
914#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 95)
915# define _GL_ATTRIBUTE_CONST __attribute__ ((__const__))
916#else
917# define _GL_ATTRIBUTE_CONST /* empty */
918#endif
85c2e611 919
7c3018f9 920#endif /* !_ISOMAC */
28f540f4 921#endif /* libc-symbols.h */