NetBSD/sys/arch/alpha/include/cdefs.h
cgd 90789b53dd by default, provide RCS IDs for NetBSD/alpha kernel files in kernel binaries.
This can be disabled (to save a bit of space) with the NO_KERNEL_RCSIDS
options, which is present but commented out in the ALPHA config file.
In ELF-format kernels, these strings are present in the kernel binary but
are not loaded into memory.  (In ECOFF-format kernels, there's no easy way
to keep them from being loaded, so they _are_ loaded into memory.)
1997-04-07 23:39:37 +00:00

109 lines
3.0 KiB
C

/* $NetBSD: cdefs.h,v 1.8 1997/04/07 23:40:16 cgd Exp $ */
/*
* Copyright (c) 1995, 1996 Carnegie-Mellon University.
* All rights reserved.
*
* Author: Chris G. Demetriou
*
* Permission to use, copy, modify and distribute this software and
* its documentation is hereby granted, provided that both the copyright
* notice and this permission notice appear in all copies of the
* software, derivative works or modified versions, and any portions
* thereof, and that both notices appear in supporting documentation.
*
* CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
* CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND
* FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
*
* Carnegie Mellon requests users of this software to return to
*
* Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
* School of Computer Science
* Carnegie Mellon University
* Pittsburgh PA 15213-3890
*
* any improvements or extensions that they make and grant Carnegie the
* rights to redistribute these changes.
*/
#ifndef _MACHINE_CDEFS_H_
#define _MACHINE_CDEFS_H_
#define _C_LABEL(x) _STRING(x)
#ifdef __ELF__
#define __DO_NOT_DO_WEAK__ /* NO WEAK SYMS IN LIBC YET */
#ifndef __DO_NOT_DO_WEAK__
#define __indr_reference(sym,alias) /* nada, since we do weak refs */
#endif /* !__DO_NOT_DO_WEAK__ */
#ifdef __STDC__
#ifndef __DO_NOT_DO_WEAK__
#define __weak_alias(alias,sym) \
__asm__(".weak " #alias " ; " #alias " = " #sym)
#endif /* !__DO_NOT_DO_WEAK__ */
#define __warn_references(sym,msg) \
__asm__(".section .gnu.warning." #sym " ; .ascii \"" msg "\" ; .text")
#else /* !__STDC__ */
#ifndef __DO_NOT_DO_WEAK__
#define __weak_alias(alias,sym) \
__asm__(".weak alias ; alias = sym")
#endif /* !__DO_NOT_DO_WEAK__ */
#define __warn_references(sym,msg) \
__asm__(".section .gnu.warning.sym ; .ascii msg ; .text")
#endif /* !__STDC__ */
#else /* !__ELF__ */
/*
* Very little to do if not ELF: we support neither indirect or
* weak references, and don't do anything with warnings.
*/
#define __warn_references(sym,msg) /* nothing */
#endif /* !__ELF__ */
#ifdef _KERNEL
#ifdef __ELF__
#ifdef __STDC__
#define __KERNEL_SECTIONSTRING(_sec, _str) \
__asm__(".section " #_sec " ; .asciz \"" _str "\" ; .text")
#else
#define __KERNEL_SECTIONSTRING(_sec, _str) \
__asm__(".section _sec ; .asciz _str ; .text")
#endif
#define __KERNEL_RCSID(_n, _s) __KERNEL_SECTIONSTRING(.ident, _s)
#define __KERNEL_COPYRIGHT(_n, _s) __KERNEL_SECTIONSTRING(.copyright, _s)
#else /* __ELF__ */
#define __KERNEL_RCSID(_n, _s) \
static const char __CONCAT(rcsid,_n)[] \
__attribute__ ((unused)) = _s
#define __KERNEL_COPYRIGHT(_n, _s) \
static const char __CONCAT(copyright,_n)[] \
__attribute__ ((unused)) = _s
#endif /* __ELF__ */
#ifdef NO_KERNEL_RCSIDS
#undef __KERNEL_RCSID
#define __KERNEL_RCSID(_n, _s) /* nothing */
#endif
#endif /* _KERNEL */
#endif /* !_MACHINE_CDEFS_H_ */