diff options
author | Jiyoung Yun <jy910.yun@samsung.com> | 2016-12-27 16:46:08 +0900 |
---|---|---|
committer | Jiyoung Yun <jy910.yun@samsung.com> | 2016-12-27 16:46:08 +0900 |
commit | db20f3f1bb8595633a7e16c8900fd401a453a6b5 (patch) | |
tree | e5435159cd1bf0519276363a6fe1663d1721bed3 /src/pal/inc/pal.h | |
parent | 4b4aad7217d3292650e77eec2cf4c198ea9c3b4b (diff) | |
download | coreclr-db20f3f1bb8595633a7e16c8900fd401a453a6b5.tar.gz coreclr-db20f3f1bb8595633a7e16c8900fd401a453a6b5.tar.bz2 coreclr-db20f3f1bb8595633a7e16c8900fd401a453a6b5.zip |
Imported Upstream version 1.0.0.9127upstream/1.0.0.9127
Diffstat (limited to 'src/pal/inc/pal.h')
-rw-r--r-- | src/pal/inc/pal.h | 196 |
1 files changed, 88 insertions, 108 deletions
diff --git a/src/pal/inc/pal.h b/src/pal/inc/pal.h index 260528285e..0d7c89e6fa 100644 --- a/src/pal/inc/pal.h +++ b/src/pal/inc/pal.h @@ -331,7 +331,7 @@ typedef char * va_list; PALIMPORT BOOL PALAPI -PAL_IsDebuggerPresent(); +PAL_IsDebuggerPresent(VOID); #define MAXIMUM_SUSPEND_COUNT MAXCHAR @@ -507,7 +507,7 @@ PAL_Initialize( PALIMPORT int PALAPI -PAL_InitializeDLL(); +PAL_InitializeDLL(VOID); PALIMPORT DWORD @@ -581,7 +581,7 @@ PAL_UnregisterForRuntimeStartup( PALIMPORT BOOL PALAPI -PAL_NotifyRuntimeStarted(); +PAL_NotifyRuntimeStarted(VOID); static const int MAX_DEBUGGER_TRANSPORT_PIPE_NAME_LENGTH = 64; @@ -648,6 +648,13 @@ PAL_DeleteExecWatchpoint( #endif +PALIMPORT +BOOL +PALAPI +PAL_ProbeMemory( + PVOID pBuffer, + DWORD cbBuffer, + BOOL fWriteAccess); /******************* winuser.h Entrypoints *******************************/ @@ -671,28 +678,6 @@ CharNextExA( #endif -PALIMPORT -int -PALAPIV -wsprintfA( - OUT LPSTR, - IN LPCSTR, - ...); - -PALIMPORT -int -PALAPIV -wsprintfW( - OUT LPWSTR, - IN LPCWSTR, - ...); - -#ifdef UNICODE -#define wsprintf wsprintfW -#else -#define wsprintf wsprintfA -#endif - #define MB_OK 0x00000000L #define MB_OKCANCEL 0x00000001L #define MB_ABORTRETRYIGNORE 0x00000002L @@ -1853,6 +1838,13 @@ QueueUserAPC( #define MAXIMUM_SUPPORTED_EXTENSION 512 +#define CONTEXT_XSTATE (CONTEXT_i386 | 0x40L) + +#define CONTEXT_EXCEPTION_ACTIVE 0x8000000L +#define CONTEXT_SERVICE_ACTIVE 0x10000000L +#define CONTEXT_EXCEPTION_REQUEST 0x40000000L +#define CONTEXT_EXCEPTION_REPORTING 0x80000000L + typedef struct _FLOATING_SAVE_AREA { DWORD ControlWord; DWORD StatusWord; @@ -1911,6 +1903,16 @@ typedef struct _CONTEXT { // support any other values in the ExtendedRegisters) but we might as well be as accurate as we can. #define CONTEXT_EXREG_XMM_OFFSET 160 +typedef struct _KNONVOLATILE_CONTEXT_POINTERS { + + // TODO WIP x86/Linux, need to fix this. + PDWORD Ebx; + PDWORD Esi; + PDWORD Edi; + PDWORD Ebp; + +} KNONVOLATILE_CONTEXT_POINTERS, *PKNONVOLATILE_CONTEXT_POINTERS; + #elif defined(_PPC_) // @@ -3256,22 +3258,22 @@ TlsFree( PALIMPORT void * PALAPI -PAL_GetStackBase(); +PAL_GetStackBase(VOID); PALIMPORT void * PALAPI -PAL_GetStackLimit(); +PAL_GetStackLimit(VOID); PALIMPORT DWORD PALAPI -PAL_GetLogicalCpuCountFromOS(); +PAL_GetLogicalCpuCountFromOS(VOID); PALIMPORT size_t PALAPI -PAL_GetLogicalProcessorCacheSizeFromOS(); +PAL_GetLogicalProcessorCacheSizeFromOS(VOID); typedef BOOL (*ReadMemoryWordCallback)(SIZE_T address, SIZE_T *value); @@ -3304,6 +3306,8 @@ PALIMPORT BOOL PALAPI PAL_VirtualUnwindOutOfProc(CONTEXT *context, #define PAL_CS_NATIVE_DATA_SIZE 80 #elif defined(__linux__) && defined(_ARM64_) #define PAL_CS_NATIVE_DATA_SIZE 116 +#elif defined(__linux__) && defined(__i386__) +#define PAL_CS_NATIVE_DATA_SIZE 76 #elif defined(__linux__) && defined(__x86_64__) #define PAL_CS_NATIVE_DATA_SIZE 96 #elif defined(__NetBSD__) && defined(__amd64__) @@ -3656,16 +3660,6 @@ VirtualQuery( IN SIZE_T dwLength); PALIMPORT -BOOL -PALAPI -ReadProcessMemory( - IN HANDLE hProcess, - IN LPCVOID lpBaseAddress, - OUT LPVOID lpBuffer, - IN SIZE_T nSize, - OUT SIZE_T * lpNumberOfBytesRead); - -PALIMPORT VOID PALAPI RtlMoveMemory( @@ -4712,19 +4706,12 @@ enum { // typedef struct _RUNTIME_FUNCTION { DWORD BeginAddress; +#ifdef _AMD64_ DWORD EndAddress; +#endif DWORD UnwindData; } RUNTIME_FUNCTION, *PRUNTIME_FUNCTION; -PALIMPORT -BOOL -PALAPI -WriteProcessMemory(IN HANDLE hProcess, - IN LPVOID lpBaseAddress, - IN LPCVOID lpBuffer, - IN SIZE_T nSize, - OUT SIZE_T * lpNumberOfBytesWritten); - #define STANDARD_RIGHTS_REQUIRED (0x000F0000L) #define SYNCHRONIZE (0x00100000L) #define READ_CONTROL (0x00020000L) @@ -4801,28 +4788,6 @@ DebugBreak( VOID); PALIMPORT -LPWSTR -PALAPI -lstrcatW( - IN OUT LPWSTR lpString1, - IN LPCWSTR lpString2); - -#ifdef UNICODE -#define lstrcat lstrcatW -#endif - -PALIMPORT -LPWSTR -PALAPI -lstrcpyW( - OUT LPWSTR lpString1, - IN LPCWSTR lpString2); - -#ifdef UNICODE -#define lstrcpy lstrcpyW -#endif - -PALIMPORT int PALAPI lstrlenA( @@ -4841,19 +4806,6 @@ lstrlenW( #endif PALIMPORT -LPWSTR -PALAPI -lstrcpynW( - OUT LPWSTR lpString1, - IN LPCWSTR lpString2, - IN int iMaxLength); - -#ifdef UNICODE -#define lstrcpyn lstrcpynW -#endif - - -PALIMPORT DWORD PALAPI GetEnvironmentVariableW( @@ -4937,7 +4889,7 @@ GetTickCount( PALIMPORT ULONGLONG PALAPI -GetTickCount64(); +GetTickCount64(VOID); PALIMPORT BOOL @@ -5377,7 +5329,7 @@ YieldProcessor( PALIMPORT DWORD PALAPI -GetCurrentProcessorNumber(); +GetCurrentProcessorNumber(VOID); /*++ Function: @@ -5389,7 +5341,7 @@ Checks if GetCurrentProcessorNumber is available in the current environment PALIMPORT BOOL PALAPI -PAL_HasGetCurrentProcessorNumber(); +PAL_HasGetCurrentProcessorNumber(VOID); #define FORMAT_MESSAGE_ALLOCATE_BUFFER 0x00000100 #define FORMAT_MESSAGE_IGNORE_INSERTS 0x00000200 @@ -5475,7 +5427,7 @@ ResetWriteWatch( PALIMPORT VOID PALAPI -FlushProcessWriteBuffers(); +FlushProcessWriteBuffers(VOID); typedef void (*PAL_ActivationFunction)(CONTEXT *context); typedef BOOL (*PAL_SafeActivationCheckFunction)(SIZE_T ip, BOOL checkingCurrentThread); @@ -5715,9 +5667,7 @@ CoCreateGuid(OUT GUID * pguid); #define printf PAL_printf #define vprintf PAL_vprintf #define wprintf PAL_wprintf -#define sprintf PAL_sprintf #define swprintf PAL_swprintf -#define sscanf PAL_sscanf #define wcsspn PAL_wcsspn #define wcstod PAL_wcstod #define wcstol PAL_wcstol @@ -5791,6 +5741,13 @@ CoCreateGuid(OUT GUID * pguid); #define log PAL_log #define log10 PAL_log10 #define pow PAL_pow +#define acosf PAL_acosf +#define asinf PAL_asinf +#define atan2f PAL_atan2f +#define expf PAL_expf +#define logf PAL_logf +#define log10f PAL_log10f +#define powf PAL_powf #define malloc PAL_malloc #define free PAL_free #define mkstemp PAL_mkstemp @@ -5802,6 +5759,7 @@ CoCreateGuid(OUT GUID * pguid); #define _wcstoui64 PAL__wcstoui64 #define _flushall PAL__flushall #define _vsnprintf PAL__vsnprintf +#define strnlen PAL_strnlen #ifdef _AMD64_ #define _mm_getcsr PAL__mm_getcsr @@ -5878,9 +5836,7 @@ PALIMPORT char * __cdecl strstr(const char *, const char *); PALIMPORT char * __cdecl strtok(char *, const char *); PALIMPORT size_t __cdecl strspn(const char *, const char *); PALIMPORT size_t __cdecl strcspn(const char *, const char *); -PALIMPORT int __cdecl sprintf(char *, const char *, ...); PALIMPORT int __cdecl vsprintf(char *, const char *, va_list); -PALIMPORT int __cdecl sscanf(const char *, const char *, ...); PALIMPORT int __cdecl atoi(const char *); PALIMPORT LONG __cdecl atol(const char *); PALIMPORT ULONG __cdecl strtoul(const char *, char **, int); @@ -5899,23 +5855,35 @@ PALIMPORT int __cdecl toupper(int); #endif // PAL_STDCPP_COMPAT +/* _TRUNCATE */ +#if !defined(_TRUNCATE) +#define _TRUNCATE ((size_t)-1) +#endif + PALIMPORT errno_t __cdecl memcpy_s(void *, size_t, const void *, size_t); PALIMPORT errno_t __cdecl memmove_s(void *, size_t, const void *, size_t); PALIMPORT char * __cdecl _strlwr(char *); PALIMPORT int __cdecl _stricmp(const char *, const char *); -PALIMPORT int __cdecl _snprintf(char *, size_t, const char *, ...); +PALIMPORT int __cdecl vsprintf_s(char *, size_t, const char *, va_list); PALIMPORT char * __cdecl _gcvt_s(char *, int, double, int); PALIMPORT char * __cdecl _ecvt(double, int, int *, int *); PALIMPORT int __cdecl __iscsym(int); -PALIMPORT size_t __cdecl _mbslen(const unsigned char *); PALIMPORT unsigned char * __cdecl _mbsinc(const unsigned char *); PALIMPORT unsigned char * __cdecl _mbsninc(const unsigned char *, size_t); PALIMPORT unsigned char * __cdecl _mbsdec(const unsigned char *, const unsigned char *); PALIMPORT int __cdecl _wcsicmp(const WCHAR *, const WCHAR*); PALIMPORT int __cdecl _wcsnicmp(const WCHAR *, const WCHAR *, size_t); PALIMPORT int __cdecl _vsnprintf(char *, size_t, const char *, va_list); -PALIMPORT int __cdecl _vsnwprintf(WCHAR *, size_t, const WCHAR *, va_list); -PALIMPORT WCHAR * __cdecl _itow(int, WCHAR *, int); +PALIMPORT int __cdecl _vsnprintf_s(char *, size_t, size_t, const char *, va_list); +PALIMPORT int __cdecl _vsnwprintf_s(WCHAR *, size_t, size_t, const WCHAR *, va_list); +PALIMPORT int __cdecl _snwprintf_s(WCHAR *, size_t, size_t, const WCHAR *, ...); +PALIMPORT int __cdecl _snprintf_s(char *, size_t, size_t, const char *, ...); +PALIMPORT int __cdecl sprintf_s(char *, size_t, const char *, ... ); +PALIMPORT int __cdecl swprintf_s(WCHAR *, size_t, const WCHAR *, ... ); +PALIMPORT int __cdecl _snwprintf_s(WCHAR *, size_t, size_t, const WCHAR *, ...); +PALIMPORT int __cdecl vswprintf_s( WCHAR *, size_t, const WCHAR *, va_list); +PALIMPORT int __cdecl sscanf_s(const char *, const char *, ...); +PALIMPORT errno_t __cdecl _itow_s(int, WCHAR *, size_t, int); PALIMPORT size_t __cdecl PAL_wcslen(const WCHAR *); PALIMPORT int __cdecl PAL_wcscmp(const WCHAR*, const WCHAR*); @@ -5933,7 +5901,6 @@ PALIMPORT size_t __cdecl PAL_wcscspn(const WCHAR *, const WCHAR *); PALIMPORT int __cdecl PAL_swprintf(WCHAR *, const WCHAR *, ...); PALIMPORT int __cdecl PAL_vswprintf(WCHAR *, const WCHAR *, va_list); PALIMPORT int __cdecl PAL__vsnprintf(LPSTR Buffer, size_t Count, LPCSTR Format, va_list ap); -PALIMPORT int __cdecl _snwprintf(WCHAR *, size_t, const WCHAR *, ...); PALIMPORT int __cdecl PAL_swscanf(const WCHAR *, const WCHAR *, ...); PALIMPORT LONG __cdecl PAL_wcstol(const WCHAR *, WCHAR **, int); PALIMPORT ULONG __cdecl PAL_wcstoul(const WCHAR *, WCHAR **, int); @@ -5950,8 +5917,7 @@ PALIMPORT WCHAR __cdecl PAL_towupper(WCHAR); PALIMPORT WCHAR * __cdecl _wcslwr(WCHAR *); PALIMPORT ULONGLONG _wcstoui64(const WCHAR *, WCHAR **, int); -PALIMPORT WCHAR * __cdecl _i64tow(__int64, WCHAR *, int); -PALIMPORT WCHAR * __cdecl _ui64tow(unsigned __int64, WCHAR *, int); +PALIMPORT errno_t __cdecl _i64tow_s(long long, WCHAR *, size_t, int); PALIMPORT int __cdecl _wtoi(const WCHAR *); #ifdef __cplusplus @@ -6039,9 +6005,29 @@ PALIMPORT double __cdecl sqrt(double); PALIMPORT double __cdecl tan(double); PALIMPORT double __cdecl tanh(double); +PALIMPORT int __cdecl _finitef(float); +PALIMPORT int __cdecl _isnanf(float); +PALIMPORT float __cdecl _copysignf(float, float); +PALIMPORT float __cdecl acosf(float); +PALIMPORT float __cdecl asinf(float); +PALIMPORT float __cdecl atanf(float); +PALIMPORT float __cdecl atan2f(float, float); +PALIMPORT float __cdecl ceilf(float); +PALIMPORT float __cdecl cosf(float); +PALIMPORT float __cdecl coshf(float); +PALIMPORT float __cdecl expf(float); PALIMPORT float __cdecl fabsf(float); +PALIMPORT float __cdecl floorf(float); PALIMPORT float __cdecl fmodf(float, float); +PALIMPORT float __cdecl logf(float); +PALIMPORT float __cdecl log10f(float); PALIMPORT float __cdecl modff(float, float*); +PALIMPORT float __cdecl powf(float, float); +PALIMPORT float __cdecl sinf(float); +PALIMPORT float __cdecl sinhf(float); +PALIMPORT float __cdecl sqrtf(float); +PALIMPORT float __cdecl tanf(float); +PALIMPORT float __cdecl tanhf(float); #ifndef PAL_STDCPP_COMPAT @@ -6086,14 +6072,8 @@ PALIMPORT void __cdecl qsort(void *, size_t, size_t, int (__cdecl *)(const void PALIMPORT void * __cdecl bsearch(const void *, const void *, size_t, size_t, int (__cdecl *)(const void *, const void *)); -PALIMPORT void __cdecl _splitpath(const char *, char *, char *, char *, char *); -PALIMPORT void __cdecl _wsplitpath(const WCHAR *, WCHAR *, WCHAR *, WCHAR *, WCHAR *); -PALIMPORT void __cdecl _makepath(char *, const char *, const char *, const char *, const char *); -PALIMPORT void __cdecl _wmakepath(WCHAR *, const WCHAR *, const WCHAR *, const WCHAR *, const WCHAR *); PALIMPORT char * __cdecl _fullpath(char *, const char *, size_t); -PALIMPORT void __cdecl _swab(char *, char *, int); - #ifndef PAL_STDCPP_COMPAT PALIMPORT time_t __cdecl time(time_t *); @@ -6307,14 +6287,14 @@ PAL_Enter(PAL_Boundary boundary); PALIMPORT BOOL PALAPI -PAL_HasEntered(); +PAL_HasEntered(VOID); // Equivalent to PAL_Enter(PAL_BoundaryTop) and is for stub // code generation use. PALIMPORT DWORD PALAPI -PAL_EnterTop(); +PAL_EnterTop(VOID); // This function needs to be called on a thread when it enters // a region of code that depends on this instance of the PAL @@ -6349,14 +6329,14 @@ PAL_Leave(PAL_Boundary boundary); PALIMPORT VOID PALAPI -PAL_LeaveBottom(); +PAL_LeaveBottom(VOID); // This function is equivalent to PAL_Leave(PAL_BoundaryTop) // and is available to limit the creation of stub code. PALIMPORT VOID PALAPI -PAL_LeaveTop(); +PAL_LeaveTop(VOID); #ifdef __cplusplus // |