Difference between revisions of "Source Codes"

From CPCWiki - THE Amstrad CPC encyclopedia!
Jump to: navigation, search
m (Algorithms: added logarithm)
m (Add link to 'A Survey of Advanced Assembly Language Programming Techniques on the MOS 6502 and Zilog Z80')
 
(27 intermediate revisions by 9 users not shown)
Line 11: Line 11:
 
*[[Z80_-_undocumented_opcodes|Z80 - undocumented opcodes]]
 
*[[Z80_-_undocumented_opcodes|Z80 - undocumented opcodes]]
 
*[[Where to learn?]]
 
*[[Where to learn?]]
 +
*[[A little optimization for Z80 Assembler]]
 +
*[https://github.com/sebastiengoutal/publications/blob/cae9abe5d684f98912571e4e713fc7af5f70760c/A%20Survey%20of%20Advanced%20Assembly%20Language%20Programming%20Techniques%20on%20the%20MOS%206502%20and%20Zilog%20Z80.pdf A publication on advanced assembly programming techniques on the Z80]
  
 
== Algorithms ==
 
== Algorithms ==
Line 26: Line 28:
 
*[[Programming:Square Root|Square Root]]
 
*[[Programming:Square Root|Square Root]]
 
*[[Programming:Precalculated square|Precalculated square]]
 
*[[Programming:Precalculated square|Precalculated square]]
 +
*[[Programming:Maze generation|Maze generation]]
 
*[[Programming:Random Number Generator|Random Number Generator]]
 
*[[Programming:Random Number Generator|Random Number Generator]]
 +
*[[Programming:Reverse A|Reverse A]]
 
*[[Programming:Quicksort|Quicksort]]
 
*[[Programming:Quicksort|Quicksort]]
 
*[[Programming:Sin/Cos calculation|Sin/Cos calculation]]
 
*[[Programming:Sin/Cos calculation|Sin/Cos calculation]]
Line 61: Line 65:
 
*[[Programming:An example to read a file byte-by-byte|An example to read a file byte-by-byte]]
 
*[[Programming:An example to read a file byte-by-byte|An example to read a file byte-by-byte]]
 
*[[Programming:An example to write a file byte-by-byte|An example to write a file byte-by-byte]]
 
*[[Programming:An example to write a file byte-by-byte|An example to write a file byte-by-byte]]
 +
*[[Programming:Read/Write a file quickly byte-by-byte|Read or write a file quickly byte-by-byte]]
 
*[[Programming:A simple file copier using firmware functions (copies byte-by-byte)|A simple file copier using firmware functions (copies byte-by-byte)]]
 
*[[Programming:A simple file copier using firmware functions (copies byte-by-byte)|A simple file copier using firmware functions (copies byte-by-byte)]]
 
*[[Programming:Loading a file|Loading a file]]
 
*[[Programming:Loading a file|Loading a file]]
Line 77: Line 82:
 
*[[Programming:Reading and writing the boot sector of a SYSTEM/VENDOR disc|Reading and writing the boot sector of a SYSTEM/VENDOR disc]]
 
*[[Programming:Reading and writing the boot sector of a SYSTEM/VENDOR disc|Reading and writing the boot sector of a SYSTEM/VENDOR disc]]
 
*[[Programming:Writing a sector to disc|Writing a sector to disc]]
 
*[[Programming:Writing a sector to disc|Writing a sector to disc]]
 +
 +
== Games ==
 +
*[[Programming:Coding a simple BASIC game into Assembly]]
  
 
== Graphics ==
 
== Graphics ==
 +
 +
*[[Programming:Calculating xpos,ypos to screen address in assembly|Calculating xpos,ypos to screen address]]
 
*[[Programming:Display a 8-bit number in binary|Display a 8-bit number in binary]]
 
*[[Programming:Display a 8-bit number in binary|Display a 8-bit number in binary]]
 
*[[Programming:Display a 8-bit number in hex|Display a 8-bit number in hex]]
 
*[[Programming:Display a 8-bit number in hex|Display a 8-bit number in hex]]
Line 87: Line 97:
 
*[[Programming:Fast Sprites|Fast Sprites]] by [[User:Executioner|Executioner]]
 
*[[Programming:Fast Sprites|Fast Sprites]] by [[User:Executioner|Executioner]]
 
*[[Programming:Fast Textoutput|Fast Textoutput]] by [[Prodatron]]
 
*[[Programming:Fast Textoutput|Fast Textoutput]] by [[Prodatron]]
 +
*[[Fastest_Character_Print_in_Mode_2|Fastest Character Print in Mode 2 in all screen positions]] by [[FG Brain]]
 
*[[Programming:Hardware scrolling|Hardware Scrolling]] by [[User:Executioner|Executioner]]
 
*[[Programming:Hardware scrolling|Hardware Scrolling]] by [[User:Executioner|Executioner]]
 
*[[Programming:Hardware scrolling 2|Hardware Scrolling 2]]
 
*[[Programming:Hardware scrolling 2|Hardware Scrolling 2]]
Line 94: Line 105:
 
*[[Programming:Overscan|Overscan]]
 
*[[Programming:Overscan|Overscan]]
 
*[[Programming:Plotting a sprite using character matrices|Plotting a sprite using character matrices]]
 
*[[Programming:Plotting a sprite using character matrices|Plotting a sprite using character matrices]]
 +
*[[Mode 4 (two bitplane emulation)| 4th Mode of CPCs: Plotting sprites on 2 bitplanes]]
 +
*[[Screen refresh rate|Set the screen refresh rate]]
 
*[[Programming:Simple Raster Example 1|Simple Raster Example]]
 
*[[Programming:Simple Raster Example 1|Simple Raster Example]]
 
*[[Programming:Simple Split Raster Example 1|Simple Split Raster Example]]
 
*[[Programming:Simple Split Raster Example 1|Simple Split Raster Example]]
 
*[[Synchronising with the CRTC and display]]
 
*[[Synchronising with the CRTC and display]]
 
*[[CRTC change colour (fill) test with precise timing]] by [[User:Matahari|Matahari]]
 
*[[CRTC change colour (fill) test with precise timing]] by [[User:Matahari|Matahari]]
 +
*[[256 byte Overscan MEGATEXT Intro - (features 50Hz fullscreen scroll)]] by [[User:Matahari|Matahari]]
  
 
== Interrupts ==
 
== Interrupts ==
Line 104: Line 118:
 
== Keyboard ==
 
== Keyboard ==
 
*[[Programming:Keyboard scanning|Keyboard scanning]]
 
*[[Programming:Keyboard scanning|Keyboard scanning]]
 +
*[[Programming:Keyboard_redefinition|Keyboard redefinition]]
 +
 +
== Cartridges ==
 +
*[[Programming:Cartridges|Cartridges]]
 +
*[[Programming:Crt0Cart|CRT0 for SDCC]] to init a CPR cart
  
 
== Other routines ==
 
== Other routines ==
Line 111: Line 130:
 
*[[Programming:Dumping the data of BASIC or AMSDOS or an expansion rom|Dumping the data of BASIC or AMSDOS or an expansion rom]]
 
*[[Programming:Dumping the data of BASIC or AMSDOS or an expansion rom|Dumping the data of BASIC or AMSDOS or an expansion rom]]
 
*[[Programming:Dumping the data of the lower rom|Dumping the data of the lower rom]]
 
*[[Programming:Dumping the data of the lower rom|Dumping the data of the lower rom]]
 +
*[[Programming:Storing and Retrieving Screens from the extra 64kb|Storing and Retrieving Screens from the extra 64kb]]
  
 
== Sound ==
 
== Sound ==
Line 125: Line 145:
  
 
[[Category:Source code]]
 
[[Category:Source code]]
 +
 +
== General Notes ==
 +
 +
* Memory range for programs is &0040-&a700. This avoids firmware and memory allocated by AMSDOS disc ROM.
 +
This is safe for the purpose of loading and being compatible with the firmware.
 +
After loading, if you disable the firmware, you can re-use the firmware areas as you want, but you need to do everything yourself (scanning keyboard, drawing, sound etc).If you need to use these areas, a common thing to do is to load most into the safe area, some into the screen, and relocate it after loading.
 +
* Programs on cassette and disc have a header that define the load address, length and execution address.
 +
 +
In Pasmo assembler use the "end" mnemonic to define the label which is the execution address and use "--amsdos" to put an AMSDOS header on it.
 +
 +
* Basic programs start at &170.
 +
* Firmware uses interrupt mode 1 of the Z80 (interrupts jump to &0038)
 +
* Lowest place you can LOAD a binary file to with BASIC is &389 e.g.:
 +
 +
openout"d"
 +
memory <address>-1
 +
closeout
 +
load "code",<address>
 +
call <exec>
 +
 +
*Screen is normally at &c000-&ffff. (It can be changed using firmware, or using CRTC R12/R13)
 +
*Stack is normally at &c000 and goes down.
 +
*Extra registers (BC', AF', HL', DE' are reserved by the firmware). Avoid if you are using firmware functions.
 +
*Lower rom (containing OS) can be paged into memory between &0000-&3fff.
 +
*Upper rom is selectable, examples are BASIC and AMSDOS. They can be paged into memory between &c000-&ffff.
 +
*From basic, a game is run with:
 +
 +
RUN"<filename>
 +
 +
keep it in the safe memory ranges and it'll run from cassette and disc.
 +
*Screen is normally 40 crtc chars wide (CRTC R1=40), 25 crtc chars tall (CRTC R6=25). 8 scan lines per char (R9=7). Firmware functions assume this.
 +
*Screen is bitmapped. You must draw/erase your own sprites and text.
 +
*Firmware refreshes the palette every 50th of a second, so you need to turn off the firmware and use the hardware directly, or set the colours using firmware.
 +
*Firmware can be "turned off", by disabling lower ROM, redirecting interrupts and not calling firmware functions.
 +
*Screen can be resized the same as the Spectrum. Provided you do not use hardware scrolling, this gives you extra space although because of the layout of the screen, it's not continuous, it's in 8 seperate blocks, but it's enough to store data and code.

Latest revision as of 13:55, 28 October 2023

This article contains source codes and programming examples. You may also have a look at


Assembler

Algorithms

CP/M

CPC Plus

Devices

File access

Floppy disk

Games

Graphics

Interrupts

Keyboard

Cartridges

Other routines

Sound

Cross Development

General Notes

  • Memory range for programs is &0040-&a700. This avoids firmware and memory allocated by AMSDOS disc ROM.

This is safe for the purpose of loading and being compatible with the firmware. After loading, if you disable the firmware, you can re-use the firmware areas as you want, but you need to do everything yourself (scanning keyboard, drawing, sound etc).If you need to use these areas, a common thing to do is to load most into the safe area, some into the screen, and relocate it after loading.

  • Programs on cassette and disc have a header that define the load address, length and execution address.

In Pasmo assembler use the "end" mnemonic to define the label which is the execution address and use "--amsdos" to put an AMSDOS header on it.

  • Basic programs start at &170.
  • Firmware uses interrupt mode 1 of the Z80 (interrupts jump to &0038)
  • Lowest place you can LOAD a binary file to with BASIC is &389 e.g.:
openout"d"
memory <address>-1
closeout
load "code",<address>
call <exec>
  • Screen is normally at &c000-&ffff. (It can be changed using firmware, or using CRTC R12/R13)
  • Stack is normally at &c000 and goes down.
  • Extra registers (BC', AF', HL', DE' are reserved by the firmware). Avoid if you are using firmware functions.
  • Lower rom (containing OS) can be paged into memory between &0000-&3fff.
  • Upper rom is selectable, examples are BASIC and AMSDOS. They can be paged into memory between &c000-&ffff.
  • From basic, a game is run with:
RUN"<filename>

keep it in the safe memory ranges and it'll run from cassette and disc.

  • Screen is normally 40 crtc chars wide (CRTC R1=40), 25 crtc chars tall (CRTC R6=25). 8 scan lines per char (R9=7). Firmware functions assume this.
  • Screen is bitmapped. You must draw/erase your own sprites and text.
  • Firmware refreshes the palette every 50th of a second, so you need to turn off the firmware and use the hardware directly, or set the colours using firmware.
  • Firmware can be "turned off", by disabling lower ROM, redirecting interrupts and not calling firmware functions.
  • Screen can be resized the same as the Spectrum. Provided you do not use hardware scrolling, this gives you extra space although because of the layout of the screen, it's not continuous, it's in 8 seperate blocks, but it's enough to store data and code.