/* s3_defs.h: IBM System/3 simulator definitions | |
Copyright (c) 2001-2005, Charles E. Owen | |
Permission is hereby granted, free of charge, to any person obtaining a | |
copy of this software and associated documentation files (the "Software"), | |
to deal in the Software without restriction, including without limitation | |
the rights to use, copy, modify, merge, publish, distribute, sublicense, | |
and/or sell copies of the Software, and to permit persons to whom the | |
Software is furnished to do so, subject to the following conditions: | |
The above copyright notice and this permission notice shall be included in | |
all copies or substantial portions of the Software. | |
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | |
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | |
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL | |
ROBERT M SUPNIK BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER | |
IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN | |
CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | |
Except as contained in this notice, the name of Charles E. Owen shall not be | |
used in advertising or otherwise to promote the sale, use or other dealings | |
in this Software without prior written authorization from Charles E. Owen. | |
*/ | |
#include "sim_defs.h" /* simulator defns */ | |
/* Simulator stop codes */ | |
#define STOP_RSRV 1 /* must be 1 */ | |
#define STOP_HALT 2 /* HALT */ | |
#define STOP_IBKPT 3 /* breakpoint */ | |
#define STOP_INVOP 4 /* program check - invalid op */ | |
#define STOP_INVQ 5 /* Prog check - invalid Q */ | |
#define STOP_INVADDR 6 /* Prog check - invalid addr */ | |
#define STOP_INVDEV 7 /* Prog check - invalid dev cmd */ | |
#define STOP_NOCD 8 /* ATTN card reader */ | |
#define RESET_INTERRUPT 77 /* special return from SIO */ | |
/* Memory */ | |
#define MAXMEMSIZE 65536 /* max memory size */ | |
#define AMASK (MAXMEMSIZE - 1) /* logical addr mask */ | |
#define PAMASK (MAXMEMSIZE - 1) /* physical addr mask */ | |
#define MEMSIZE (cpu_unit.capac) /* actual memory size */ | |
#define MAX_DECIMAL_DIGITS 31 /* max size of a decimal number */ | |
#define CDR_WIDTH 80 /* Max card size */ | |
#define CDP_WIDTH 80 /* Punch width */ | |
#define LPT_WIDTH 132 | |
#define CCT_LNT 132 | |
#define DSK_SECTSIZE 256 /* Sector length */ | |
#define DSK_CYLSIZE 256*48 /* Cylinder length */ | |
/* I/O structure | |
The I/O structure is tied together by dev_table, indexed by | |
the device number. Each entry in dev_table consists of | |
level Interrupt level for device (0-7) | |
priority Priority for device (1-8) | |
routine IOT action routine | |
*/ | |
struct ndev { | |
int32 level; /* interrupt level */ | |
int32 pri; /* Device priority */ | |
int32 (*routine)(int32, int32, int32, int32); /* dispatch routine */ | |
}; | |
/* Structure to define operation codes */ | |
struct opdef { | |
char op[6]; /* Mnemonic for op */ | |
int32 opmask; /* Bits set on in opcode */ | |
int32 q; /* Qbyte */ | |
int32 form; /* Forms are: | |
0 - 1-byte hex operand | |
1 - 1-byte register addr, A-Addr | |
2 - A-addr,B-addr,Qbyte | |
3 - A-addr,Qbyte | |
4 - da,m,n | |
5 - da,m,n,cc | |
6 - da,m,n,A-addr | |
7 - 1-address implict Q | |
8 - 2-address implict Q */ | |
int32 group; /* Group Code: | |
0 - Command Format (0xFx) | |
1 - 1-address A (0x<C,D,E>x) | |
2 - 2-address (0x<0,1,2,4,5,6,8,9,A>x) | |
3 - 1-address B (0x<3,7,B>x) */ | |
}; |