commonerror.c 1.34 KB
/**************************************************************************
 *									  *
 *		 Copyright (C) 1994, Silicon Graphics, Inc.		  *
 *									  *
 *  These coded instructions, statements, and computer programs  contain  *
 *  unpublished  proprietary  information of Silicon Graphics, Inc., and  *
 *  are protected by Federal copyright law.  They  may  not be disclosed  *
 *  to  third  parties  or copied or duplicated in any form, in whole or  *
 *  in part, without the prior written consent of Silicon Graphics, Inc.  *
 *									  *
 **************************************************************************/


#include "osint.h"

#define	ERROR_LOG_LEN	((OS_LOG_MAX_ARGS * sizeof(u32)) + sizeof(OSLogItem))

static void	__commonErrorHandler(s16, s16, ...);

static u32	errorLogData[ERROR_LOG_LEN/sizeof(u32)];
static OSLog	errorLog = {OS_ERROR_MAGIC, ERROR_LOG_LEN, errorLogData, 0, 0};
OSErrorHandler	__osCommonHandler = __commonErrorHandler;

#include "oserr.h"
extern void __osSyncVPrintf(const char *, va_list);

void
__commonErrorHandler(s16 code, s16 numArgs, ...)
{
    va_list	argPtr;
    char *fmt;

#ifndef _FINALROM
    fmt = __os_error_message[code];

    va_start(argPtr, numArgs);
    osSyncPrintf("0x%08X (%04d):",osGetCount(),code);
    __osSyncVPrintf(fmt,argPtr);
    va_end(argPtr);
    osSyncPrintf("\n");
#endif /* _FINALROM */
}