Add function prototypes.
This commit is contained in:
parent
9979fb37d2
commit
efecff78b9
3 changed files with 37 additions and 35 deletions
|
@ -80,3 +80,18 @@ extern expr_t addr_inf; /* .val (address) up to 23 bits! */
|
|||
extern expr_t immed;
|
||||
|
||||
#define regerr() serror("register error")
|
||||
|
||||
/* Z8000 specific routines */
|
||||
void settype( int type );
|
||||
int twolog(int s);
|
||||
void setmod(int opr);
|
||||
void chtype(int opr, int typerange );
|
||||
void chreg(int opc, int reg);
|
||||
ATYPE checkaddr(valu_t addr );
|
||||
void emit_ad(expr_t ad_inf);
|
||||
void ldmcode(int wrd1,int wrd2, int num);
|
||||
valu_t adjust(valu_t absval);
|
||||
void branch(int opc,expr_t exp);
|
||||
void ldrel(int opc,expr_t exp);
|
||||
void shiftcode(int w1, int w2);
|
||||
void argerr(void);
|
||||
|
|
|
@ -91,7 +91,7 @@ f2 : F2_1 reg ',' src
|
|||
if ( oprtype[ SRC ] == IM
|
||||
&& ( $1 == 0x0B00 || $1 == 0x0A00 ) )
|
||||
/* cp or cpb */
|
||||
{ setmode( DST );
|
||||
{ setmod( DST );
|
||||
emit2( mode | $1 + 0x201 | $2<<4 );
|
||||
break;
|
||||
}
|
||||
|
@ -182,7 +182,7 @@ f2 : F2_1 reg ',' src
|
|||
}
|
||||
break;
|
||||
case REG: case IR: case DA: case X:
|
||||
setmode( SRC );
|
||||
setmod( SRC );
|
||||
emit2( mode | 0x2000 | $1 | $4<<4 | $2 );
|
||||
if ( mode>>12 == 4 ) emit_ad( addr_inf );
|
||||
break;
|
||||
|
@ -202,7 +202,7 @@ f2 : F2_1 reg ',' src
|
|||
if ( oprtype[ SRC ] == REG )
|
||||
{ switch( oprtype[ DST ] )
|
||||
{ case IR: case DA: case X:
|
||||
setmode( DST );
|
||||
setmod( DST );
|
||||
emit2( mode | 0x2E00 | $1 | $2<<4 | $4 );
|
||||
if ( mode>>12 == 4 ) emit_ad( addr_inf );
|
||||
break;
|
||||
|
@ -252,7 +252,7 @@ f2 : F2_1 reg ',' src
|
|||
emit4( immed.val );
|
||||
break;
|
||||
case REG: case IR: case DA: case X:
|
||||
setmode( SRC );
|
||||
setmod( SRC );
|
||||
emit2( mode | 0x1400 | $4<<4 | $2 );
|
||||
if ( mode>>12 == 4 ) emit_ad( addr_inf );
|
||||
break;
|
||||
|
@ -272,7 +272,7 @@ f2 : F2_1 reg ',' src
|
|||
if ( oprtype[ SRC ] == REG )
|
||||
{ switch( oprtype[ DST ] )
|
||||
{ case IR: case DA: case X:
|
||||
setmode( DST );
|
||||
setmod( DST );
|
||||
emit2( mode | 0x1D00 | $2<<4 | $4 );
|
||||
if ( mode>>12 == 4 ) emit_ad( addr_inf );
|
||||
break;
|
||||
|
|
|
@ -4,37 +4,33 @@
|
|||
*/
|
||||
#define RCSID5 "$Id$"
|
||||
|
||||
settype( type )
|
||||
int type;
|
||||
void settype( int type )
|
||||
{ oprtype[ operand ] = type; }
|
||||
|
||||
|
||||
int twolog( s )
|
||||
int s;
|
||||
int twolog(int s)
|
||||
{ int twopower = 0;
|
||||
while ( (s>>=1) != 0 ) twopower++;
|
||||
return( twopower );
|
||||
}
|
||||
|
||||
|
||||
setmode( opr )
|
||||
int opr;
|
||||
{ mode = modetbl[ twolog( oprtype[opr] ) ] << 12; }
|
||||
void setmod(int opr)
|
||||
{
|
||||
mode = modetbl[ twolog( oprtype[opr] ) ] << 12;
|
||||
}
|
||||
|
||||
|
||||
chtype( opr, typerange )
|
||||
int opr,
|
||||
typerange;
|
||||
void chtype(int opr, int typerange )
|
||||
/* Check type of 'opr' with given 'typerange' and
|
||||
** set the global var 'mode'.
|
||||
*/
|
||||
{ if ( (oprtype[opr] & typerange) != oprtype[opr] ) argerr();
|
||||
else /* We have a permitted type for 'opr'. */ setmode( opr );
|
||||
else /* We have a permitted type for 'opr'. */ setmod( opr );
|
||||
}
|
||||
|
||||
|
||||
chreg( opc, reg )
|
||||
int opc, reg;
|
||||
void chreg(int opc, int reg)
|
||||
{ switch( opc ) {
|
||||
case 0xB10A: case 0x1B00: case 0x1900:
|
||||
/* R32 expected */ if (reg & 1) regerr(); break;
|
||||
|
@ -43,8 +39,7 @@ int opc, reg;
|
|||
}
|
||||
}
|
||||
|
||||
ATYPE checkaddr( addr )
|
||||
valu_t addr;
|
||||
ATYPE checkaddr( valu_t addr )
|
||||
/* Called by functions emit_ad() and branch(). */
|
||||
{ ATYPE addr_struct;
|
||||
|
||||
|
@ -57,8 +52,7 @@ valu_t addr;
|
|||
return( addr_struct );
|
||||
}
|
||||
|
||||
emit_ad( ad_inf )
|
||||
expr_t ad_inf;
|
||||
void emit_ad(expr_t ad_inf)
|
||||
/* When the type of an operand is 'da' or 'x' this function
|
||||
** emits the address.
|
||||
*/
|
||||
|
@ -75,8 +69,7 @@ expr_t ad_inf;
|
|||
}
|
||||
|
||||
|
||||
ldmcode( wrd1, wrd2, num )
|
||||
int wrd1, wrd2, num;
|
||||
void ldmcode(int wrd1,int wrd2, int num)
|
||||
{ fit(fit4(num-1));
|
||||
emit2( mode | wrd1 );
|
||||
emit2( wrd2<<8 | num-1 );
|
||||
|
@ -84,8 +77,7 @@ int wrd1, wrd2, num;
|
|||
}
|
||||
|
||||
|
||||
valu_t adjust( absval )
|
||||
valu_t absval;
|
||||
valu_t adjust(valu_t absval)
|
||||
{ valu_t val = absval - DOTVAL - 2;
|
||||
|
||||
if ( pass == PASS_2 && val > 0 ) val -= DOTGAIN;
|
||||
|
@ -93,9 +85,7 @@ valu_t absval;
|
|||
}
|
||||
|
||||
|
||||
branch( opc, exp )
|
||||
int opc;
|
||||
expr_t exp;
|
||||
void branch(int opc,expr_t exp)
|
||||
/* This routine determines for the F3 format instructions whether the
|
||||
** relative address is small enough to fit in normal code; If this is
|
||||
** so normal code is emitted otherwise 'long' code is emitted contai-
|
||||
|
@ -145,9 +135,7 @@ expr_t exp;
|
|||
}
|
||||
|
||||
|
||||
ldrel( opc, exp )
|
||||
int opc;
|
||||
expr_t exp;
|
||||
void ldrel(int opc,expr_t exp)
|
||||
/* This routine determines for the F4 format instructions whether the
|
||||
** address is within the same segment (meaning a relative address of
|
||||
** less than 16 bits); If this is so normal code is emitted otherwise
|
||||
|
@ -160,8 +148,7 @@ expr_t exp;
|
|||
}
|
||||
|
||||
|
||||
shiftcode( w1, w2 )
|
||||
int w1, w2;
|
||||
void shiftcode(int w1, int w2)
|
||||
{ switch( w1 & 0x0F04 )
|
||||
{ /* Remember: w2 negative means right shift ! */
|
||||
case 0x200: /*byte*/ fit( w2>=-8 && w2<=8 ); break;
|
||||
|
@ -173,5 +160,5 @@ int w1, w2;
|
|||
}
|
||||
|
||||
|
||||
argerr()
|
||||
void argerr(void)
|
||||
{ serror( "illegal operand" ); }
|
||||
|
|
Loading…
Reference in a new issue