Mark Pizzolato | fffad7c | 2012-03-19 16:05:24 -0700 | [diff] [blame] | 1 | /* vax_syslist.c: VAX device list
|
Bob Supnik | b6393b3 | 2004-11-23 15:49:00 -0800 | [diff] [blame] | 2 |
|
Bob Supnik | 9c4779c | 2009-02-08 09:06:00 -0800 | [diff] [blame] | 3 | Copyright (c) 1998-2008, Robert M Supnik
|
Bob Supnik | b6393b3 | 2004-11-23 15:49:00 -0800 | [diff] [blame] | 4 |
|
| 5 | Permission is hereby granted, free of charge, to any person obtaining a
|
| 6 | copy of this software and associated documentation files (the "Software"),
|
| 7 | to deal in the Software without restriction, including without limitation
|
| 8 | the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
| 9 | and/or sell copies of the Software, and to permit persons to whom the
|
| 10 | Software is furnished to do so, subject to the following conditions:
|
| 11 |
|
| 12 | The above copyright notice and this permission notice shall be included in
|
| 13 | all copies or substantial portions of the Software.
|
| 14 |
|
| 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
| 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
| 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
| 18 | ROBERT M SUPNIK BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
|
| 19 | IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
| 20 | CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
| 21 |
|
Bob Supnik | b7c1eae | 2005-09-09 18:09:00 -0700 | [diff] [blame] | 22 | Except as contained in this notice, the name of Robert M Supnik shall not be
|
| 23 | used in advertising or otherwise to promote the sale, use or other dealings
|
Bob Supnik | b6393b3 | 2004-11-23 15:49:00 -0800 | [diff] [blame] | 24 | in this Software without prior written authorization from Robert M Supnik.
|
| 25 |
|
Bob Supnik | 53d02f7 | 2007-02-03 14:59:00 -0800 | [diff] [blame] | 26 | 17-Oct-06 RMS Re-ordered device list
|
Mark Pizzolato | 6e813b8 | 2012-03-24 19:46:37 -0700 | [diff] [blame] | 27 | 17-May-06 RMS Added CR11/CD11 support (John Dundas)
|
Bob Supnik | b7c1eae | 2005-09-09 18:09:00 -0700 | [diff] [blame] | 28 | 01-Oct-2004 RMS Cloned from vax_sys.c
|
Bob Supnik | b6393b3 | 2004-11-23 15:49:00 -0800 | [diff] [blame] | 29 | */
|
| 30 |
|
| 31 | #include "vax_defs.h"
|
| 32 |
|
| 33 | char sim_name[] = "VAX";
|
| 34 |
|
| 35 | extern DEVICE cpu_dev;
|
| 36 | extern DEVICE tlb_dev;
|
| 37 | extern DEVICE rom_dev;
|
| 38 | extern DEVICE nvr_dev;
|
| 39 | extern DEVICE sysd_dev;
|
| 40 | extern DEVICE qba_dev;
|
| 41 | extern DEVICE tti_dev, tto_dev;
|
Bob Supnik | dc871fa | 2006-05-27 11:34:00 -0700 | [diff] [blame] | 42 | extern DEVICE cr_dev;
|
Bob Supnik | b6393b3 | 2004-11-23 15:49:00 -0800 | [diff] [blame] | 43 | extern DEVICE lpt_dev;
|
| 44 | extern DEVICE clk_dev;
|
| 45 | extern DEVICE rq_dev, rqb_dev, rqc_dev, rqd_dev;
|
| 46 | extern DEVICE rl_dev;
|
| 47 | extern DEVICE ry_dev;
|
| 48 | extern DEVICE ts_dev;
|
| 49 | extern DEVICE tq_dev;
|
| 50 | extern DEVICE dz_dev;
|
| 51 | extern DEVICE csi_dev, cso_dev;
|
| 52 | extern DEVICE xq_dev, xqb_dev;
|
| 53 | extern DEVICE vh_dev;
|
Mark Pizzolato | ecbbcc7 | 2012-11-07 14:50:32 -0800 | [diff] [blame] | 54 | extern DEVICE dmc_dev[];
|
| 55 | extern DEVICE dmp_dev[];
|
Bob Supnik | b6393b3 | 2004-11-23 15:49:00 -0800 | [diff] [blame] | 56 |
|
| 57 | extern int32 sim_switches;
|
Bob Supnik | 1e704bf | 2005-10-15 15:38:00 -0700 | [diff] [blame] | 58 | extern void WriteB (uint32 pa, int32 val);
|
Bob Supnik | b6393b3 | 2004-11-23 15:49:00 -0800 | [diff] [blame] | 59 | extern void rom_wr_B (int32 pa, int32 val);
|
| 60 | extern UNIT cpu_unit;
|
| 61 |
|
| 62 | DEVICE *sim_devices[] = {
|
Bob Supnik | b7c1eae | 2005-09-09 18:09:00 -0700 | [diff] [blame] | 63 | &cpu_dev,
|
| 64 | &tlb_dev,
|
| 65 | &rom_dev,
|
| 66 | &nvr_dev,
|
| 67 | &sysd_dev,
|
| 68 | &qba_dev,
|
Bob Supnik | 53d02f7 | 2007-02-03 14:59:00 -0800 | [diff] [blame] | 69 | &clk_dev,
|
Bob Supnik | b7c1eae | 2005-09-09 18:09:00 -0700 | [diff] [blame] | 70 | &tti_dev,
|
| 71 | &tto_dev,
|
| 72 | &csi_dev,
|
| 73 | &cso_dev,
|
Bob Supnik | b7c1eae | 2005-09-09 18:09:00 -0700 | [diff] [blame] | 74 | &dz_dev,
|
| 75 | &vh_dev,
|
Bob Supnik | dc871fa | 2006-05-27 11:34:00 -0700 | [diff] [blame] | 76 | &cr_dev,
|
Bob Supnik | b7c1eae | 2005-09-09 18:09:00 -0700 | [diff] [blame] | 77 | &lpt_dev,
|
| 78 | &rl_dev,
|
| 79 | &rq_dev,
|
| 80 | &rqb_dev,
|
| 81 | &rqc_dev,
|
| 82 | &rqd_dev,
|
| 83 | &ry_dev,
|
| 84 | &ts_dev,
|
| 85 | &tq_dev,
|
| 86 | &xq_dev,
|
| 87 | &xqb_dev,
|
Mark Pizzolato | ecbbcc7 | 2012-11-07 14:50:32 -0800 | [diff] [blame] | 88 | &dmc_dev[0],
|
| 89 | &dmc_dev[1],
|
| 90 | &dmc_dev[2],
|
| 91 | &dmc_dev[3],
|
| 92 | &dmp_dev[0],
|
Bob Supnik | b7c1eae | 2005-09-09 18:09:00 -0700 | [diff] [blame] | 93 | NULL
|
| 94 | };
|
| 95 |
|
Bob Supnik | b6393b3 | 2004-11-23 15:49:00 -0800 | [diff] [blame] | 96 | /* Binary loader
|
| 97 |
|
| 98 | The binary loader handles absolute system images, that is, system
|
| 99 | images linked /SYSTEM. These are simply a byte stream, with no
|
| 100 | origin or relocation information.
|
| 101 |
|
Bob Supnik | b7c1eae | 2005-09-09 18:09:00 -0700 | [diff] [blame] | 102 | -r load ROM
|
| 103 | -n load NVR
|
| 104 | -o for memory, specify origin
|
Bob Supnik | b6393b3 | 2004-11-23 15:49:00 -0800 | [diff] [blame] | 105 | */
|
| 106 |
|
| 107 | t_stat sim_load (FILE *fileref, char *cptr, char *fnam, int flag)
|
| 108 | {
|
| 109 | t_stat r;
|
| 110 | int32 i;
|
| 111 | uint32 origin, limit;
|
| 112 | extern int32 ssc_cnf;
|
Bob Supnik | b7c1eae | 2005-09-09 18:09:00 -0700 | [diff] [blame] | 113 | #define SSCCNF_BLO 0x80000000
|
Bob Supnik | b6393b3 | 2004-11-23 15:49:00 -0800 | [diff] [blame] | 114 |
|
Bob Supnik | 9c4779c | 2009-02-08 09:06:00 -0800 | [diff] [blame] | 115 | if (flag) /* dump? */
|
| 116 | return SCPE_ARG;
|
Bob Supnik | b7c1eae | 2005-09-09 18:09:00 -0700 | [diff] [blame] | 117 | if (sim_switches & SWMASK ('R')) { /* ROM? */
|
| 118 | origin = ROMBASE;
|
| 119 | limit = ROMBASE + ROMSIZE;
|
| 120 | }
|
| 121 | else if (sim_switches & SWMASK ('N')) { /* NVR? */
|
| 122 | origin = NVRBASE;
|
| 123 | limit = NVRBASE + NVRSIZE;
|
| 124 | ssc_cnf = ssc_cnf & ~SSCCNF_BLO;
|
| 125 | }
|
| 126 | else {
|
| 127 | origin = 0; /* memory */
|
| 128 | limit = (uint32) cpu_unit.capac;
|
| 129 | if (sim_switches & SWMASK ('O')) { /* origin? */
|
| 130 | origin = (int32) get_uint (cptr, 16, 0xFFFFFFFF, &r);
|
Bob Supnik | 9c4779c | 2009-02-08 09:06:00 -0800 | [diff] [blame] | 131 | if (r != SCPE_OK)
|
| 132 | return SCPE_ARG;
|
Bob Supnik | b7c1eae | 2005-09-09 18:09:00 -0700 | [diff] [blame] | 133 | }
|
| 134 | }
|
| 135 | while ((i = getc (fileref)) != EOF) { /* read byte stream */
|
Bob Supnik | 9c4779c | 2009-02-08 09:06:00 -0800 | [diff] [blame] | 136 | if (origin >= limit) /* NXM? */
|
| 137 | return SCPE_NXM;
|
Bob Supnik | b7c1eae | 2005-09-09 18:09:00 -0700 | [diff] [blame] | 138 | if (sim_switches & SWMASK ('R')) /* ROM? */
|
| 139 | rom_wr_B (origin, i); /* not writeable */
|
| 140 | else WriteB (origin, i); /* store byte */
|
| 141 | origin = origin + 1;
|
| 142 | }
|
Bob Supnik | b6393b3 | 2004-11-23 15:49:00 -0800 | [diff] [blame] | 143 | return SCPE_OK;
|
| 144 | }
|
| 145 |
|