[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: stdarg.h



>stdarg.h を書き直してみました。

いろいろ問題があったのと、まだ実装していなかったところを直しました。
これで /sbin/dump をつくると core dump しません。
(/usr/lib は以前のままでも大丈夫)

#↓の #if 0 のところは alpha みたいに ansi.h にもっていく必要があります

#ifndef _POWERPC_STDARG_H_
#define _POWERPC_STDARG_H_

#include <machine/ansi.h>
#include <sys/featuretest.h>

#if 0
typedef struct {
	char __gpr;	/* GPR offset */
	char __fpr;	/* FPR offset */
	char *__stack;	/* args passed on stack */
	char *__base;	/* args passed by registers (r3-r10, f1-f8) */
} __va_list;
#endif

typedef _BSD_VA_LIST_	va_list;

#define	va_start(ap, last)						\
	(__builtin_next_arg(last),					\
	 (ap).__stack = __va_stack_args,				\
	 (ap).__base = __va_reg_args,					\
	 (ap).__gpr = __va_first_gpr,					\
	 (ap).__fpr = __va_first_fpr)

#define __va_first_gpr	(__builtin_args_info(0))
#define __va_first_fpr	(__builtin_args_info(1) - 32 - 1)
#define __va_stack_args							\
	((char *)__builtin_saveregs() +					\
		(__va_first_gpr >= 8 ? __va_first_gpr - 8 : 0))
#define __va_reg_args							\
	((char *)__builtin_frame_address(0) + __builtin_args_info(4))

#define	__va_size(type)							\
	((sizeof(type) + sizeof(int) - 1) / sizeof(int) * sizeof(int))

#define __va_longlong(type)						\
	(__builtin_classify_type(*(type *)0) == 1 && sizeof(type) == 8)

#define __va_double(type)						\
	(__builtin_classify_type(*(type *)0) == 8)

#define __va_struct(type)						\
	(__builtin_classify_type(*(type *)0) >= 12)

#define __va_savedgpr(ap, type)						\
	((ap).__base + (ap).__gpr * sizeof(int) - sizeof(type))

#define __va_savedfpr(ap, type)						\
	((ap).__base + 8 * sizeof(int) + (ap).__fpr * sizeof(double) -	\
	 sizeof(type))

#define __va_stack(ap, type)						\
	((ap).__stack += __va_size(type) +				\
			(__va_longlong(type) ? (int)(ap).__stack & 4 : 0), \
	 (ap).__stack - sizeof(type))

#define __va_gpr(ap, type)						\
	((ap).__gpr += __va_size(type) / sizeof(int) +			\
		      (__va_longlong(type) ? (ap).__gpr & 1 : 0),	\
	 (ap).__gpr <= 8 ? __va_savedgpr(ap, type) : __va_stack(ap, type))

#define __va_fpr(ap, type)						\
	((ap).__fpr++,							\
	 (ap).__fpr <= 8 ? __va_savedfpr(ap, type) : __va_stack(ap, type))

#define	va_arg(ap, type)						\
	(*(type *)(__va_struct(type) ? (*(void **)__va_gpr(ap, void *)) : \
		   __va_double(type) ? __va_fpr(ap, type) :		\
		   __va_gpr(ap, type)))

#define	va_end(ap)	

#if !defined(_ANSI_SOURCE) &&						\
    (!defined(_POSIX_C_SOURCE) && !defined(_XOPEN_SOURCE) ||		\
     defined(_ISOC99_SOURCE) || (__STDC_VERSION__ - 0) >= 199901L)
#define va_copy(dest, src)						\
	((dest) = (src))
#endif

#endif /* _POWERPC_STDARG_H_ */