1
0
mirror of https://github.com/mist-devel/mist-firmware.git synced 2026-01-13 15:17:43 +00:00
2022-07-01 22:30:06 +02:00

225 lines
7.5 KiB
C

/*
* user_io.h
*
*/
#ifndef USER_IO_H
#define USER_IO_H
#include <inttypes.h>
#include "fat_compat.h"
#define UIO_STATUS 0x00
#define UIO_BUT_SW 0x01
// codes as used by minimig (amiga)
#define UIO_JOYSTICK0 0x02 // also used by 8 bit
#define UIO_JOYSTICK1 0x03 // -"-
#define UIO_MOUSE 0x04 // -"-
#define UIO_KEYBOARD 0x05 // -"-
#define UIO_KBD_OSD 0x06 // keycodes used by OSD only
// codes as used by MiST (atari)
// directions (in/out) are from an io controller view
#define UIO_IKBD_OUT 0x02
#define UIO_IKBD_IN 0x03
#define UIO_SERIAL_OUT 0x04 // Warning! same as UIO_MOUSE
#define UIO_SERIAL_IN 0x05 // Warning! same as UIO_KEYBOARD
#define UIO_PARALLEL_IN 0x06
#define UIO_MIDI_OUT 0x07
#define UIO_MIDI_IN 0x08
#define UIO_ETH_MAC 0x09
#define UIO_ETH_STATUS 0x0a
#define UIO_ETH_FRM_IN 0x0b
#define UIO_ETH_FRM_OUT 0x0c
#define UIO_SERIAL_STAT 0x0d
#define UIO_KEYBOARD_IN 0x0e // PS2 keyboard cmd
#define UIO_MOUSE_IN 0x0f // PS2 mouse cmd
#define UIO_JOYSTICK2 0x10 // also used by minimig and 8 bit
#define UIO_JOYSTICK3 0x11 // -"-
#define UIO_JOYSTICK4 0x12 // -"-
#define UIO_JOYSTICK5 0x13 // -"-
// general codes used by 8bit, archie and mist2
#define UIO_GET_STRING 0x14
#define UIO_SET_STATUS 0x15
#define UIO_GET_SDSTAT 0x16 // read status of sd card emulation
#define UIO_SECTOR_RD 0x17 // SD card sector read
#define UIO_SECTOR_WR 0x18 // SD card sector write
#define UIO_SET_SDCONF 0x19 // send SD card configuration (CSD, CID)
#define UIO_ASTICK 0x1a
#define UIO_SIO_IN 0x1b // serial in
#define UIO_SET_SDSTAT 0x1c // set sd card status
#define UIO_SET_SDINFO 0x1d // send info about mounted image
#define UIO_SET_STATUS2 0x1e // 32bit status
#define UIO_GET_KBD_LED 0x1f // keyboard LEDs control
#define UIO_SIO_OUT 0x20 // serial out
#define UIO_SET_MOD 0x21 // send core variant from metadata (ARC) file
#define UIO_SET_RTC 0x22 // send real-time-clock data
#define UIO_SD_ACK 0x23 // send ack for sector read/write
// extended joystick control (32 bit value)
#define UIO_JOYSTICK0_EXT 0x60
#define UIO_JOYSTICK1_EXT 0x61
#define UIO_JOYSTICK2_EXT 0x62
#define UIO_JOYSTICK3_EXT 0x63
#define UIO_JOYSTICK4_EXT 0x64
#define UIO_JOYSTICK5_EXT 0x65
// extended mouse control (with wheel support)
#define UIO_MOUSE0_EXT 0x70
#define UIO_MOUSE1_EXT 0x71
// codes as used by 8bit (atari 800, zx81) via SS2
#define UIO_GET_STATUS 0x50 // removed
#define UIO_SECTOR_SND 0x51 // removed
#define UIO_SECTOR_RCV 0x52 // removed
#define UIO_GET_FEATS 0x80 // get core features (only once after fpga init)
#define FEAT_MENU 0x01 // menu core
#define FEAT_PCECD 0x02 // call pcecd_poll()
#define JOY_RIGHT 0x01
#define JOY_LEFT 0x02
#define JOY_DOWN 0x04
#define JOY_UP 0x08
#define JOY_BTN_SHIFT 4
#define JOY_BTN1 0x10
#define JOY_BTN2 0x20
#define JOY_BTN3 0x40
#define JOY_BTN4 0x80
#define JOY_MOVE (JOY_RIGHT|JOY_LEFT|JOY_UP|JOY_DOWN)
#define BUTTON1 0x01
#define BUTTON2 0x02
#define SWITCH1 0x04
#define SWITCH2 0x08
// virtual gamepad buttons
#define JOY_A JOY_BTN1
#define JOY_B JOY_BTN2
#define JOY_SELECT JOY_BTN3
#define JOY_START JOY_BTN4
#define JOY_X 0x100
#define JOY_Y 0x200
#define JOY_L 0x400
#define JOY_R 0x800
#define JOY_L2 0x1000
#define JOY_R2 0x2000
#define JOY_L3 0x4000
#define JOY_R3 0x8000
// Right stick
#define JOY_RIGHT2 0x010000
#define JOY_LEFT2 0x020000
#define JOY_DOWN2 0x040000
#define JOY_UP2 0x080000
// keyboard LEDs control
#define KBD_LED_CAPS_CONTROL 0x01
#define KBD_LED_CAPS_STATUS 0x02
#define KBD_LED_CAPS_MASK (KBD_LED_CAPS_CONTROL | KBD_LED_CAPS_STATUS)
#define KBD_LED_NUM_CONTROL 0x04
#define KBD_LED_NUM_STATUS 0x08
#define KBD_LED_NUM_MASK (KBD_LED_NUM_CONTROL | KBD_LED_NUM_STATUS)
#define KBD_LED_SCRL_CONTROL 0x10
#define KBD_LED_SCRL_STATUS 0x20
#define KBD_LED_SCRL_MASK (KBD_LED_SCRL_CONTROL | KBD_LED_SCRL_STATUS)
#define KBD_LED_FLAG_MASK 0xC0
#define KBD_LED_FLAG_STATUS 0x40
#define CONF_SCANDOUBLER_DISABLE 0x10
#define CONF_YPBPR 0x20
#define CONF_CSYNC_DISABLE 0x40
#define CONF_SDRAM64 0x80
// core type value should be unlikely to be returned by broken cores
#define CORE_TYPE_UNKNOWN 0x55
#define CORE_TYPE_DUMB 0xa0 // core without any io controller interaction
#define CORE_TYPE_MINIMIG 0xa1 // minimig amiga core
#define CORE_TYPE_PACE 0xa2 // core from pacedev.net (joystick only)
#define CORE_TYPE_MIST 0xa3 // mist atari st core
#define CORE_TYPE_8BIT 0xa4 // atari 800/c64 like core
#define CORE_TYPE_MINIMIG2 0xa5 // new Minimig with AGA
#define CORE_TYPE_ARCHIE 0xa6 // Acorn Archimedes
#define CORE_TYPE_MIST2 0xa7 // New MiST core
// user io status bits (currently only used by 8bit)
#define UIO_STATUS_RESET 0x01
#define UIO_STOP_BIT_1 0
#define UIO_STOP_BIT_1_5 1
#define UIO_STOP_BIT_2 2
#define UIO_PARITY_NONE 0
#define UIO_PARITY_ODD 1
#define UIO_PARITY_EVEN 2
#define UIO_PARITY_MARK 3
#define UIO_PARITY_SPACE 4
#define UIO_PRIORITY_KEYBOARD 0
#define UIO_PRIORITY_GAMEPAD 1
// serial status data type returned from the core
typedef struct {
uint32_t bitrate; // 300, 600 ... 115200
uint8_t datasize; // 5,6,7,8 ...
uint8_t parity;
uint8_t stopbits;
uint8_t fifo_stat; // space in cores input fifo
} __attribute__ ((packed)) serial_status_t;
void user_io_reset();
void user_io_init();
void user_io_detect_core_type();
unsigned char user_io_core_type();
uint32_t user_io_get_core_features();
char minimig_v1();
char minimig_v2();
char user_io_is_8bit_with_config_string();
void user_io_poll();
void user_io_osd_key_enable(char);
void user_io_serial_tx(char *, uint16_t);
char *user_io_8bit_get_string(char);
unsigned long long user_io_8bit_set_status(unsigned long long, unsigned long long);
void user_io_sd_set_config(void);
char user_io_dip_switch1(void);
char user_io_serial_status(serial_status_t *, uint8_t);
char user_io_is_mounted(unsigned char index);
void user_io_file_mount(const unsigned char*, unsigned char);
char user_io_is_cue_mounted();
char user_io_cue_mount(const unsigned char*);
char *user_io_get_core_name();
void user_io_set_core_mod(char);
// io controllers interface for FPGA ethernet emulation using usb ethernet
// devices attached to the io controller (ethernec emulation)
void user_io_eth_send_mac(uint8_t *);
uint32_t user_io_eth_get_status(void);
void user_io_eth_send_rx_frame(uint8_t *, uint16_t);
void user_io_eth_receive_tx_frame(uint8_t *, uint16_t);
// hooks from the usb layer
void user_io_mouse(unsigned char idx, unsigned char b, char x, char y, char z);
void user_io_kbd(unsigned char m, unsigned char *k, uint8_t priority, unsigned short vid, unsigned short pid);
#define CONFIG_ROOT 1 // create config filename in the root directory
#define CONFIG_VHD 2 // create config filename according to VHD= in arc file
char user_io_create_config_name(char *s, const char *ext, char flags);
void user_io_digital_joystick(unsigned char, unsigned char);
void user_io_digital_joystick_ext(unsigned char, uint32_t);
void user_io_analog_joystick(unsigned char, char, char, char, char);
char user_io_osd_is_visible();
void user_io_send_buttons(char);
char user_io_key_remap(char *, char, int);
void add_modifiers(uint8_t mod, uint16_t* keys_ps2);
unsigned char user_io_ext_idx(const char*, const char*);
void user_io_change_into_core_dir(void);
#endif // USER_IO_H