Category : Assembly Language Source Code
Archive   : CUG292.ZIP
Filename : M11MCH.C

 
Output of file : M11MCH.C contained in archive : CUG292.ZIP
/* m11mch.c */

/*
* (C) Copyright 1989,1990
* All Rights Reserved
*
* Alan R. Baldwin
* 721 Berkeley St.
* Kent, Ohio 44240
*/

#include
#include
#include "asm.h"
#include "m6811.h"

/*
* Process a machine op.
*/
VOID
machine(mp)
struct mne *mp;
{
register op, t1, t2;
struct expr e1, e2, e3;
struct area *espa;
char id[NCPS];
int c, reg, cpg, type, v1, v3;

reg = 0;
cpg = 0;
op = mp->m_valu;
type = mp->m_type;
switch (type) {

case S_SDP:
e1.e_mode = 0;
e1.e_flag = 0;
e1.e_addr = 0;
e1.e_base.e_ap = NULL;
espa = NULL;
if (more()) {
expr(&e1, 0);
if (e1.e_flag == 0 && e1.e_base.e_ap == NULL) {
if (e1.e_addr) {
err('b');
}
}
if ((c = getnb()) == ',') {
getid(id, -1);
espa = alookup(id);
if (espa == NULL) {
err('u');
}
} else {
unget(c);
}
}
if (espa) {
outdp(espa, &e1);
} else {
outdp(dot.s_area, &e1);
}
lmode = SLIST;
break;

case S_INH2:
outab(PAGE2);

case S_INH:
outab(op);
break;

case S_PUL:
v1 = admode(abdxy);
if (v1 == S_A) {
outab(op);
break;
}
if (v1 == S_B) {
outab(op+1);
break;
}
if (v1 == S_X) {
outab(op+6);
break;
}
if (v1 == S_Y) {
outab(PAGE2);
outab(op+6);
break;
}
aerr();
break;

case S_BRA:
expr(&e1, 0);
outab(op);
if (e1.e_base.e_ap == NULL || e1.e_base.e_ap == dot.s_area) {
v1 = e1.e_addr - dot.s_addr - 1;
if ((v1 < -128) || (v1 > 127))
aerr();
outab(v1);
} else {
outrb(&e1, R_PCR);
}
if (e1.e_mode != S_USER)
rerr();
break;

case S_TYP1:
t1 = addr(&e1);
if (t1 == S_A) {
outab(op|A);
break;
}
if (t1 == S_B) {
outab(op|B);
break;
}
if (t1 == S_D) {
if (op == 0x44) {
outab(0x04);
break;
}
if (op == 0x48) {
outab(0x05);
break;
}
aerr();
break;
}
if (t1 == S_INDX || t1 == S_INDY) {
if (t1 == S_INDY)
outab(PAGE2);
outab(op|X);
outrb(&e1, R_USGN);
break;
}
if (t1 == S_DIR || t1 == S_EXT) {
outab(op|0x30);
outrw(&e1, 0);
break;
}
aerr();
break;

case S_TYP2:
if ((reg = admode(abdxy)) == 0)
aerr();

case S_TYP3:
if (!reg) {
reg = op & 0x40;
} else
if (reg == S_A) {
reg = 0x00;
} else
if (reg == S_B) {
reg = 0x40;
} else
if (reg == S_D) {
if (op == 0x80) {
op = 0x83;
} else
if (op == 0x8B) {
op = 0xC3;
} else {
aerr();
}
reg = 0x00;
} else {
aerr();
reg = 0x00;
}
t1 = addr(&e1);
if (t1 == S_IMMED) {
if ((op|0x40) == 0xC7)
aerr();
if (op == 0x83 || op == 0xC3) {
outab(op|reg);
outrw(&e1, 0);
} else {
outab(op|reg);
outrb(&e1, 0);
}
break;
}
if (t1 == S_DIR) {
outab(op|reg|0x10);
outrb(&e1, R_PAG0);
break;
}
if (t1 == S_INDX || t1 == S_INDY) {
if (t1 == S_INDY)
outab(PAGE2);
outab(op|reg|0x20);
outrb(&e1, R_USGN);
break;
}
if (t1 == S_EXT) {
outab(op|reg|0x30);
outrw(&e1, 0);
break;
}
aerr();
break;

case S_TYP4:
t1 = addr(&e1);
if (t1 == S_IMMED) {
if (op&0x0D == 0x0D)
aerr();
outab(op);
outrw(&e1, 0);
break;
}
if (t1 == S_DIR) {
outab(op|0x10);
outrb(&e1, R_PAG0);
break;
}
if (t1 == S_INDX || t1 == S_INDY) {
if (t1 == S_INDY)
outab(PAGE2);
outab(op|0x20);
outrb(&e1, R_USGN);
break;
}
if (t1 == S_EXT) {
outab(op|0x30);
outrw(&e1, 0);
break;
}
aerr();
break;

case S_TYP5:
t1 = addr(&e1);
if (t1 == S_INDX || t1 == S_INDY) {
if (t1 == S_INDY)
outab(PAGE2);
outab(op);
outrb(&e1, R_USGN);
break;
}
if (t1 == S_EXT) {
outab(op|0x10);
outrw(&e1, 0);
break;
}
aerr();
break;

case S_PG3:
cpg += (PAGE3-PAGE2);

case S_PG2:
cpg += PAGE2;

case S_TYP6:
t1 = addr(&e1);
if (t1 == S_IMMED) {
if (op == 0xCF)
aerr();
if (cpg)
outab(cpg);
outab(op);
outrw(&e1, 0);
break;
}
if (t1 == S_DIR) {
if (cpg)
outab(cpg);
outab(op|0x10);
outrb(&e1, R_PAG0);
break;
}
if (t1 == S_INDX) {
if (cpg)
outab(PAGE3);
outab(op|0x20);
outrb(&e1, R_USGN);
break;
}
if (t1 == S_INDY) {
if (cpg == PAGE2) {
outab(PAGE2);
} else {
outab(PAGE4);
}
outab(op|0x20);
outrb(&e1, R_USGN);
break;
}
if (t1 == S_EXT) {
if (cpg)
outab(cpg);
outab(op|0x30);
outrw(&e1, 0);
break;
}
aerr();
break;

case S_BTB:
case S_STCLR:
t1 = addr(&e1);
comma();
t2 = addr(&e2);
if (type == S_BTB) {
comma();
expr(&e3, 0);
}
if (t1 == S_DIR) {
outab(op);
outrb(&e1, R_PAG0);
} else
if (t1 == S_INDX || t1 == S_INDY) {
if (type == S_BTB) {
op += 0x0C;
} else {
op += 0x08;
}
if (t1 == S_INDY)
outab(PAGE2);
outab(op);
outrb(&e1, R_USGN);
} else {
outab(op);
outrb(&e1, 0);
aerr();
}
if (t2 != S_IMMED)
aerr();
outrb(&e2, 0);
if (type == S_BTB) {
if (e3.e_base.e_ap == NULL || e3.e_base.e_ap == dot.s_area) {
v3 = e3.e_addr - dot.s_addr - 1;
if ((v3 < -128) || (v3 > 127))
aerr();
outab(v3);
} else {
outrb(&e3, R_PCR);
}
if (e3.e_mode != S_USER)
rerr();
}
break;

default:
err('o');
}
}


/*
* The next character must be a
* comma.
*/
VOID
comma()
{
if (getnb() != ',')
qerr();
}

/*
* Machine dependent initialization
*/
VOID
minit()
{
}


  3 Responses to “Category : Assembly Language Source Code
Archive   : CUG292.ZIP
Filename : M11MCH.C

  1. Very nice! Thank you for this wonderful archive. I wonder why I found it only now. Long live the BBS file archives!

  2. This is so awesome! 😀 I’d be cool if you could download an entire archive of this at once, though.

  3. But one thing that puzzles me is the “mtswslnkmcjklsdlsbdmMICROSOFT” string. There is an article about it here. It is definitely worth a read: http://www.os2museum.com/wp/mtswslnk/