mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-28 08:45:32 +01:00
4e9746877e
1) The new ERROR, WARN, INFO, DEBUG _LOG macros were used ERROR, // Bad errors - that still don't deserve a PanicAlert. WARNING, // Something is suspicious. INFO, // General information. DEBUG, // Strictly for detailed debugging - might make things slow. 2) Made all LOG macro use into some of the logging level supporting macros LOG is commented out on linux can someone try it on windows? (it's in Log.h) 3) Added ERROR_lOG next to each panic alert I hope I helped making the logs a bit more useful/readble git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@2510 8ced0084-cf51-0410-be5f-012b33b47a6e
123 lines
3.3 KiB
C
123 lines
3.3 KiB
C
// Copyright (C) 2003-2008 Dolphin Project.
|
||
|
||
// This program is free software: you can redistribute it and/or modify
|
||
// it under the terms of the GNU General Public License as published by
|
||
// the Free Software Foundation, version 2.0.
|
||
|
||
// This program is distributed in the hope that it will be useful,
|
||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
// GNU General Public License 2.0 for more details.
|
||
|
||
// A copy of the GPL 2.0 should have been included with the program.
|
||
// If not, see http://www.gnu.org/licenses/
|
||
|
||
// Official SVN repository and contact information can be found at
|
||
// http://code.google.com/p/dolphin-emu/
|
||
|
||
#ifndef _VIDEOCOMMON_H
|
||
#define _VIDEOCOMMON_H
|
||
|
||
#include "Common.h"
|
||
#include "pluginspecs_video.h"
|
||
|
||
#if defined(_MSC_VER) && !defined(__x86_64__) && !defined(_M_X64)
|
||
void * memcpy_amd(void *dest, const void *src, size_t n);
|
||
unsigned char memcmp_mmx(const void* src1, const void* src2, int cmpsize);
|
||
#define memcpy_gc memcpy_amd
|
||
#define memcmp_gc memcmp_mmx
|
||
#else
|
||
#define memcpy_gc memcpy
|
||
#define memcmp_gc memcmp
|
||
#endif
|
||
|
||
// These are accurate (disregarding AA modes).
|
||
enum
|
||
{
|
||
EFB_WIDTH = 640,
|
||
EFB_HEIGHT = 528,
|
||
};
|
||
|
||
enum
|
||
{
|
||
XFB_WIDTH = 640,
|
||
XFB_HEIGHT = 480, // 574 can be used with tricks (multi pass render and dual xfb copies, etc).
|
||
// TODO: figure out what to do with PAL
|
||
};
|
||
|
||
extern SVideoInitialize g_VideoInitialize;
|
||
// (mb2) for XFB update hack. TODO: find a static better place
|
||
extern volatile u32 g_XFBUpdateRequested;
|
||
|
||
void DebugLog(const char* _fmt, ...);
|
||
|
||
//////////////////////////////////////////////////////////////////////////
|
||
inline u8 *Memory_GetPtr(u32 _uAddress)
|
||
{
|
||
return g_VideoInitialize.pGetMemoryPointer(_uAddress);
|
||
}
|
||
|
||
inline u8 Memory_Read_U8(u32 _uAddress)
|
||
{
|
||
return *(u8*)g_VideoInitialize.pGetMemoryPointer(_uAddress);
|
||
}
|
||
|
||
inline u16 Memory_Read_U16(u32 _uAddress)
|
||
{
|
||
return Common::swap16(*(u16*)g_VideoInitialize.pGetMemoryPointer(_uAddress));
|
||
}
|
||
|
||
inline u32 Memory_Read_U32(u32 _uAddress)
|
||
{
|
||
return Common::swap32(*(u32*)g_VideoInitialize.pGetMemoryPointer(_uAddress));
|
||
}
|
||
//////////////////////////////////////////////////////////////////////////
|
||
inline u8* Memory_Read_U8_Ptr(u32 _uAddress)
|
||
{
|
||
return (u8*)g_VideoInitialize.pGetMemoryPointer(_uAddress);
|
||
}
|
||
|
||
inline u16* Memory_Read_U16_Unswapped_Ptr(u32 _uAddress)
|
||
{
|
||
return (u16*)g_VideoInitialize.pGetMemoryPointer(_uAddress);
|
||
}
|
||
|
||
inline u32* Memory_Read_U32_Unswapped_Ptr(u32 _uAddress)
|
||
{
|
||
return (u32*)g_VideoInitialize.pGetMemoryPointer(_uAddress);
|
||
}
|
||
//////////////////////////////////////////////////////////////////////////
|
||
|
||
inline float Memory_Read_Float(u32 _uAddress)
|
||
{
|
||
union {u32 i; float f;} temp;
|
||
temp.i = Memory_Read_U32(_uAddress);
|
||
return temp.f;
|
||
}
|
||
|
||
struct TRectangle
|
||
{
|
||
int left, top, right, bottom;
|
||
};
|
||
|
||
// Logging
|
||
// <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
||
void DebugLog(const char *_fmt, ...); // This one goes to the main program
|
||
void HandleGLError();
|
||
|
||
|
||
|
||
#ifdef _WIN32
|
||
#define PRIM_LOG(...) {DEBUG_LOG(VIDEO, __VA_ARGS__)}
|
||
#else
|
||
#define PRIM_LOG(...) {DEBUG_LOG(VIDEO, ##__VA_ARGS__)}
|
||
#endif
|
||
|
||
#ifdef LOGGING
|
||
#define LOG_VTX() PRIM_LOG("vtx: %f %f %f, ", ((float*)VertexManager::s_pCurBufferPointer)[0], ((float*)VertexManager::s_pCurBufferPointer)[1], ((float*)VertexManager::s_pCurBufferPointer)[2]);
|
||
#else
|
||
#define LOG_VTX()
|
||
#endif
|
||
|
||
#endif // _VIDEOCOMMON_H
|