analog-firmware/vga/vgaout.h
David Kuder bc17d64651 Revert extended PIO pixel hold values
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.
2023-05-02 15:08:04 -04:00

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();