Maxim Poliakovski
d863fa0c80
Bandit: use common PCI configuration code.
2022-05-21 14:51:27 +02:00
Maxim Poliakovski
1f67a57d7b
Common code for handling PCI config space.
2022-05-21 14:51:26 +02:00
Maxim Poliakovski
9d7d9f3103
MACE: add MaceEnet namespace.
2022-05-21 14:51:26 +02:00
Maxim Poliakovski
8d9691cc6f
MESH: add MeshScsi namespace.
2022-05-21 14:51:26 +02:00
Maxim Poliakovski
6c564cb720
amic: fix MACE register range.
2022-05-21 14:51:26 +02:00
Maxim Poliakovski
4b32e9bd30
Initial emulation of the Platinum Memory controller.
2022-05-21 14:51:26 +02:00
Maxim Poliakovski
23a046d889
Refine Bandit config address handling.
2022-05-21 14:51:26 +02:00
Maxim Poliakovski
cdb34032bc
Initial emulation of the Bandit ARBus-to-PCI bridge.
2022-05-21 14:51:26 +02:00
Maxim Poliakovski
74f4dbd7e6
pcihost: pull common code from Grackle.
2022-05-21 14:51:26 +02:00
Maxim Poliakovski
8889759f33
GrandCentral: improve error logging.
2022-05-21 14:45:33 +02:00
Maxim Poliakovski
533edf6ef5
GrandCentral: properly connect Curio SCSI.
2022-05-17 13:27:58 +02:00
Maxim Poliakovski
b26baaaeff
CharIoStdin: disable SIGINT generation with Ctrl-C.
2022-05-07 23:42:33 +02:00
Maxim Poliakovski
e0b94e0b47
ESCC: connect NULL and STDIO backends.
2022-05-07 21:47:22 +02:00
Maxim Poliakovski
d4c08bbe31
Fix ESCC register addressing.
2022-05-07 21:47:22 +02:00
Maxim Poliakovski
57b102dae2
ATI Mach64 GX controller emulation.
2022-04-13 23:31:44 +02:00
Maxim Poliakovski
0e09ecdfa4
displayid: constructor with parameters.
2022-04-13 23:31:44 +02:00
Maxim Poliakovski
8fcdc5298a
videoctrl: add pixel_depth member.
2022-04-13 23:31:44 +02:00
Maxim Poliakovski
3a4f22f459
Move ATI Mach64 definitions to separate header.
2022-04-13 23:31:44 +02:00
Maxim Poliakovski
b78f17c161
pcidevice: loading of expansion ROMs from files.
2022-04-13 23:31:44 +02:00
Maxim Poliakovski
4bba61a920
Bandit: implement I/O space transactions.
2022-04-13 23:31:44 +02:00
Maxim Poliakovski
d64f901f85
Bandit: implement address mask register.
2022-04-13 23:31:44 +02:00
Maxim Poliakovski
883aac2d05
ofnvram: implement changing of string variables.
2022-04-13 23:27:53 +02:00
Maxim Poliakovski
f6e5d72e3c
videoctrl: fix surface size.
2022-04-13 23:27:53 +02:00
Maxim Poliakovski
c967eb3c65
ATIRage: hack to support OF output.
2022-04-13 23:27:53 +02:00
Maxim Poliakovski
ba8e3b657c
Utility class for viewing/changing OF NVRAM variables.
2022-03-29 01:55:11 +02:00
Maxim Poliakovski
4d87ed9b38
Make NVRAM a full-fledged HW component.
2022-03-29 01:55:11 +02:00
Maxim Poliakovski
d71a7b8694
GrandCentral: basic device interrupt handling.
2022-03-28 18:33:59 +02:00
Maxim Poliakovski
e01d0e3d59
GrandCentral: external SCSI (Curio style).
2022-03-28 18:26:47 +02:00
Maxim Poliakovski
4525fd50cc
GrandCentral: fix access to NVRAM subdevice.
2022-03-28 18:26:47 +02:00
Maxim Poliakovski
29ce960dbf
GrandCentral: access to ESCC and board reg 1.
2022-03-28 18:26:47 +02:00
Maxim Poliakovski
ac5078f133
Platinum: implement memory controller registers.
2022-03-28 18:26:47 +02:00
Maxim Poliakovski
276cd37cfe
Heathrow: interrupt registers & mode 1 interrupts.
2022-03-14 18:13:47 +01:00
Maxim Poliakovski
1500c63e26
Initial emulation of the GrandCentral I/O controller.
2022-03-14 18:13:47 +01:00
Maxim Poliakovski
4c45b3dfa2
Heathrow: use common PCI configuration code.
2022-03-14 18:13:47 +01:00
Maxim Poliakovski
574677490f
MPC106: use common PCI configuration code.
2022-03-14 18:13:47 +01:00
Maxim Poliakovski
e47b66e1af
ATIRage: use common PCI configuration code.
2022-03-14 18:13:47 +01:00
Maxim Poliakovski
73aa68bc30
Bandit: use common PCI configuration code.
2022-03-14 18:13:47 +01:00
Maxim Poliakovski
3bce7bb1ea
Common code for handling PCI config space.
2022-03-14 18:13:47 +01:00
Maxim Poliakovski
6d004f0bf8
MACE: add MaceEnet namespace.
2022-03-14 18:13:47 +01:00
Maxim Poliakovski
e913f39812
MESH: add MeshScsi namespace.
2022-03-14 18:13:47 +01:00
Maxim Poliakovski
3235018260
amic: fix MACE register range.
2022-03-14 18:13:47 +01:00
Maxim Poliakovski
a7e4dc9d83
Initial emulation of the Platinum Memory controller.
2022-03-14 18:13:47 +01:00
Maxim Poliakovski
13f18c416d
Refine Bandit config address handling.
2022-03-14 18:13:47 +01:00
Maxim Poliakovski
400ce0b713
Initial emulation of the Bandit ARBus-to-PCI bridge.
2022-03-14 18:13:47 +01:00
Maxim Poliakovski
289df32817
pcihost: pull common code from Grackle.
2022-03-14 18:13:47 +01:00
dingusdev
36fa53e8c1
MSVC compilation fixes
2022-03-12 15:43:45 -07:00
Maxim Poliakovski
827d7f10dd
pdmonboard: reduce logging messages.
2022-02-26 13:37:47 +01:00
Maxim Poliakovski
4de10898ea
Improve ESCC stub to bypass LocalTalk.
2022-02-26 10:57:13 +01:00
Maxim Poliakovski
205b5a4956
escc: implement reset commands.
2022-02-26 10:57:13 +01:00
Maxim Poliakovski
c946693450
escc: unify compatible and MacRISC addressing.
2022-02-26 10:57:13 +01:00
dingusdev
80a4864a92
Floppy disk write protection
2022-02-24 07:33:30 -07:00
Maxim Poliakovski
edd3979647
Cuda: increase size of the input buffer.
2022-02-19 23:23:24 +01:00
Maxim Poliakovski
689fe51d80
Add required includes for gcc.
2022-02-17 00:50:37 +01:00
Maxim Poliakovski
2ce2cae48c
SWIM3: implement disk reading.
2022-02-15 15:55:16 +01:00
Maxim Poliakovski
579a56f749
AMIC: implement floppy DMA channel.
2022-02-15 15:54:21 +01:00
Maxim Poliakovski
2525398b6e
SWIM3: add support for floppy DMA.
2022-02-15 15:53:18 +01:00
Maxim Poliakovski
e91843034b
Superdrive: method for retrieving disk data.
2022-02-15 15:49:12 +01:00
Maxim Poliakovski
9da4a9ec6a
SWIM3: respect interrupt enable flag in mode register.
2022-02-14 23:06:07 +01:00
Maxim Poliakovski
cfb8977f09
AMIC: implement floppy DMA registers.
2022-02-13 23:47:45 +01:00
Maxim Poliakovski
54107b2aac
SWIM3: track seeking and header reading.
2022-02-13 03:07:32 +01:00
Maxim Poliakovski
8d8cecbaba
Superdrive: implement track seeking.
2022-02-13 03:05:55 +01:00
Maxim Poliakovski
0d3fd01fef
Improve emulation of the VIA timers.
2022-02-13 03:02:17 +01:00
Maxim Poliakovski
9f3f46603f
AMIC: handle SWIM3 interrupts.
2022-02-07 23:10:17 +01:00
Maxim Poliakovski
c77155199b
Superdrive: report track zero status.
2022-02-07 23:05:58 +01:00
Maxim Poliakovski
1872eca44f
SWIM3: implement head stepping.
2022-02-07 23:05:58 +01:00
Maxim Poliakovski
9aaf441625
Superdrive: more commands and status requests.
2022-02-07 15:05:57 +01:00
Maxim Poliakovski
b9fbd9b7c9
Superdrive: support for inserting of virtual disks.
2022-02-06 21:23:20 +01:00
Maxim Poliakovski
5e2f2b12e4
Properly connect Superdrive to SWIM3 and machines.
2022-02-06 15:23:30 +01:00
Maxim Poliakovski
b25b526582
hwcomponent: add floppy disk drive component type.
2022-02-06 15:20:07 +01:00
Maxim Poliakovski
dea863b6e6
Superdrive: support disk-in-drive status.
2022-02-06 03:25:35 +01:00
Maxim Poliakovski
00093bdc95
sc53c94: support interrupts.
2022-02-06 01:50:54 +01:00
Maxim Poliakovski
298135fd7a
AMIC: process VIA2 interrupts.
2022-02-06 01:50:54 +01:00
Maxim Poliakovski
7c53620a40
sc53c94: implement sequencer and some commands.
2022-02-06 01:50:54 +01:00
Maxim Poliakovski
b5f70feb28
Initial SCSI bus emulation.
2022-02-06 01:50:54 +01:00
Maxim Poliakovski
5c177cc50f
Simplify registration of HW component types.
2022-01-26 16:45:21 +01:00
Maxim Poliakovski
dc34f282b7
53C94: support more registers and commands.
2022-01-24 22:55:49 +01:00
Maxim Poliakovski
5883524fb8
53C94: chip initialization and identification.
2022-01-22 04:37:52 +01:00
Maxim Poliakovski
3bdc6f915a
AMIC: implement periodic VBL (60.15 Hz) interrupt.
2022-01-21 12:42:05 +01:00
Maxim Poliakovski
0899186ffc
ViaCuda: implement post-initialization.
2022-01-21 12:42:05 +01:00
Maxim Poliakovski
c1208b398e
Add posti-initialization to HW components.
2022-01-21 12:42:05 +01:00
Maxim Poliakovski
4867a68e11
VIA: public method for asserting control lines.
2022-01-21 11:08:32 +01:00
Maxim Poliakovski
9c4e6c8a86
Rewrite ViaCuda to support SR and T2 interrupts.
2022-01-10 17:56:24 +01:00
Maxim Poliakovski
c218badd5a
Clean up some ctors/dtors.
2022-01-10 17:56:24 +01:00
Maxim Poliakovski
d61d1d71eb
Add interrupt processing to AMIC.
2022-01-10 17:56:24 +01:00
Maxim Poliakovski
d9d8384d4a
Add interrupt controller interface and definitions.
2022-01-10 17:56:24 +01:00
Maxim Poliakovski
d4ecb77b24
pdmonboard: enable periodic video updates.
2022-01-10 17:56:24 +01:00
Maxim Poliakovski
9a0c340712
Basic SWIM3 and Superdrive emulation.
2021-12-12 21:40:04 +01:00
Maxim Poliakovski
9caaf0f538
Basic emulation of the PDM on-board video.
2021-12-07 22:54:03 +01:00
Maxim Poliakovski
476d893094
videoctrl: add framebuffer conversion callback.
2021-12-07 22:47:25 +01:00
Maxim Poliakovski
fff597075d
Monitor type can be now specified from the command line.
2021-12-06 00:40:40 +01:00
Maxim Poliakovski
793335d9b8
Clean up includes.
2021-12-05 20:01:57 +01:00
Maxim Poliakovski
f39188beb1
Initial support for floppy disk images.
2021-12-04 14:22:02 +01:00
Maxim Poliakovski
609fb43726
Rewrite DisplayID to work with AMIC & ATI Rage.
2021-11-30 01:26:32 +01:00
Maxim Poliakovski
99f5aba12e
atirage: replace raw pointers with unique_ptr.
2021-11-17 23:30:43 +01:00
Maxim Poliakovski
cbf4e266e1
atirage: better name for HW registers.
2021-11-11 14:57:31 +01:00
dingusdev
84ded9fc7a
Added further CUDA commands
2021-11-10 07:56:50 -07:00
Maxim Poliakovski
a01cd9c993
Make display ID method selectable in video controller.
2021-11-09 14:15:21 +01:00
Maxim Poliakovski
fc44cdcc83
Heathrow: logging monitor sense status.
2021-11-09 13:41:48 +01:00
Maxim Poliakovski
958d3ee96a
Factor out common video controller code.
2021-11-09 13:40:13 +01:00
Maxim Poliakovski
392fa87ba4
Add NCR 53C90 stub.
2021-10-26 19:00:04 +02:00
Maxim Poliakovski
87b8e1759a
Connect ESCC to AMIC and Heathrow.
2021-10-25 22:19:45 +02:00
Maxim Poliakovski
cb946e41b5
Initial ESCC emulation.
2021-10-25 22:19:45 +02:00
Maxim Poliakovski
3f20d0a700
heathrow: use unique_ptr with internal objects.
2021-10-25 22:19:45 +02:00
Maxim Poliakovski
6a756df5e3
Add MACE Ethernet emulation stub.
2021-10-24 21:02:30 +02:00
Maxim Poliakovski
c0cd6eb38f
Add missing licence headers, update license date.
2021-10-23 21:00:31 +02:00
Maxim Poliakovski
9329d56d83
Move devices into dedicated subdirectories.
2021-10-23 20:17:47 +02:00
Maxim Poliakovski
7daf4aa317
viacuda: improve READ_MCU_MEM & WRITE_MCU_MEM emulation.
...
68k boot code in ROM uses those commands for applying patches
to Cuda and getting Cuda firmware version. This commit
implements as much as needed for boot code to work.
2021-10-18 23:52:12 +02:00
Maxim Poliakovski
f194887d34
viacuda: properly initialize VIA registers.
2021-10-18 16:38:12 +02:00
Maxim Poliakovski
46549d68a2
viacuda: remove superfluous newlines and casts from messages.
2021-10-18 16:38:12 +02:00
Maxim Poliakovski
c7544d9c2f
amic: reorganize registers in blocks.
2021-10-16 15:07:53 +02:00
Maxim Poliakovski
2f725fe3e4
viacuda: fix PRAM reading and writing.
2021-10-14 00:01:30 +02:00
Maxim Poliakovski
7c47b9c1e7
amic: implement AMIC2 identification.
2021-10-13 09:06:16 +02:00
Maxim Poliakovski
9caef55c19
amic: implement diagnostics register.
2021-10-10 22:01:02 +02:00
Maxim Poliakovski
89e79d05cb
Load bootrom code to primary ROM region.
2021-10-10 22:01:02 +02:00
Maxim Poliakovski
c313a9c8bb
Use std::bind() based callbacks.
2021-10-05 00:29:27 +02:00
Maxim Poliakovski
03e58dac35
Overhaul AWACs and implement PDM sound HW.
2021-10-05 00:29:27 +02:00
Maxim Poliakovski
3ca7a78a37
AWAC-PDM control and status registers.
2021-10-01 01:02:43 +02:00
Maxim Poliakovski
0f55877137
Add basic PDM I/O emulation.
2021-09-30 23:01:56 +02:00
Maxim Poliakovski
b4d399ffa2
Improve three logging messages.
2021-09-30 23:01:56 +02:00
Maxim Poliakovski
8c9f23daf4
Fix memory controller interface for PDM.
2021-09-30 22:55:10 +02:00
Maxim Poliakovski
e9fcc51b93
Debugger fixes for PDM.
2021-09-26 14:21:31 +02:00
Maxim Poliakovski
e052eb4a87
Merge branch 'atirage-hacks'.
2021-09-25 23:16:38 +02:00
Maxim Poliakovski
d2cd43fcb1
Merge branch 'machine-pdm'.
2021-09-25 22:30:31 +02:00
Maxim Poliakovski
84e111290f
Fix includes for loguru and SDL.
2021-09-16 00:46:38 +02:00
dingusdev
1c77057860
Fixed building through CMake
2021-09-12 08:08:22 -07:00
dingusdev
738e2d3bd1
Fixed compiling for Visual Studio 2019
2021-09-11 22:55:24 -07:00
Maxim Poliakovski
ea5b0d9f52
atirage: framebuffer rendering and various improvements.
2021-09-11 21:02:46 +02:00
Maxim Poliakovski
16d9e6c681
Basic MESH emulation skeleton with events logging.
2021-08-23 00:20:28 +02:00
Maxim Poliakovski
05330bc942
memctrlbase: allocate address map entries with new().
2021-05-16 00:50:44 +02:00
Maxim Poliakovski
baa7f8b211
atirage: use standard names for common pixel formats.
2021-02-08 22:25:36 +01:00
Maxim Poliakovski
2f4a3b955e
atirage: calculation of display parameters.
2021-02-08 02:20:55 +01:00
Maxim Poliakovski
a4eb658309
atirage: increase PLL registers count to 64.
2021-02-05 02:01:31 +01:00
Maxim Poliakovski
508ef2eaa9
atirage: increase registers array and add boundary checks.
2021-02-05 01:23:04 +01:00
Maxim Poliakovski
a5ef814ec4
atirage: add reading and writing of PLL registers.
2021-02-05 01:23:04 +01:00
Maxim Poliakovski
ace19c0bdf
atirage: clean up register names.
2021-02-05 01:11:23 +01:00
Maxim Poliakovski
3a9ed2671c
atirage: remove obsolete memaccess code.
2021-02-04 19:05:39 +01:00
Maxim Poliakovski
3c787a87cd
atirage: add ASIC ID for Rage Pro.
2021-02-04 19:01:55 +01:00
Maxim Poliakovski
a0b43754a7
atirage: fix and clean up PCI interface.
2021-02-04 01:03:23 +01:00
Maxim Poliakovski
1adbf90e21
MPC106: use memaccess thoroughly.
2021-02-03 23:39:19 +01:00
Maxim Poliakovski
478ca1065f
MPC106: fix RAM size calculation.
2021-02-03 23:29:48 +01:00
Maxim Poliakovski
7628ec92c0
Rename memreadwrite.h to memaccess.h
2021-02-03 12:19:18 +01:00
dingusdev
2bac606365
Added to Heathrow
...
Plus some debugging stuff to help figure out what register 0x34 is responsible for.
2021-01-08 15:29:43 -07:00
dingusdev
9210244c0c
Further ATI Rage registers
2021-01-08 14:32:06 -07:00
dingusdev
14d3874382
More ATI Rage register names added
2021-01-08 13:12:06 -07:00
Maxim Poliakovski
18a19cd52f
Add an implementation for the Highspeed Memory Controller.
2020-12-19 09:56:39 +01:00
Maxim Poliakovski
282940e580
memctrlbase: fix range bug in add_mem_mirror.
2020-12-19 08:24:04 +01:00
Maxim Poliakovski
81b3c3c4a0
Default initialization of Heathrow registers.
2020-11-26 03:03:52 +01:00
Maxim Poliakovski
3b29ff9514
atirage: fix monitor identification.
2020-10-14 16:55:38 +02:00
dingusdev
14ef7564cd
CLI fixes - RAM and GFXMEM work better
2020-08-25 20:07:02 -07:00
Maxim Poliakovski
8094fb30f6
atirage: add access to internal DAC palette.
2020-06-11 01:30:10 +02:00