Skip to content

Add an HPS-FPGA bridge to minimig, so we can emulate the 68k on the Arm

Notifications You must be signed in to change notification settings

scrameta/Minimig-AGA_MiSTer_Hybrid

 
 

Repository files navigation

Minimig-AGA_MiSTer

This is a port of the minimig core to the MiSTer board.

minimig (short for Mini Amiga) is an open source re-implementation of an Amiga using a field-programmable gate array (FPGA). Original minimig author is Dennis van Weeren.

Amiga was - in my opinion - an amazing personal computer, announced around 1984, which - at the time - far surpassed any other personal computer on the market, with advanced graphic & sound capabilities, not to mention its great OS with preemptive multitasking capabilities.

The minimig-MiSTer variant in this repository has been upgraded with AGA chipset capabilites, which allows it to emulate the latest Amiga models (Amiga 1200, Amiga 4000 and (partially) Amiga CD32). Ofcourse it also supports previous OCS/ECS Amigas like Amiga 500, Amiga 600 etc.

Core features supported

  • chipset variants : OCS, ECS, AGA
  • chipRAM : 0.5MB - 2.0MB
  • slowRAM : 0.0MB - 1.5MB
  • fastRAM : 0.0MB - 384MB
  • CPU core : 68000, 68020, 68Arm (qemu or musashi etc)
  • kickstart : 1.2 - 3.1 (256kB, 512kB & 1MB kickstart ROMs currently supported)
  • HRTmon with custom registers mirror
  • floppy disks : 1-4 floppies (supports ADF floppy image format), with normal & turbo speeds
  • Up to 4 IDE devices
  • CDROM
  • video standard : PAL / NTSC
  • supports almost all OCS/ECS/AGA custom resolutions
  • RTG with up to 1920x1080 and 1600x1200 resolutions
  • peripherals : USB keyboards, USB mice, USB gamepads
  • serial connection to Linux with ability to connect to internet.
  • shared folder for rapid file exchange between Linux and Amiga.
  • MIDI: both MiSTer internal emulation and external through USER_IO port (MT32-pi and generic MIDI device)
  • Akiko chunk to planar implementation
  • Mouse with wheel.

Usage

Screen adjustment

Adjustment is initiated from OSD menu. Keyboard control:

  • Cursor keys - top/left corner.
  • ALT+Cursor keys - bottom/right corner.
  • Enter - finish and store position.
  • Backspace - reset do default.
  • Esc - cancel and finish.

Positions are saved in the configuration file. Up to 64 different resolutions can be adjusted.

Hybrid CPU

You need a patched CPU emulator and a patched Mister binary to use this. There are some all in one setups here in the .zst files: http://www.64kib.com/mister_hybrid_files/ Extract the .zst on your own box, then the .tar on the mister when in /media/fat

Main discussion thread: https://misterfpga.org/viewtopic.php?f=4&t=2397

Shared folder

All required files (and sources) are in extra/MiSTer_share.lha

Amiga driver is based on Niklas Ekström a314 driver.

On Amiga:

  • copy dummy.device to DEVS:
  • copy MountList to DEVS: (or add content from MountList to existing file)
  • copy MiSTerFileSystem to L:
  • open CLI and type there: mount share:
  • MiSTer drive will appear on main WB screen. If it will work, then you can add this command into user-startup file, and it will be mounted at every boot.

On Linux side the folder is "shared" inside Amiga folder.

RTG

  • install Picasso96.lha Choose uaegfx while installing.
  • remove uaegfx (or whatever driver you choose in install) from SYS:Devs/Monitors
  • extract MiSTer_RTG.lha and copy content to SYS:
  • reboot

New video modes will appear in ScreenMode preference. For more screen modes use Picasso96Mode preference (attn: it has awkward interface!)

Note: RTG outputs to HDMI primarily as it uses scaler. If you want to see RTG video on VGA output, then set vga_scaler=1 in MiSTer.ini. RTG is available only for 68020 CPU.

IDE and CDROM

By default up to 2 IDE devices are supported. For Secondary Master/Slave devices, you have to install either IDEFix97 (shareware, WB3.1/3.9) or AtapiMagic (freeware, WB 3.1.4/3.2). Removable/CD mode allows to hot swap CDs. Currently audio portion of CD isn't implemented (although playback commands should be accepted).

How to make a new HDF (HDD Image)

  1. Create an empty HDF file of required size on PC (ideally fill it by 0 if possible).
  2. Copy it to MiSTer
  3. Mount it as HDF on OSD, and also mount some adf with HDToolBox (for example install3.2.adf from OS3.2)
  4. Boot that ADF
  5. go to HDToolBox, then Change Drive Type -> Define New -> Read Configuration. Then Ok, Ok. Then Save Changes to Drive.
  6. Press Partition Drive. Optionally delete MDH1 partition, expand MDH0 to full drive. Rename MDH0 to standard DH0 name, mark it as Bootable. Then OK, then Save Changes to Drive.
  7. Exit, reboot.
  8. After booting you will see DH0:Uninitialized. Format it from Workbench menu. You can use Quick format option.
  9. Install required OS.

MIDI

Supported internal MiSTer emulation and external devices such as MT32-pi or generic MIDI though USER_IO. For MIDI-IN support through USER_IO set UART mode to None in OSD settings.

Akiko

Chunk to planar engine of Akiko is supported. It requires SetAkiko util (from releases/WheelDriverAkiko.adf) to be executed.

Mouse Wheel

To enable wheel support both WheelDriver and FreeWheel must be run from releases/WheelDriverAkiko.adf

Software

To use the core, you will need a Kickstart ROM image file, which you can obtain by copying Kickstart ROM IC from your actual Amiga, or by buying an Amiga Forever software pack. The Kickstart image should be placed on the root of the SD card with the name KICK.ROM. Minimig also supports the AROS kickstart ROM replacement.

The minimig can read any ADF floppy images you place on the SD card. I recommend at least Workbench 1.3 or 3.1 (AmigaOS), some of the Amigas great games (I recommend Ruff'n'Tumble) or some of the amazing demos from the vast Amiga demoscene (like State of the Art from Spaceballs).

The minimig can also use HDF harddisk images, which can be created with WinUAE.

Recommended minimig config

  • for ECS games / demos : CPU = 68000, Turbo=NONE, Chipset=ECS, chipRAM=0.5MB, slowRAM=0.5MB, Kickstart 1.3
  • for AGA games / demos : CPU = 68020, Turbo=NONE, Chipset=AGA, chipRAM=2MB, slowRAM=0MB, fastRAM=24MB, Kickstart 3.1

Controlling minimig

Keyboard special keys:

  • F12 - OSD menu
  • F11 - start monitor (HRTmon) if HRTmon is enabled in OSD menu (otherwise F11 is the Amiga HELP key)
  • ScrollLock - toggle keyoard only / mouse / joystick 1 / joystick 2 emulation on the keyboard (direction keys + LCTRL)

Sources

This sourcecode is based on Rok Krajnc project (minimig-de1).

Original minimig sources from Dennis van Weeren with updates by Jakub Bednarski are published on Google Code.

Some minimig updates are published on the Minimig Discussion Forum, done by Sascha Boing.

ARM firmware updates and minimig-tc64 port changes by Christian Vogelsang (minimig_tc64) and A.M. Robinson (minimig_tc64).

MiSTer project by Sorgelig (MiSTer).

TG68K.C core by Tobias Gubener.

Links & more info

My page somuch.guru.

Further info about minimig can be found on the Minimig Discussion Forum.

MiSTer board support & other cores on the MiSTer Project Page.

License

Copyright © 2011 - 2016 Rok Krajnc ([email protected])

Copyright © 2005 - 2015 Dennis van Weeren, Jakub Bednarski, Sascha Boing, A.M. Robinson, Tobias Gubener, Till Harbaum

Copyright © 2017 - 2020 Sorgelig ([email protected])

Copyright © 2021 Mark Watson ([email protected])

This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.

About

Add an HPS-FPGA bridge to minimig, so we can emulate the 68k on the Arm

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Verilog 25.5%
  • SystemVerilog 25.2%
  • HTML 22.9%
  • C 10.4%
  • VHDL 7.9%
  • Tcl 5.6%
  • Other 2.5%