commonerror.c
1.34 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
/**************************************************************************
* *
* 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 */
}