Merge pull request #304 from r-a-sattarov/master
Added support for MCST Elbrus 2000 (e2k) architecture
This commit is contained in:
commit
d14b4df347
17
extern/poshlib/posh.h
vendored
17
extern/poshlib/posh.h
vendored
@ -87,6 +87,7 @@ GNU GCC/G++:
|
|||||||
- m68000: 68K
|
- m68000: 68K
|
||||||
- m68k: 68K
|
- m68k: 68K
|
||||||
- __palmos__: PalmOS
|
- __palmos__: PalmOS
|
||||||
|
- __e2k__: on MCST Elbrus 2000 processor platforms
|
||||||
|
|
||||||
Intel C/C++ Compiler:
|
Intel C/C++ Compiler:
|
||||||
- __ECC : compiler version, IA64 only
|
- __ECC : compiler version, IA64 only
|
||||||
@ -206,6 +207,11 @@ Metrowerks:
|
|||||||
LLVM:
|
LLVM:
|
||||||
- __llvm__
|
- __llvm__
|
||||||
- __clang__
|
- __clang__
|
||||||
|
|
||||||
|
LCC predefines the following:
|
||||||
|
- __LCC__:
|
||||||
|
if also defined e2k it is MCST eLbrus C Compiler
|
||||||
|
else it is Local (or Little) C Compiler
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -549,6 +555,11 @@ LLVM:
|
|||||||
# define POSH_CPU_STRING "PA-RISC"
|
# define POSH_CPU_STRING "PA-RISC"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined __e2k__
|
||||||
|
# define POSH_CPU_E2K 1
|
||||||
|
# define POSH_CPU_STRING "MCST Elbrus 2000"
|
||||||
|
#endif
|
||||||
|
|
||||||
#if !defined POSH_CPU_STRING
|
#if !defined POSH_CPU_STRING
|
||||||
# error POSH cannot determine target CPU
|
# error POSH cannot determine target CPU
|
||||||
# define POSH_CPU_STRING "Unknown" /* this is here for Doxygen's benefit */
|
# define POSH_CPU_STRING "Unknown" /* this is here for Doxygen's benefit */
|
||||||
@ -686,7 +697,7 @@ LLVM:
|
|||||||
** the MIPS series, so we have to be careful about those.
|
** the MIPS series, so we have to be careful about those.
|
||||||
** ----------------------------------------------------------------------------
|
** ----------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
#if defined POSH_CPU_X86 || defined POSH_CPU_AXP || defined POSH_CPU_STRONGARM || defined POSH_CPU_AARCH64 || defined POSH_OS_WIN32 || defined POSH_OS_WINCE || defined __MIPSEL__ || defined __ORDER_LITTLE_ENDIAN__
|
#if defined POSH_CPU_X86 || defined POSH_CPU_AXP || defined POSH_CPU_STRONGARM || defined POSH_CPU_AARCH64 || defined POSH_OS_WIN32 || defined POSH_OS_WINCE || defined __MIPSEL__ || defined __ORDER_LITTLE_ENDIAN__ || defined POSH_CPU_E2K
|
||||||
# define POSH_ENDIAN_STRING "little"
|
# define POSH_ENDIAN_STRING "little"
|
||||||
# define POSH_LITTLE_ENDIAN 1
|
# define POSH_LITTLE_ENDIAN 1
|
||||||
#else
|
#else
|
||||||
@ -714,7 +725,7 @@ LLVM:
|
|||||||
** for 64-bit support, we ignore the POSH_USE_LIMITS_H directive.
|
** for 64-bit support, we ignore the POSH_USE_LIMITS_H directive.
|
||||||
** ----------------------------------------------------------------------------
|
** ----------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
#if defined ( __LP64__ ) || defined ( __powerpc64__ ) || defined POSH_CPU_SPARC64
|
#if defined ( __LP64__ ) || defined ( __powerpc64__ ) || defined POSH_CPU_SPARC64 || defined POSH_CPU_E2K
|
||||||
# define POSH_64BIT_INTEGER 1
|
# define POSH_64BIT_INTEGER 1
|
||||||
typedef long posh_i64_t;
|
typedef long posh_i64_t;
|
||||||
typedef unsigned long posh_u64_t;
|
typedef unsigned long posh_u64_t;
|
||||||
@ -883,7 +894,7 @@ POSH_COMPILE_TIME_ASSERT(posh_i32_t, sizeof(posh_i32_t) == 4);
|
|||||||
# define POSH_64BIT_POINTER 1
|
# define POSH_64BIT_POINTER 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined POSH_CPU_SPARC64 || defined POSH_OS_WIN64 || defined __64BIT__ || defined __LP64 || defined _LP64 || defined __LP64__ || defined _ADDR64 || defined _CRAYC
|
#if defined POSH_CPU_SPARC64 || defined POSH_OS_WIN64 || defined __64BIT__ || defined __LP64 || defined _LP64 || defined __LP64__ || defined _ADDR64 || defined _CRAYC || defined POSH_CPU_E2K
|
||||||
# define POSH_64BIT_POINTER 1
|
# define POSH_64BIT_POINTER 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -668,6 +668,13 @@ namespace
|
|||||||
# elif NV_CPU_AARCH64
|
# elif NV_CPU_AARCH64
|
||||||
ucontext_t * ucp = (ucontext_t *)secret;
|
ucontext_t * ucp = (ucontext_t *)secret;
|
||||||
return (void *) ucp->uc_mcontext.pc;
|
return (void *) ucp->uc_mcontext.pc;
|
||||||
|
# elif NV_CPU_E2K /* MCST Elbrus 2000 */
|
||||||
|
// e2k has 3 stacks - Procedure Stack (PS), Procedure Chain Stack (PCS) and User Stack (US)
|
||||||
|
// CR0 and CR1 (Chain Register) are the 128-bit registers of the Procedure Chain Stack (PCS)
|
||||||
|
// CR's divided into _HI and _LO 64-bit parts (as in x86, for example, AX is divided into AH and AL)
|
||||||
|
// CR0_HI stores an Instruction Pointer
|
||||||
|
ucontext_t * ucp = (ucontext_t *)secret;
|
||||||
|
return (void *) ucp->uc_mcontext.cr0_hi;
|
||||||
# else
|
# else
|
||||||
# error "Unknown CPU"
|
# error "Unknown CPU"
|
||||||
# endif
|
# endif
|
||||||
|
@ -98,6 +98,7 @@
|
|||||||
// NV_CPU_PPC
|
// NV_CPU_PPC
|
||||||
// NV_CPU_ARM
|
// NV_CPU_ARM
|
||||||
// NV_CPU_ARM_64
|
// NV_CPU_ARM_64
|
||||||
|
// NV_CPU_E2K
|
||||||
|
|
||||||
#define NV_CPU_STRING POSH_CPU_STRING
|
#define NV_CPU_STRING POSH_CPU_STRING
|
||||||
|
|
||||||
@ -112,6 +113,8 @@
|
|||||||
# define NV_CPU_ARM 1
|
# define NV_CPU_ARM 1
|
||||||
#elif defined POSH_CPU_AARCH64
|
#elif defined POSH_CPU_AARCH64
|
||||||
# define NV_CPU_ARM_64 1
|
# define NV_CPU_ARM_64 1
|
||||||
|
#elif defined POSH_CPU_E2K
|
||||||
|
# define NV_CPU_E2K 1
|
||||||
#else
|
#else
|
||||||
# error "Unsupported CPU"
|
# error "Unsupported CPU"
|
||||||
#endif
|
#endif
|
||||||
|
@ -61,7 +61,7 @@ namespace nv {
|
|||||||
#elif POSH_CPU_STRONGARM || POSH_CPU_AARCH64
|
#elif POSH_CPU_STRONGARM || POSH_CPU_AARCH64
|
||||||
// need more specific cpu type for armv7?
|
// need more specific cpu type for armv7?
|
||||||
// also utilizes a full barrier
|
// also utilizes a full barrier
|
||||||
// currently treating laod like x86 - this could be wrong
|
// currently treating load like x86 - this could be wrong
|
||||||
|
|
||||||
// this is the easiest but slowest way to do this
|
// this is the easiest but slowest way to do this
|
||||||
nvCompilerReadWriteBarrier();
|
nvCompilerReadWriteBarrier();
|
||||||
@ -73,6 +73,16 @@ namespace nv {
|
|||||||
// also utilizes a full barrier
|
// also utilizes a full barrier
|
||||||
// currently treating load like x86 - this could be wrong
|
// currently treating load like x86 - this could be wrong
|
||||||
|
|
||||||
|
// this is the easiest but slowest way to do this
|
||||||
|
nvCompilerReadWriteBarrier();
|
||||||
|
uint32 ret = *ptr; // replace with ldrex?
|
||||||
|
nvCompilerReadWriteBarrier();
|
||||||
|
return ret;
|
||||||
|
#elif POSH_CPU_E2K
|
||||||
|
// need more specific cpu type for e2k?
|
||||||
|
// also utilizes a full barrier
|
||||||
|
// currently treating load like x86 - this could be wrong
|
||||||
|
|
||||||
// this is the easiest but slowest way to do this
|
// this is the easiest but slowest way to do this
|
||||||
nvCompilerReadWriteBarrier();
|
nvCompilerReadWriteBarrier();
|
||||||
uint32 ret = *ptr; // replace with ldrex?
|
uint32 ret = *ptr; // replace with ldrex?
|
||||||
@ -102,6 +112,11 @@ namespace nv {
|
|||||||
nvCompilerReadWriteBarrier();
|
nvCompilerReadWriteBarrier();
|
||||||
*ptr = value; //strex?
|
*ptr = value; //strex?
|
||||||
nvCompilerReadWriteBarrier();
|
nvCompilerReadWriteBarrier();
|
||||||
|
#elif POSH_CPU_E2K
|
||||||
|
// this is the easiest but slowest way to do this
|
||||||
|
nvCompilerReadWriteBarrier();
|
||||||
|
*ptr = value; //strex?
|
||||||
|
nvCompilerReadWriteBarrier();
|
||||||
#else
|
#else
|
||||||
#error "Atomics not implemented."
|
#error "Atomics not implemented."
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user