/* texmfmem.h: the memory_word type, which is too hard to translate
automatically from Pascal. We have to make sure the byte-swapping
that the (un)dumping routines do suffices to put things in the right
place in memory.
A memory_word can be broken up into a `twohalves' or a
`fourquarters', and a `twohalves' can be further broken up. Here is
a picture. ..._M = most significant byte, ..._L = least significant
byte.
The halfword fields are four bytes if we are building a big TeX or MF;
this leads to further complications:
BigEndian:
twohalves.v: RH_MM RH_ML RH_LM RH_LL LH_MM LH_ML LH_LM LH_LL
twohalves.u: ---------JUNK---------- B0 B1
fourquarters: B0 B1 B2 B3
LittleEndian:
twohalves.v: LH_LL LH_LM LH_ML LH_MM RH_LL RH_LM RH_ML RH_MM
twohalves.u: B1 B0
fourquarters: ---------JUNK---------- B3 B2 B1 B0
I guess TeX and Metafont never refer to the B1 and B0 in the
fourquarters structure as the B1 and B0 in the twohalves.u structure.
The B0 and B1 fields are declared short instead of quarterword,
because they are used in character nodes to store a font number and a
character. If left as a quarterword (which is a single byte), we
couldn't support more than 256 fonts. (If shorts aren't two bytes,
this will lose.)
In the old four-byte memory structure (something more needs to be
done to handle >256 fonts):
If BigEndian:
twohalves.v: RH_M RH_L LH_M LH_L
twohalves.u: JNK1 JNK2 B0 B1
fourquarters: B0 B1 B2 B3
If LittleEndian:
twohalves.v: LH_L LH_M RH_L RH_M
twohalves.u: B1 B0 JNK1 JNK2
fourquarters: B3 B2 B1 B0
In Omega, quarterwords are two octets, so the picture becomes simpler:
BigEndian:
twohalves.v: RH_MM RH_ML RH_LM RH_LL LH_MM LH_ML LH_LM LH_LL
twohalves.u: ---------JUNK---------- ----B0----- ----B1-----
fourquarters: ----B0----- ----B1----- ----B2----- ----B3-----
twoints: ---------CINT0--------- ---------CINT1---------
LittleEndian:
twohalves.v: LH_LL LH_LM LH_ML LH_MM RH_LL RH_LM RH_ML RH_MM
twohalves.u: ----B1----- ----B0-----
fourquarters: ----B3----- ----B2----- ----B1----- ----B0-----
twoints: ---------CINT1--------- ---------CINT0---------
This file can't be part of texmf.h, because texmf.h gets included by
{tex,mf,mp}d.h before the `halfword' etc. types are defined. So we
include it from the change file instead.
*/
typedef union
{
struct
{
#ifdef WORDS_BIGENDIAN
halfword RH, LH;
#else
halfword LH, RH;
#endif
} v;
struct
{ /* Make B0,B1 overlap the most significant bytes of LH. */
#ifdef WORDS_BIGENDIAN
halfword junk;
short B0, B1;
#else /* not WORDS_BIGENDIAN */
/* If 32-bit memory words, have to do something. */
#if defined (SMALLTeX) || defined (SMALLMF) || defined (SMALLMP)
fixme
#else
short B1, B0;
#endif /* big memory words */
#endif /* LittleEndian */
} u;
} twohalves;
typedef struct
{
struct
{
#ifdef WORDS_BIGENDIAN
quarterword B0, B1, B2, B3;
#else
quarterword B3, B2, B1, B0;
#endif
} u;
} fourquarters;
/* Omega is sufficiently different to separate the definition. */
#ifndef Omega
typedef union
{
#ifdef TeX
glueratio gr;
twohalves hh;
#else
twohalves hhfield;
#endif
#ifdef WORDS_BIGENDIAN
integer cint;
fourquarters qqqq;
#else /* not WORDS_BIGENDIAN */
struct
{
#if defined (TeX) && !defined (SMALLTeX) || defined (MF) && !defined (SMALLMF) || defined (MP) && !defined (SMALLMP)
halfword junk;
#endif /* big {TeX,MF,MP} */
integer CINT;
} u;
struct
{
#if defined (TeX) && !defined (SMALLTeX) || defined (MF) && !defined (SMALLMF) || defined (MP) && !defined (SMALLMP)
halfword junk;
#endif /* big {TeX,MF,MP} */
fourquarters QQQQ;
} v;
#endif /* not WORDS_BIGENDIAN */
} memoryword;
/* fmemory_word for font_list; needs to be only four bytes. This saves
significant space in the .fmt files. */
typedef union
{
#ifdef WORDS_BIGENDIAN
integer cint;
fourquarters qqqq;
#else /* not WORDS_BIGENDIAN */
struct
{
integer CINT;
} u;
struct
{
fourquarters QQQQ;
} v;
#endif /* not WORDS_BIGENDIAN */
} fmemoryword;
/* To keep the original structure accesses working, we must go through
the extra names C forced us to introduce. */
#define b0 u.B0
#define b1 u.B1
#define b2 u.B2
#define b3 u.B3
#define rh v.RH
#define lhfield v.LH
#ifndef WORDS_BIGENDIAN
#define cint u.CINT
#define qqqq v.QQQQ
#endif
#else /* Omega */
typedef struct
{
#ifdef WORDS_BIGENDIAN
integer CINT0, CINT1;
#else
integer CINT1, CINT0;
#endif
} twoints;
typedef struct
{
glueratio GLUE;
} glues;
typedef union
{
twohalves hh;
fourquarters qqqq;
twoints ii;
glues gg;
} memoryword;
#define b0 u.B0
#define b1 u.B1
#define b2 u.B2
#define b3 u.B3
#define rh v.RH
#define lhfield v.LH
#define cint ii.CINT0
#define cint1 ii.CINT1
#define gr gg.GLUE
#endif /* Omega */
|