ref: 460f482ad05aeb12a7ed3bb92adeb03d8c6e4c0a
parent: 3a322e9f329909c3c751de6cb5da33e7280c2738
author: cinap_lenrek <[email protected]>
date: Thu Sep 4 19:02:37 EDT 2014
doom: fix alignment issues for arm
--- a/sys/src/games/doom/doomdata.h
+++ b/sys/src/games/doom/doomdata.h
@@ -211,7 +211,6 @@
short options;
} mapthing_t;
-
#pragma pack off
--- a/sys/src/games/doom/f_wipe.c
+++ b/sys/src/games/doom/f_wipe.c
@@ -184,7 +184,7 @@
width/=2;
- while (ticks--)
+ while (ticks-- >= 0)
{
for (i=0;i<width;i++)
{
--- a/sys/src/games/doom/p_mobj.c
+++ b/sys/src/games/doom/p_mobj.c
@@ -396,7 +396,7 @@
// inherit attributes from deceased one
mo = P_SpawnMobj (x,y,z, mobj->type);
- mo->spawnpoint = mobj->spawnpoint;
+ memcpy (&mo->spawnpoint, mthing, sizeof(*mthing));
mo->angle = ANG45 * (mthing->angle/45);
if (mthing->options & MTF_AMBUSH)
@@ -552,7 +552,7 @@
&& (mobj->type != MT_INV)
&& (mobj->type != MT_INS))
{
- itemrespawnque[iquehead] = mobj->spawnpoint;
+ memcpy (&itemrespawnque[iquehead], &mobj->spawnpoint, sizeof(mobj->spawnpoint));
itemrespawntime[iquehead] = leveltime;
iquehead = (iquehead+1)&(ITEMQUESIZE-1);
@@ -625,7 +625,7 @@
z = ONFLOORZ;
mo = P_SpawnMobj (x,y,z, i);
- mo->spawnpoint = *mthing;
+ memcpy (&mo->spawnpoint, mthing, sizeof(*mthing));
mo->angle = ANG45 * (mthing->angle/45);
// pull it from the que
@@ -728,10 +728,10 @@
}
// check for players specially
- if (mthing->type <= 4)
+ if (mthing->type <= MAXPLAYERS)
{
// save spots for respawning in network games
- playerstarts[mthing->type-1] = *mthing;
+ memcpy (&playerstarts[mthing->type-1], mthing, sizeof(*mthing));
if (!deathmatch)
P_SpawnPlayer (mthing);
@@ -784,7 +784,7 @@
z = ONFLOORZ;
mobj = P_SpawnMobj (x,y,z, i);
- mobj->spawnpoint = *mthing;
+ memcpy (&mobj->spawnpoint, mthing, sizeof(*mthing));
if (mobj->tics > 0)
mobj->tics = 1 + (P_Random () % mobj->tics);
--- a/sys/src/games/doom/r_data.c
+++ b/sys/src/games/doom/r_data.c
@@ -91,6 +91,7 @@
mappatch_t patches[1];
} maptexture_t;
+#pragma pack off
/* A single patch from a texture definition,
** basically a rectangular area within
@@ -125,10 +126,6 @@
short patchcount;
texpatch_t patches[1];
} texture_t;
-
-
-#pragma pack off
-
int firstflat;
int lastflat;
--- a/sys/src/games/doom/r_things.c
+++ b/sys/src/games/doom/r_things.c
@@ -173,12 +173,12 @@
/* char** check; */
int i;
int l;
- int intname;
int frame;
int rotation;
int start;
int end;
int patched;
+ char* name;
/* BUG
This would work if the namelist was NULL terminated which it is not.
@@ -213,13 +213,13 @@
memset (sprtemp,-1, sizeof(sprtemp));
maxframe = -1;
- intname = *(int *)namelist[i];
+ name = namelist[i];
// scan the lumps,
// filling in the frames for whatever is found
for (l=start+1 ; l<end ; l++)
{
- if (*(int *)lumpinfo[l].name == intname)
+ if (memcmp(lumpinfo[l].name, name, 4) == 0)
{
frame = lumpinfo[l].name[4] - 'A';
rotation = lumpinfo[l].name[5] - '0';