mirror of
https://git.code.sf.net/p/quake/quakeforge
synced 2024-11-26 14:20:59 +00:00
[gamecode] Switch dstatement ops to signed
I realized recently that I had made a huge mistake making Ruamoko's based addressing use unsigned offsets as it makes stack-relative addressing more awkward when it comes to runtime-determined stack frames (eg, using alloca). This does put a bit of an extra limit on directly addressable globals, but that's what the based addressing is meant to help with anyway.
This commit is contained in:
parent
a238eac75b
commit
74405ee31b
3 changed files with 86 additions and 72 deletions
|
@ -490,7 +490,7 @@ const opcode_t *PR_Opcode (pr_ushort_t opcode) __attribute__((const));
|
||||||
|
|
||||||
typedef struct dstatement_s {
|
typedef struct dstatement_s {
|
||||||
pr_opcode_e op; // will be pr_opcode_v6p_e for older progs
|
pr_opcode_e op; // will be pr_opcode_v6p_e for older progs
|
||||||
pr_ushort_t a,b,c;
|
pr_short_t a,b,c;
|
||||||
} GCC_STRUCT dstatement_t;
|
} GCC_STRUCT dstatement_t;
|
||||||
|
|
||||||
typedef struct ddef_s {
|
typedef struct ddef_s {
|
||||||
|
|
|
@ -1514,17 +1514,26 @@ PR_Debug_Print (progs_t *pr, const char *expr)
|
||||||
}
|
}
|
||||||
|
|
||||||
static const char *
|
static const char *
|
||||||
print_raw_op (progs_t *pr, pr_ushort_t op, pr_ushort_t base_ind,
|
print_raw_op (progs_t *pr, pr_short_t op, pr_ushort_t base_ind,
|
||||||
etype_t op_type, int op_width)
|
etype_t op_type, int op_width)
|
||||||
{
|
{
|
||||||
prdeb_resources_t *res = pr->pr_debug_resources;
|
prdeb_resources_t *res = pr->pr_debug_resources;
|
||||||
const char *width = va (res->va, "%d", op_width);
|
const char *width = va (res->va, "%d", op_width);
|
||||||
return va (res->va, "%d:%04x<%08x>%s:%-8s",
|
return va (res->va, "%d:%04hx<%08x>%s:%-8s",
|
||||||
base_ind, op, op + pr->pr_bases[base_ind],
|
base_ind, op, op + pr->pr_bases[base_ind],
|
||||||
op_width > 0 ? width : op_width < 0 ? "X" : "?",
|
op_width > 0 ? width : op_width < 0 ? "X" : "?",
|
||||||
pr_type_name[op_type]);
|
pr_type_name[op_type]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static pr_uint_t
|
||||||
|
get_opval (progs_t *pr, pr_short_t op)
|
||||||
|
{
|
||||||
|
if (pr->progs->version < PROG_VERSION) {
|
||||||
|
return (pr_ushort_t) op;
|
||||||
|
}
|
||||||
|
return op;
|
||||||
|
}
|
||||||
|
|
||||||
VISIBLE void
|
VISIBLE void
|
||||||
PR_PrintStatement (progs_t *pr, dstatement_t *s, int contents)
|
PR_PrintStatement (progs_t *pr, dstatement_t *s, int contents)
|
||||||
{
|
{
|
||||||
|
@ -1591,7 +1600,7 @@ PR_PrintStatement (progs_t *pr, dstatement_t *s, int contents)
|
||||||
if (pr_debug > 2) {
|
if (pr_debug > 2) {
|
||||||
if (pr->progs->version < PROG_VERSION) {
|
if (pr->progs->version < PROG_VERSION) {
|
||||||
dasprintf (res->line,
|
dasprintf (res->line,
|
||||||
"%03x %04x(%8s) %04x(%8s) %04x(%8s)\t",
|
"%03x %04hx(%8s) %04hx(%8s) %04hx(%8s)\t",
|
||||||
s->op,
|
s->op,
|
||||||
s->a, pr_type_name[op_type[0]],
|
s->a, pr_type_name[op_type[0]],
|
||||||
s->b, pr_type_name[op_type[1]],
|
s->b, pr_type_name[op_type[1]],
|
||||||
|
@ -1647,17 +1656,17 @@ PR_PrintStatement (progs_t *pr, dstatement_t *s, int contents)
|
||||||
switch (opchar) {
|
switch (opchar) {
|
||||||
case 'a':
|
case 'a':
|
||||||
opreg = PR_BASE_IND (s->op, A);
|
opreg = PR_BASE_IND (s->op, A);
|
||||||
opval = s->a;
|
opval = get_opval (pr, s->a);
|
||||||
optype = res->type_encodings[op_type[0]];
|
optype = res->type_encodings[op_type[0]];
|
||||||
break;
|
break;
|
||||||
case 'b':
|
case 'b':
|
||||||
opreg = PR_BASE_IND (s->op, B);
|
opreg = PR_BASE_IND (s->op, B);
|
||||||
opval = s->b;
|
opval = get_opval (pr, s->b);
|
||||||
optype = res->type_encodings[op_type[1]];
|
optype = res->type_encodings[op_type[1]];
|
||||||
break;
|
break;
|
||||||
case 'c':
|
case 'c':
|
||||||
opreg = PR_BASE_IND (s->op, C);
|
opreg = PR_BASE_IND (s->op, C);
|
||||||
opval = s->c;
|
opval = get_opval (pr, s->c);
|
||||||
optype = res->type_encodings[op_type[2]];
|
optype = res->type_encodings[op_type[2]];
|
||||||
break;
|
break;
|
||||||
case 'o':
|
case 'o':
|
||||||
|
@ -1729,8 +1738,8 @@ PR_PrintStatement (progs_t *pr, dstatement_t *s, int contents)
|
||||||
case 'E':
|
case 'E':
|
||||||
{
|
{
|
||||||
edict_t *ed = 0;
|
edict_t *ed = 0;
|
||||||
opval = G_ENTITY (pr, s->a);
|
opval = G_ENTITY (pr, (pr_ushort_t) s->a);
|
||||||
param_ind = G_FIELD (pr, s->b);
|
param_ind = G_FIELD (pr, (pr_ushort_t) s->b);
|
||||||
if (param_ind < pr->progs->entityfields
|
if (param_ind < pr->progs->entityfields
|
||||||
&& opval > 0
|
&& opval > 0
|
||||||
&& opval < pr->pr_edict_area_size) {
|
&& opval < pr->pr_edict_area_size) {
|
||||||
|
@ -1744,7 +1753,8 @@ PR_PrintStatement (progs_t *pr, dstatement_t *s, int contents)
|
||||||
str = global_string (&data, opval, optype,
|
str = global_string (&data, opval, optype,
|
||||||
contents & 1);
|
contents & 1);
|
||||||
str = dsprintf (res->dva, "$%x $%x %s",
|
str = dsprintf (res->dva, "$%x $%x %s",
|
||||||
s->a, s->b, str);
|
(pr_ushort_t) s->a,
|
||||||
|
(pr_ushort_t) s->b, str);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'M':
|
case 'M':
|
||||||
|
@ -1761,7 +1771,7 @@ PR_PrintStatement (progs_t *pr, dstatement_t *s, int contents)
|
||||||
case 2:
|
case 2:
|
||||||
ptr = s->a + PR_BASE (pr, s, A);
|
ptr = s->a + PR_BASE (pr, s, A);
|
||||||
ptr = G_POINTER (pr, ptr);
|
ptr = G_POINTER (pr, ptr);
|
||||||
offs = (short) s->b;
|
offs = s->b;
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
ptr = s->a + PR_BASE (pr, s, A);
|
ptr = s->a + PR_BASE (pr, s, A);
|
||||||
|
|
|
@ -547,9 +547,9 @@ pr_exec_quakec (progs_t *pr, int exitdepth)
|
||||||
PR_RunError (pr, "runaway loop error");
|
PR_RunError (pr, "runaway loop error");
|
||||||
}
|
}
|
||||||
|
|
||||||
op_a = pr->pr_globals + st->a;
|
op_a = pr->pr_globals + (pr_ushort_t) st->a;
|
||||||
op_b = pr->pr_globals + st->b;
|
op_b = pr->pr_globals + (pr_ushort_t) st->b;
|
||||||
op_c = pr->pr_globals + st->c;
|
op_c = pr->pr_globals + (pr_ushort_t) st->c;
|
||||||
|
|
||||||
if (pr->pr_trace) {
|
if (pr->pr_trace) {
|
||||||
if (pr->debug_handler) {
|
if (pr->debug_handler) {
|
||||||
|
@ -888,7 +888,7 @@ pr_exec_quakec (progs_t *pr, int exitdepth)
|
||||||
case OP_ADDRESS_I_v6p:
|
case OP_ADDRESS_I_v6p:
|
||||||
case OP_ADDRESS_P_v6p:
|
case OP_ADDRESS_P_v6p:
|
||||||
case OP_ADDRESS_D_v6p:
|
case OP_ADDRESS_D_v6p:
|
||||||
OPC(int) = st->a;
|
OPC(int) = (pr_ushort_t) st->a;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case OP_LOAD_F_v6p:
|
case OP_LOAD_F_v6p:
|
||||||
|
@ -990,7 +990,7 @@ pr_exec_quakec (progs_t *pr, int exitdepth)
|
||||||
case OP_LOADBI_FN_v6p:
|
case OP_LOADBI_FN_v6p:
|
||||||
case OP_LOADBI_I_v6p:
|
case OP_LOADBI_I_v6p:
|
||||||
case OP_LOADBI_P_v6p:
|
case OP_LOADBI_P_v6p:
|
||||||
pointer = OPA(ptr) + (short) st->b;
|
pointer = OPA(ptr) + st->b;
|
||||||
if (pr_boundscheck) {
|
if (pr_boundscheck) {
|
||||||
PR_BoundsCheck (pr, pointer, ev_int);
|
PR_BoundsCheck (pr, pointer, ev_int);
|
||||||
}
|
}
|
||||||
|
@ -998,7 +998,7 @@ pr_exec_quakec (progs_t *pr, int exitdepth)
|
||||||
OPC(int) = ptr->value;
|
OPC(int) = ptr->value;
|
||||||
break;
|
break;
|
||||||
case OP_LOADBI_V_v6p:
|
case OP_LOADBI_V_v6p:
|
||||||
pointer = OPA(ptr) + (short) st->b;
|
pointer = OPA(ptr) + st->b;
|
||||||
if (pr_boundscheck) {
|
if (pr_boundscheck) {
|
||||||
PR_BoundsCheck (pr, pointer, ev_vector);
|
PR_BoundsCheck (pr, pointer, ev_vector);
|
||||||
}
|
}
|
||||||
|
@ -1006,7 +1006,7 @@ pr_exec_quakec (progs_t *pr, int exitdepth)
|
||||||
VectorCopy (G_VECTOR (pr, pointer), &OPC(float));
|
VectorCopy (G_VECTOR (pr, pointer), &OPC(float));
|
||||||
break;
|
break;
|
||||||
case OP_LOADBI_Q_v6p:
|
case OP_LOADBI_Q_v6p:
|
||||||
pointer = OPA(ptr) + (short) st->b;
|
pointer = OPA(ptr) + st->b;
|
||||||
if (pr_boundscheck) {
|
if (pr_boundscheck) {
|
||||||
PR_BoundsCheck (pr, pointer, ev_quaternion);
|
PR_BoundsCheck (pr, pointer, ev_quaternion);
|
||||||
}
|
}
|
||||||
|
@ -1014,7 +1014,7 @@ pr_exec_quakec (progs_t *pr, int exitdepth)
|
||||||
QuatCopy (G_QUAT (pr, pointer), &OPC(float));
|
QuatCopy (G_QUAT (pr, pointer), &OPC(float));
|
||||||
break;
|
break;
|
||||||
case OP_LOADBI_D_v6p:
|
case OP_LOADBI_D_v6p:
|
||||||
pointer = OPA(ptr) + (short) st->b;
|
pointer = OPA(ptr) + st->b;
|
||||||
if (pr_boundscheck) {
|
if (pr_boundscheck) {
|
||||||
PR_BoundsCheck (pr, pointer, ev_quaternion);
|
PR_BoundsCheck (pr, pointer, ev_quaternion);
|
||||||
}
|
}
|
||||||
|
@ -1028,7 +1028,7 @@ pr_exec_quakec (progs_t *pr, int exitdepth)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case OP_LEAI_v6p:
|
case OP_LEAI_v6p:
|
||||||
pointer = OPA(ptr) + (short) st->b;
|
pointer = OPA(ptr) + st->b;
|
||||||
OPC(ptr) = pointer;
|
OPC(ptr) = pointer;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -1078,7 +1078,7 @@ pr_exec_quakec (progs_t *pr, int exitdepth)
|
||||||
case OP_STOREBI_FN_v6p:
|
case OP_STOREBI_FN_v6p:
|
||||||
case OP_STOREBI_I_v6p:
|
case OP_STOREBI_I_v6p:
|
||||||
case OP_STOREBI_P_v6p:
|
case OP_STOREBI_P_v6p:
|
||||||
pointer = OPB(ptr) + (short) st->c;
|
pointer = OPB(ptr) + st->c;
|
||||||
if (pr_boundscheck) {
|
if (pr_boundscheck) {
|
||||||
PR_BoundsCheck (pr, pointer, ev_int);
|
PR_BoundsCheck (pr, pointer, ev_int);
|
||||||
}
|
}
|
||||||
|
@ -1086,7 +1086,7 @@ pr_exec_quakec (progs_t *pr, int exitdepth)
|
||||||
ptr->value = OPA(int);
|
ptr->value = OPA(int);
|
||||||
break;
|
break;
|
||||||
case OP_STOREBI_V_v6p:
|
case OP_STOREBI_V_v6p:
|
||||||
pointer = OPB(ptr) + (short) st->c;
|
pointer = OPB(ptr) + st->c;
|
||||||
if (pr_boundscheck) {
|
if (pr_boundscheck) {
|
||||||
PR_BoundsCheck (pr, pointer, ev_vector);
|
PR_BoundsCheck (pr, pointer, ev_vector);
|
||||||
}
|
}
|
||||||
|
@ -1094,7 +1094,7 @@ pr_exec_quakec (progs_t *pr, int exitdepth)
|
||||||
VectorCopy (&OPA(float), G_VECTOR (pr, pointer));
|
VectorCopy (&OPA(float), G_VECTOR (pr, pointer));
|
||||||
break;
|
break;
|
||||||
case OP_STOREBI_Q_v6p:
|
case OP_STOREBI_Q_v6p:
|
||||||
pointer = OPB(ptr) + (short) st->c;
|
pointer = OPB(ptr) + st->c;
|
||||||
if (pr_boundscheck) {
|
if (pr_boundscheck) {
|
||||||
PR_BoundsCheck (pr, pointer, ev_quaternion);
|
PR_BoundsCheck (pr, pointer, ev_quaternion);
|
||||||
}
|
}
|
||||||
|
@ -1102,7 +1102,7 @@ pr_exec_quakec (progs_t *pr, int exitdepth)
|
||||||
QuatCopy (&OPA(float), G_QUAT (pr, pointer));
|
QuatCopy (&OPA(float), G_QUAT (pr, pointer));
|
||||||
break;
|
break;
|
||||||
case OP_STOREBI_D_v6p:
|
case OP_STOREBI_D_v6p:
|
||||||
pointer = OPB(ptr) + (short) st->c;
|
pointer = OPB(ptr) + st->c;
|
||||||
if (pr_boundscheck) {
|
if (pr_boundscheck) {
|
||||||
PR_BoundsCheck (pr, pointer, ev_quaternion);
|
PR_BoundsCheck (pr, pointer, ev_quaternion);
|
||||||
}
|
}
|
||||||
|
@ -1217,7 +1217,7 @@ pr_exec_quakec (progs_t *pr, int exitdepth)
|
||||||
pr_ptr_t stack = *pr->globals.stack - 1;
|
pr_ptr_t stack = *pr->globals.stack - 1;
|
||||||
pr_type_t *stk = pr->pr_globals + stack;
|
pr_type_t *stk = pr->pr_globals + stack;
|
||||||
|
|
||||||
pointer = OPA(ptr) + st->b;
|
pointer = OPA(ptr) + (pr_ushort_t) st->b;
|
||||||
ptr = pr->pr_globals + pointer;
|
ptr = pr->pr_globals + pointer;
|
||||||
|
|
||||||
if (pr_boundscheck) {
|
if (pr_boundscheck) {
|
||||||
|
@ -1233,7 +1233,7 @@ pr_exec_quakec (progs_t *pr, int exitdepth)
|
||||||
{
|
{
|
||||||
pr_ptr_t stack = *pr->globals.stack - 3;
|
pr_ptr_t stack = *pr->globals.stack - 3;
|
||||||
|
|
||||||
pointer = OPA(ptr) + st->b;
|
pointer = OPA(ptr) + (pr_ushort_t) st->b;
|
||||||
ptr = pr->pr_globals + pointer;
|
ptr = pr->pr_globals + pointer;
|
||||||
|
|
||||||
if (pr_boundscheck) {
|
if (pr_boundscheck) {
|
||||||
|
@ -1249,7 +1249,7 @@ pr_exec_quakec (progs_t *pr, int exitdepth)
|
||||||
{
|
{
|
||||||
pr_ptr_t stack = *pr->globals.stack - 4;
|
pr_ptr_t stack = *pr->globals.stack - 4;
|
||||||
|
|
||||||
pointer = OPA(ptr) + st->b;
|
pointer = OPA(ptr) + (pr_ushort_t) st->b;
|
||||||
ptr = pr->pr_globals + pointer;
|
ptr = pr->pr_globals + pointer;
|
||||||
|
|
||||||
if (pr_boundscheck) {
|
if (pr_boundscheck) {
|
||||||
|
@ -1369,7 +1369,7 @@ pr_exec_quakec (progs_t *pr, int exitdepth)
|
||||||
pr_ptr_t stack = *pr->globals.stack;
|
pr_ptr_t stack = *pr->globals.stack;
|
||||||
pr_type_t *stk = pr->pr_globals + stack;
|
pr_type_t *stk = pr->pr_globals + stack;
|
||||||
|
|
||||||
pointer = OPA(ptr) + st->b;
|
pointer = OPA(ptr) + (pr_ushort_t) st->b;
|
||||||
ptr = pr->pr_globals + pointer;
|
ptr = pr->pr_globals + pointer;
|
||||||
|
|
||||||
if (pr_boundscheck) {
|
if (pr_boundscheck) {
|
||||||
|
@ -1385,7 +1385,7 @@ pr_exec_quakec (progs_t *pr, int exitdepth)
|
||||||
{
|
{
|
||||||
pr_ptr_t stack = *pr->globals.stack;
|
pr_ptr_t stack = *pr->globals.stack;
|
||||||
|
|
||||||
pointer = OPA(ptr) + st->b;
|
pointer = OPA(ptr) + (pr_ushort_t) st->b;
|
||||||
ptr = pr->pr_globals + pointer;
|
ptr = pr->pr_globals + pointer;
|
||||||
|
|
||||||
if (pr_boundscheck) {
|
if (pr_boundscheck) {
|
||||||
|
@ -1401,7 +1401,7 @@ pr_exec_quakec (progs_t *pr, int exitdepth)
|
||||||
{
|
{
|
||||||
pr_ptr_t stack = *pr->globals.stack;
|
pr_ptr_t stack = *pr->globals.stack;
|
||||||
|
|
||||||
pointer = OPA(ptr) + st->b;
|
pointer = OPA(ptr) + (pr_ushort_t) st->b;
|
||||||
ptr = pr->pr_globals + pointer;
|
ptr = pr->pr_globals + pointer;
|
||||||
|
|
||||||
if (pr_boundscheck) {
|
if (pr_boundscheck) {
|
||||||
|
@ -1417,42 +1417,42 @@ pr_exec_quakec (progs_t *pr, int exitdepth)
|
||||||
// ==================
|
// ==================
|
||||||
case OP_IFNOT_v6p:
|
case OP_IFNOT_v6p:
|
||||||
if (!OPA(int)) {
|
if (!OPA(int)) {
|
||||||
pr->pr_xstatement += (short)st->b - 1; // offset the st++
|
pr->pr_xstatement += st->b - 1; // offset the st++
|
||||||
st = pr->pr_statements + pr->pr_xstatement;
|
st = pr->pr_statements + pr->pr_xstatement;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case OP_IF_v6p:
|
case OP_IF_v6p:
|
||||||
if (OPA(int)) {
|
if (OPA(int)) {
|
||||||
pr->pr_xstatement += (short)st->b - 1; // offset the st++
|
pr->pr_xstatement += st->b - 1; // offset the st++
|
||||||
st = pr->pr_statements + pr->pr_xstatement;
|
st = pr->pr_statements + pr->pr_xstatement;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case OP_IFBE_v6p:
|
case OP_IFBE_v6p:
|
||||||
if (OPA(int) <= 0) {
|
if (OPA(int) <= 0) {
|
||||||
pr->pr_xstatement += (short)st->b - 1; // offset the st++
|
pr->pr_xstatement += st->b - 1; // offset the st++
|
||||||
st = pr->pr_statements + pr->pr_xstatement;
|
st = pr->pr_statements + pr->pr_xstatement;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case OP_IFB_v6p:
|
case OP_IFB_v6p:
|
||||||
if (OPA(int) < 0) {
|
if (OPA(int) < 0) {
|
||||||
pr->pr_xstatement += (short)st->b - 1; // offset the st++
|
pr->pr_xstatement += st->b - 1; // offset the st++
|
||||||
st = pr->pr_statements + pr->pr_xstatement;
|
st = pr->pr_statements + pr->pr_xstatement;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case OP_IFAE_v6p:
|
case OP_IFAE_v6p:
|
||||||
if (OPA(int) >= 0) {
|
if (OPA(int) >= 0) {
|
||||||
pr->pr_xstatement += (short)st->b - 1; // offset the st++
|
pr->pr_xstatement += st->b - 1; // offset the st++
|
||||||
st = pr->pr_statements + pr->pr_xstatement;
|
st = pr->pr_statements + pr->pr_xstatement;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case OP_IFA_v6p:
|
case OP_IFA_v6p:
|
||||||
if (OPA(int) > 0) {
|
if (OPA(int) > 0) {
|
||||||
pr->pr_xstatement += (short)st->b - 1; // offset the st++
|
pr->pr_xstatement += st->b - 1; // offset the st++
|
||||||
st = pr->pr_statements + pr->pr_xstatement;
|
st = pr->pr_statements + pr->pr_xstatement;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case OP_GOTO_v6p:
|
case OP_GOTO_v6p:
|
||||||
pr->pr_xstatement += (short)st->a - 1; // offset the st++
|
pr->pr_xstatement += st->a - 1; // offset the st++
|
||||||
st = pr->pr_statements + pr->pr_xstatement;
|
st = pr->pr_statements + pr->pr_xstatement;
|
||||||
break;
|
break;
|
||||||
case OP_JUMP_v6p:
|
case OP_JUMP_v6p:
|
||||||
|
@ -1464,7 +1464,7 @@ pr_exec_quakec (progs_t *pr, int exitdepth)
|
||||||
st = pr->pr_statements + pr->pr_xstatement;
|
st = pr->pr_statements + pr->pr_xstatement;
|
||||||
break;
|
break;
|
||||||
case OP_JUMPB_v6p:
|
case OP_JUMPB_v6p:
|
||||||
pointer = st->a + OPB(int);
|
pointer = (pr_ushort_t) st->a + OPB(int);
|
||||||
if (pr_boundscheck) {
|
if (pr_boundscheck) {
|
||||||
PR_BoundsCheck (pr, pointer, ev_int);
|
PR_BoundsCheck (pr, pointer, ev_int);
|
||||||
}
|
}
|
||||||
|
@ -1684,7 +1684,7 @@ op_call:
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case OP_MOVEI_v6p:
|
case OP_MOVEI_v6p:
|
||||||
memmove (op_c, op_a, st->b * 4);
|
memmove (op_c, op_a, (pr_ushort_t) st->b * 4);
|
||||||
break;
|
break;
|
||||||
case OP_MOVEP_v6p:
|
case OP_MOVEP_v6p:
|
||||||
if (pr_boundscheck) {
|
if (pr_boundscheck) {
|
||||||
|
@ -1697,15 +1697,15 @@ op_call:
|
||||||
break;
|
break;
|
||||||
case OP_MOVEPI_v6p:
|
case OP_MOVEPI_v6p:
|
||||||
if (pr_boundscheck) {
|
if (pr_boundscheck) {
|
||||||
PR_BoundsCheckSize (pr, OPC(ptr), st->b);
|
PR_BoundsCheckSize (pr, OPC(ptr), (pr_ushort_t) st->b);
|
||||||
PR_BoundsCheckSize (pr, OPA(ptr), st->b);
|
PR_BoundsCheckSize (pr, OPA(ptr), (pr_ushort_t) st->b);
|
||||||
}
|
}
|
||||||
memmove (pr->pr_globals + OPC(ptr),
|
memmove (pr->pr_globals + OPC(ptr),
|
||||||
pr->pr_globals + OPA(ptr),
|
pr->pr_globals + OPA(ptr),
|
||||||
st->b * 4);
|
(pr_ushort_t) st->b * 4);
|
||||||
break;
|
break;
|
||||||
case OP_MEMSETI_v6p:
|
case OP_MEMSETI_v6p:
|
||||||
pr_memset (op_c, OPA(ptr), st->b);
|
pr_memset (op_c, OPA(ptr), (pr_ushort_t) st->b);
|
||||||
break;
|
break;
|
||||||
case OP_MEMSETP_v6p:
|
case OP_MEMSETP_v6p:
|
||||||
if (pr_boundscheck) {
|
if (pr_boundscheck) {
|
||||||
|
@ -1716,10 +1716,10 @@ op_call:
|
||||||
break;
|
break;
|
||||||
case OP_MEMSETPI_v6p:
|
case OP_MEMSETPI_v6p:
|
||||||
if (pr_boundscheck) {
|
if (pr_boundscheck) {
|
||||||
PR_BoundsCheckSize (pr, OPC(ptr), st->b);
|
PR_BoundsCheckSize (pr, OPC(ptr), (pr_ushort_t) st->b);
|
||||||
}
|
}
|
||||||
pr_memset (pr->pr_globals + OPC(ptr), OPA(int),
|
pr_memset (pr->pr_globals + OPC(ptr), OPA(int),
|
||||||
st->b);
|
(pr_ushort_t) st->b);
|
||||||
break;
|
break;
|
||||||
case OP_GE_D_v6p:
|
case OP_GE_D_v6p:
|
||||||
OPC(float) = OPA(double) >= OPB(double);
|
OPC(float) = OPA(double) >= OPB(double);
|
||||||
|
@ -1758,9 +1758,10 @@ op_call:
|
||||||
// LordHavoc: to be enabled when Progs version 7 (or whatever it will be numbered) is finalized
|
// LordHavoc: to be enabled when Progs version 7 (or whatever it will be numbered) is finalized
|
||||||
/*
|
/*
|
||||||
case OP_BOUNDCHECK_v6p:
|
case OP_BOUNDCHECK_v6p:
|
||||||
if (OPA(ptr) >= st->b) {
|
if (OPA(ptr) >= (pr_ushort_t) st->b) {
|
||||||
PR_RunError (pr, "Progs boundcheck failed at line number "
|
PR_RunError (pr, "Progs boundcheck failed at line number "
|
||||||
"%d, value is < 0 or >= %d", st->b, st->c);
|
"%d, value is < 0 or >= %d", (pr_ushort_t) st->b,
|
||||||
|
(pr_ushort_t) st->c);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -1807,7 +1808,7 @@ pr_address_mode (progs_t *pr, const dstatement_t *st, int mm_ind)
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
// constant indexed pointer: *a + b (supports -ve offset)
|
// constant indexed pointer: *a + b (supports -ve offset)
|
||||||
mm_offs = OPA(ptr) + (short) st->b;
|
mm_offs = OPA(ptr) + st->b;
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
// variable indexed pointer: *a + *b (supports -ve offset)
|
// variable indexed pointer: *a + *b (supports -ve offset)
|
||||||
|
@ -1815,7 +1816,7 @@ pr_address_mode (progs_t *pr, const dstatement_t *st, int mm_ind)
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
// global access with constant offset (supports -ve offset)
|
// global access with constant offset (supports -ve offset)
|
||||||
mm_offs = op_a - pr->pr_globals + (short) st->b;
|
mm_offs = op_a - pr->pr_globals + st->b;
|
||||||
break;
|
break;
|
||||||
case 5:
|
case 5:
|
||||||
// global access with variable offset (supports -ve offset)
|
// global access with variable offset (supports -ve offset)
|
||||||
|
@ -1840,7 +1841,7 @@ pr_call_mode (progs_t *pr, const dstatement_t *st, int mm_ind)
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
// constant indexed pointer: *a + b (supports -ve offset)
|
// constant indexed pointer: *a + b (supports -ve offset)
|
||||||
mm_offs = OPA(ptr) + (short) st->b;
|
mm_offs = OPA(ptr) + st->b;
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
// variable indexed pointer: *a + *b (supports -ve offset)
|
// variable indexed pointer: *a + *b (supports -ve offset)
|
||||||
|
@ -1865,7 +1866,7 @@ pr_jump_mode (progs_t *pr, const dstatement_t *st, int jump_ind)
|
||||||
switch (jump_ind) {
|
switch (jump_ind) {
|
||||||
case 0:
|
case 0:
|
||||||
// instruction relative offset
|
// instruction relative offset
|
||||||
jump_offs = jump_offs + (short) st->a;
|
jump_offs = jump_offs + st->a;
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
// variable indexed array: a + *b (only +ve)
|
// variable indexed array: a + *b (only +ve)
|
||||||
|
@ -1873,7 +1874,7 @@ pr_jump_mode (progs_t *pr, const dstatement_t *st, int jump_ind)
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
// constant indexed pointer: *a + b (supports -ve offset)
|
// constant indexed pointer: *a + b (supports -ve offset)
|
||||||
jump_offs = OPA(ptr) + (short) st->b;
|
jump_offs = OPA(ptr) + st->b;
|
||||||
break;
|
break;
|
||||||
case 3:
|
case 3:
|
||||||
// variable indexed pointer: *a + *b (supports -ve offset)
|
// variable indexed pointer: *a + *b (supports -ve offset)
|
||||||
|
@ -1938,24 +1939,24 @@ pr_with (progs_t *pr, const dstatement_t *st)
|
||||||
// fixed offset
|
// fixed offset
|
||||||
case 0:
|
case 0:
|
||||||
// hard-0 base
|
// hard-0 base
|
||||||
pr->pr_bases[st->c & 3] = st->b;
|
pr->pr_bases[st->c & 3] = (pr_ushort_t) st->b;
|
||||||
return;
|
return;
|
||||||
case 1:
|
case 1:
|
||||||
// relative to current base (-ve offset)
|
// relative to current base (-ve offset)
|
||||||
pr->pr_bases[st->c & 3] = PR_BASE (pr, st, B) + (pr_short_t) st->b;
|
pr->pr_bases[st->c & 3] = PR_BASE (pr, st, B) + st->b;
|
||||||
return;
|
return;
|
||||||
case 2:
|
case 2:
|
||||||
// relative to stack (-ve offset)
|
// relative to stack (-ve offset)
|
||||||
pr->pr_bases[st->c & 3] = *pr->globals.stack + (pr_short_t) st->b;
|
pr->pr_bases[st->c & 3] = *pr->globals.stack + st->b;
|
||||||
return;
|
return;
|
||||||
case 3:
|
case 3:
|
||||||
// relative to edict_area (only +ve)
|
// relative to edict_area (only +ve)
|
||||||
pr->pr_bases[st->c & 3] = edict_area + st->b;
|
pr->pr_bases[st->c & 3] = edict_area + (pr_ushort_t) st->b;
|
||||||
return;
|
return;
|
||||||
|
|
||||||
case 4:
|
case 4:
|
||||||
// hard-0 base
|
// hard-0 base
|
||||||
pr->pr_bases[st->c & 3] = G_POINTER (pr, st->b);;
|
pr->pr_bases[st->c & 3] = G_POINTER (pr, (pr_ushort_t) st->b);;
|
||||||
return;
|
return;
|
||||||
case 5:
|
case 5:
|
||||||
pr->pr_bases[st->c & 3] = OPB(ptr);
|
pr->pr_bases[st->c & 3] = OPB(ptr);
|
||||||
|
@ -2159,7 +2160,7 @@ pr_exec_ruamoko (progs_t *pr, int exitdepth)
|
||||||
case OP_NOP:
|
case OP_NOP:
|
||||||
break;
|
break;
|
||||||
case OP_ADJSTK:
|
case OP_ADJSTK:
|
||||||
pr_stack_adjust (pr, st->a, (short) st->b);
|
pr_stack_adjust (pr, (pr_ushort_t) st->a, st->b);
|
||||||
break;
|
break;
|
||||||
case OP_LDCONST:
|
case OP_LDCONST:
|
||||||
PR_RunError (pr, "OP_LDCONST not implemented");
|
PR_RunError (pr, "OP_LDCONST not implemented");
|
||||||
|
@ -2553,8 +2554,8 @@ pr_exec_ruamoko (progs_t *pr, int exitdepth)
|
||||||
OP_cmp_T (LT, U, long, lvec2, lvec4, <, ulong, ulvec2, ulvec4);
|
OP_cmp_T (LT, U, long, lvec2, lvec4, <, ulong, ulvec2, ulvec4);
|
||||||
case OP_RETURN:
|
case OP_RETURN:
|
||||||
ret_size = (st->c & 0x1f) + 1; // up to 32 words
|
ret_size = (st->c & 0x1f) + 1; // up to 32 words
|
||||||
if (st->c != 0xffff) {
|
if ((pr_ushort_t) st->c != 0xffff) {
|
||||||
mm = pr_address_mode (pr, st, st->c >> 5);
|
mm = pr_address_mode (pr, st, ((pr_ushort_t) st->c) >> 5);
|
||||||
memcpy (&R_INT (pr), mm, ret_size * sizeof (*op_a));
|
memcpy (&R_INT (pr), mm, ret_size * sizeof (*op_a));
|
||||||
}
|
}
|
||||||
pr->pr_xfunction->profile += profile - startprofile;
|
pr->pr_xfunction->profile += profile - startprofile;
|
||||||
|
@ -2583,7 +2584,7 @@ pr_exec_ruamoko (progs_t *pr, int exitdepth)
|
||||||
// 1 1010
|
// 1 1010
|
||||||
OP_cmp_T (GT, u, int, ivec2, ivec4, >, uint, uivec2, uivec4);
|
OP_cmp_T (GT, u, int, ivec2, ivec4, >, uint, uivec2, uivec4);
|
||||||
case OP_SWIZZLE_F:
|
case OP_SWIZZLE_F:
|
||||||
OPC(ivec4) = pr_swizzle_f (OPA(ivec4), st->b);
|
OPC(ivec4) = pr_swizzle_f (OPA(ivec4), (pr_ushort_t) st->b);
|
||||||
break;
|
break;
|
||||||
case OP_SCALE_F_2:
|
case OP_SCALE_F_2:
|
||||||
OPC(vec2) = OPA(vec2) * OPB(float);
|
OPC(vec2) = OPA(vec2) * OPB(float);
|
||||||
|
@ -2596,7 +2597,7 @@ pr_exec_ruamoko (progs_t *pr, int exitdepth)
|
||||||
break;
|
break;
|
||||||
OP_cmp_T (GT, U, long, lvec2, lvec4, >, ulong, ulvec2, ulvec4);
|
OP_cmp_T (GT, U, long, lvec2, lvec4, >, ulong, ulvec2, ulvec4);
|
||||||
case OP_SWIZZLE_D:
|
case OP_SWIZZLE_D:
|
||||||
OPC(lvec4) = pr_swizzle_d (OPA(lvec4), st->b);
|
OPC(lvec4) = pr_swizzle_d (OPA(lvec4), (pr_ushort_t) st->b);
|
||||||
break;
|
break;
|
||||||
case OP_SCALE_D_2:
|
case OP_SCALE_D_2:
|
||||||
OPC(dvec2) = OPA(dvec2) * OPB(double);
|
OPC(dvec2) = OPA(dvec2) * OPB(double);
|
||||||
|
@ -2698,7 +2699,7 @@ pr_exec_ruamoko (progs_t *pr, int exitdepth)
|
||||||
// 1 1101
|
// 1 1101
|
||||||
OP_cmp_T (GE, u, int, ivec2, ivec4, >=, uint, uivec2, uivec4);
|
OP_cmp_T (GE, u, int, ivec2, ivec4, >=, uint, uivec2, uivec4);
|
||||||
case OP_MOVE_I:
|
case OP_MOVE_I:
|
||||||
memmove (op_c, op_a, st->b * sizeof (pr_type_t));
|
memmove (op_c, op_a, (pr_ushort_t) st->b * sizeof (pr_type_t));
|
||||||
break;
|
break;
|
||||||
case OP_MOVE_P:
|
case OP_MOVE_P:
|
||||||
memmove (pr->pr_globals + OPC(ptr), pr->pr_globals + OPA(ptr),
|
memmove (pr->pr_globals + OPC(ptr), pr->pr_globals + OPA(ptr),
|
||||||
|
@ -2706,7 +2707,7 @@ pr_exec_ruamoko (progs_t *pr, int exitdepth)
|
||||||
break;
|
break;
|
||||||
case OP_MOVE_PI:
|
case OP_MOVE_PI:
|
||||||
memmove (pr->pr_globals + OPC(ptr), pr->pr_globals + OPA(ptr),
|
memmove (pr->pr_globals + OPC(ptr), pr->pr_globals + OPA(ptr),
|
||||||
st->b * sizeof (pr_type_t));
|
(pr_ushort_t) st->b * sizeof (pr_type_t));
|
||||||
break;
|
break;
|
||||||
case OP_STATE_ft:
|
case OP_STATE_ft:
|
||||||
{
|
{
|
||||||
|
@ -2722,13 +2723,14 @@ pr_exec_ruamoko (progs_t *pr, int exitdepth)
|
||||||
break;
|
break;
|
||||||
OP_cmp_T (GE, U, long, lvec2, lvec4, >=, ulong, ulvec2, ulvec4);
|
OP_cmp_T (GE, U, long, lvec2, lvec4, >=, ulong, ulvec2, ulvec4);
|
||||||
case OP_MEMSET_I:
|
case OP_MEMSET_I:
|
||||||
pr_memset (op_c, OPA(int), st->b);
|
pr_memset (op_c, OPA(int), (pr_ushort_t) st->b);
|
||||||
break;
|
break;
|
||||||
case OP_MEMSET_P:
|
case OP_MEMSET_P:
|
||||||
pr_memset (pr->pr_globals + OPC(ptr), OPA(int), OPB(uint));
|
pr_memset (pr->pr_globals + OPC(ptr), OPA(int), OPB(uint));
|
||||||
break;
|
break;
|
||||||
case OP_MEMSET_PI:
|
case OP_MEMSET_PI:
|
||||||
pr_memset (pr->pr_globals + OPC(ptr), OPA(int), st->b);
|
pr_memset (pr->pr_globals + OPC(ptr), OPA(int),
|
||||||
|
(pr_ushort_t) st->b);
|
||||||
break;
|
break;
|
||||||
case OP_STATE_ftt:
|
case OP_STATE_ftt:
|
||||||
{
|
{
|
||||||
|
@ -2838,31 +2840,33 @@ pr_exec_ruamoko (progs_t *pr, int exitdepth)
|
||||||
OPC(float) = ~ (int) OPA(float);
|
OPC(float) = ~ (int) OPA(float);
|
||||||
break;
|
break;
|
||||||
case OP_CONV:
|
case OP_CONV:
|
||||||
switch (st->b) {
|
switch ((pr_ushort_t) st->b) {
|
||||||
#include "libs/gamecode/pr_convert.cinc"
|
#include "libs/gamecode/pr_convert.cinc"
|
||||||
default:
|
default:
|
||||||
PR_RunError (pr, "invalid conversion code: %04o",
|
PR_RunError (pr, "invalid conversion code: %04o",
|
||||||
st->b);
|
(pr_ushort_t) st->b);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case OP_WITH:
|
case OP_WITH:
|
||||||
pr_with (pr, st);
|
pr_with (pr, st);
|
||||||
break;
|
break;
|
||||||
case OP_EXTEND:
|
case OP_EXTEND:
|
||||||
switch (st->b) {
|
switch ((pr_ushort_t) st->b) {
|
||||||
#include "libs/gamecode/pr_extend.cinc"
|
#include "libs/gamecode/pr_extend.cinc"
|
||||||
default:
|
default:
|
||||||
PR_RunError (pr, "invalid extend code: %04o", st->b);
|
PR_RunError (pr, "invalid extend code: %04o",
|
||||||
|
(pr_ushort_t) st->b);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
#define OP_hop2(vec, op) ((vec)[0] op (vec)[1])
|
#define OP_hop2(vec, op) ((vec)[0] op (vec)[1])
|
||||||
#define OP_hop3(vec, op) ((vec)[0] op (vec)[1] op (vec)[2])
|
#define OP_hop3(vec, op) ((vec)[0] op (vec)[1] op (vec)[2])
|
||||||
#define OP_hop4(vec, op) ((vec)[0] op (vec)[1] op (vec)[2] op (vec)[3])
|
#define OP_hop4(vec, op) ((vec)[0] op (vec)[1] op (vec)[2] op (vec)[3])
|
||||||
case OP_HOPS:
|
case OP_HOPS:
|
||||||
switch (st->b) {
|
switch ((pr_ushort_t) st->b) {
|
||||||
#include "libs/gamecode/pr_hops.cinc"
|
#include "libs/gamecode/pr_hops.cinc"
|
||||||
default:
|
default:
|
||||||
PR_RunError (pr, "invalid hops code: %04o", st->b);
|
PR_RunError (pr, "invalid hops code: %04o",
|
||||||
|
(pr_ushort_t) st->b);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
|
Loading…
Reference in a new issue