mirror of
https://github.com/V2RetroComputing/analog-firmware.git
synced 2024-10-20 04:24:00 +00:00
bc17d64651
due to how the PIO program counter operates, the pixel holds are also used to shift the active area after a HSYNC. the larger values of pixel holds caused problems and had to be removed.
48 lines
1.1 KiB
C
48 lines
1.1 KiB
C
#pragma once
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
#define VGA_WIDTH 640
|
|
#define VGA_HEIGHT 480
|
|
|
|
#ifdef ANALOG_GS
|
|
#define THEN_WAIT_VSYNC (2 << 12)
|
|
#define THEN_WAIT_HSYNC (3 << 12)
|
|
#define THEN_EXTEND_7 (4 << 12)
|
|
#define THEN_EXTEND_6 (5 << 12)
|
|
#define THEN_EXTEND_3 (6 << 12)
|
|
#define THEN_EXTEND_1 (7 << 12)
|
|
#else
|
|
#define THEN_WAIT_VSYNC (2 << 9)
|
|
#define THEN_WAIT_HSYNC (3 << 9)
|
|
#define THEN_EXTEND_7 (4 << 9)
|
|
#define THEN_EXTEND_6 (5 << 9)
|
|
#define THEN_EXTEND_3 (6 << 9)
|
|
#define THEN_EXTEND_1 (7 << 9)
|
|
#endif
|
|
|
|
struct vga_scanline {
|
|
// number of 32-bit words in the data array
|
|
uint_fast16_t length;
|
|
|
|
// number of times to repeat the scanline
|
|
uint_fast16_t repeat_count;
|
|
|
|
volatile uint_fast8_t _flags;
|
|
|
|
uint32_t _sync;
|
|
uint32_t data[(VGA_WIDTH/2)+8];
|
|
};
|
|
|
|
extern void vga_prepare_frame();
|
|
extern struct vga_scanline *vga_prepare_scanline();
|
|
extern struct vga_scanline *vga_prepare_scanline_quick();
|
|
extern void vga_submit_scanline(struct vga_scanline *scanline);
|
|
|
|
extern void vga_stop();
|
|
extern void vga_dpms_sleep();
|
|
extern void vga_dpms_wake();
|
|
|
|
extern void terminal_process_input();
|