git @ Cat's Eye Technologies SixtyPical / master eg / c64 / ribos / ribos2.60p
master

Tree @master (Download .tar.gz)

ribos2.60p @masterraw · history · blame

// ribos2.60p - SixtyPical source for RIBOS2:
// Demonstration of the VIC-II raster interrupt on the Commodore 64:
// Alter the border colour in the middle part of the screen only,
// Simplified (KERNAL IRQ vector) version.

// SPDX-FileCopyrightText:  Chris Pressey, the author of this work, has dedicated it to the public domain.
// For more information, please refer to <https://unlicense.org/>
// SPDX-License-Identifier: Unlicense

// For comments, see ribos2.p65.

// ----- Types -----

typedef routine
  inputs border_color, vic_intr, scanline
  outputs border_color, vic_intr, scanline
  trashes a, z, n, c, vic_raster
    irq_handler

// ----- Addresses -----

// The CIA #1 chip.

byte cia1             @ $dc00       // pp. 328-331
byte intr_ctrl        @ $dc0d       // "CIA Interrupt Control Register
                                    // (Read IRQs/Write Mask)"

// The VIC-II chip.

byte vic              @ $d000       // Appendix G:
byte vic_ctrl         @ $d011       // "Y SCROLL MODE"
byte vic_raster       @ $d012       // "RASTER"
byte vic_intr         @ $d019       // "Interrupt Request's" (sic)
byte vic_intr_enable  @ $d01a       // "Interrupt Request MASKS"
byte border_color     @ $d020       // "BORDER COLOR"

// The address at which the IRQ vector is stored.

vector irq_handler cinv @ $314      // p. 319, "Vector: Hardware
                                    // IRQ Interrupt"

// ----- Variables -----

vector irq_handler saved_irq_vec
byte scanline : 85  //   %01010101

// ----- Externals ------

// An address in ROM which contains "PLA TAY PLA TAX RTI".
// ribos2.p65 just contains these instructions itself, but
// generating them as part of a SixtyPical program would not
// be practical.  So we just jump to this location instead.

define pla_tay_pla_tax_pla_rti routine
  inputs border_color, vic_intr
  outputs border_color, vic_intr
  trashes a, z, n, c
    @ $EA81

// ----- Interrupt Handler -----

define our_service_routine irq_handler
{
    ld a, vic_intr
    st a, vic_intr
    and a, 1
    cmp a, 1
    if not z {
        goto saved_irq_vec
    } else {
        ld a, border_color
        xor a, $ff
        st a, border_color

        ld a, scanline
        xor a, $ff
        st a, scanline
        st a, vic_raster

        trash vic_raster

        goto pla_tay_pla_tax_pla_rti
    }
}

// ----- Main Program -----

define main routine
  inputs cinv, scanline, vic_ctrl, intr_ctrl
  outputs cinv, saved_irq_vec, vic_ctrl, vic_intr_enable
  trashes a, n, z, vic_raster
{
    with interrupts off {
        copy cinv, saved_irq_vec
        copy our_service_routine, cinv

        ld a, scanline
        st a, vic_raster
        ld a, vic_ctrl
        and a, 127
        st a, vic_ctrl
        ld a, 1
        st a, vic_intr_enable
        ld a, intr_ctrl
    }
}