mirror of
https://github.com/reactos/reactos.git
synced 2025-01-12 17:16:58 +00:00
Better support for non X86 systems
svn path=/trunk/; revision=25264
This commit is contained in:
parent
4afb3f0181
commit
f9b6e910f9
12 changed files with 64 additions and 50 deletions
|
@ -68,6 +68,7 @@
|
|||
<file>pixel.c</file>
|
||||
<file>video.c</file>
|
||||
</directory>
|
||||
<if property="ARCH" value="i386">
|
||||
<directory name="windows">
|
||||
<file>conversion.c</file>
|
||||
<file>peloader.c</file>
|
||||
|
@ -75,6 +76,7 @@
|
|||
<file>wlmemory.c</file>
|
||||
<file>wlregistry.c</file>
|
||||
</directory>
|
||||
</if>
|
||||
<file>freeldr.c</file>
|
||||
<file>debug.c</file>
|
||||
<file>version.c</file>
|
||||
|
|
|
@ -5219,6 +5219,31 @@ typedef struct _KFLOATING_SAVE {
|
|||
ULONG Spare1;
|
||||
} KFLOATING_SAVE, *PKFLOATING_SAVE;
|
||||
|
||||
static __inline
|
||||
ULONG
|
||||
DDKAPI
|
||||
KeGetCurrentProcessorNumber(VOID)
|
||||
{
|
||||
#if defined(__GNUC__)
|
||||
ULONG ret;
|
||||
__asm__ __volatile__ (
|
||||
"movl %%fs:%c1, %0\n"
|
||||
: "=r" (ret)
|
||||
: "i" (FIELD_OFFSET(KPCR, Number))
|
||||
);
|
||||
return ret;
|
||||
#elif defined(_MSC_VER)
|
||||
#if _MSC_FULL_VER >= 13012035
|
||||
return (ULONG)__readfsbyte(FIELD_OFFSET(KPCR, Number));
|
||||
#else
|
||||
__asm { movzx eax, _PCR KPCR.Number }
|
||||
#endif
|
||||
#else
|
||||
#error Unknown compiler
|
||||
#endif
|
||||
}
|
||||
#endif /* _X86_ */
|
||||
|
||||
#define PAGE_SIZE 0x1000
|
||||
#define PAGE_SHIFT 12L
|
||||
|
||||
|
@ -5296,30 +5321,6 @@ DDKAPI
|
|||
KeGetCurrentIrql(
|
||||
VOID);
|
||||
|
||||
static __inline
|
||||
ULONG
|
||||
DDKAPI
|
||||
KeGetCurrentProcessorNumber(VOID)
|
||||
{
|
||||
#if defined(__GNUC__)
|
||||
ULONG ret;
|
||||
__asm__ __volatile__ (
|
||||
"movl %%fs:%c1, %0\n"
|
||||
: "=r" (ret)
|
||||
: "i" (FIELD_OFFSET(KPCR, Number))
|
||||
);
|
||||
return ret;
|
||||
#elif defined(_MSC_VER)
|
||||
#if _MSC_FULL_VER >= 13012035
|
||||
return (ULONG)__readfsbyte(FIELD_OFFSET(KPCR, Number));
|
||||
#else
|
||||
__asm { movzx eax, _PCR KPCR.Number }
|
||||
#endif
|
||||
#else
|
||||
#error Unknown compiler
|
||||
#endif
|
||||
}
|
||||
|
||||
#if !defined(__INTERLOCKED_DECLARED)
|
||||
#define __INTERLOCKED_DECLARED
|
||||
|
||||
|
@ -5416,8 +5417,6 @@ KfReleaseSpinLock(
|
|||
|
||||
#define KeGetDcacheFillSize() 1L
|
||||
|
||||
#endif /* _X86_ */
|
||||
|
||||
|
||||
|
||||
/*
|
||||
|
@ -10579,13 +10578,13 @@ DbgBreakPointWithStatus(
|
|||
IN ULONG Status);
|
||||
|
||||
ULONG
|
||||
__cdecl
|
||||
DDKCDECLAPI
|
||||
DbgPrint(
|
||||
IN PCCH Format,
|
||||
IN ...);
|
||||
|
||||
ULONG
|
||||
__cdecl
|
||||
DDKCDECLAPI
|
||||
DbgPrintEx(
|
||||
IN ULONG ComponentId,
|
||||
IN ULONG Level,
|
||||
|
|
|
@ -34,7 +34,7 @@ Author:
|
|||
//
|
||||
// Sanity checks for Paging Macros
|
||||
//
|
||||
#ifndef __GNUC__
|
||||
#ifdef C_ASSERT
|
||||
C_ASSERT(PAGE_SIZE == (1 << PAGE_SHIFT));
|
||||
C_ASSERT(MM_ALLOCATION_GRANULARITY == (1 << MM_ALLOCATION_GRANULARITY_SHIFT));
|
||||
C_ASSERT(MM_ALLOCATION_GRANULARITY &&
|
||||
|
|
|
@ -229,6 +229,7 @@ NtCreateThread(
|
|||
);
|
||||
|
||||
#ifndef NTOS_MODE_USER
|
||||
#if defined(_M_IX86)
|
||||
FORCEINLINE
|
||||
PTEB
|
||||
NtCurrentTeb(VOID)
|
||||
|
@ -248,6 +249,9 @@ NtCurrentTeb(VOID)
|
|||
#endif
|
||||
}
|
||||
#endif
|
||||
#else
|
||||
struct _TEB * NtCurrentTeb(void);
|
||||
#endif
|
||||
|
||||
NTSYSCALLAPI
|
||||
NTSTATUS
|
||||
|
|
|
@ -1216,7 +1216,7 @@ typedef struct _EPROCESS
|
|||
#endif
|
||||
union
|
||||
{
|
||||
HARDWARE_PTE_X86 PagedirectoryPte;
|
||||
HARDWARE_PTE PagedirectoryPte;
|
||||
ULONGLONG Filler;
|
||||
};
|
||||
ULONG Session;
|
||||
|
|
|
@ -138,7 +138,7 @@ Author:
|
|||
HEAP_CREATE_ALIGN_16 | \
|
||||
HEAP_CREATE_ENABLE_TRACING | \
|
||||
HEAP_CREATE_ENABLE_EXECUTE)
|
||||
#ifndef __GNUC__
|
||||
#ifdef C_ASSERT
|
||||
C_ASSERT(HEAP_CREATE_VALID_MASK == 0x0007F0FF);
|
||||
#endif
|
||||
|
||||
|
|
|
@ -29,6 +29,7 @@ unsigned int __cpu_features = 0;
|
|||
|
||||
void __cpu_features_init (void)
|
||||
{
|
||||
#ifdef __i386__
|
||||
unsigned int eax, ebx, ecx, edx;
|
||||
/* Try to change the value of CPUID bit (bit 21) in EFLAGS.
|
||||
If the bit can be toggled, CPUID is supported. */
|
||||
|
@ -75,8 +76,7 @@ void __cpu_features_init (void)
|
|||
__cpu_features |= _CRT_3DNOW;
|
||||
if (edx & EDX_3DNOWP)
|
||||
__cpu_features |= _CRT_3DNOWP;
|
||||
|
||||
return;
|
||||
#endif
|
||||
}
|
||||
|
||||
#ifdef TEST
|
||||
|
|
|
@ -218,7 +218,11 @@ __mingw_wCRTStartup (void)
|
|||
|
||||
/* Align the stack to 16 bytes for the sake of SSE ops in main
|
||||
or in functions inlined into main. */
|
||||
#if defined(__i386__)
|
||||
asm __volatile__ ("andl $-16, %%esp" : : : "%esp");
|
||||
#else
|
||||
#error Unsupported architecture
|
||||
#endif
|
||||
|
||||
/*
|
||||
* Call the main function. If the user does not supply one
|
||||
|
|
|
@ -1,8 +1,10 @@
|
|||
<module name="pseh" type="staticlibrary">
|
||||
<define name="__USE_W32API" />
|
||||
<if property="ARCH" value="i386">
|
||||
<directory name="i386">
|
||||
<file>framebased.asm</file>
|
||||
<file>setjmp.asm</file>
|
||||
</directory>
|
||||
</if>
|
||||
<file>framebased.c</file>
|
||||
</module>
|
||||
|
|
|
@ -104,7 +104,6 @@ RosSymGetAddressInformation(PROSSYM_INFO RosSymInfo,
|
|||
if (RosSymInfo->Symbols == NULL || RosSymInfo->SymbolsCount == 0 ||
|
||||
RosSymInfo->Strings == NULL || RosSymInfo->StringsLength == 0)
|
||||
{
|
||||
__asm__("int $3\n");
|
||||
DPRINT1("Uninitialized RosSymInfo\n");
|
||||
return FALSE;
|
||||
}
|
||||
|
|
|
@ -858,6 +858,10 @@ IopInitializeBuiltinDriver(
|
|||
{
|
||||
FileNameWithoutPath = ModuleName->Buffer;
|
||||
}
|
||||
else
|
||||
{
|
||||
FileNameWithoutPath++;
|
||||
}
|
||||
|
||||
/*
|
||||
* Load the module
|
||||
|
|
Loading…
Reference in a new issue