mirror of
https://git.planet-casio.com/Lephenixnoir/OpenLibm.git
synced 2024-12-29 13:03:42 +01:00
Avoid redefining macros defined by the system
In particular, OpenBSD already defines __GNUC_PREREQ__, __BEGIN_DECLS, and __warn_references. Hiding the definitions behind #ifndef guards avoids warnings when building.
This commit is contained in:
parent
48c6c2c2ac
commit
72bfab46a0
2 changed files with 12 additions and 0 deletions
|
@ -78,12 +78,14 @@
|
||||||
/*
|
/*
|
||||||
* Macro to test if we're using a specific version of gcc or later.
|
* Macro to test if we're using a specific version of gcc or later.
|
||||||
*/
|
*/
|
||||||
|
#ifndef __GNUC_PREREQ__
|
||||||
#if defined(__GNUC__) && !defined(__INTEL_COMPILER)
|
#if defined(__GNUC__) && !defined(__INTEL_COMPILER)
|
||||||
#define __GNUC_PREREQ__(ma, mi) \
|
#define __GNUC_PREREQ__(ma, mi) \
|
||||||
(__GNUC__ > (ma) || __GNUC__ == (ma) && __GNUC_MINOR__ >= (mi))
|
(__GNUC__ > (ma) || __GNUC__ == (ma) && __GNUC_MINOR__ >= (mi))
|
||||||
#else
|
#else
|
||||||
#define __GNUC_PREREQ__(ma, mi) 0
|
#define __GNUC_PREREQ__(ma, mi) 0
|
||||||
#endif
|
#endif
|
||||||
|
#endif /* __GNUC_PREREQ__ */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Compiler-dependent macro to help declare pure (no side effects) functions.
|
* Compiler-dependent macro to help declare pure (no side effects) functions.
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
#ifndef _CDEFS_COMPAT_H_
|
#ifndef _CDEFS_COMPAT_H_
|
||||||
#define _CDEFS_COMPAT_H_
|
#define _CDEFS_COMPAT_H_
|
||||||
|
|
||||||
|
#if !defined(__BEGIN_DECLS)
|
||||||
#if defined(__cplusplus)
|
#if defined(__cplusplus)
|
||||||
#define __BEGIN_DECLS extern "C" {
|
#define __BEGIN_DECLS extern "C" {
|
||||||
#define __END_DECLS }
|
#define __END_DECLS }
|
||||||
|
@ -8,6 +9,7 @@
|
||||||
#define __BEGIN_DECLS
|
#define __BEGIN_DECLS
|
||||||
#define __END_DECLS
|
#define __END_DECLS
|
||||||
#endif
|
#endif
|
||||||
|
#endif /* !defined(__BEGIN_DECLS) */
|
||||||
|
|
||||||
#ifdef __GNUC__
|
#ifdef __GNUC__
|
||||||
#ifndef __strong_reference
|
#ifndef __strong_reference
|
||||||
|
@ -25,18 +27,22 @@
|
||||||
#define __weak_reference(sym,alias) \
|
#define __weak_reference(sym,alias) \
|
||||||
__asm__(".weak " #alias); \
|
__asm__(".weak " #alias); \
|
||||||
__asm__(".equ " #alias ", " #sym)
|
__asm__(".equ " #alias ", " #sym)
|
||||||
|
#ifndef __warn_references
|
||||||
#define __warn_references(sym,msg) \
|
#define __warn_references(sym,msg) \
|
||||||
__asm__(".section .gnu.warning." #sym); \
|
__asm__(".section .gnu.warning." #sym); \
|
||||||
__asm__(".asciz \"" msg "\""); \
|
__asm__(".asciz \"" msg "\""); \
|
||||||
__asm__(".previous")
|
__asm__(".previous")
|
||||||
|
#endif /* __warn_references */
|
||||||
#else
|
#else
|
||||||
#define __weak_reference(sym,alias) \
|
#define __weak_reference(sym,alias) \
|
||||||
__asm__(".weak alias"); \
|
__asm__(".weak alias"); \
|
||||||
__asm__(".equ alias, sym")
|
__asm__(".equ alias, sym")
|
||||||
|
#ifndef __warn_references
|
||||||
#define __warn_references(sym,msg) \
|
#define __warn_references(sym,msg) \
|
||||||
__asm__(".section .gnu.warning.sym"); \
|
__asm__(".section .gnu.warning.sym"); \
|
||||||
__asm__(".asciz \"msg\""); \
|
__asm__(".asciz \"msg\""); \
|
||||||
__asm__(".previous")
|
__asm__(".previous")
|
||||||
|
#endif /* __warn_references */
|
||||||
#endif /* __STDC__ */
|
#endif /* __STDC__ */
|
||||||
#elif defined(__clang__) /* CLANG */
|
#elif defined(__clang__) /* CLANG */
|
||||||
#ifdef __STDC__
|
#ifdef __STDC__
|
||||||
|
@ -53,16 +59,20 @@
|
||||||
#define __weak_reference(sym,alias) \
|
#define __weak_reference(sym,alias) \
|
||||||
__asm__(".stabs \"_" #alias "\",11,0,0,0"); \
|
__asm__(".stabs \"_" #alias "\",11,0,0,0"); \
|
||||||
__asm__(".stabs \"_" #sym "\",1,0,0,0")
|
__asm__(".stabs \"_" #sym "\",1,0,0,0")
|
||||||
|
#ifndef __warn_references
|
||||||
#define __warn_references(sym,msg) \
|
#define __warn_references(sym,msg) \
|
||||||
__asm__(".stabs \"" msg "\",30,0,0,0"); \
|
__asm__(".stabs \"" msg "\",30,0,0,0"); \
|
||||||
__asm__(".stabs \"_" #sym "\",1,0,0,0")
|
__asm__(".stabs \"_" #sym "\",1,0,0,0")
|
||||||
|
#endif /* __warn_references */
|
||||||
#else
|
#else
|
||||||
#define __weak_reference(sym,alias) \
|
#define __weak_reference(sym,alias) \
|
||||||
__asm__(".stabs \"_/**/alias\",11,0,0,0"); \
|
__asm__(".stabs \"_/**/alias\",11,0,0,0"); \
|
||||||
__asm__(".stabs \"_/**/sym\",1,0,0,0")
|
__asm__(".stabs \"_/**/sym\",1,0,0,0")
|
||||||
|
#ifndef __warn_references
|
||||||
#define __warn_references(sym,msg) \
|
#define __warn_references(sym,msg) \
|
||||||
__asm__(".stabs msg,30,0,0,0"); \
|
__asm__(".stabs msg,30,0,0,0"); \
|
||||||
__asm__(".stabs \"_/**/sym\",1,0,0,0")
|
__asm__(".stabs \"_/**/sym\",1,0,0,0")
|
||||||
|
#endif /* __warn_references */
|
||||||
#endif /* __STDC__ */
|
#endif /* __STDC__ */
|
||||||
#endif /* __ELF__ */
|
#endif /* __ELF__ */
|
||||||
#endif /* __weak_reference */
|
#endif /* __weak_reference */
|
||||||
|
|
Loading…
Reference in a new issue