Amiga programming examples
Go to file
alpine9000 0e2d2619e4 Removed conflicting ADF name 2016-03-14 13:49:20 +11:00
000.trackdisk Update README.md 2016-03-09 15:14:03 +11:00
001.simple_image Latest disk images 2016-03-14 13:45:54 +11:00
002.sprite_display Removed conflicting ADF name 2016-03-14 13:49:20 +11:00
003.music Latest disk images 2016-03-14 13:45:54 +11:00
004.copper_bars Update README.md 2016-03-09 14:53:30 +11:00
005.copper_vert Update README.md 2016-03-09 14:54:17 +11:00
006.simple_blit Latest disk images 2016-03-14 13:45:54 +11:00
007.masked_blit Latest disk images 2016-03-14 13:45:54 +11:00
008.shift_blit Latest disk images 2016-03-14 13:45:54 +11:00
009.anim_blit Latest disk images 2016-03-14 13:45:54 +11:00
010.blit_speed Update README.md 2016-03-09 14:58:45 +11:00
011.ehb_mode Latest disk images 2016-03-14 13:45:54 +11:00
012.ham_mode Latest disk images 2016-03-12 14:49:29 +11:00
013.dithered_ham Latest disk images 2016-03-12 14:49:29 +11:00
014.lace_mode Latest disk images 2016-03-12 14:49:29 +11:00
015.sliced_ham Latest disk images 2016-03-14 13:45:54 +11:00
016.copper_fun Merge branch 'master' of https://github.com/alpine9000/amiga_examples 2016-03-13 12:40:28 +11:00
017.dual_playfield Update README.md 2016-03-13 20:00:54 +11:00
assets Used better test image 2016-03-14 13:24:13 +11:00
doc First pass at resize utility 2016-03-12 10:51:08 +11:00
examples
include Updates for dual playfield example 2016-03-13 19:39:42 +11:00
shared Latest disk images 2016-03-14 13:45:54 +11:00
tools Forgot to add a file 2016-03-14 13:15:01 +11:00
.gitignore Updated .gitignore 2016-03-14 13:47:53 +11:00
Makefile Latest disk images 2016-03-14 13:45:54 +11:00
README.md Update README.md 2016-03-12 11:44:18 +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

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.

Each example will have an ADF file in it's bin directory. These files can be loaded directly as DF0: on FS-UAE or Scripted Amiga Emulator using the AROS ROM.

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

# cd 001.simple_image
# make

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

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.