- This change introduces a full refactor of the interrupt subsystem for the system board (SBD) and the I/O bus (CIO). Interrupt decode should now be significantly faster, and not require an expensive calculation on every step. - The TIMER device has been split into Rev 2 and Rev 3 implementations. - The optional 3B2/400 Debug Monitor ROMs can now be booted by passing the "DEMON" argument to the 3B2/400 simulator BOOT command. Any of the following will cause the Debug Monitor ROM to be booted instead of the standard 3B2/400 ROM: sim> BOOT DEMON sim> BOOT CPU DEMON sim> BOOT DEMON CPU
80 lines
2.3 KiB
C
80 lines
2.3 KiB
C
/* 3b2_rev3_sys.c: AT&T 3B2/600G system definition
|
|
|
|
Copyright (c) 2020, Seth J. Morabito
|
|
|
|
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 THE AUTHORS OR COPYRIGHT HOLDERS
|
|
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 the author shall
|
|
not be used in advertising or otherwise to promote the sale, use or
|
|
other dealings in this Software without prior written authorization
|
|
from the author.
|
|
*/
|
|
|
|
#include "3b2_defs.h"
|
|
|
|
#include "3b2_cpu.h"
|
|
#include "3b2_csr.h"
|
|
#include "3b2_if.h"
|
|
#include "3b2_iu.h"
|
|
#include "3b2_mau.h"
|
|
#include "3b2_ni.h"
|
|
#include "3b2_ports.h"
|
|
#include "3b2_scsi.h"
|
|
#include "3b2_stddev.h"
|
|
#include "3b2_timer.h"
|
|
|
|
char sim_name[] = "AT&T 3B2/600G";
|
|
|
|
DEVICE *sim_devices[] = {
|
|
&cpu_dev,
|
|
&csr_dev,
|
|
&flt_dev,
|
|
&mmu_dev,
|
|
&mau_dev,
|
|
&timer_dev,
|
|
&tod_dev,
|
|
&nvram_dev,
|
|
&tti_dev,
|
|
&tto_dev,
|
|
&contty_dev,
|
|
&iu_timer_dev,
|
|
&dmac_dev,
|
|
&if_dev,
|
|
&ha_dev,
|
|
&ports_dev,
|
|
&ni_dev,
|
|
NULL
|
|
};
|
|
|
|
void full_reset()
|
|
{
|
|
cpu_reset(&cpu_dev);
|
|
mau_reset(&mau_dev);
|
|
tti_reset(&tti_dev);
|
|
contty_reset(&contty_dev);
|
|
iu_timer_reset(&iu_timer_dev);
|
|
timer_reset(&timer_dev);
|
|
if_reset(&if_dev);
|
|
ha_reset(&ha_dev);
|
|
csr_reset(&csr_dev);
|
|
ports_reset(&ports_dev);
|
|
ni_reset(&ni_dev);
|
|
}
|