Fixed to also handle pseudo instructions
This commit is contained in:
parent
11b54f5d47
commit
3bcec5fe6c
|
@ -24,7 +24,9 @@
|
|||
|
||||
extern char em_flag[]; /* One per EM instruction: indicates parameter kind */
|
||||
extern short em_ptyp[]; /* One per parameter kind: indicates parameter type */
|
||||
static char *C_error;
|
||||
char *C_error;
|
||||
|
||||
PRIVATE C_dopseudo();
|
||||
|
||||
EXPORT int
|
||||
C_out(p)
|
||||
|
@ -60,7 +62,6 @@ C_out(p)
|
|||
/* defining occurrence of an instruction label */
|
||||
C_df_ilb(p->em_ilb);
|
||||
break;
|
||||
#ifdef ____
|
||||
case EM_DEFDLB:
|
||||
/* defining occurrence of a global data label */
|
||||
C_df_dlb(p->em_dlb);
|
||||
|
@ -71,9 +72,8 @@ C_out(p)
|
|||
break;
|
||||
case EM_PSEU:
|
||||
/* pseudo */
|
||||
EM_dopseudo(p);
|
||||
C_dopseudo(p);
|
||||
break;
|
||||
#endif
|
||||
case EM_STARTMES:
|
||||
/* start of a MES pseudo */
|
||||
C_mes_begin((int) (p->em_cst));
|
||||
|
@ -119,3 +119,226 @@ C_out(p)
|
|||
if (C_error) return 0;
|
||||
return 1;
|
||||
}
|
||||
|
||||
PRIVATE
|
||||
C_dopseudo(p)
|
||||
register struct e_instr *p;
|
||||
{
|
||||
|
||||
switch(p->em_opcode) {
|
||||
case ps_exc: {
|
||||
C_error = "EXC not allowed";
|
||||
break;
|
||||
}
|
||||
case ps_hol: {
|
||||
switch(p->em_argtype) {
|
||||
case cst_ptyp:
|
||||
C_hol_cst(EM_holsize,
|
||||
p->em_cst,
|
||||
EM_holinit);
|
||||
break;
|
||||
case ico_ptyp:
|
||||
C_hol_icon(EM_holsize,
|
||||
p->em_string,
|
||||
p->em_size,
|
||||
EM_holinit);
|
||||
break;
|
||||
case uco_ptyp:
|
||||
C_hol_ucon(EM_holsize,
|
||||
p->em_string,
|
||||
p->em_size,
|
||||
EM_holinit);
|
||||
break;
|
||||
case fco_ptyp:
|
||||
C_hol_fcon(EM_holsize,
|
||||
p->em_string,
|
||||
p->em_size,
|
||||
EM_holinit);
|
||||
break;
|
||||
case sof_ptyp:
|
||||
C_hol_dnam(EM_holsize,
|
||||
p->em_dnam,
|
||||
p->em_off,
|
||||
EM_holinit);
|
||||
break;
|
||||
case nof_ptyp:
|
||||
C_hol_dlb(EM_holsize,
|
||||
p->em_dlb,
|
||||
p->em_off,
|
||||
EM_holinit);
|
||||
break;
|
||||
case ilb_ptyp:
|
||||
C_hol_ilb(EM_holsize,
|
||||
p->em_ilb,
|
||||
EM_holinit);
|
||||
break;
|
||||
case pro_ptyp:
|
||||
C_hol_pnam(EM_holsize,
|
||||
p->em_pnam,
|
||||
EM_holinit);
|
||||
break;
|
||||
default:
|
||||
C_error = "Illegal parameter type";
|
||||
break;
|
||||
}
|
||||
break;
|
||||
}
|
||||
case ps_bss: {
|
||||
switch(p->em_argtype) {
|
||||
case cst_ptyp:
|
||||
C_bss_cst(EM_bsssize,
|
||||
p->em_cst,
|
||||
EM_bssinit);
|
||||
break;
|
||||
case ico_ptyp:
|
||||
C_bss_icon(EM_bsssize,
|
||||
p->em_string,
|
||||
p->em_size,
|
||||
EM_bssinit);
|
||||
break;
|
||||
case uco_ptyp:
|
||||
C_bss_ucon(EM_bsssize,
|
||||
p->em_string,
|
||||
p->em_size,
|
||||
EM_bssinit);
|
||||
break;
|
||||
case fco_ptyp:
|
||||
C_bss_fcon(EM_bsssize,
|
||||
p->em_string,
|
||||
p->em_size,
|
||||
EM_bssinit);
|
||||
break;
|
||||
case sof_ptyp:
|
||||
C_bss_dnam(EM_bsssize,
|
||||
p->em_dnam,
|
||||
p->em_off,
|
||||
EM_bssinit);
|
||||
break;
|
||||
case nof_ptyp:
|
||||
C_bss_dlb(EM_bsssize,
|
||||
p->em_dlb,
|
||||
p->em_off,
|
||||
EM_bssinit);
|
||||
break;
|
||||
case ilb_ptyp:
|
||||
C_bss_ilb(EM_bsssize,
|
||||
p->em_ilb,
|
||||
EM_bssinit);
|
||||
break;
|
||||
case pro_ptyp:
|
||||
C_bss_pnam(EM_bsssize,
|
||||
p->em_pnam,
|
||||
EM_bssinit);
|
||||
break;
|
||||
default:
|
||||
C_error = "Illegal parameter type";
|
||||
break;
|
||||
}
|
||||
break;
|
||||
}
|
||||
case ps_end:
|
||||
if (p->em_argtype != 0) {
|
||||
C_end(p->em_cst);
|
||||
break;
|
||||
}
|
||||
C_end_narg();
|
||||
break;
|
||||
case ps_exa:
|
||||
case ps_ina:
|
||||
if (p->em_argtype == nof_ptyp) {
|
||||
if (p->em_opcode == ps_exa) {
|
||||
C_exa_dlb(p->em_dlb);
|
||||
}
|
||||
else C_ina_dlb(p->em_dlb);
|
||||
break;
|
||||
}
|
||||
if (p->em_opcode == ps_exa) {
|
||||
C_exa_dnam(p->em_dnam);
|
||||
}
|
||||
else C_ina_dnam(p->em_dnam);
|
||||
break;
|
||||
case ps_exp:
|
||||
C_exp(p->em_pnam);
|
||||
break;
|
||||
case ps_inp:
|
||||
C_inp(p->em_pnam);
|
||||
break;
|
||||
case ps_pro:
|
||||
if (p->em_nlocals >= 0) {
|
||||
C_pro(p->em_pnam, p->em_nlocals);
|
||||
}
|
||||
else C_pro_narg(p->em_pnam);
|
||||
break;
|
||||
case ps_con:
|
||||
switch(p->em_argtype) {
|
||||
case ilb_ptyp:
|
||||
C_con_ilb(p->em_ilb);
|
||||
break;
|
||||
case nof_ptyp:
|
||||
C_con_dlb(p->em_dlb, p->em_off);
|
||||
break;
|
||||
case sof_ptyp:
|
||||
C_con_dnam(p->em_dnam, p->em_off);
|
||||
break;
|
||||
case cst_ptyp:
|
||||
C_con_cst(p->em_cst);
|
||||
break;
|
||||
case pro_ptyp:
|
||||
C_con_pnam(p->em_pnam);
|
||||
break;
|
||||
case str_ptyp:
|
||||
C_con_scon(p->em_string, p->em_size);
|
||||
break;
|
||||
case ico_ptyp:
|
||||
C_con_icon(p->em_string, p->em_size);
|
||||
break;
|
||||
case uco_ptyp:
|
||||
C_con_ucon(p->em_string, p->em_size);
|
||||
break;
|
||||
case fco_ptyp:
|
||||
C_con_fcon(p->em_string, p->em_size);
|
||||
break;
|
||||
default:
|
||||
C_error = "Illegal argument type";
|
||||
return;
|
||||
}
|
||||
break;
|
||||
case ps_rom:
|
||||
switch(p->em_argtype) {
|
||||
case ilb_ptyp:
|
||||
C_rom_ilb(p->em_ilb);
|
||||
break;
|
||||
case nof_ptyp:
|
||||
C_rom_dlb(p->em_dlb, p->em_off);
|
||||
break;
|
||||
case sof_ptyp:
|
||||
C_rom_dnam(p->em_dnam, p->em_off);
|
||||
break;
|
||||
case cst_ptyp:
|
||||
C_rom_cst(p->em_cst);
|
||||
break;
|
||||
case pro_ptyp:
|
||||
C_rom_pnam(p->em_pnam);
|
||||
break;
|
||||
case str_ptyp:
|
||||
C_rom_scon(p->em_string, p->em_size);
|
||||
break;
|
||||
case ico_ptyp:
|
||||
C_rom_icon(p->em_string, p->em_size);
|
||||
break;
|
||||
case uco_ptyp:
|
||||
C_rom_ucon(p->em_string, p->em_size);
|
||||
break;
|
||||
case fco_ptyp:
|
||||
C_rom_fcon(p->em_string, p->em_size);
|
||||
break;
|
||||
default:
|
||||
C_error = "Illegal argument type";
|
||||
return;
|
||||
}
|
||||
break;
|
||||
default:
|
||||
C_error = "Illegal pseudo instruction";
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue