compile fixes for alpha linux

This commit is contained in:
Bill Currie 2002-11-10 02:50:42 +00:00
parent 77288fe90b
commit 498bdcc406
9 changed files with 180 additions and 172 deletions

7
libs/gib/.gitignore vendored Normal file
View file

@ -0,0 +1,7 @@
*.la
*.lo
.deps
.libs
.vimrc
Makefile
Makefile.in

View file

@ -458,7 +458,7 @@ GIB_String_Length_f (void)
"string.length: invalid syntax\n" "string.length: invalid syntax\n"
"usage: string.length string"); "usage: string.length string");
else else
GIB_Return (va("%i", strlen(GIB_Argv(1)))); GIB_Return (va("%i", (int) strlen(GIB_Argv(1))));
} }
void void

View file

@ -122,50 +122,131 @@ byte *skinstart;
#undef USE_INTEL_ASM //XXX asm pic hack #undef USE_INTEL_ASM //XXX asm pic hack
#endif #endif
void
D_PolysetSetEdgeTable (void)
{
int edgetableindex;
// assume the vertices are already in top to bottom order
edgetableindex = 0;
// determine which edges are right & left, and the order in which
// to rasterize them
if (r_p0[1] >= r_p1[1]) {
if (r_p0[1] == r_p1[1]) {
if (r_p0[1] < r_p2[1])
pedgetable = &edgetables[2];
else
pedgetable = &edgetables[5];
return;
} else {
edgetableindex = 1;
}
}
if (r_p0[1] == r_p2[1]) {
if (edgetableindex)
pedgetable = &edgetables[8];
else
pedgetable = &edgetables[9];
return;
} else if (r_p1[1] == r_p2[1]) {
if (edgetableindex)
pedgetable = &edgetables[10];
else
pedgetable = &edgetables[11];
return;
}
if (r_p0[1] > r_p2[1])
edgetableindex += 2;
if (r_p1[1] > r_p2[1])
edgetableindex += 4;
pedgetable = &edgetables[edgetableindex];
}
#ifndef USE_INTEL_ASM #ifndef USE_INTEL_ASM
void void
D_PolysetDraw (void) D_PolysetRecursiveTriangle (int *lp1, int *lp2, int *lp3)
{ {
spanpackage_t spans[DPS_MAXSPANS + 1 + int *temp;
((CACHE_SIZE - 1) / sizeof (spanpackage_t)) + 1]; int d;
int new[6];
// one extra because of cache line pretouching int z;
a_spans = (spanpackage_t *)
(((long) &spans[0] + CACHE_SIZE - 1) & ~(CACHE_SIZE - 1));
if (r_affinetridesc.drawtype) {
D_DrawSubdiv ();
} else {
D_DrawNonSubdiv ();
}
}
void
D_PolysetDrawFinalVerts (finalvert_t *fv, int numverts)
{
int i, z;
short *zbuf; short *zbuf;
for (i = 0; i < numverts; i++, fv++) { d = lp2[0] - lp1[0];
// valid triangle coordinates for filling can include the bottom and if (d < -1 || d > 1)
// right clip edges, due to the fill rule; these shouldn't be drawn goto split;
if ((fv->v[0] < r_refdef.vrectright) && d = lp2[1] - lp1[1];
(fv->v[1] < r_refdef.vrectbottom)) { if (d < -1 || d > 1)
z = fv->v[5] >> 16; goto split;
zbuf = zspantable[fv->v[1]] + fv->v[0];
d = lp3[0] - lp2[0];
if (d < -1 || d > 1)
goto split2;
d = lp3[1] - lp2[1];
if (d < -1 || d > 1)
goto split2;
d = lp1[0] - lp3[0];
if (d < -1 || d > 1)
goto split3;
d = lp1[1] - lp3[1];
if (d < -1 || d > 1) {
split3:
temp = lp1;
lp1 = lp3;
lp3 = lp2;
lp2 = temp;
goto split;
}
return; // entire tri is filled
split2:
temp = lp1;
lp1 = lp2;
lp2 = lp3;
lp3 = temp;
split:
// split this edge
new[0] = (lp1[0] + lp2[0]) >> 1;
new[1] = (lp1[1] + lp2[1]) >> 1;
new[2] = (lp1[2] + lp2[2]) >> 1;
new[3] = (lp1[3] + lp2[3]) >> 1;
new[5] = (lp1[5] + lp2[5]) >> 1;
// draw the point if splitting a leading edge
if (lp2[1] > lp1[1])
goto nodraw;
if ((lp2[1] == lp1[1]) && (lp2[0] < lp1[0]))
goto nodraw;
z = new[5] >> 16;
zbuf = zspantable[new[1]] + new[0];
if (z >= *zbuf) { if (z >= *zbuf) {
int pix; int pix;
*zbuf = z; *zbuf = z;
pix = skintable[fv->v[3] >> 16][fv->v[2] >> 16]; pix = d_pcolormap[skintable[new[3] >> 16][new[2] >> 16]];
pix = ((byte *) acolormap)[pix + (fv->v[4] & 0xFF00)]; d_viewbuffer[d_scantable[new[1]] + new[0]] = pix;
d_viewbuffer[d_scantable[fv->v[1]] + fv->v[0]] = pix;
}
}
} }
nodraw:
// recursively continue
D_PolysetRecursiveTriangle (lp3, lp1, new);
D_PolysetRecursiveTriangle (lp3, new, lp2);
} }
@ -282,79 +363,47 @@ D_DrawNonSubdiv (void)
void void
D_PolysetRecursiveTriangle (int *lp1, int *lp2, int *lp3) D_PolysetDraw (void)
{ {
int *temp; spanpackage_t spans[DPS_MAXSPANS + 1 +
int d; ((CACHE_SIZE - 1) / sizeof (spanpackage_t)) + 1];
int new[6];
int z;
short *zbuf;
d = lp2[0] - lp1[0]; // one extra because of cache line pretouching
if (d < -1 || d > 1)
goto split;
d = lp2[1] - lp1[1];
if (d < -1 || d > 1)
goto split;
d = lp3[0] - lp2[0]; a_spans = (spanpackage_t *)
if (d < -1 || d > 1) (((long) &spans[0] + CACHE_SIZE - 1) & ~(CACHE_SIZE - 1));
goto split2;
d = lp3[1] - lp2[1];
if (d < -1 || d > 1)
goto split2;
d = lp1[0] - lp3[0]; if (r_affinetridesc.drawtype) {
if (d < -1 || d > 1) D_DrawSubdiv ();
goto split3; } else {
d = lp1[1] - lp3[1]; D_DrawNonSubdiv ();
if (d < -1 || d > 1) { }
split3:
temp = lp1;
lp1 = lp3;
lp3 = lp2;
lp2 = temp;
goto split;
} }
return; // entire tri is filled
split2: void
temp = lp1; D_PolysetDrawFinalVerts (finalvert_t *fv, int numverts)
lp1 = lp2; {
lp2 = lp3; int i, z;
lp3 = temp; short *zbuf;
split: for (i = 0; i < numverts; i++, fv++) {
// split this edge // valid triangle coordinates for filling can include the bottom and
new[0] = (lp1[0] + lp2[0]) >> 1; // right clip edges, due to the fill rule; these shouldn't be drawn
new[1] = (lp1[1] + lp2[1]) >> 1; if ((fv->v[0] < r_refdef.vrectright) &&
new[2] = (lp1[2] + lp2[2]) >> 1; (fv->v[1] < r_refdef.vrectbottom)) {
new[3] = (lp1[3] + lp2[3]) >> 1; z = fv->v[5] >> 16;
new[5] = (lp1[5] + lp2[5]) >> 1; zbuf = zspantable[fv->v[1]] + fv->v[0];
// draw the point if splitting a leading edge
if (lp2[1] > lp1[1])
goto nodraw;
if ((lp2[1] == lp1[1]) && (lp2[0] < lp1[0]))
goto nodraw;
z = new[5] >> 16;
zbuf = zspantable[new[1]] + new[0];
if (z >= *zbuf) { if (z >= *zbuf) {
int pix; int pix;
*zbuf = z; *zbuf = z;
pix = d_pcolormap[skintable[new[3] >> 16][new[2] >> 16]]; pix = skintable[fv->v[3] >> 16][fv->v[2] >> 16];
d_viewbuffer[d_scantable[new[1]] + new[0]] = pix; pix = ((byte *) acolormap)[pix + (fv->v[4] & 0xFF00)];
d_viewbuffer[d_scantable[fv->v[1]] + fv->v[0]] = pix;
}
}
} }
nodraw:
// recursively continue
D_PolysetRecursiveTriangle (lp3, lp1, new);
D_PolysetRecursiveTriangle (lp3, new, lp2);
} }
#endif // !USE_INTEL_ASM #endif // !USE_INTEL_ASM
@ -836,55 +885,6 @@ D_RasterizeAliasPolySmooth (void)
} }
void
D_PolysetSetEdgeTable (void)
{
int edgetableindex;
// assume the vertices are already in top to bottom order
edgetableindex = 0;
// determine which edges are right & left, and the order in which
// to rasterize them
if (r_p0[1] >= r_p1[1]) {
if (r_p0[1] == r_p1[1]) {
if (r_p0[1] < r_p2[1])
pedgetable = &edgetables[2];
else
pedgetable = &edgetables[5];
return;
} else {
edgetableindex = 1;
}
}
if (r_p0[1] == r_p2[1]) {
if (edgetableindex)
pedgetable = &edgetables[8];
else
pedgetable = &edgetables[9];
return;
} else if (r_p1[1] == r_p2[1]) {
if (edgetableindex)
pedgetable = &edgetables[10];
else
pedgetable = &edgetables[11];
return;
}
if (r_p0[1] > r_p2[1])
edgetableindex += 2;
if (r_p1[1] > r_p2[1])
edgetableindex += 4;
pedgetable = &edgetables[edgetableindex];
}
#if 0 #if 0
void void

View file

@ -755,12 +755,12 @@ CreateHulls (void)
if (!fork ()) { if (!fork ()) {
hullnum = 1; hullnum = 1;
options.verbosity = 0; options.verbosity = 0;
drawflag = false; options.drawflag = false;
sprintf (argv0, "HUL%i", hullnum); sprintf (argv0, "HUL%i", hullnum);
} else if (!fork ()) { } else if (!fork ()) {
hullnum = 2; hullnum = 2;
options.verbosity = 0; options.verbosity = 0;
drawflag = false; options.drawflag = false;
sprintf (argv0, "HUL%i", hullnum); sprintf (argv0, "HUL%i", hullnum);
} }
CreateSingleHull (); CreateSingleHull ();

View file

@ -81,8 +81,8 @@ dump_defs (qfo_t *qfo)
qfo_func_t *func; qfo_func_t *func;
for (def = qfo->defs; def - qfo->defs < qfo->num_defs; def++) { for (def = qfo->defs; def - qfo->defs < qfo->num_defs; def++) {
printf ("%5d %4d %4x %d %s %s %d %d %s:%d\n", printf ("%5ld %4d %4x %d %s %s %d %d %s:%d\n",
def - qfo->defs, (long) (def - qfo->defs),
def->ofs, def->ofs,
def->flags, def->flags,
def->basic_type, def->basic_type,

View file

@ -48,7 +48,7 @@ static const char rcsid[] =
static const char * static const char *
strpool_get_key (void *_str, void *_strpool) strpool_get_key (void *_str, void *_strpool)
{ {
int str = (long) _str; long str = (long) _str;
strpool_t *strpool = (strpool_t *) _strpool; strpool_t *strpool = (strpool_t *) _strpool;
return strpool->strings + str; return strpool->strings + str;
@ -70,7 +70,7 @@ strpool_new (void)
strpool_t * strpool_t *
strpool_build (const char *strings, int size) strpool_build (const char *strings, int size)
{ {
int s; long s;
strpool_t *strpool = malloc (sizeof (strpool_t)); strpool_t *strpool = malloc (sizeof (strpool_t));
strpool->str_tab = Hash_NewTable (16381, strpool_get_key, 0, strpool); strpool->str_tab = Hash_NewTable (16381, strpool_get_key, 0, strpool);
@ -96,7 +96,7 @@ strpool_delete (strpool_t *strpool)
int int
strpool_addstr (strpool_t *strpool, const char *str) strpool_addstr (strpool_t *strpool, const char *str)
{ {
int s; long s;
int len; int len;
if (!str || !*str) if (!str || !*str)

View file

@ -53,26 +53,26 @@ output_def (FILE *out, const char *line)
; ;
if (strncmp ("int", type, type_e - type) == 0) { if (strncmp ("int", type, type_e - type) == 0) {
fprintf (out, "\t{ev_entity | DEF_SAVEGLOBAL,\t%d,\t\"%.*s\"},\n", fprintf (out, "\t{ev_entity | DEF_SAVEGLOBAL,\t%d,\t\"%.*s\"},\n",
offset, name_e - name, name); offset, (int) (name_e - name), name);
offset += 1; offset += 1;
} else if (strncmp ("float", type, type_e - type) == 0) { } else if (strncmp ("float", type, type_e - type) == 0) {
fprintf (out, "\t{ev_float | DEF_SAVEGLOBAL,\t%d,\t\"%.*s\"},\n", fprintf (out, "\t{ev_float | DEF_SAVEGLOBAL,\t%d,\t\"%.*s\"},\n",
offset, name_e - name, name); offset, (int) (name_e - name), name);
offset += 1; offset += 1;
} else if (strncmp ("string_t", type, type_e - type) == 0) { } else if (strncmp ("string_t", type, type_e - type) == 0) {
fprintf (out, "\t{ev_string | DEF_SAVEGLOBAL,\t%d,\t\"%.*s\"},\n", fprintf (out, "\t{ev_string | DEF_SAVEGLOBAL,\t%d,\t\"%.*s\"},\n",
offset, name_e - name, name); offset, (int) (name_e - name), name);
offset += 1; offset += 1;
} else if (strncmp ("vec3_t", type, type_e - type) == 0) { } else if (strncmp ("vec3_t", type, type_e - type) == 0) {
fprintf (out, "\t{ev_vector | DEF_SAVEGLOBAL,\t%d,\t\"%.*s\"},\n", fprintf (out, "\t{ev_vector | DEF_SAVEGLOBAL,\t%d,\t\"%.*s\"},\n",
offset, name_e - name, name); offset, (int) (name_e - name), name);
offset += 3; offset += 3;
} else if (strncmp ("func_t", type, type_e - type) == 0) { } else if (strncmp ("func_t", type, type_e - type) == 0) {
fprintf (out, "\t{ev_func,\t%d,\t\"%.*s\"},\n", fprintf (out, "\t{ev_func,\t%d,\t\"%.*s\"},\n",
offset, name_e - name, name); offset, (int) (name_e - name), name);
offset += 1; offset += 1;
} else { } else {
fprintf (stderr, "unknown type %.*s\n", type_e - type, type); fprintf (stderr, "unknown type %.*s\n", (int) (type_e - type), type);
exit (1); exit (1);
} }
} }

View file

@ -81,7 +81,7 @@ RunThreadsOn (threadfunc_t *func)
pthread_t work_threads[256]; pthread_t work_threads[256];
void *status; void *status;
pthread_attr_t attrib; pthread_attr_t attrib;
int i; long i;
if (pthread_attr_init (&attrib) == -1) if (pthread_attr_init (&attrib) == -1)
fprintf (stderr, "pthread_attr_init failed"); fprintf (stderr, "pthread_attr_init failed");
@ -89,7 +89,8 @@ RunThreadsOn (threadfunc_t *func)
fprintf (stderr, "pthread_attr_setstacksize failed"); fprintf (stderr, "pthread_attr_setstacksize failed");
for (i = 0; i < options.threads; i++) { for (i = 0; i < options.threads; i++) {
if (pthread_create (&work_threads[i], &attrib, func, (void *) i) == -1) if (pthread_create (&work_threads[i], &attrib, func,
(void *) i) == -1)
fprintf (stderr, "pthread_create failed"); fprintf (stderr, "pthread_create failed");
} }

View file

@ -114,7 +114,7 @@ NewWinding (int points)
if (points > MAX_POINTS_ON_WINDING) if (points > MAX_POINTS_ON_WINDING)
Sys_Error ("NewWinding: %i points", points); Sys_Error ("NewWinding: %i points", points);
size = (int) ((winding_t *) 0)->points[points]; size = (long) ((winding_t *) 0)->points[points];
winding = calloc (1, size); winding = calloc (1, size);
return winding; return winding;
@ -133,7 +133,7 @@ CopyWinding (winding_t *winding)
int size; int size;
winding_t *copy; winding_t *copy;
size = (int) ((winding_t *) 0)->points[winding->numpoints]; size = (long) ((winding_t *) 0)->points[winding->numpoints];
copy = malloc (size); copy = malloc (size);
memcpy (copy, winding, size); memcpy (copy, winding, size);
copy->original = false; copy->original = false;
@ -373,7 +373,7 @@ LeafFlow (int leafnum)
void void
CalcPortalVis (void) CalcPortalVis (void)
{ {
int i; long i;
// fastvis just uses mightsee for a very loose bound // fastvis just uses mightsee for a very loose bound
if (options.minimal) { if (options.minimal) {