Amiga programming examples
Go to file
alpine9000 58b9c11c19 File used for resize test 2016-03-31 08:40:56 +11:00
000.trackdisk
001.simple_image A few incorrect dbra counters 2016-03-25 19:49:36 +11:00
002.sprite_display Removed conflicting ADF name 2016-03-14 13:49:20 +11:00
003.music A few incorrect dbra counters 2016-03-25 19:49:36 +11:00
004.copper_bars
005.copper_vert
006.simple_blit A few incorrect dbra counters 2016-03-25 19:49:36 +11:00
007.masked_blit A few incorrect dbra counters 2016-03-25 19:49:36 +11:00
008.shift_blit A few incorrect dbra counters 2016-03-25 19:49:36 +11:00
009.anim_blit Updates for removal of -phxass option 2016-03-21 20:35:08 +11:00
010.blit_speed Updates for removal of -phxass option 2016-03-21 20:35:08 +11:00
011.ehb_mode Updates for removal of -phxass option 2016-03-21 20:35:08 +11:00
012.ham_mode Updates for removal of -phxass option 2016-03-21 20:35:08 +11:00
013.dithered_ham Updates for removal of -phxass option 2016-03-21 20:35:08 +11:00
014.lace_mode Removed -phxass assembler argument 2016-03-20 21:11:56 +11:00
015.sliced_ham Disabled interlaced for space 2016-03-21 21:24:02 +11:00
016.copper_fun Updates for removal of -phxass option 2016-03-21 20:35:08 +11:00
017.dual_playfield Removed -phxass assembler argument 2016-03-20 21:11:56 +11:00
018.vert_scroll Removed -phxass assembler argument 2016-03-20 21:11:56 +11:00
019.hori_scroll Removed -phxass assembler argument 2016-03-20 21:11:56 +11:00
020.shrinkler Updates for removal of -phxass option 2016-03-21 20:35:08 +11:00
021.calling_c Updates for removal of -phxass option 2016-03-21 20:35:08 +11:00
022.photons_bootloader Updates for removal of -phxass option 2016-03-21 20:35:08 +11:00
023.slideshow Changes for fs-uae debugger symbols 2016-03-29 08:44:18 +11:00
024.simple_text Optimisations 2016-03-30 19:18:15 +11:00
assets File used for resize test 2016-03-31 08:40:56 +11:00
doc
examples
include Slight improvements to text 2016-03-27 12:06:45 +11:00
shared Changes for fs-uae debugger symbols 2016-03-29 08:44:18 +11:00
tools More palette options 2016-03-26 18:23:14 +11:00
.gitignore
Makefile Added new examples to top level Makefile 2016-03-29 13:13:38 +11:00
README.md Update README.md 2016-03-16 10:42:33 +11:00

README.md

(re)Learning how to program an Amiga after a 20 year break

introduction

This repo contains example programs I have written as I re-learn how to program an amiga. The programs are written in assembler and directly access the hardware. The target is an Amiga 500 (my long lost friend). Currently I do not own an amiga, so I can only test using UAE, so it's possible they will not work on the real hardware.

Don't use this as an amiga programming guide. I don't do things the "correct" way. There are heaps of great guides out there if you want to do things the right way.

documentation

Most of the sites I have used during the learning process:

examples

Each example tries to introduce only one new concept, often building on the previous examples.

See each example's README.md for a limited description as well as a clickable link to run the example in your browser using my hacked version of Scripted Amiga Emulator

Most of the examples are only tested on a 512kb chip ram A500. Some examples have an option extended versoin that might require more chip ram, and in that case an A600 would be the best option.

cross development environment

These examples are developed on a mac using cahirwpz's AmigaOS cross compiler for Linux / MacOSX / Windows.

https://github.com/cahirwpz/amigaos-cross-toolchain

The support tools I have developed have additional requirements which you may not have on your system.

For a dump of what I did to install them see installing the cross development environment

building

Build all examples by running make at the top level directory.

Individual examples can be built by entering the directory and running make:

# cd 001.simple_image
# make

this will create a bootable ADF image in the bin directory.

Load this file directly into your emulator of choice as DF0:, or even better, run it on the real hardware.

emulators

The following are the emulators I have used so far:

they each have strengths and weaknesses, so it's worth giving them each a try.

tools

The following cross development tools have been developed to support the examples:

  • imagecon # create amiga compatible raw image data from true color images
  • resize # resize images ready for imagecon
  • makeadf # make ADF disk image

external tools

The following cross development tools have been sourced from external authors:

Each tool has a test to check if any changes you have made have broken basic functionality:

# cd tools/imagecon
# make test
______  ___   _____ _____ ___________
| ___ \/ _ \ /  ___/  ___|  ___|  _  \
| |_/ / /_\ \\ `--.\ `--.| |__ | | | |
|  __/|  _  | `--. \`--. \  __|| | | |
| |   | | | |/\__/ /\__/ / |___| |/ /
\_|   \_| |_/\____/\____/\____/|___/
#

or test all by running make test at the top level

license

Some of the code I have included in this repository is copyright by various authors and provided under various licenses. Copyright notices are preseved where possible.

Some of the tools use GPL licensed libraries which would mean they could only be distributed under the conditions of the respective version of the GPL.

All code without a copyright notice is probably in the public domain.