X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=Pico%2FPico.h;h=3714ad1200ce318c72f8f80cd3f4f723762bcb42;hb=2cb51c3c621ed60e192e8342fdeb4225def91bd8;hp=4439480ba69ea6c1eb1b9c454c103cf8e8cf771a;hpb=602133e1c66666f9152b1edb3014e137a9768cad;p=picodrive.git diff --git a/Pico/Pico.h b/Pico/Pico.h index 4439480..3714ad1 100644 --- a/Pico/Pico.h +++ b/Pico/Pico.h @@ -24,7 +24,6 @@ extern "C" { // external funcs for Sega/Mega CD int mp3_get_bitrate(FILE *f, int size); void mp3_start_play(FILE *f, int pos); -int mp3_get_offset(void); // 0-1023 void mp3_update(int *buffer, int length, int stereo); @@ -47,11 +46,17 @@ void mp3_update(int *buffer, int length, int stereo); #define POPT_EN_MCD_RAMCART (1<<15) #define POPT_DIS_VDP_FIFO (1<<16) // 0x 0000 #define POPT_EN_SVP_DRC (1<<17) +#define POPT_DIS_SPRITE_LIM (1<<18) extern int PicoOpt; // bitfield +#define PAHW_MCD (1<<0) +#define PAHW_32X (1<<1) +#define PAHW_SVP (1<<2) +#define PAHW_PICO (1<<3) +extern int PicoAHW; // Pico active hw extern int PicoVer; -extern int PicoSkipFrame; // skip rendering frame, but still do sound (if enabled) and emulation stuff +extern int PicoSkipFrame; // skip rendering frame, but still do sound (if enabled) and emulation stuff extern int PicoRegionOverride; // override the region detection 0: auto, 1: Japan NTSC, 2: Japan PAL, 4: US, 8: Europe -extern int PicoAutoRgnOrder; // packed priority list of regions, for example 0x148 means this detection order: EUR, USA, JAP +extern int PicoAutoRgnOrder; // packed priority list of regions, for example 0x148 means this detection order: EUR, USA, JAP extern int PicoSVPCycles; int PicoInit(void); void PicoExit(void); @@ -70,6 +75,23 @@ extern void (*PicoMCDopenTray)(void); extern int (*PicoMCDcloseTray)(void); extern int PicoCDBuffers; +// Pico/Pico.c +#define XPCM_BUFFER_SIZE (320+160) +typedef struct +{ + int pen_pos[2]; + int page; + // internal + int fifo_bytes; // bytes in FIFO + int fifo_bytes_prev; + int fifo_line_bytes; // float part, << 16 + int line_counter; + unsigned short r1, r12; + unsigned char xpcm_buffer[XPCM_BUFFER_SIZE+4]; + unsigned char *xpcm_ptr; +} picohw_state; +extern picohw_state PicoPicohw; + // Area.c typedef size_t (arearw)(void *p, size_t _size, size_t _n, void *file); typedef size_t (areaeof)(void *file); @@ -90,9 +112,11 @@ int PicoCdLoadStateGfx(void *file); // cd/buffering.c void PicoCDBufferInit(void); void PicoCDBufferFree(void); +void PicoCDBufferFlush(void); // cd/cd_sys.c int Insert_CD(char *iso_name, int is_bin); +int Insert_CD(char *cdimg_name, int type); void Stop_CD(void); // releases all resources taken when CD game was started. // Cart.c @@ -136,7 +160,7 @@ void vidConvCpyRGB565(void *to, void *from, int pixels); #define PDRAW_SPRITES_MOVED (1<<0) #define PDRAW_WND_DIFF_PRIO (1<<1) // not all window tiles use same priority #define PDRAW_ACC_SPRITES (1<<2) // accurate sprites (copied from PicoOpt) -#define PDRAW_INTERLACE (1<<3) // +#define PDRAW_INTERLACE (1<<3) // #define PDRAW_DIRTY_SPRITES (1<<4) #define PDRAW_SONIC_MODE (1<<5) // mid-frame palette changes for 8bit renderer #define PDRAW_PLANE_HI_PRIO (1<<6) // have layer with all hi prio tiles (mk3)