server: Add ARM64 support.
This commit is contained in:
parent
a431f83ec1
commit
d11e72f925
|
@ -102,6 +102,8 @@ static const enum cpu_type client_cpu = CPU_POWERPC;
|
||||||
static const enum cpu_type client_cpu = CPU_SPARC;
|
static const enum cpu_type client_cpu = CPU_SPARC;
|
||||||
#elif defined(__arm__)
|
#elif defined(__arm__)
|
||||||
static const enum cpu_type client_cpu = CPU_ARM;
|
static const enum cpu_type client_cpu = CPU_ARM;
|
||||||
|
#elif defined(__aarch64__)
|
||||||
|
static const enum cpu_type client_cpu = CPU_ARM64;
|
||||||
#else
|
#else
|
||||||
#error Unsupported CPU
|
#error Unsupported CPU
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -129,7 +129,7 @@ typedef union
|
||||||
|
|
||||||
enum cpu_type
|
enum cpu_type
|
||||||
{
|
{
|
||||||
CPU_x86, CPU_x86_64, CPU_POWERPC, CPU_ARM, CPU_SPARC
|
CPU_x86, CPU_x86_64, CPU_POWERPC, CPU_ARM, CPU_ARM64, CPU_SPARC
|
||||||
};
|
};
|
||||||
typedef int cpu_type_t;
|
typedef int cpu_type_t;
|
||||||
|
|
||||||
|
@ -145,6 +145,7 @@ typedef struct
|
||||||
unsigned int cs, ss, flags, __pad; } x86_64_regs;
|
unsigned int cs, ss, flags, __pad; } x86_64_regs;
|
||||||
struct { unsigned int iar, msr, ctr, lr, dar, dsisr, trap, __pad; } powerpc_regs;
|
struct { unsigned int iar, msr, ctr, lr, dar, dsisr, trap, __pad; } powerpc_regs;
|
||||||
struct { unsigned int sp, lr, pc, cpsr; } arm_regs;
|
struct { unsigned int sp, lr, pc, cpsr; } arm_regs;
|
||||||
|
struct { unsigned __int64 sp, pc, pstate; } arm64_regs;
|
||||||
struct { unsigned int psr, pc, npc, y, wim, tbr; } sparc_regs;
|
struct { unsigned int psr, pc, npc, y, wim, tbr; } sparc_regs;
|
||||||
} ctl;
|
} ctl;
|
||||||
union
|
union
|
||||||
|
@ -154,6 +155,7 @@ typedef struct
|
||||||
r8, r9, r10, r11, r12, r13, r14, r15; } x86_64_regs;
|
r8, r9, r10, r11, r12, r13, r14, r15; } x86_64_regs;
|
||||||
struct { unsigned int gpr[32], cr, xer; } powerpc_regs;
|
struct { unsigned int gpr[32], cr, xer; } powerpc_regs;
|
||||||
struct { unsigned int r[13]; } arm_regs;
|
struct { unsigned int r[13]; } arm_regs;
|
||||||
|
struct { unsigned __int64 x[31]; } arm64_regs;
|
||||||
struct { unsigned int g[8], o[8], l[8], i[8]; } sparc_regs;
|
struct { unsigned int g[8], o[8], l[8], i[8]; } sparc_regs;
|
||||||
} integer;
|
} integer;
|
||||||
union
|
union
|
||||||
|
@ -5713,6 +5715,6 @@ union generic_reply
|
||||||
struct set_suspend_context_reply set_suspend_context_reply;
|
struct set_suspend_context_reply set_suspend_context_reply;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define SERVER_PROTOCOL_VERSION 437
|
#define SERVER_PROTOCOL_VERSION 438
|
||||||
|
|
||||||
#endif /* __WINE_WINE_SERVER_PROTOCOL_H */
|
#endif /* __WINE_WINE_SERVER_PROTOCOL_H */
|
||||||
|
|
|
@ -145,7 +145,7 @@ typedef union
|
||||||
/* supported CPU types */
|
/* supported CPU types */
|
||||||
enum cpu_type
|
enum cpu_type
|
||||||
{
|
{
|
||||||
CPU_x86, CPU_x86_64, CPU_POWERPC, CPU_ARM, CPU_SPARC
|
CPU_x86, CPU_x86_64, CPU_POWERPC, CPU_ARM, CPU_ARM64, CPU_SPARC
|
||||||
};
|
};
|
||||||
typedef int cpu_type_t;
|
typedef int cpu_type_t;
|
||||||
|
|
||||||
|
@ -161,6 +161,7 @@ typedef struct
|
||||||
unsigned int cs, ss, flags, __pad; } x86_64_regs;
|
unsigned int cs, ss, flags, __pad; } x86_64_regs;
|
||||||
struct { unsigned int iar, msr, ctr, lr, dar, dsisr, trap, __pad; } powerpc_regs;
|
struct { unsigned int iar, msr, ctr, lr, dar, dsisr, trap, __pad; } powerpc_regs;
|
||||||
struct { unsigned int sp, lr, pc, cpsr; } arm_regs;
|
struct { unsigned int sp, lr, pc, cpsr; } arm_regs;
|
||||||
|
struct { unsigned __int64 sp, pc, pstate; } arm64_regs;
|
||||||
struct { unsigned int psr, pc, npc, y, wim, tbr; } sparc_regs;
|
struct { unsigned int psr, pc, npc, y, wim, tbr; } sparc_regs;
|
||||||
} ctl; /* selected by SERVER_CTX_CONTROL */
|
} ctl; /* selected by SERVER_CTX_CONTROL */
|
||||||
union
|
union
|
||||||
|
@ -170,6 +171,7 @@ typedef struct
|
||||||
r8, r9, r10, r11, r12, r13, r14, r15; } x86_64_regs;
|
r8, r9, r10, r11, r12, r13, r14, r15; } x86_64_regs;
|
||||||
struct { unsigned int gpr[32], cr, xer; } powerpc_regs;
|
struct { unsigned int gpr[32], cr, xer; } powerpc_regs;
|
||||||
struct { unsigned int r[13]; } arm_regs;
|
struct { unsigned int r[13]; } arm_regs;
|
||||||
|
struct { unsigned __int64 x[31]; } arm64_regs;
|
||||||
struct { unsigned int g[8], o[8], l[8], i[8]; } sparc_regs;
|
struct { unsigned int g[8], o[8], l[8], i[8]; } sparc_regs;
|
||||||
} integer; /* selected by SERVER_CTX_INTEGER */
|
} integer; /* selected by SERVER_CTX_INTEGER */
|
||||||
union
|
union
|
||||||
|
|
|
@ -63,6 +63,8 @@ static const unsigned int supported_cpus = CPU_FLAG(CPU_POWERPC);
|
||||||
static const unsigned int supported_cpus = CPU_FLAG(CPU_SPARC);
|
static const unsigned int supported_cpus = CPU_FLAG(CPU_SPARC);
|
||||||
#elif defined(__arm__)
|
#elif defined(__arm__)
|
||||||
static const unsigned int supported_cpus = CPU_FLAG(CPU_ARM);
|
static const unsigned int supported_cpus = CPU_FLAG(CPU_ARM);
|
||||||
|
#elif defined(__aarch64__)
|
||||||
|
static const unsigned int supported_cpus = CPU_FLAG(CPU_ARM64);
|
||||||
#else
|
#else
|
||||||
#error Unsupported CPU
|
#error Unsupported CPU
|
||||||
#endif
|
#endif
|
||||||
|
@ -1023,6 +1025,7 @@ static unsigned int get_context_system_regs( enum cpu_type cpu )
|
||||||
case CPU_x86_64: return SERVER_CTX_DEBUG_REGISTERS;
|
case CPU_x86_64: return SERVER_CTX_DEBUG_REGISTERS;
|
||||||
case CPU_POWERPC: return 0;
|
case CPU_POWERPC: return 0;
|
||||||
case CPU_ARM: return 0;
|
case CPU_ARM: return 0;
|
||||||
|
case CPU_ARM64: return 0;
|
||||||
case CPU_SPARC: return 0;
|
case CPU_SPARC: return 0;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -1056,6 +1059,9 @@ void break_thread( struct thread *thread )
|
||||||
case CPU_ARM:
|
case CPU_ARM:
|
||||||
data.exception.address = thread->context->ctl.arm_regs.pc;
|
data.exception.address = thread->context->ctl.arm_regs.pc;
|
||||||
break;
|
break;
|
||||||
|
case CPU_ARM64:
|
||||||
|
data.exception.address = thread->context->ctl.arm64_regs.pc;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
generate_debug_event( thread, EXCEPTION_DEBUG_EVENT, &data );
|
generate_debug_event( thread, EXCEPTION_DEBUG_EVENT, &data );
|
||||||
thread->debug_break = 0;
|
thread->debug_break = 0;
|
||||||
|
|
|
@ -557,6 +557,48 @@ static void dump_varargs_context( const char *prefix, data_size_t size )
|
||||||
if (ctx.flags & SERVER_CTX_INTEGER)
|
if (ctx.flags & SERVER_CTX_INTEGER)
|
||||||
for (i = 0; i < 13; i++) fprintf( stderr, ",r%u=%08x", i, ctx.integer.arm_regs.r[i] );
|
for (i = 0; i < 13; i++) fprintf( stderr, ",r%u=%08x", i, ctx.integer.arm_regs.r[i] );
|
||||||
break;
|
break;
|
||||||
|
case CPU_ARM64:
|
||||||
|
if (ctx.flags & SERVER_CTX_CONTROL)
|
||||||
|
{
|
||||||
|
dump_uint64( ",sp=", &ctx.ctl.arm64_regs.sp );
|
||||||
|
dump_uint64( ",pc=", &ctx.ctl.arm64_regs.pc );
|
||||||
|
dump_uint64( ",pstate=", &ctx.ctl.arm64_regs.pstate );
|
||||||
|
}
|
||||||
|
if (ctx.flags & SERVER_CTX_INTEGER)
|
||||||
|
{
|
||||||
|
dump_uint64( ",x0=", &ctx.integer.arm64_regs.x[0] );
|
||||||
|
dump_uint64( ",x1=", &ctx.integer.arm64_regs.x[1] );
|
||||||
|
dump_uint64( ",x2=", &ctx.integer.arm64_regs.x[2] );
|
||||||
|
dump_uint64( ",x3=", &ctx.integer.arm64_regs.x[3] );
|
||||||
|
dump_uint64( ",x4=", &ctx.integer.arm64_regs.x[4] );
|
||||||
|
dump_uint64( ",x5=", &ctx.integer.arm64_regs.x[5] );
|
||||||
|
dump_uint64( ",x6=", &ctx.integer.arm64_regs.x[6] );
|
||||||
|
dump_uint64( ",x7=", &ctx.integer.arm64_regs.x[7] );
|
||||||
|
dump_uint64( ",x8=", &ctx.integer.arm64_regs.x[8] );
|
||||||
|
dump_uint64( ",x9=", &ctx.integer.arm64_regs.x[9] );
|
||||||
|
dump_uint64( ",x10=", &ctx.integer.arm64_regs.x[10] );
|
||||||
|
dump_uint64( ",x11=", &ctx.integer.arm64_regs.x[11] );
|
||||||
|
dump_uint64( ",x12=", &ctx.integer.arm64_regs.x[12] );
|
||||||
|
dump_uint64( ",x13=", &ctx.integer.arm64_regs.x[13] );
|
||||||
|
dump_uint64( ",x14=", &ctx.integer.arm64_regs.x[14] );
|
||||||
|
dump_uint64( ",x15=", &ctx.integer.arm64_regs.x[15] );
|
||||||
|
dump_uint64( ",x16=", &ctx.integer.arm64_regs.x[16] );
|
||||||
|
dump_uint64( ",x17=", &ctx.integer.arm64_regs.x[17] );
|
||||||
|
dump_uint64( ",x18=", &ctx.integer.arm64_regs.x[18] );
|
||||||
|
dump_uint64( ",x19=", &ctx.integer.arm64_regs.x[19] );
|
||||||
|
dump_uint64( ",x20=", &ctx.integer.arm64_regs.x[20] );
|
||||||
|
dump_uint64( ",x21=", &ctx.integer.arm64_regs.x[21] );
|
||||||
|
dump_uint64( ",x22=", &ctx.integer.arm64_regs.x[22] );
|
||||||
|
dump_uint64( ",x23=", &ctx.integer.arm64_regs.x[23] );
|
||||||
|
dump_uint64( ",x24=", &ctx.integer.arm64_regs.x[24] );
|
||||||
|
dump_uint64( ",x25=", &ctx.integer.arm64_regs.x[25] );
|
||||||
|
dump_uint64( ",x26=", &ctx.integer.arm64_regs.x[26] );
|
||||||
|
dump_uint64( ",x27=", &ctx.integer.arm64_regs.x[27] );
|
||||||
|
dump_uint64( ",x28=", &ctx.integer.arm64_regs.x[28] );
|
||||||
|
dump_uint64( ",x29=", &ctx.integer.arm64_regs.x[29] );
|
||||||
|
dump_uint64( ",x30=", &ctx.integer.arm64_regs.x[30] );
|
||||||
|
}
|
||||||
|
break;
|
||||||
case CPU_SPARC:
|
case CPU_SPARC:
|
||||||
if (ctx.flags & SERVER_CTX_CONTROL)
|
if (ctx.flags & SERVER_CTX_CONTROL)
|
||||||
fprintf( stderr, ",psr=%08x,pc=%08x,npc=%08x,y=%08x,wim=%08x,tbr=%08x",
|
fprintf( stderr, ",psr=%08x,pc=%08x,npc=%08x,y=%08x,wim=%08x,tbr=%08x",
|
||||||
|
|
Loading…
Reference in New Issue