mirror of
https://github.com/holub/mame
synced 2025-05-17 19:24:59 +03:00
Implemented basic Argonaut SuperFX support, needs to be hooked to the SNES driver. [Anonymous]
This commit is contained in:
parent
055946db2b
commit
76a4664cb9
3
.gitattributes
vendored
3
.gitattributes
vendored
@ -383,6 +383,9 @@ src/emu/cpu/ssem/ssemdasm.c svneol=native#text/plain
|
||||
src/emu/cpu/ssp1601/ssp1601.c svneol=native#text/plain
|
||||
src/emu/cpu/ssp1601/ssp1601.h svneol=native#text/plain
|
||||
src/emu/cpu/ssp1601/ssp1601d.c svneol=native#text/plain
|
||||
src/emu/cpu/superfx/sfx_dasm.c svneol=native#text/plain
|
||||
src/emu/cpu/superfx/superfx.c svneol=native#text/plain
|
||||
src/emu/cpu/superfx/superfx.h svneol=native#text/plain
|
||||
src/emu/cpu/t11/t11.c svneol=native#text/plain
|
||||
src/emu/cpu/t11/t11.h svneol=native#text/plain
|
||||
src/emu/cpu/t11/t11dasm.c svneol=native#text/plain
|
||||
|
@ -1172,7 +1172,6 @@ $(CPUOBJ)/minx/minx.o: $(CPUSRC)/minx/minx.c \
|
||||
$(CPUSRC)/minx/minxfunc.h
|
||||
|
||||
|
||||
|
||||
#-------------------------------------------------
|
||||
# Nintendo/SGI RSP (R3000-based + vector processing)
|
||||
#-------------------------------------------------
|
||||
@ -1285,6 +1284,21 @@ $(CPUOBJ)/ssp1610/ssp1601.o: $(CPUSRC)/ssp1601/ssp1601.c \
|
||||
|
||||
|
||||
|
||||
#-------------------------------------------------
|
||||
# Atmel 8-bit AVR
|
||||
#-------------------------------------------------
|
||||
|
||||
ifneq ($(filter AVR8,$(CPUS)),)
|
||||
OBJDIRS += $(CPUOBJ)/avr8
|
||||
CPUOBJS += $(CPUOBJ)/avr8/avr8.o
|
||||
DASMOBJS += $(CPUOBJ)/avr8/avr8dasm.o
|
||||
endif
|
||||
|
||||
$(CPUOBJ)/avr8/avr8.o: $(CPUSRC)/avr8/avr8.c \
|
||||
$(CPUSRC)/avr8/avr8.h
|
||||
|
||||
|
||||
|
||||
#-------------------------------------------------
|
||||
# Texas Instruments TMS0980
|
||||
#-------------------------------------------------
|
||||
@ -1572,3 +1586,18 @@ $(CPUOBJ)/z8000/z8000.o: $(CPUSRC)/z8000/z8000.c \
|
||||
$(CPUSRC)/z8000/z8000dab.h \
|
||||
$(CPUSRC)/z8000/z8000ops.c \
|
||||
$(CPUSRC)/z8000/z8000tbl.c
|
||||
|
||||
|
||||
|
||||
#-------------------------------------------------
|
||||
# Argonaut SuperFX
|
||||
#-------------------------------------------------
|
||||
|
||||
ifneq ($(filter SUPERFX,$(CPUS)),)
|
||||
OBJDIRS += $(CPUOBJ)/superfx
|
||||
CPUOBJS += $(CPUOBJ)/superfx/superfx.o
|
||||
DASMOBJS += $(CPUOBJ)/superfx/sfx_dasm.o
|
||||
endif
|
||||
|
||||
$(CPUOBJ)/superfx/superfx.o:$(CPUSRC)/superfx/superfx.c \
|
||||
$(CPUSRC)/superfx/superfx.h
|
||||
|
233
src/emu/cpu/superfx/sfx_dasm.c
Normal file
233
src/emu/cpu/superfx/sfx_dasm.c
Normal file
@ -0,0 +1,233 @@
|
||||
#include "cpuintrf.h"
|
||||
#include <stdarg.h>
|
||||
|
||||
static char *output;
|
||||
|
||||
static void ATTR_PRINTF(1,2) print(const char *fmt, ...)
|
||||
{
|
||||
va_list vl;
|
||||
|
||||
va_start(vl, fmt);
|
||||
output += vsprintf(output, fmt, vl);
|
||||
va_end(vl);
|
||||
}
|
||||
|
||||
offs_t superfx_dasm_one(char *buffer, offs_t pc, UINT8 op, UINT8 param0, UINT8 param1)
|
||||
{
|
||||
UINT8 bytes_consumed = 1;
|
||||
output = buffer;
|
||||
|
||||
switch(op)
|
||||
{
|
||||
case 0x00: // STOP
|
||||
print("STOP");
|
||||
break;
|
||||
case 0x01: // NOP
|
||||
print("NOP");
|
||||
break;
|
||||
case 0x02: // CACHE
|
||||
print("CACHE");
|
||||
break;
|
||||
case 0x03: // LSR
|
||||
print("LSR");
|
||||
break;
|
||||
case 0x04: // ROL
|
||||
print("ROL");
|
||||
break;
|
||||
case 0x05: // BRA
|
||||
print("BRA %d", (INT8)param0);
|
||||
bytes_consumed = 2;
|
||||
break;
|
||||
case 0x06: // BLT
|
||||
print("BLT %d", (INT8)param0);
|
||||
bytes_consumed = 2;
|
||||
break;
|
||||
case 0x07: // BGE
|
||||
print("BGE %d", (INT8)param0);
|
||||
bytes_consumed = 2;
|
||||
break;
|
||||
case 0x08: // BNE
|
||||
print("BNE %d", (INT8)param0);
|
||||
bytes_consumed = 2;
|
||||
break;
|
||||
case 0x09: // BEQ
|
||||
print("BEQ %d", (INT8)param0);
|
||||
bytes_consumed = 2;
|
||||
break;
|
||||
case 0x0a: // BPL
|
||||
print("BPL %d", (INT8)param0);
|
||||
bytes_consumed = 2;
|
||||
break;
|
||||
case 0x0b: // BMI
|
||||
print("BMI %d", (INT8)param0);
|
||||
bytes_consumed = 2;
|
||||
break;
|
||||
case 0x0c: // BCC
|
||||
print("BCC %d", (INT8)param0);
|
||||
bytes_consumed = 2;
|
||||
break;
|
||||
case 0x0d: // BCS
|
||||
print("BCS %d", (INT8)param0);
|
||||
bytes_consumed = 2;
|
||||
break;
|
||||
case 0x0e: // BVC
|
||||
print("BVC %d", (INT8)param0);
|
||||
bytes_consumed = 2;
|
||||
break;
|
||||
case 0x0f: // BVS
|
||||
print("BVS %d", (INT8)param0);
|
||||
bytes_consumed = 2;
|
||||
break;
|
||||
|
||||
case 0x10: case 0x11: case 0x12: case 0x13: case 0x14: case 0x15: case 0x16: case 0x17:
|
||||
case 0x18: case 0x19: case 0x1a: case 0x1b: case 0x1c: case 0x1d: case 0x1e: case 0x1f: // TO
|
||||
print("TO R%d", op & 0xf);
|
||||
break;
|
||||
|
||||
case 0x20: case 0x21: case 0x22: case 0x23: case 0x24: case 0x25: case 0x26: case 0x27:
|
||||
case 0x28: case 0x29: case 0x2a: case 0x2b: case 0x2c: case 0x2d: case 0x2e: case 0x2f: // WITH
|
||||
print("WITH R%d", op & 0xf);
|
||||
break;
|
||||
|
||||
case 0x30: case 0x31: case 0x32: case 0x33: case 0x34: case 0x35:
|
||||
case 0x36: case 0x37: case 0x38: case 0x39: case 0x3a: case 0x3b: // STW_IR / STB_IR
|
||||
print("STW/B (R%d)", op & 0xf);
|
||||
break;
|
||||
|
||||
case 0x3c: // LOOP
|
||||
print("LOOP");
|
||||
break;
|
||||
case 0x3d: // ALT1
|
||||
print("ALT1");
|
||||
break;
|
||||
case 0x3e: // ALT2
|
||||
print("ALT2");
|
||||
break;
|
||||
case 0x3f: // ALT3
|
||||
print("ALT3");
|
||||
break;
|
||||
|
||||
case 0x40: case 0x41: case 0x42: case 0x43: case 0x44: case 0x45:
|
||||
case 0x46: case 0x47: case 0x48: case 0x49: case 0x4a: case 0x4b: // LDW_IR / LDB_IR
|
||||
print("LDW/B (R%d)", op & 0xf);
|
||||
break;
|
||||
|
||||
case 0x4c: // PLOT / RPIX
|
||||
print("PLOT/RPIX");
|
||||
break;
|
||||
|
||||
case 0x4d: // SWAP
|
||||
print("SWAP");
|
||||
break;
|
||||
|
||||
case 0x4e: // COLOR / CMODE
|
||||
print("COLOR/CMODE");
|
||||
break;
|
||||
|
||||
case 0x4f: // NOT
|
||||
print("NOT");
|
||||
break;
|
||||
|
||||
case 0x50: case 0x51: case 0x52: case 0x53: case 0x54: case 0x55: case 0x56: case 0x57:
|
||||
case 0x58: case 0x59: case 0x5a: case 0x5b: case 0x5c: case 0x5d: case 0x5e: case 0x5f: // ADD / ADC / ADDI / ADCI
|
||||
print("ADD R%d ; ADC/ADDI/ADCI", op &0xf);
|
||||
break;
|
||||
|
||||
case 0x60: case 0x61: case 0x62: case 0x63: case 0x64: case 0x65: case 0x66: case 0x67:
|
||||
case 0x68: case 0x69: case 0x6a: case 0x6b: case 0x6c: case 0x6d: case 0x6e: case 0x6f: // SUB / SBC / SUBI / CMP
|
||||
print("SUB R%d ; SBC/SUBI/CMP", op &0xf);
|
||||
break;
|
||||
|
||||
case 0x70: // MERGE
|
||||
print("MERGE");
|
||||
break;
|
||||
|
||||
case 0x71: case 0x72: case 0x73: case 0x74: case 0x75: case 0x76: case 0x77:
|
||||
case 0x78: case 0x79: case 0x7a: case 0x7b: case 0x7c: case 0x7d: case 0x7e: case 0x7f: // AND / BIC / ANDI / BICI
|
||||
print("AND R%d ; BIC/ANDI/BICI", op & 0xf);
|
||||
break;
|
||||
|
||||
case 0x80: case 0x81: case 0x82: case 0x83: case 0x84: case 0x85: case 0x86: case 0x87:
|
||||
case 0x88: case 0x89: case 0x8a: case 0x8b: case 0x8c: case 0x8d: case 0x8e: case 0x8f: // MULT / UMULT / MULTI / UMULTI
|
||||
print("MULT R%d ; UMULT/MULTI/UMULTI", op & 0xf);
|
||||
break;
|
||||
|
||||
case 0x90: // SBK
|
||||
print("SBK");
|
||||
break;
|
||||
|
||||
case 0x91: case 0x92: case 0x93: case 0x94: // LINK
|
||||
print("LINK %d", op & 0xf);
|
||||
break;
|
||||
|
||||
case 0x95: // SEX
|
||||
print("SEX");
|
||||
break;
|
||||
|
||||
case 0x96: // ASR / DIV2
|
||||
print("ASR/DIV2");
|
||||
break;
|
||||
|
||||
case 0x97: // ROR
|
||||
print("ROR");
|
||||
break;
|
||||
|
||||
case 0x98: case 0x99: case 0x9a: case 0x9b: case 0x9c: case 0x9d: // JMP / LJMP
|
||||
print("(L)JMP R%d", op & 0xf);
|
||||
break;
|
||||
|
||||
case 0x9e: // LOB
|
||||
print("LOB");
|
||||
break;
|
||||
|
||||
case 0x9f: // FMULT / LMULT
|
||||
print("FMULT/LMULT");
|
||||
break;
|
||||
|
||||
case 0xa0: case 0xa1: case 0xa2: case 0xa3: case 0xa4: case 0xa5: case 0xa6: case 0xa7:
|
||||
case 0xa8: case 0xa9: case 0xaa: case 0xab: case 0xac: case 0xad: case 0xae: case 0xaf: // IBT / LMS / SMS / LML
|
||||
print("IBT R%d,0x%02x ; SMS/LMS", op & 0xf, param0);
|
||||
bytes_consumed = 2;
|
||||
break;
|
||||
|
||||
case 0xb0: case 0xb1: case 0xb2: case 0xb3: case 0xb4: case 0xb5: case 0xb6: case 0xb7:
|
||||
case 0xb8: case 0xb9: case 0xba: case 0xbb: case 0xbc: case 0xbd: case 0xbe: case 0xbf: // FROM
|
||||
print("FROM R%d", op & 0xf);
|
||||
break;
|
||||
|
||||
case 0xc0: // HIB
|
||||
print("HIB");
|
||||
break;
|
||||
|
||||
case 0xc1: case 0xc2: case 0xc3: case 0xc4: case 0xc5: case 0xc6: case 0xc7:
|
||||
case 0xc8: case 0xc9: case 0xca: case 0xcb: case 0xcc: case 0xcd: case 0xce: case 0xcf: // OR / XOR / ORI / XORI
|
||||
print("OR R%d ; XOR/ORI/XORI", op & 0xf);
|
||||
break;
|
||||
|
||||
case 0xd0: case 0xd1: case 0xd2: case 0xd3: case 0xd4: case 0xd5: case 0xd6: case 0xd7:
|
||||
case 0xd8: case 0xd9: case 0xda: case 0xdb: case 0xdc: case 0xdd: case 0xde: // INC
|
||||
print("INC R%d", op & 0xf);
|
||||
break;
|
||||
|
||||
case 0xdf: // GETC / RAMB / ROMB
|
||||
print("GETC/RAMB/ROMB");
|
||||
break;
|
||||
|
||||
case 0xe0: case 0xe1: case 0xe2: case 0xe3: case 0xe4: case 0xe5: case 0xe6: case 0xe7:
|
||||
case 0xe8: case 0xe9: case 0xea: case 0xeb: case 0xec: case 0xed: case 0xee: // DEC
|
||||
print("DEC R%d", op & 0xf);
|
||||
break;
|
||||
|
||||
case 0xef: // GETB / GETBH / GETBL / GETBS
|
||||
print("GETB/GETBH/GETBL/GETBS");
|
||||
break;
|
||||
|
||||
case 0xf0: case 0xf1: case 0xf2: case 0xf3: case 0xf4: case 0xf5: case 0xf6: case 0xf7:
|
||||
case 0xf8: case 0xf9: case 0xfa: case 0xfb: case 0xfc: case 0xfd: case 0xfe: case 0xff: // IWT / LM / SM / LM
|
||||
print("IWT R%d,#%02x%02x ; SM/LM", op & 0xf, param1, param0);
|
||||
bytes_consumed = 3;
|
||||
break;
|
||||
}
|
||||
|
||||
return bytes_consumed | DASMFLAG_SUPPORTED;
|
||||
}
|
1336
src/emu/cpu/superfx/superfx.c
Normal file
1336
src/emu/cpu/superfx/superfx.c
Normal file
File diff suppressed because it is too large
Load Diff
73
src/emu/cpu/superfx/superfx.h
Normal file
73
src/emu/cpu/superfx/superfx.h
Normal file
@ -0,0 +1,73 @@
|
||||
#ifndef __SUPERFX_H__
|
||||
#define __SUPERFX_H__
|
||||
|
||||
enum
|
||||
{
|
||||
SUPERFX_PC = 1,
|
||||
|
||||
SUPERFX_SFR,
|
||||
SUPERFX_ROMBR,
|
||||
SUPERFX_RAMBR,
|
||||
SUPERFX_CBR,
|
||||
SUPERFX_SCBR,
|
||||
SUPERFX_SCMR,
|
||||
SUPERFX_COLR,
|
||||
SUPERFX_POR,
|
||||
SUPERFX_BRAMR,
|
||||
SUPERFX_VCR,
|
||||
SUPERFX_CFGR,
|
||||
SUPERFX_CLSR,
|
||||
|
||||
SUPERFX_ROMCL,
|
||||
SUPERFX_ROMDR,
|
||||
|
||||
SUPERFX_RAMCL,
|
||||
SUPERFX_RAMAR,
|
||||
SUPERFX_RAMDR,
|
||||
SUPERFX_RAMADDR,
|
||||
};
|
||||
|
||||
#define SUPERFX_SFR_IRQ 0x8000 // Interrupt Flag
|
||||
#define SUPERFX_SFR_B 0x1000 // WITH Flag
|
||||
#define SUPERFX_SFR_IH 0x0800 // Immediate Higher 8-bit Flag
|
||||
#define SUPERFX_SFR_IL 0x0400 // Immediate Lower 8-bit Flag
|
||||
#define SUPERFX_SFR_ALT 0x0300 // ALT Mode, both bits
|
||||
#define SUPERFX_SFR_ALT0 0x0000 // ALT Mode, no bits
|
||||
#define SUPERFX_SFR_ALT1 0x0100 // ALT Mode, bit 0
|
||||
#define SUPERFX_SFR_ALT2 0x0200 // ALT Mode, bit 1
|
||||
#define SUPERFX_SFR_ALT3 0x0300 // ALT Mode, both bits (convenience dupe)
|
||||
#define SUPERFX_SFR_R 0x0040 // ROM R14 Read Flag
|
||||
#define SUPERFX_SFR_G 0x0020 // GO Flag
|
||||
#define SUPERFX_SFR_OV 0x0010 // Overflow Flag
|
||||
#define SUPERFX_SFR_S 0x0008 // Sign Flag
|
||||
#define SUPERFX_SFR_CY 0x0004 // Carry Flag
|
||||
#define SUPERFX_SFR_Z 0x0002 // Zero Flag
|
||||
|
||||
#define SUPERFX_POR_OBJ 0x10
|
||||
#define SUPERFX_POR_FREEZEHIGH 0x08
|
||||
#define SUPERFX_POR_HIGHNIBBLE 0x04
|
||||
#define SUPERFX_POR_DITHER 0x02
|
||||
#define SUPERFX_POR_TRANSPARENT 0x01
|
||||
|
||||
#define SUPERFX_SCMR_HT_MASK 0x24
|
||||
#define SUPERFX_SCMR_HT0 0x00
|
||||
#define SUPERFX_SCMR_HT1 0x04
|
||||
#define SUPERFX_SCMR_HT2 0x20
|
||||
#define SUPERFX_SCMR_HT3 0x24
|
||||
#define SUPERFX_SCMR_RON 0x10
|
||||
#define SUPERFX_SCMR_RAN 0x08
|
||||
#define SUPERFX_SCMR_MD 0x03
|
||||
|
||||
#define SUPERFX_CFGR_IRQ 0x80 // IRQ
|
||||
#define SUPERFX_CFGR_MS0 0x20 // MS0
|
||||
|
||||
CPU_GET_INFO( superfx );
|
||||
#define CPU_SUPERFX CPU_GET_INFO_NAME( superfx )
|
||||
|
||||
CPU_DISASSEMBLE( superfx );
|
||||
extern offs_t superfx_dasm_one(char *buffer, offs_t pc, UINT8 op, UINT8 param0, UINT8 param1);
|
||||
|
||||
UINT8 superfx_mmio_read(const device_config *cpu, UINT32 addr);
|
||||
void superfx_mmio_write(const device_config *cpu, UINT32 addr, UINT8 data);
|
||||
|
||||
#endif /* __SUPERFX_H__ */
|
@ -114,6 +114,7 @@ CPUS += SSEM
|
||||
CPUS += AVR8
|
||||
CPUS += TMS0980
|
||||
CPUS += I4004
|
||||
CPUS += SUPERFX
|
||||
|
||||
|
||||
#-------------------------------------------------
|
||||
|
Loading…
Reference in New Issue
Block a user