mirror of
https://github.com/tildearrow/furnace.git
synced 2024-11-27 06:53:01 +00:00
Unify shared channel struct, De-duplicate channel debug
This commit is contained in:
parent
f455d2d942
commit
ce09edef84
55 changed files with 209 additions and 714 deletions
|
@ -20,46 +20,41 @@
|
||||||
#ifndef _CHIP_UTILS_H
|
#ifndef _CHIP_UTILS_H
|
||||||
#define _CHIP_UTILS_H
|
#define _CHIP_UTILS_H
|
||||||
|
|
||||||
|
#include "macroInt.h"
|
||||||
|
|
||||||
// custom clock limits
|
// custom clock limits
|
||||||
#define MIN_CUSTOM_CLOCK 100000
|
#define MIN_CUSTOM_CLOCK 100000
|
||||||
#define MAX_CUSTOM_CLOCK 40000000
|
#define MAX_CUSTOM_CLOCK 40000000
|
||||||
|
|
||||||
// common shared channel struct
|
// common shared channel struct
|
||||||
|
template<typename T>
|
||||||
struct SharedChannel {
|
struct SharedChannel {
|
||||||
int ins;
|
|
||||||
int note;
|
|
||||||
bool active, insChanged, keyOn, keyOff;
|
|
||||||
SharedChannel():
|
|
||||||
ins(-1),
|
|
||||||
note(0),
|
|
||||||
active(false),
|
|
||||||
insChanged(true),
|
|
||||||
keyOn(false),
|
|
||||||
keyOff(false) {}
|
|
||||||
};
|
|
||||||
|
|
||||||
// common shared channel struct with frequency
|
|
||||||
struct SharedChannelFreq: public SharedChannel {
|
|
||||||
int freq, baseFreq, pitch, pitch2;
|
int freq, baseFreq, pitch, pitch2;
|
||||||
bool freqChanged, inPorta, portaPause;
|
int ins, note;
|
||||||
SharedChannelFreq():
|
bool active, insChanged, freqChanged, keyOn, keyOff, portaPause, inPorta;
|
||||||
SharedChannel(),
|
T vol, outVol;
|
||||||
|
DivMacroInt std;
|
||||||
|
void macroInit(DivInstrument* which) {
|
||||||
|
std.init(which);
|
||||||
|
pitch2=0;
|
||||||
|
}
|
||||||
|
SharedChannel(T initVol):
|
||||||
freq(0),
|
freq(0),
|
||||||
baseFreq(0),
|
baseFreq(0),
|
||||||
pitch(0),
|
pitch(0),
|
||||||
pitch2(0),
|
pitch2(0),
|
||||||
|
ins(-1),
|
||||||
|
note(0),
|
||||||
|
active(false),
|
||||||
|
insChanged(true),
|
||||||
freqChanged(false),
|
freqChanged(false),
|
||||||
|
keyOn(false),
|
||||||
|
keyOff(false),
|
||||||
|
portaPause(false),
|
||||||
inPorta(false),
|
inPorta(false),
|
||||||
portaPause(false) {}
|
|
||||||
};
|
|
||||||
|
|
||||||
// common shared channel volume struct
|
|
||||||
template<typename T>
|
|
||||||
struct SharedChannelVolume {
|
|
||||||
T vol, outVol;
|
|
||||||
SharedChannelVolume(T initVol):
|
|
||||||
vol(initVol),
|
vol(initVol),
|
||||||
outVol(initVol) {}
|
outVol(initVol),
|
||||||
|
std() {}
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -22,11 +22,10 @@
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "../waveSynth.h"
|
#include "../waveSynth.h"
|
||||||
|
|
||||||
class DivPlatformAmiga: public DivDispatch {
|
class DivPlatformAmiga: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
unsigned int audLoc;
|
unsigned int audLoc;
|
||||||
unsigned short audLen;
|
unsigned short audLen;
|
||||||
unsigned int audPos;
|
unsigned int audPos;
|
||||||
|
@ -35,15 +34,9 @@ class DivPlatformAmiga: public DivDispatch {
|
||||||
int sample, wave;
|
int sample, wave;
|
||||||
int busClock;
|
int busClock;
|
||||||
bool useWave, setPos, useV, useP;
|
bool useWave, setPos, useV, useP;
|
||||||
DivMacroInt std;
|
|
||||||
DivWaveSynth ws;
|
DivWaveSynth ws;
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(64),
|
||||||
SharedChannelVolume<signed char>(64),
|
|
||||||
audLoc(0),
|
audLoc(0),
|
||||||
audLen(0),
|
audLen(0),
|
||||||
audPos(0),
|
audPos(0),
|
||||||
|
|
|
@ -20,7 +20,6 @@
|
||||||
#ifndef _AY_H
|
#ifndef _AY_H
|
||||||
#define _AY_H
|
#define _AY_H
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "sound/ay8910.h"
|
#include "sound/ay8910.h"
|
||||||
|
|
||||||
|
@ -30,7 +29,7 @@ class DivPlatformAY8910: public DivDispatch {
|
||||||
0,4,1,5,2,6,9,8,11,12,13,3,7,10,14,15
|
0,4,1,5,2,6,9,8,11,12,13,3,7,10,14,15
|
||||||
};
|
};
|
||||||
inline unsigned char regRemap(unsigned char reg) { return intellivision?AY8914RegRemap[reg&0x0f]:reg&0x0f; }
|
inline unsigned char regRemap(unsigned char reg) { return intellivision?AY8914RegRemap[reg&0x0f]:reg&0x0f; }
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<int> {
|
struct Channel: public SharedChannel<int> {
|
||||||
struct PSGMode {
|
struct PSGMode {
|
||||||
union {
|
union {
|
||||||
struct {
|
struct {
|
||||||
|
@ -75,14 +74,8 @@ class DivPlatformAY8910: public DivDispatch {
|
||||||
|
|
||||||
unsigned char autoEnvNum, autoEnvDen;
|
unsigned char autoEnvNum, autoEnvDen;
|
||||||
signed char konCycles;
|
signed char konCycles;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<int>(15),
|
||||||
SharedChannelVolume<int>(15),
|
|
||||||
curPSGMode(PSGMode(0)),
|
curPSGMode(PSGMode(0)),
|
||||||
nextPSGMode(PSGMode(1)),
|
nextPSGMode(PSGMode(1)),
|
||||||
dac(DAC()),
|
dac(DAC()),
|
||||||
|
|
|
@ -20,13 +20,12 @@
|
||||||
#ifndef _AY8930_H
|
#ifndef _AY8930_H
|
||||||
#define _AY8930_H
|
#define _AY8930_H
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "sound/ay8910.h"
|
#include "sound/ay8910.h"
|
||||||
|
|
||||||
class DivPlatformAY8930: public DivDispatch {
|
class DivPlatformAY8930: public DivDispatch {
|
||||||
protected:
|
protected:
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<int> {
|
struct Channel: public SharedChannel<int> {
|
||||||
struct Envelope {
|
struct Envelope {
|
||||||
unsigned char mode;
|
unsigned char mode;
|
||||||
unsigned short period;
|
unsigned short period;
|
||||||
|
@ -83,14 +82,8 @@ class DivPlatformAY8930: public DivDispatch {
|
||||||
|
|
||||||
unsigned char autoEnvNum, autoEnvDen, duty;
|
unsigned char autoEnvNum, autoEnvDen, duty;
|
||||||
signed char konCycles;
|
signed char konCycles;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<int>(31),
|
||||||
SharedChannelVolume<int>(31),
|
|
||||||
envelope(Envelope()),
|
envelope(Envelope()),
|
||||||
curPSGMode(PSGMode(0)),
|
curPSGMode(PSGMode(0)),
|
||||||
nextPSGMode(PSGMode(1)),
|
nextPSGMode(PSGMode(1)),
|
||||||
|
|
|
@ -22,23 +22,16 @@
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "../waveSynth.h"
|
#include "../waveSynth.h"
|
||||||
#include "vgsound_emu/src/k005289/k005289.hpp"
|
#include "vgsound_emu/src/k005289/k005289.hpp"
|
||||||
|
|
||||||
class DivPlatformBubSysWSG: public DivDispatch {
|
class DivPlatformBubSysWSG: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
signed short wave;
|
signed short wave;
|
||||||
signed char waveROM[32] = {0}; // 4 bit PROM per channel on bubble system
|
signed char waveROM[32] = {0}; // 4 bit PROM per channel on bubble system
|
||||||
DivMacroInt std;
|
|
||||||
DivWaveSynth ws;
|
DivWaveSynth ws;
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(15),
|
||||||
SharedChannelVolume<signed char>(15),
|
|
||||||
wave(-1) {}
|
wave(-1) {}
|
||||||
};
|
};
|
||||||
Channel chan[2];
|
Channel chan[2];
|
||||||
|
|
|
@ -22,25 +22,18 @@
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "sound/c64/sid.h"
|
#include "sound/c64/sid.h"
|
||||||
#include "sound/c64_fp/SID.h"
|
#include "sound/c64_fp/SID.h"
|
||||||
|
|
||||||
class DivPlatformC64: public DivDispatch {
|
class DivPlatformC64: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
int prevFreq, testWhen;
|
int prevFreq, testWhen;
|
||||||
unsigned char sweep, wave, attack, decay, sustain, release;
|
unsigned char sweep, wave, attack, decay, sustain, release;
|
||||||
short duty;
|
short duty;
|
||||||
bool sweepChanged, filter;
|
bool sweepChanged, filter;
|
||||||
bool resetMask, resetFilter, resetDuty, ring, sync, test;
|
bool resetMask, resetFilter, resetDuty, ring, sync, test;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(15),
|
||||||
SharedChannelVolume<signed char>(15),
|
|
||||||
prevFreq(65535),
|
prevFreq(65535),
|
||||||
testWhen(0),
|
testWhen(0),
|
||||||
sweep(0),
|
sweep(0),
|
||||||
|
|
|
@ -21,26 +21,18 @@
|
||||||
#define _FDS_H
|
#define _FDS_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "../waveSynth.h"
|
#include "../waveSynth.h"
|
||||||
|
|
||||||
#include "sound/nes_nsfplay/nes_fds.h"
|
#include "sound/nes_nsfplay/nes_fds.h"
|
||||||
|
|
||||||
class DivPlatformFDS: public DivDispatch {
|
class DivPlatformFDS: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
int prevFreq, modFreq;
|
int prevFreq, modFreq;
|
||||||
unsigned char duty, sweep, modDepth, modPos;
|
unsigned char duty, sweep, modDepth, modPos;
|
||||||
bool sweepChanged, modOn;
|
bool sweepChanged, modOn;
|
||||||
signed short wave;
|
signed short wave;
|
||||||
signed char modTable[32];
|
signed char modTable[32];
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(32),
|
||||||
SharedChannelVolume<signed char>(32),
|
|
||||||
prevFreq(65535),
|
prevFreq(65535),
|
||||||
modFreq(0),
|
modFreq(0),
|
||||||
duty(0),
|
duty(0),
|
||||||
|
|
|
@ -123,19 +123,13 @@ class DivPlatformOPN: public DivPlatformFMBase {
|
||||||
pan(3) {}
|
pan(3) {}
|
||||||
};
|
};
|
||||||
|
|
||||||
struct OPNOpChannel: public SharedChannelFreq, public SharedChannelVolume<int> {
|
struct OPNOpChannel: public SharedChannel<int> {
|
||||||
DivMacroInt std;
|
|
||||||
unsigned char freqH, freqL;
|
unsigned char freqH, freqL;
|
||||||
int portaPauseFreq;
|
int portaPauseFreq;
|
||||||
signed char konCycles;
|
signed char konCycles;
|
||||||
bool mask;
|
bool mask;
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
OPNOpChannel():
|
OPNOpChannel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<int>(0),
|
||||||
SharedChannelVolume<int>(0),
|
|
||||||
freqH(0),
|
freqH(0),
|
||||||
freqL(0),
|
freqL(0),
|
||||||
portaPauseFreq(0),
|
portaPauseFreq(0),
|
||||||
|
|
|
@ -22,7 +22,6 @@
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../instrument.h"
|
#include "../instrument.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
#include <deque>
|
#include <deque>
|
||||||
|
|
||||||
#define KVS(x,y) ((chan[x].state.op[y].kvs==2 && isOutput[chan[x].state.alg][y]) || chan[x].state.op[y].kvs==1)
|
#define KVS(x,y) ((chan[x].state.op[y].kvs==2 && isOutput[chan[x].state.alg][y]) || chan[x].state.op[y].kvs==1)
|
||||||
|
@ -48,22 +47,16 @@ class DivPlatformFMBase: public DivDispatch {
|
||||||
0,2,1,3
|
0,2,1,3
|
||||||
};
|
};
|
||||||
|
|
||||||
struct FMChannel: public SharedChannelFreq, public SharedChannelVolume<int> {
|
struct FMChannel: public SharedChannel<int> {
|
||||||
DivInstrumentFM state;
|
DivInstrumentFM state;
|
||||||
DivMacroInt std;
|
|
||||||
unsigned char freqH, freqL;
|
unsigned char freqH, freqL;
|
||||||
int portaPauseFreq;
|
int portaPauseFreq;
|
||||||
unsigned char opMask;
|
unsigned char opMask;
|
||||||
signed char konCycles;
|
signed char konCycles;
|
||||||
bool hardReset, opMaskChanged;
|
bool hardReset, opMaskChanged;
|
||||||
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
FMChannel():
|
FMChannel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<int>(0),
|
||||||
SharedChannelVolume<int>(0),
|
|
||||||
freqH(0),
|
freqH(0),
|
||||||
freqL(0),
|
freqL(0),
|
||||||
portaPauseFreq(0),
|
portaPauseFreq(0),
|
||||||
|
@ -125,8 +118,7 @@ class DivPlatformFMBase: public DivDispatch {
|
||||||
|
|
||||||
friend void putDispatchChan(void*,int,int);
|
friend void putDispatchChan(void*,int,int);
|
||||||
|
|
||||||
DivPlatformFMBase():
|
DivPlatformFMBase():DivDispatch(),
|
||||||
DivDispatch(),
|
|
||||||
lastBusy(0),
|
lastBusy(0),
|
||||||
delay(0) {}
|
delay(0) {}
|
||||||
};
|
};
|
||||||
|
|
|
@ -21,13 +21,12 @@
|
||||||
#define _GB_H
|
#define _GB_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "../waveSynth.h"
|
#include "../waveSynth.h"
|
||||||
#include "sound/gb/gb.h"
|
#include "sound/gb/gb.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
|
|
||||||
class DivPlatformGB: public DivDispatch {
|
class DivPlatformGB: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
unsigned char duty, sweep;
|
unsigned char duty, sweep;
|
||||||
bool sweepChanged, released, softEnv, killIt;
|
bool sweepChanged, released, softEnv, killIt;
|
||||||
bool soManyHacksToMakeItDefleCompatible;
|
bool soManyHacksToMakeItDefleCompatible;
|
||||||
|
@ -36,14 +35,8 @@ class DivPlatformGB: public DivDispatch {
|
||||||
unsigned char envVol, envDir, envLen, soundLen;
|
unsigned char envVol, envDir, envLen, soundLen;
|
||||||
unsigned short hwSeqPos;
|
unsigned short hwSeqPos;
|
||||||
short hwSeqDelay;
|
short hwSeqDelay;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(15),
|
||||||
SharedChannelVolume<signed char>(15),
|
|
||||||
duty(0),
|
duty(0),
|
||||||
sweep(0),
|
sweep(0),
|
||||||
sweepChanged(false),
|
sweepChanged(false),
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
#ifndef _GENESIS_H
|
#ifndef _GENESIS_H
|
||||||
#define _GENESIS_H
|
#define _GENESIS_H
|
||||||
#include "fmshared_OPN.h"
|
#include "fmshared_OPN.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "../../../extern/Nuked-OPN2/ym3438.h"
|
#include "../../../extern/Nuked-OPN2/ym3438.h"
|
||||||
#include "sound/ymfm/ymfm_opn.h"
|
#include "sound/ymfm/ymfm_opn.h"
|
||||||
|
|
||||||
|
|
|
@ -21,7 +21,6 @@
|
||||||
#define _LYNX_H
|
#define _LYNX_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "sound/lynx/Mikey.hpp"
|
#include "sound/lynx/Mikey.hpp"
|
||||||
|
|
||||||
class DivPlatformLynx: public DivDispatch {
|
class DivPlatformLynx: public DivDispatch {
|
||||||
|
@ -40,22 +39,15 @@ class DivPlatformLynx: public DivDispatch {
|
||||||
MikeyDuty(int duty);
|
MikeyDuty(int duty);
|
||||||
};
|
};
|
||||||
|
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
DivMacroInt std;
|
|
||||||
MikeyFreqDiv fd;
|
MikeyFreqDiv fd;
|
||||||
MikeyDuty duty;
|
MikeyDuty duty;
|
||||||
int actualNote, lfsr, sample, samplePos, sampleAccum, sampleBaseFreq, sampleFreq;
|
int actualNote, lfsr, sample, samplePos, sampleAccum, sampleBaseFreq, sampleFreq;
|
||||||
unsigned char pan;
|
unsigned char pan;
|
||||||
bool pcm;
|
bool pcm;
|
||||||
int macroVolMul;
|
int macroVolMul;
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(127),
|
||||||
SharedChannelVolume<signed char>(127),
|
|
||||||
std(),
|
|
||||||
fd(0),
|
fd(0),
|
||||||
duty(0),
|
duty(0),
|
||||||
actualNote(0),
|
actualNote(0),
|
||||||
|
|
|
@ -21,22 +21,15 @@
|
||||||
#define _MMC5_H
|
#define _MMC5_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
|
|
||||||
class DivPlatformMMC5: public DivDispatch {
|
class DivPlatformMMC5: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
int prevFreq;
|
int prevFreq;
|
||||||
unsigned char duty, sweep;
|
unsigned char duty, sweep;
|
||||||
bool sweepChanged, furnaceDac;
|
bool sweepChanged, furnaceDac;
|
||||||
signed char wave;
|
signed short wave;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(15),
|
||||||
SharedChannelVolume<signed char>(15),
|
|
||||||
prevFreq(65535),
|
prevFreq(65535),
|
||||||
duty(0),
|
duty(0),
|
||||||
sweep(8),
|
sweep(8),
|
||||||
|
|
|
@ -22,20 +22,13 @@
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "sound/oki/msm5232.h"
|
#include "sound/oki/msm5232.h"
|
||||||
|
|
||||||
class DivPlatformMSM5232: public DivDispatch {
|
class DivPlatformMSM5232: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
bool noise;
|
bool noise;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(127),
|
||||||
SharedChannelVolume<signed char>(127),
|
|
||||||
noise(false) {}
|
noise(false) {}
|
||||||
};
|
};
|
||||||
Channel chan[8];
|
Channel chan[8];
|
||||||
|
|
|
@ -19,24 +19,19 @@
|
||||||
|
|
||||||
#ifndef _MSM6258_H
|
#ifndef _MSM6258_H
|
||||||
#define _MSM6258_H
|
#define _MSM6258_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "sound/oki/okim6258.h"
|
#include "sound/oki/okim6258.h"
|
||||||
|
|
||||||
class DivPlatformMSM6258: public DivDispatch {
|
class DivPlatformMSM6258: public DivDispatch {
|
||||||
protected:
|
protected:
|
||||||
struct Channel: public SharedChannel, public SharedChannelVolume<int> {
|
struct Channel: public SharedChannel<int> {
|
||||||
bool furnacePCM;
|
bool furnacePCM;
|
||||||
int sample;
|
int sample;
|
||||||
unsigned char pan;
|
unsigned char pan;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannel(),
|
SharedChannel<int>(8),
|
||||||
SharedChannelVolume<int>(8),
|
|
||||||
furnacePCM(false),
|
furnacePCM(false),
|
||||||
sample(-1),
|
sample(-1),
|
||||||
pan(3) {}
|
pan(3) {}
|
||||||
|
|
|
@ -19,23 +19,18 @@
|
||||||
|
|
||||||
#ifndef _MSM6295_H
|
#ifndef _MSM6295_H
|
||||||
#define _MSM6295_H
|
#define _MSM6295_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "vgsound_emu/src/msm6295/msm6295.hpp"
|
#include "vgsound_emu/src/msm6295/msm6295.hpp"
|
||||||
|
|
||||||
class DivPlatformMSM6295: public DivDispatch, public vgsound_emu_mem_intf {
|
class DivPlatformMSM6295: public DivDispatch, public vgsound_emu_mem_intf {
|
||||||
protected:
|
protected:
|
||||||
struct Channel: public SharedChannel, public SharedChannelVolume<int> {
|
struct Channel: public SharedChannel<int> {
|
||||||
bool furnacePCM;
|
bool furnacePCM;
|
||||||
int sample;
|
int sample;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannel(),
|
SharedChannel<int>(8),
|
||||||
SharedChannelVolume<int>(8),
|
|
||||||
furnacePCM(false),
|
furnacePCM(false),
|
||||||
sample(-1) {}
|
sample(-1) {}
|
||||||
};
|
};
|
||||||
|
@ -96,8 +91,7 @@ class DivPlatformMSM6295: public DivDispatch, public vgsound_emu_mem_intf {
|
||||||
|
|
||||||
virtual int init(DivEngine* parent, int channels, int sugRate, const DivConfig& flags) override;
|
virtual int init(DivEngine* parent, int channels, int sugRate, const DivConfig& flags) override;
|
||||||
virtual void quit() override;
|
virtual void quit() override;
|
||||||
DivPlatformMSM6295():
|
DivPlatformMSM6295():DivDispatch(),
|
||||||
DivDispatch(),
|
|
||||||
vgsound_emu_mem_intf(),
|
vgsound_emu_mem_intf(),
|
||||||
msm(*this) {}
|
msm(*this) {}
|
||||||
~DivPlatformMSM6295();
|
~DivPlatformMSM6295();
|
||||||
|
|
|
@ -22,12 +22,11 @@
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "../waveSynth.h"
|
#include "../waveSynth.h"
|
||||||
#include "vgsound_emu/src/n163/n163.hpp"
|
#include "vgsound_emu/src/n163/n163.hpp"
|
||||||
|
|
||||||
class DivPlatformN163: public DivDispatch {
|
class DivPlatformN163: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
signed char resVol;
|
signed char resVol;
|
||||||
short wave, wavePos, waveLen;
|
short wave, wavePos, waveLen;
|
||||||
unsigned char waveMode;
|
unsigned char waveMode;
|
||||||
|
@ -35,15 +34,9 @@ class DivPlatformN163: public DivDispatch {
|
||||||
unsigned char loadMode;
|
unsigned char loadMode;
|
||||||
bool volumeChanged;
|
bool volumeChanged;
|
||||||
bool waveChanged, waveUpdated;
|
bool waveChanged, waveUpdated;
|
||||||
DivMacroInt std;
|
|
||||||
DivWaveSynth ws;
|
DivWaveSynth ws;
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(15),
|
||||||
SharedChannelVolume<signed char>(15),
|
|
||||||
resVol(15),
|
resVol(15),
|
||||||
wave(-1),
|
wave(-1),
|
||||||
wavePos(0),
|
wavePos(0),
|
||||||
|
|
|
@ -22,24 +22,17 @@
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "../waveSynth.h"
|
#include "../waveSynth.h"
|
||||||
#include "sound/namco.h"
|
#include "sound/namco.h"
|
||||||
|
|
||||||
class DivPlatformNamcoWSG: public DivDispatch {
|
class DivPlatformNamcoWSG: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
unsigned char pan;
|
unsigned char pan;
|
||||||
bool noise;
|
bool noise;
|
||||||
signed char wave;
|
signed short wave;
|
||||||
DivMacroInt std;
|
|
||||||
DivWaveSynth ws;
|
DivWaveSynth ws;
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(15),
|
||||||
SharedChannelVolume<signed char>(15),
|
|
||||||
pan(255),
|
pan(255),
|
||||||
noise(false),
|
noise(false),
|
||||||
wave(-1) {}
|
wave(-1) {}
|
||||||
|
|
|
@ -21,24 +21,17 @@
|
||||||
#define _NES_H
|
#define _NES_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
|
|
||||||
#include "sound/nes_nsfplay/nes_apu.h"
|
#include "sound/nes_nsfplay/nes_apu.h"
|
||||||
|
|
||||||
class DivPlatformNES: public DivDispatch {
|
class DivPlatformNES: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
int prevFreq;
|
int prevFreq;
|
||||||
unsigned char duty, sweep, envMode, len;
|
unsigned char duty, sweep, envMode, len;
|
||||||
bool sweepChanged, furnaceDac;
|
bool sweepChanged, furnaceDac;
|
||||||
signed char wave;
|
signed short wave;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(15),
|
||||||
SharedChannelVolume<signed char>(15),
|
|
||||||
prevFreq(65535),
|
prevFreq(65535),
|
||||||
duty(0),
|
duty(0),
|
||||||
sweep(8),
|
sweep(8),
|
||||||
|
|
|
@ -19,8 +19,8 @@
|
||||||
|
|
||||||
#ifndef _OPL_H
|
#ifndef _OPL_H
|
||||||
#define _OPL_H
|
#define _OPL_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "../../../extern/opl/opl3.h"
|
#include "../../../extern/opl/opl3.h"
|
||||||
#include "sound/ymfm/ymfm_adpcm.h"
|
#include "sound/ymfm/ymfm_adpcm.h"
|
||||||
|
@ -36,21 +36,15 @@ class DivOPLAInterface: public ymfm::ymfm_interface {
|
||||||
|
|
||||||
class DivPlatformOPL: public DivDispatch {
|
class DivPlatformOPL: public DivDispatch {
|
||||||
protected:
|
protected:
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<int> {
|
struct Channel: public SharedChannel<int> {
|
||||||
DivInstrumentFM state;
|
DivInstrumentFM state;
|
||||||
DivMacroInt std;
|
|
||||||
unsigned char freqH, freqL;
|
unsigned char freqH, freqL;
|
||||||
int sample, fixedFreq;
|
int sample, fixedFreq;
|
||||||
bool furnacePCM, fourOp, hardReset;
|
bool furnacePCM, fourOp, hardReset;
|
||||||
unsigned char pan;
|
unsigned char pan;
|
||||||
int macroVolMul;
|
int macroVolMul;
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<int>(0),
|
||||||
SharedChannelVolume<int>(0),
|
|
||||||
freqH(0),
|
freqH(0),
|
||||||
freqL(0),
|
freqL(0),
|
||||||
sample(-1),
|
sample(-1),
|
||||||
|
|
|
@ -19,8 +19,8 @@
|
||||||
|
|
||||||
#ifndef _OPLL_H
|
#ifndef _OPLL_H
|
||||||
#define _OPLL_H
|
#define _OPLL_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
#include <queue>
|
#include <queue>
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
|
@ -29,20 +29,14 @@ extern "C" {
|
||||||
|
|
||||||
class DivPlatformOPLL: public DivDispatch {
|
class DivPlatformOPLL: public DivDispatch {
|
||||||
protected:
|
protected:
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<int> {
|
struct Channel: public SharedChannel<int> {
|
||||||
DivInstrumentFM state;
|
DivInstrumentFM state;
|
||||||
DivMacroInt std;
|
|
||||||
unsigned char freqH, freqL;
|
unsigned char freqH, freqL;
|
||||||
int fixedFreq;
|
int fixedFreq;
|
||||||
bool furnaceDac;
|
bool furnaceDac;
|
||||||
unsigned char pan;
|
unsigned char pan;
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<int>(0),
|
||||||
SharedChannelVolume<int>(0),
|
|
||||||
freqH(0),
|
freqH(0),
|
||||||
freqL(0),
|
freqL(0),
|
||||||
fixedFreq(0),
|
fixedFreq(0),
|
||||||
|
|
|
@ -22,12 +22,11 @@
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "../waveSynth.h"
|
#include "../waveSynth.h"
|
||||||
#include "sound/pce_psg.h"
|
#include "sound/pce_psg.h"
|
||||||
|
|
||||||
class DivPlatformPCE: public DivDispatch {
|
class DivPlatformPCE: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
int antiClickPeriodCount, antiClickWavePos;
|
int antiClickPeriodCount, antiClickWavePos;
|
||||||
int dacPeriod, dacRate, dacOut;
|
int dacPeriod, dacRate, dacOut;
|
||||||
unsigned int dacPos;
|
unsigned int dacPos;
|
||||||
|
@ -36,15 +35,9 @@ class DivPlatformPCE: public DivDispatch {
|
||||||
bool noise, pcm, furnaceDac, deferredWaveUpdate;
|
bool noise, pcm, furnaceDac, deferredWaveUpdate;
|
||||||
signed short wave;
|
signed short wave;
|
||||||
int macroVolMul;
|
int macroVolMul;
|
||||||
DivMacroInt std;
|
|
||||||
DivWaveSynth ws;
|
DivWaveSynth ws;
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(31),
|
||||||
SharedChannelVolume<signed char>(31),
|
|
||||||
antiClickPeriodCount(0),
|
antiClickPeriodCount(0),
|
||||||
antiClickWavePos(0),
|
antiClickWavePos(0),
|
||||||
dacPeriod(0),
|
dacPeriod(0),
|
||||||
|
|
|
@ -22,11 +22,10 @@
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "../waveSynth.h"
|
#include "../waveSynth.h"
|
||||||
|
|
||||||
class DivPlatformPCMDAC: public DivDispatch {
|
class DivPlatformPCMDAC: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq {
|
struct Channel: public SharedChannel<int> {
|
||||||
bool audDir;
|
bool audDir;
|
||||||
unsigned int audLoc;
|
unsigned int audLoc;
|
||||||
unsigned short audLen;
|
unsigned short audLen;
|
||||||
|
@ -35,15 +34,10 @@ class DivPlatformPCMDAC: public DivDispatch {
|
||||||
int sample, wave;
|
int sample, wave;
|
||||||
int panL, panR;
|
int panL, panR;
|
||||||
bool useWave, setPos;
|
bool useWave, setPos;
|
||||||
int vol, envVol;
|
int envVol;
|
||||||
DivMacroInt std;
|
|
||||||
DivWaveSynth ws;
|
DivWaveSynth ws;
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<int>(255),
|
||||||
audDir(false),
|
audDir(false),
|
||||||
audLoc(0),
|
audLoc(0),
|
||||||
audLen(0),
|
audLen(0),
|
||||||
|
@ -55,7 +49,6 @@ class DivPlatformPCMDAC: public DivDispatch {
|
||||||
panR(255),
|
panR(255),
|
||||||
useWave(false),
|
useWave(false),
|
||||||
setPos(false),
|
setPos(false),
|
||||||
vol(255),
|
|
||||||
envVol(64) {}
|
envVol(64) {}
|
||||||
};
|
};
|
||||||
Channel chan;
|
Channel chan;
|
||||||
|
|
|
@ -21,22 +21,15 @@
|
||||||
#define _PCSPKR_H
|
#define _PCSPKR_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include <thread>
|
#include <thread>
|
||||||
#include <mutex>
|
#include <mutex>
|
||||||
#include <condition_variable>
|
#include <condition_variable>
|
||||||
|
|
||||||
class DivPlatformPCSpeaker: public DivDispatch {
|
class DivPlatformPCSpeaker: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(15) {}
|
||||||
SharedChannelVolume<signed char>(15) {}
|
|
||||||
};
|
};
|
||||||
Channel chan[1];
|
Channel chan[1];
|
||||||
DivDispatchOscBuffer* oscBuf;
|
DivDispatchOscBuffer* oscBuf;
|
||||||
|
|
|
@ -21,23 +21,16 @@
|
||||||
#define _PET_H
|
#define _PET_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
|
|
||||||
class DivPlatformPET: public DivDispatch {
|
class DivPlatformPET: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<int> {
|
struct Channel: public SharedChannel<int> {
|
||||||
bool enable;
|
bool enable;
|
||||||
int wave;
|
int wave;
|
||||||
unsigned char sreg;
|
unsigned char sreg;
|
||||||
int cnt;
|
int cnt;
|
||||||
short out;
|
short out;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<int>(1),
|
||||||
SharedChannelVolume<int>(1),
|
|
||||||
enable(false),
|
enable(false),
|
||||||
wave(0b00001111),
|
wave(0b00001111),
|
||||||
sreg(0),
|
sreg(0),
|
||||||
|
|
|
@ -21,18 +21,11 @@
|
||||||
#define _PONG_H
|
#define _PONG_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
|
|
||||||
class DivPlatformPong: public DivDispatch {
|
class DivPlatformPong: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(1) {}
|
||||||
SharedChannelVolume<signed char>(1) {}
|
|
||||||
};
|
};
|
||||||
Channel chan[1];
|
Channel chan[1];
|
||||||
DivDispatchOscBuffer* oscBuf;
|
DivDispatchOscBuffer* oscBuf;
|
||||||
|
|
|
@ -22,24 +22,17 @@
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "sound/qsound.h"
|
#include "sound/qsound.h"
|
||||||
|
|
||||||
class DivPlatformQSound: public DivDispatch {
|
class DivPlatformQSound: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<int> {
|
struct Channel: public SharedChannel<int> {
|
||||||
int resVol;
|
int resVol;
|
||||||
int sample, wave;
|
int sample, wave;
|
||||||
int panning;
|
int panning;
|
||||||
int echo;
|
int echo;
|
||||||
bool useWave, surround, isNewQSound;
|
bool useWave, surround, isNewQSound;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<int>(255),
|
||||||
SharedChannelVolume<int>(255),
|
|
||||||
resVol(4095),
|
resVol(4095),
|
||||||
sample(-1),
|
sample(-1),
|
||||||
panning(0x10),
|
panning(0x10),
|
||||||
|
|
|
@ -22,24 +22,17 @@
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "sound/rf5c68.h"
|
#include "sound/rf5c68.h"
|
||||||
|
|
||||||
class DivPlatformRF5C68: public DivDispatch {
|
class DivPlatformRF5C68: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<int> {
|
struct Channel: public SharedChannel<int> {
|
||||||
unsigned int audPos;
|
unsigned int audPos;
|
||||||
int sample, wave;
|
int sample, wave;
|
||||||
int panning;
|
int panning;
|
||||||
bool setPos;
|
bool setPos;
|
||||||
int macroVolMul;
|
int macroVolMul;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<int>(255),
|
||||||
SharedChannelVolume<int>(255),
|
|
||||||
audPos(0),
|
audPos(0),
|
||||||
sample(-1),
|
sample(-1),
|
||||||
panning(255),
|
panning(255),
|
||||||
|
|
|
@ -19,25 +19,19 @@
|
||||||
|
|
||||||
#ifndef _SAA_H
|
#ifndef _SAA_H
|
||||||
#define _SAA_H
|
#define _SAA_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "../../../extern/SAASound/src/SAASound.h"
|
#include "../../../extern/SAASound/src/SAASound.h"
|
||||||
|
|
||||||
class DivPlatformSAA1099: public DivDispatch {
|
class DivPlatformSAA1099: public DivDispatch {
|
||||||
protected:
|
protected:
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<int> {
|
struct Channel: public SharedChannel<int> {
|
||||||
unsigned char freqH, freqL;
|
unsigned char freqH, freqL;
|
||||||
unsigned char psgMode;
|
unsigned char psgMode;
|
||||||
unsigned char pan;
|
unsigned char pan;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<int>(15),
|
||||||
SharedChannelVolume<int>(15),
|
|
||||||
freqH(0),
|
freqH(0),
|
||||||
freqL(0),
|
freqL(0),
|
||||||
psgMode(1),
|
psgMode(1),
|
||||||
|
|
|
@ -22,24 +22,17 @@
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "../waveSynth.h"
|
#include "../waveSynth.h"
|
||||||
#include "vgsound_emu/src/scc/scc.hpp"
|
#include "vgsound_emu/src/scc/scc.hpp"
|
||||||
|
|
||||||
class DivPlatformSCC: public DivDispatch {
|
class DivPlatformSCC: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
bool freqInit;
|
bool freqInit;
|
||||||
signed short wave;
|
signed short wave;
|
||||||
signed char waveROM[32] = {0}; // 8 bit signed waveform
|
signed char waveROM[32] = {0}; // 8 bit signed waveform
|
||||||
DivMacroInt std;
|
|
||||||
DivWaveSynth ws;
|
DivWaveSynth ws;
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(15),
|
||||||
SharedChannelVolume<signed char>(15),
|
|
||||||
freqInit(false),
|
freqInit(false),
|
||||||
wave(-1) {}
|
wave(-1) {}
|
||||||
};
|
};
|
||||||
|
|
|
@ -19,15 +19,14 @@
|
||||||
|
|
||||||
#ifndef _SEGAPCM_H
|
#ifndef _SEGAPCM_H
|
||||||
#define _SEGAPCM_H
|
#define _SEGAPCM_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../instrument.h"
|
#include "../instrument.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "../macroInt.h"
|
|
||||||
|
|
||||||
class DivPlatformSegaPCM: public DivDispatch {
|
class DivPlatformSegaPCM: public DivDispatch {
|
||||||
protected:
|
protected:
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<int> {
|
struct Channel: public SharedChannel<int> {
|
||||||
DivMacroInt std;
|
|
||||||
bool furnacePCM, isNewSegaPCM;
|
bool furnacePCM, isNewSegaPCM;
|
||||||
unsigned char chVolL, chVolR;
|
unsigned char chVolL, chVolR;
|
||||||
unsigned char chPanL, chPanR;
|
unsigned char chPanL, chPanR;
|
||||||
|
@ -40,13 +39,8 @@ class DivPlatformSegaPCM: public DivDispatch {
|
||||||
unsigned char freq;
|
unsigned char freq;
|
||||||
PCMChannel(): sample(-1), pos(0), len(0), freq(0) {}
|
PCMChannel(): sample(-1), pos(0), len(0), freq(0) {}
|
||||||
} pcm;
|
} pcm;
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<int>(127),
|
||||||
SharedChannelVolume<int>(127),
|
|
||||||
furnacePCM(false),
|
furnacePCM(false),
|
||||||
isNewSegaPCM(false),
|
isNewSegaPCM(false),
|
||||||
chVolL(127),
|
chVolL(127),
|
||||||
|
|
|
@ -21,7 +21,6 @@
|
||||||
#define _SMS_H
|
#define _SMS_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "sound/sn76496.h"
|
#include "sound/sn76496.h"
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#include "../../../extern/Nuked-PSG/ympsg.h"
|
#include "../../../extern/Nuked-PSG/ympsg.h"
|
||||||
|
@ -29,17 +28,11 @@ extern "C" {
|
||||||
#include <queue>
|
#include <queue>
|
||||||
|
|
||||||
class DivPlatformSMS: public DivDispatch {
|
class DivPlatformSMS: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
int actualNote;
|
int actualNote;
|
||||||
bool writeVol;
|
bool writeVol;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(15),
|
||||||
SharedChannelVolume<signed char>(15),
|
|
||||||
actualNote(0),
|
actualNote(0),
|
||||||
writeVol(false) {}
|
writeVol(false) {}
|
||||||
};
|
};
|
||||||
|
|
|
@ -21,28 +21,21 @@
|
||||||
#define _SNES_H
|
#define _SNES_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "../waveSynth.h"
|
#include "../waveSynth.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "sound/snes/SPC_DSP.h"
|
#include "sound/snes/SPC_DSP.h"
|
||||||
|
|
||||||
class DivPlatformSNES: public DivDispatch {
|
class DivPlatformSNES: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<int> {
|
struct Channel: public SharedChannel<int> {
|
||||||
unsigned int audPos;
|
unsigned int audPos;
|
||||||
int sample, wave;
|
int sample, wave;
|
||||||
int panL, panR;
|
int panL, panR;
|
||||||
bool useWave, setPos, noise, echo, pitchMod, invertL, invertR, shallWriteVol, shallWriteEnv;
|
bool useWave, setPos, noise, echo, pitchMod, invertL, invertR, shallWriteVol, shallWriteEnv;
|
||||||
int wtLen;
|
int wtLen;
|
||||||
DivInstrumentSNES state;
|
DivInstrumentSNES state;
|
||||||
DivMacroInt std;
|
|
||||||
DivWaveSynth ws;
|
DivWaveSynth ws;
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<int>(127),
|
||||||
SharedChannelVolume<int>(127),
|
|
||||||
audPos(0),
|
audPos(0),
|
||||||
sample(-1),
|
sample(-1),
|
||||||
wave(-1),
|
wave(-1),
|
||||||
|
|
|
@ -22,11 +22,10 @@
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "sound/su.h"
|
#include "sound/su.h"
|
||||||
|
|
||||||
class DivPlatformSoundUnit: public DivDispatch {
|
class DivPlatformSoundUnit: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
int cutoff, baseCutoff, res, control, hasOffset;
|
int cutoff, baseCutoff, res, control, hasOffset;
|
||||||
signed char pan;
|
signed char pan;
|
||||||
unsigned char duty;
|
unsigned char duty;
|
||||||
|
@ -37,14 +36,8 @@ class DivPlatformSoundUnit: public DivDispatch {
|
||||||
unsigned char freqSweepV, volSweepV, cutSweepV;
|
unsigned char freqSweepV, volSweepV, cutSweepV;
|
||||||
unsigned short syncTimer;
|
unsigned short syncTimer;
|
||||||
signed short wave;
|
signed short wave;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(127),
|
||||||
SharedChannelVolume<signed char>(127),
|
|
||||||
cutoff(16383),
|
cutoff(16383),
|
||||||
baseCutoff(16380),
|
baseCutoff(16380),
|
||||||
res(0),
|
res(0),
|
||||||
|
|
|
@ -21,24 +21,17 @@
|
||||||
#define _SWAN_H
|
#define _SWAN_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "../waveSynth.h"
|
#include "../waveSynth.h"
|
||||||
#include "sound/swan.h"
|
#include "sound/swan.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
|
|
||||||
class DivPlatformSwan: public DivDispatch {
|
class DivPlatformSwan: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<int> {
|
struct Channel: public SharedChannel<int> {
|
||||||
unsigned char pan;
|
unsigned char pan;
|
||||||
int wave;
|
int wave;
|
||||||
DivMacroInt std;
|
|
||||||
DivWaveSynth ws;
|
DivWaveSynth ws;
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<int>(15),
|
||||||
SharedChannelVolume<int>(15),
|
|
||||||
pan(255),
|
pan(255),
|
||||||
wave(-1) {}
|
wave(-1) {}
|
||||||
};
|
};
|
||||||
|
|
|
@ -22,20 +22,13 @@
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "sound/t6w28/T6W28_Apu.h"
|
#include "sound/t6w28/T6W28_Apu.h"
|
||||||
|
|
||||||
class DivPlatformT6W28: public DivDispatch {
|
class DivPlatformT6W28: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
unsigned char panL, panR, duty;
|
unsigned char panL, panR, duty;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(15),
|
||||||
SharedChannelVolume<signed char>(15),
|
|
||||||
panL(15),
|
panL(15),
|
||||||
panR(15),
|
panR(15),
|
||||||
duty(7) {}
|
duty(7) {}
|
||||||
|
|
|
@ -19,23 +19,17 @@
|
||||||
|
|
||||||
#ifndef _TIA_H
|
#ifndef _TIA_H
|
||||||
#define _TIA_H
|
#define _TIA_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "sound/tia/Audio.h"
|
#include "sound/tia/Audio.h"
|
||||||
|
|
||||||
class DivPlatformTIA: public DivDispatch {
|
class DivPlatformTIA: public DivDispatch {
|
||||||
protected:
|
protected:
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<int> {
|
struct Channel: public SharedChannel<int> {
|
||||||
unsigned char shape;
|
unsigned char shape;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<int>(15),
|
||||||
SharedChannelVolume<int>(15),
|
|
||||||
shape(4) {}
|
shape(4) {}
|
||||||
};
|
};
|
||||||
Channel chan[2];
|
Channel chan[2];
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
|
|
||||||
#ifndef _TX81Z_H
|
#ifndef _TX81Z_H
|
||||||
#define _TX81Z_H
|
#define _TX81Z_H
|
||||||
|
|
||||||
#include "fmshared_OPM.h"
|
#include "fmshared_OPM.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "sound/ymfm/ymfm_opz.h"
|
#include "sound/ymfm/ymfm_opz.h"
|
||||||
|
|
|
@ -22,24 +22,17 @@
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "../waveSynth.h"
|
#include "../waveSynth.h"
|
||||||
#include "sound/vsu.h"
|
#include "sound/vsu.h"
|
||||||
|
|
||||||
class DivPlatformVB: public DivDispatch {
|
class DivPlatformVB: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
unsigned char pan, envLow, envHigh;
|
unsigned char pan, envLow, envHigh;
|
||||||
bool noise, deferredWaveUpdate;
|
bool noise, deferredWaveUpdate;
|
||||||
signed short wave;
|
signed short wave;
|
||||||
DivMacroInt std;
|
|
||||||
DivWaveSynth ws;
|
DivWaveSynth ws;
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(15),
|
||||||
SharedChannelVolume<signed char>(15),
|
|
||||||
pan(255),
|
pan(255),
|
||||||
envLow(0),
|
envLow(0),
|
||||||
envHigh(0),
|
envHigh(0),
|
||||||
|
|
|
@ -19,20 +19,19 @@
|
||||||
|
|
||||||
#ifndef _VERA_H
|
#ifndef _VERA_H
|
||||||
#define _VERA_H
|
#define _VERA_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../instrument.h"
|
#include "../instrument.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
|
|
||||||
struct VERA_PSG;
|
struct VERA_PSG;
|
||||||
struct VERA_PCM;
|
struct VERA_PCM;
|
||||||
|
|
||||||
class DivPlatformVERA: public DivDispatch {
|
class DivPlatformVERA: public DivDispatch {
|
||||||
protected:
|
protected:
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<int> {
|
struct Channel: public SharedChannel<int> {
|
||||||
unsigned char pan;
|
unsigned char pan;
|
||||||
unsigned accum;
|
unsigned accum;
|
||||||
int noiseval;
|
int noiseval;
|
||||||
DivMacroInt std;
|
|
||||||
|
|
||||||
struct PCMChannel {
|
struct PCMChannel {
|
||||||
int sample;
|
int sample;
|
||||||
|
@ -42,14 +41,8 @@ class DivPlatformVERA: public DivDispatch {
|
||||||
bool depth16;
|
bool depth16;
|
||||||
PCMChannel(): sample(-1), pos(0), len(0), freq(0), depth16(false) {}
|
PCMChannel(): sample(-1), pos(0), len(0), freq(0), depth16(false) {}
|
||||||
} pcm;
|
} pcm;
|
||||||
// somebody please split this into multiple lines!
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<int>(0),
|
||||||
SharedChannelVolume<int>(0),
|
|
||||||
pan(0),
|
pan(0),
|
||||||
accum(0),
|
accum(0),
|
||||||
noiseval(0),
|
noiseval(0),
|
||||||
|
|
|
@ -21,21 +21,14 @@
|
||||||
#define _VIC20_H
|
#define _VIC20_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "sound/vic20sound.h"
|
#include "sound/vic20sound.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
|
|
||||||
class DivPlatformVIC20: public DivDispatch {
|
class DivPlatformVIC20: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<int> {
|
struct Channel: public SharedChannel<int> {
|
||||||
int wave, waveWriteCycle;
|
int wave, waveWriteCycle;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<int>(15),
|
||||||
SharedChannelVolume<int>(15),
|
|
||||||
wave(0),
|
wave(0),
|
||||||
waveWriteCycle(-1) {}
|
waveWriteCycle(-1) {}
|
||||||
};
|
};
|
||||||
|
|
|
@ -22,25 +22,18 @@
|
||||||
|
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "vgsound_emu/src/vrcvi/vrcvi.hpp"
|
#include "vgsound_emu/src/vrcvi/vrcvi.hpp"
|
||||||
|
|
||||||
|
|
||||||
class DivPlatformVRC6: public DivDispatch, public vrcvi_intf {
|
class DivPlatformVRC6: public DivDispatch, public vrcvi_intf {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
int dacPeriod, dacRate, dacOut;
|
int dacPeriod, dacRate, dacOut;
|
||||||
unsigned int dacPos;
|
unsigned int dacPos;
|
||||||
int dacSample;
|
int dacSample;
|
||||||
unsigned char duty;
|
unsigned char duty;
|
||||||
bool pcm, furnaceDac;
|
bool pcm, furnaceDac;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(15),
|
||||||
SharedChannelVolume<signed char>(15),
|
|
||||||
dacPeriod(0),
|
dacPeriod(0),
|
||||||
dacRate(0),
|
dacRate(0),
|
||||||
dacOut(0),
|
dacOut(0),
|
||||||
|
|
|
@ -22,12 +22,11 @@
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include "../engine.h"
|
#include "../engine.h"
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "../waveSynth.h"
|
#include "../waveSynth.h"
|
||||||
#include "vgsound_emu/src/x1_010/x1_010.hpp"
|
#include "vgsound_emu/src/x1_010/x1_010.hpp"
|
||||||
|
|
||||||
class DivPlatformX1_010: public DivDispatch, public vgsound_emu_mem_intf {
|
class DivPlatformX1_010: public DivDispatch, public vgsound_emu_mem_intf {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<int> {
|
struct Channel: public SharedChannel<int> {
|
||||||
struct Envelope {
|
struct Envelope {
|
||||||
struct EnvFlag {
|
struct EnvFlag {
|
||||||
unsigned char envEnable : 1;
|
unsigned char envEnable : 1;
|
||||||
|
@ -77,7 +76,6 @@ class DivPlatformX1_010: public DivDispatch, public vgsound_emu_mem_intf {
|
||||||
unsigned char waveBank;
|
unsigned char waveBank;
|
||||||
unsigned int bankSlot;
|
unsigned int bankSlot;
|
||||||
Envelope env;
|
Envelope env;
|
||||||
DivMacroInt std;
|
|
||||||
DivWaveSynth ws;
|
DivWaveSynth ws;
|
||||||
void reset() {
|
void reset() {
|
||||||
freq=baseFreq=pitch=pitch2=note=0;
|
freq=baseFreq=pitch=pitch2=note=0;
|
||||||
|
@ -90,13 +88,8 @@ class DivPlatformX1_010: public DivDispatch, public vgsound_emu_mem_intf {
|
||||||
vol=outVol=lvol=rvol=15;
|
vol=outVol=lvol=rvol=15;
|
||||||
waveBank=0;
|
waveBank=0;
|
||||||
}
|
}
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<int>(15),
|
||||||
SharedChannelVolume<int>(15),
|
|
||||||
fixedFreq(0),
|
fixedFreq(0),
|
||||||
wave(-1),
|
wave(-1),
|
||||||
sample(-1),
|
sample(-1),
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
|
|
||||||
#ifndef _YM2203_H
|
#ifndef _YM2203_H
|
||||||
#define _YM2203_H
|
#define _YM2203_H
|
||||||
|
|
||||||
#include "fmshared_OPN.h"
|
#include "fmshared_OPN.h"
|
||||||
#include "sound/ymfm/ymfm_opn.h"
|
#include "sound/ymfm/ymfm_opn.h"
|
||||||
|
|
||||||
|
|
|
@ -17,6 +17,9 @@
|
||||||
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifndef _YM2203EXT_H
|
||||||
|
#define _YM2203EXT_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
|
|
||||||
#include "ym2203.h"
|
#include "ym2203.h"
|
||||||
|
@ -40,3 +43,5 @@ class DivPlatformYM2203Ext: public DivPlatformYM2203 {
|
||||||
void quit();
|
void quit();
|
||||||
~DivPlatformYM2203Ext();
|
~DivPlatformYM2203Ext();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#endif
|
|
@ -19,6 +19,7 @@
|
||||||
|
|
||||||
#ifndef _YM2608_H
|
#ifndef _YM2608_H
|
||||||
#define _YM2608_H
|
#define _YM2608_H
|
||||||
|
|
||||||
#include "fmshared_OPN.h"
|
#include "fmshared_OPN.h"
|
||||||
#include "sound/ymfm/ymfm_opn.h"
|
#include "sound/ymfm/ymfm_opn.h"
|
||||||
|
|
||||||
|
|
|
@ -17,6 +17,9 @@
|
||||||
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifndef _YM2608EXT_H
|
||||||
|
#define _YM2608EXT_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
|
|
||||||
#include "ym2608.h"
|
#include "ym2608.h"
|
||||||
|
@ -40,3 +43,5 @@ class DivPlatformYM2608Ext: public DivPlatformYM2608 {
|
||||||
void quit();
|
void quit();
|
||||||
~DivPlatformYM2608Ext();
|
~DivPlatformYM2608Ext();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#endif
|
|
@ -19,6 +19,7 @@
|
||||||
|
|
||||||
#ifndef _YM2610_H
|
#ifndef _YM2610_H
|
||||||
#define _YM2610_H
|
#define _YM2610_H
|
||||||
|
|
||||||
#include "ym2610shared.h"
|
#include "ym2610shared.h"
|
||||||
|
|
||||||
class DivPlatformYM2610: public DivPlatformYM2610Base<14> {
|
class DivPlatformYM2610: public DivPlatformYM2610Base<14> {
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
|
|
||||||
#ifndef _YM2610B_H
|
#ifndef _YM2610B_H
|
||||||
#define _YM2610B_H
|
#define _YM2610B_H
|
||||||
|
|
||||||
#include "ym2610shared.h"
|
#include "ym2610shared.h"
|
||||||
|
|
||||||
class DivPlatformYM2610B: public DivPlatformYM2610Base<16> {
|
class DivPlatformYM2610B: public DivPlatformYM2610Base<16> {
|
||||||
|
|
|
@ -17,6 +17,9 @@
|
||||||
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifndef _YM2610BEXT_H
|
||||||
|
#define _YM2610BEXT_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
|
|
||||||
#include "ym2610b.h"
|
#include "ym2610b.h"
|
||||||
|
@ -40,3 +43,5 @@ class DivPlatformYM2610BExt: public DivPlatformYM2610B {
|
||||||
void quit();
|
void quit();
|
||||||
~DivPlatformYM2610BExt();
|
~DivPlatformYM2610BExt();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#endif
|
|
@ -17,6 +17,9 @@
|
||||||
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifndef _YM2610EXT_H
|
||||||
|
#define _YM2610EXT_H
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
|
|
||||||
#include "ym2610.h"
|
#include "ym2610.h"
|
||||||
|
@ -40,3 +43,5 @@ class DivPlatformYM2610Ext: public DivPlatformYM2610 {
|
||||||
void quit();
|
void quit();
|
||||||
~DivPlatformYM2610Ext();
|
~DivPlatformYM2610Ext();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#endif
|
|
@ -19,6 +19,7 @@
|
||||||
|
|
||||||
#ifndef _YM2610SHARED_H
|
#ifndef _YM2610SHARED_H
|
||||||
#define _YM2610SHARED_H
|
#define _YM2610SHARED_H
|
||||||
|
|
||||||
#include "fmshared_OPN.h"
|
#include "fmshared_OPN.h"
|
||||||
#include "../engine.h"
|
#include "../engine.h"
|
||||||
#include "../../ta-log.h"
|
#include "../../ta-log.h"
|
||||||
|
|
|
@ -22,24 +22,17 @@
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "../macroInt.h"
|
|
||||||
#include "sound/ymz280b.h"
|
#include "sound/ymz280b.h"
|
||||||
|
|
||||||
class DivPlatformYMZ280B: public DivDispatch {
|
class DivPlatformYMZ280B: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<int> {
|
struct Channel: public SharedChannel<int> {
|
||||||
unsigned int audPos;
|
unsigned int audPos;
|
||||||
int sample, wave;
|
int sample, wave;
|
||||||
int panning;
|
int panning;
|
||||||
bool setPos, isNewYMZ;
|
bool setPos, isNewYMZ;
|
||||||
int macroVolMul;
|
int macroVolMul;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<int>(255),
|
||||||
SharedChannelVolume<int>(255),
|
|
||||||
audPos(0),
|
audPos(0),
|
||||||
sample(-1),
|
sample(-1),
|
||||||
panning(8),
|
panning(8),
|
||||||
|
|
|
@ -22,20 +22,13 @@
|
||||||
|
|
||||||
#include "../dispatch.h"
|
#include "../dispatch.h"
|
||||||
#include <queue>
|
#include <queue>
|
||||||
#include "../macroInt.h"
|
|
||||||
|
|
||||||
class DivPlatformZXBeeper: public DivDispatch {
|
class DivPlatformZXBeeper: public DivDispatch {
|
||||||
struct Channel: public SharedChannelFreq, public SharedChannelVolume<signed char> {
|
struct Channel: public SharedChannel<signed char> {
|
||||||
unsigned short sPosition;
|
unsigned short sPosition;
|
||||||
unsigned char duty;
|
unsigned char duty;
|
||||||
DivMacroInt std;
|
|
||||||
void macroInit(DivInstrument* which) {
|
|
||||||
std.init(which);
|
|
||||||
pitch2=0;
|
|
||||||
}
|
|
||||||
Channel():
|
Channel():
|
||||||
SharedChannelFreq(),
|
SharedChannel<signed char>(1),
|
||||||
SharedChannelVolume<signed char>(1),
|
|
||||||
sPosition(0),
|
sPosition(0),
|
||||||
duty(64) {}
|
duty(64) {}
|
||||||
};
|
};
|
||||||
|
|
|
@ -123,14 +123,30 @@
|
||||||
ImGui::TextColored(sms->nuked?colorOn:colorOff,">> Nuked");
|
ImGui::TextColored(sms->nuked?colorOn:colorOff,">> Nuked");
|
||||||
|
|
||||||
|
|
||||||
#define GENESIS_CHAN_DEBUG \
|
#define COMMON_CHAN_DEBUG \
|
||||||
DivPlatformGenesis::Channel* ch=(DivPlatformGenesis::Channel*)data; \
|
|
||||||
ImGui::Text("> YM2612"); \
|
|
||||||
ImGui::Text("- freqHL: %.2x%.2x",ch->freqH,ch->freqL); \
|
|
||||||
ImGui::Text("* freq: %d",ch->freq); \
|
ImGui::Text("* freq: %d",ch->freq); \
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq); \
|
ImGui::Text(" - base: %d",ch->baseFreq); \
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch); \
|
ImGui::Text(" - pitch: %d",ch->pitch); \
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2); \
|
ImGui::Text(" - pitch2: %d",ch->pitch2); \
|
||||||
|
ImGui::Text("- note: %d",ch->note); \
|
||||||
|
ImGui::Text("- ins: %d",ch->ins); \
|
||||||
|
ImGui::Text("- vol: %.2x",ch->vol); \
|
||||||
|
ImGui::Text("- outVol: %.2x",ch->outVol);
|
||||||
|
|
||||||
|
#define COMMON_CHAN_DEBUG_BOOL \
|
||||||
|
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active"); \
|
||||||
|
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged"); \
|
||||||
|
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged"); \
|
||||||
|
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn"); \
|
||||||
|
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff"); \
|
||||||
|
ImGui::TextColored(ch->portaPause?colorOn:colorOff,">> PortaPause"); \
|
||||||
|
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta");
|
||||||
|
|
||||||
|
#define GENESIS_CHAN_DEBUG \
|
||||||
|
DivPlatformGenesis::Channel* ch=(DivPlatformGenesis::Channel*)data; \
|
||||||
|
ImGui::Text("> YM2612"); \
|
||||||
|
ImGui::Text("- freqHL: %.2x%.2x",ch->freqH,ch->freqL); \
|
||||||
|
COMMON_CHAN_DEBUG; \
|
||||||
ImGui::Text("- portaPauseFreq: %d",ch->portaPauseFreq); \
|
ImGui::Text("- portaPauseFreq: %d",ch->portaPauseFreq); \
|
||||||
ImGui::Text("* DAC:"); \
|
ImGui::Text("* DAC:"); \
|
||||||
ImGui::Text(" - period: %d",ch->dacPeriod); \
|
ImGui::Text(" - period: %d",ch->dacPeriod); \
|
||||||
|
@ -139,21 +155,11 @@
|
||||||
ImGui::Text(" - sample: %d",ch->dacSample); \
|
ImGui::Text(" - sample: %d",ch->dacSample); \
|
||||||
ImGui::Text(" - delay: %d",ch->dacDelay); \
|
ImGui::Text(" - delay: %d",ch->dacDelay); \
|
||||||
ImGui::Text(" - output: %d",ch->dacOutput); \
|
ImGui::Text(" - output: %d",ch->dacOutput); \
|
||||||
ImGui::Text("- note: %d",ch->note); \
|
|
||||||
ImGui::Text("- ins: %d",ch->ins); \
|
|
||||||
ImGui::Text("- vol: %.2x",ch->vol); \
|
|
||||||
ImGui::Text("- outVol: %.2x",ch->outVol); \
|
|
||||||
ImGui::Text("- pan: %x",ch->pan); \
|
ImGui::Text("- pan: %x",ch->pan); \
|
||||||
ImGui::Text("- opMask: %x",ch->opMask); \
|
ImGui::Text("- opMask: %x",ch->opMask); \
|
||||||
ImGui::Text("- sampleBank: %d",ch->sampleBank); \
|
ImGui::Text("- sampleBank: %d",ch->sampleBank); \
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active"); \
|
COMMON_CHAN_DEBUG_BOOL; \
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged"); \
|
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged"); \
|
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn"); \
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff"); \
|
|
||||||
ImGui::TextColored(ch->portaPause?colorOn:colorOff,">> PortaPause"); \
|
|
||||||
ImGui::TextColored(ch->furnaceDac?colorOn:colorOff,">> FurnaceDAC"); \
|
ImGui::TextColored(ch->furnaceDac?colorOn:colorOff,">> FurnaceDAC"); \
|
||||||
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta"); \
|
|
||||||
ImGui::TextColored(ch->hardReset?colorOn:colorOff,">> hardReset"); \
|
ImGui::TextColored(ch->hardReset?colorOn:colorOff,">> hardReset"); \
|
||||||
ImGui::TextColored(ch->opMaskChanged?colorOn:colorOff,">> opMaskChanged"); \
|
ImGui::TextColored(ch->opMaskChanged?colorOn:colorOff,">> opMaskChanged"); \
|
||||||
ImGui::TextColored(ch->dacMode?colorOn:colorOff,">> DACMode"); \
|
ImGui::TextColored(ch->dacMode?colorOn:colorOff,">> DACMode"); \
|
||||||
|
@ -164,67 +170,31 @@
|
||||||
DivPlatformOPN::OPNOpChannelStereo* ch=(DivPlatformOPN::OPNOpChannelStereo*)data; \
|
DivPlatformOPN::OPNOpChannelStereo* ch=(DivPlatformOPN::OPNOpChannelStereo*)data; \
|
||||||
ImGui::Text("> YM2612 (per operator)"); \
|
ImGui::Text("> YM2612 (per operator)"); \
|
||||||
ImGui::Text("- freqHL: %.2x%.2x",ch->freqH,ch->freqL); \
|
ImGui::Text("- freqHL: %.2x%.2x",ch->freqH,ch->freqL); \
|
||||||
ImGui::Text("* freq: %d",ch->freq); \
|
COMMON_CHAN_DEBUG; \
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq); \
|
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch); \
|
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2); \
|
|
||||||
ImGui::Text("- portaPauseFreq: %d",ch->portaPauseFreq); \
|
ImGui::Text("- portaPauseFreq: %d",ch->portaPauseFreq); \
|
||||||
ImGui::Text("- ins: %d",ch->ins); \
|
|
||||||
ImGui::Text("- vol: %.2x",ch->vol); \
|
|
||||||
ImGui::Text("- outVol: %.2x",ch->outVol); \
|
|
||||||
ImGui::Text("- pan: %x",ch->pan); \
|
ImGui::Text("- pan: %x",ch->pan); \
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active"); \
|
COMMON_CHAN_DEBUG_BOOL; \
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged"); \
|
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged"); \
|
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn"); \
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff"); \
|
|
||||||
ImGui::TextColored(ch->portaPause?colorOn:colorOff,">> PortaPause"); \
|
|
||||||
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta"); \
|
|
||||||
ImGui::TextColored(ch->mask?colorOn:colorOff,">> Mask");
|
ImGui::TextColored(ch->mask?colorOn:colorOff,">> Mask");
|
||||||
|
|
||||||
#define SMS_CHAN_DEBUG \
|
#define SMS_CHAN_DEBUG \
|
||||||
DivPlatformSMS::Channel* ch=(DivPlatformSMS::Channel*)data; \
|
DivPlatformSMS::Channel* ch=(DivPlatformSMS::Channel*)data; \
|
||||||
ImGui::Text("> SMS"); \
|
ImGui::Text("> SMS"); \
|
||||||
ImGui::Text("* freq: %d",ch->freq); \
|
COMMON_CHAN_DEBUG; \
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq); \
|
COMMON_CHAN_DEBUG_BOOL;
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch); \
|
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2); \
|
|
||||||
ImGui::Text("- note: %d",ch->note); \
|
|
||||||
ImGui::Text("- ins: %d",ch->ins); \
|
|
||||||
ImGui::Text("- vol: %.2x",ch->vol); \
|
|
||||||
ImGui::Text("- outVol: %.2x",ch->outVol); \
|
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active"); \
|
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged"); \
|
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged"); \
|
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn"); \
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff");
|
|
||||||
|
|
||||||
#define OPN_CHAN_DEBUG \
|
#define OPN_CHAN_DEBUG \
|
||||||
DivPlatformOPN::OPNChannel* ch=(DivPlatformOPN::OPNChannel*)data; \
|
DivPlatformOPN::OPNChannel* ch=(DivPlatformOPN::OPNChannel*)data; \
|
||||||
ImGui::Text("> YM2203"); \
|
ImGui::Text("> YM2203"); \
|
||||||
ImGui::Text("- freqHL: %.2x%.2x",ch->freqH,ch->freqL); \
|
ImGui::Text("- freqHL: %.2x%.2x",ch->freqH,ch->freqL); \
|
||||||
ImGui::Text("* freq: %d",ch->freq); \
|
COMMON_CHAN_DEBUG; \
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq); \
|
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch); \
|
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2); \
|
|
||||||
ImGui::Text("- portaPauseFreq: %d",ch->portaPauseFreq); \
|
ImGui::Text("- portaPauseFreq: %d",ch->portaPauseFreq); \
|
||||||
ImGui::Text("* PSG:"); \
|
ImGui::Text("* PSG:"); \
|
||||||
ImGui::Text(" - psgMode: %d",ch->psgMode); \
|
ImGui::Text(" - psgMode: %d",ch->psgMode); \
|
||||||
ImGui::Text(" - autoEnvNum: %d",ch->autoEnvNum); \
|
ImGui::Text(" - autoEnvNum: %d",ch->autoEnvNum); \
|
||||||
ImGui::Text(" - autoEnvDen: %d",ch->autoEnvDen); \
|
ImGui::Text(" - autoEnvDen: %d",ch->autoEnvDen); \
|
||||||
ImGui::Text("- sample: %d",ch->sample); \
|
ImGui::Text("- sample: %d",ch->sample); \
|
||||||
ImGui::Text("- note: %d",ch->note); \
|
|
||||||
ImGui::Text("- ins: %d",ch->ins); \
|
|
||||||
ImGui::Text("- vol: %.2x",ch->vol); \
|
|
||||||
ImGui::Text("- outVol: %.2x",ch->outVol); \
|
|
||||||
ImGui::Text("- opMask: %x",ch->opMask); \
|
ImGui::Text("- opMask: %x",ch->opMask); \
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active"); \
|
COMMON_CHAN_DEBUG_BOOL; \
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged"); \
|
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged"); \
|
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn"); \
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff"); \
|
|
||||||
ImGui::TextColored(ch->portaPause?colorOn:colorOff,">> PortaPause"); \
|
|
||||||
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta"); \
|
|
||||||
ImGui::TextColored(ch->hardReset?colorOn:colorOff,">> hardReset"); \
|
ImGui::TextColored(ch->hardReset?colorOn:colorOff,">> hardReset"); \
|
||||||
ImGui::TextColored(ch->opMaskChanged?colorOn:colorOff,">> opMaskChanged"); \
|
ImGui::TextColored(ch->opMaskChanged?colorOn:colorOff,">> opMaskChanged"); \
|
||||||
ImGui::TextColored(ch->furnacePCM?colorOn:colorOff,">> FurnacePCM");
|
ImGui::TextColored(ch->furnacePCM?colorOn:colorOff,">> FurnacePCM");
|
||||||
|
@ -233,71 +203,34 @@
|
||||||
DivPlatformOPN::OPNOpChannel* ch=(DivPlatformOPN::OPNOpChannel*)data; \
|
DivPlatformOPN::OPNOpChannel* ch=(DivPlatformOPN::OPNOpChannel*)data; \
|
||||||
ImGui::Text("> YM2203 (per operator)"); \
|
ImGui::Text("> YM2203 (per operator)"); \
|
||||||
ImGui::Text("- freqHL: %.2x%.2x",ch->freqH,ch->freqL); \
|
ImGui::Text("- freqHL: %.2x%.2x",ch->freqH,ch->freqL); \
|
||||||
ImGui::Text("* freq: %d",ch->freq); \
|
COMMON_CHAN_DEBUG; \
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq); \
|
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch); \
|
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2); \
|
|
||||||
ImGui::Text("- portaPauseFreq: %d",ch->portaPauseFreq); \
|
ImGui::Text("- portaPauseFreq: %d",ch->portaPauseFreq); \
|
||||||
ImGui::Text("- ins: %d",ch->ins); \
|
COMMON_CHAN_DEBUG_BOOL; \
|
||||||
ImGui::Text("- vol: %.2x",ch->vol); \
|
|
||||||
ImGui::Text("- outVol: %.2x",ch->outVol); \
|
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active"); \
|
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged"); \
|
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged"); \
|
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn"); \
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff"); \
|
|
||||||
ImGui::TextColored(ch->portaPause?colorOn:colorOff,">> PortaPause"); \
|
|
||||||
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta"); \
|
|
||||||
ImGui::TextColored(ch->mask?colorOn:colorOff,">> Mask");
|
ImGui::TextColored(ch->mask?colorOn:colorOff,">> Mask");
|
||||||
|
|
||||||
#define OPNB_CHAN_DEBUG \
|
#define OPNB_CHAN_DEBUG \
|
||||||
ImGui::Text("- freqHL: %.2x%.2x",ch->freqH,ch->freqL); \
|
ImGui::Text("- freqHL: %.2x%.2x",ch->freqH,ch->freqL); \
|
||||||
ImGui::Text("* freq: %d",ch->freq); \
|
COMMON_CHAN_DEBUG; \
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq); \
|
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch); \
|
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2); \
|
|
||||||
ImGui::Text("- portaPauseFreq: %d",ch->portaPauseFreq); \
|
ImGui::Text("- portaPauseFreq: %d",ch->portaPauseFreq); \
|
||||||
ImGui::Text("* PSG:"); \
|
ImGui::Text("* PSG:"); \
|
||||||
ImGui::Text(" - psgMode: %d",ch->psgMode); \
|
ImGui::Text(" - psgMode: %d",ch->psgMode); \
|
||||||
ImGui::Text(" - autoEnvNum: %d",ch->autoEnvNum); \
|
ImGui::Text(" - autoEnvNum: %d",ch->autoEnvNum); \
|
||||||
ImGui::Text(" - autoEnvDen: %d",ch->autoEnvDen); \
|
ImGui::Text(" - autoEnvDen: %d",ch->autoEnvDen); \
|
||||||
ImGui::Text("- sample: %d",ch->sample); \
|
ImGui::Text("- sample: %d",ch->sample); \
|
||||||
ImGui::Text("- note: %d",ch->note); \
|
|
||||||
ImGui::Text("- ins: %d",ch->ins); \
|
|
||||||
ImGui::Text("- vol: %.2x",ch->vol); \
|
|
||||||
ImGui::Text("- outVol: %.2x",ch->outVol); \
|
|
||||||
ImGui::Text("- pan: %x",ch->pan); \
|
ImGui::Text("- pan: %x",ch->pan); \
|
||||||
ImGui::Text("- opMask: %x",ch->opMask); \
|
ImGui::Text("- opMask: %x",ch->opMask); \
|
||||||
ImGui::Text("- macroVolMul: %x",ch->macroVolMul); \
|
ImGui::Text("- macroVolMul: %x",ch->macroVolMul); \
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active"); \
|
COMMON_CHAN_DEBUG_BOOL; \
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged"); \
|
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged"); \
|
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn"); \
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff"); \
|
|
||||||
ImGui::TextColored(ch->portaPause?colorOn:colorOff,">> PortaPause"); \
|
|
||||||
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta"); \
|
|
||||||
ImGui::TextColored(ch->hardReset?colorOn:colorOff,">> hardReset"); \
|
ImGui::TextColored(ch->hardReset?colorOn:colorOff,">> hardReset"); \
|
||||||
ImGui::TextColored(ch->opMaskChanged?colorOn:colorOff,">> opMaskChanged"); \
|
ImGui::TextColored(ch->opMaskChanged?colorOn:colorOff,">> opMaskChanged"); \
|
||||||
ImGui::TextColored(ch->furnacePCM?colorOn:colorOff,">> FurnacePCM");
|
ImGui::TextColored(ch->furnacePCM?colorOn:colorOff,">> FurnacePCM");
|
||||||
|
|
||||||
#define OPNB_OPCHAN_DEBUG \
|
#define OPNB_OPCHAN_DEBUG \
|
||||||
ImGui::Text("- freqHL: %.2x%.2x",ch->freqH,ch->freqL); \
|
ImGui::Text("- freqHL: %.2x%.2x",ch->freqH,ch->freqL); \
|
||||||
ImGui::Text("* freq: %d",ch->freq); \
|
COMMON_CHAN_DEBUG; \
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq); \
|
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch); \
|
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2); \
|
|
||||||
ImGui::Text("- portaPauseFreq: %d",ch->portaPauseFreq); \
|
ImGui::Text("- portaPauseFreq: %d",ch->portaPauseFreq); \
|
||||||
ImGui::Text("- ins: %d",ch->ins); \
|
|
||||||
ImGui::Text("- vol: %.2x",ch->vol); \
|
|
||||||
ImGui::Text("- outVol: %.2x",ch->outVol); \
|
|
||||||
ImGui::Text("- pan: %x",ch->pan); \
|
ImGui::Text("- pan: %x",ch->pan); \
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active"); \
|
COMMON_CHAN_DEBUG_BOOL; \
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged"); \
|
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged"); \
|
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn"); \
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff"); \
|
|
||||||
ImGui::TextColored(ch->portaPause?colorOn:colorOff,">> PortaPause"); \
|
|
||||||
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta"); \
|
|
||||||
ImGui::TextColored(ch->mask?colorOn:colorOff,">> Mask");
|
ImGui::TextColored(ch->mask?colorOn:colorOff,">> Mask");
|
||||||
|
|
||||||
void putDispatchChip(void* data, int type) {
|
void putDispatchChip(void* data, int type) {
|
||||||
|
@ -677,52 +610,28 @@ void putDispatchChan(void* data, int chanNum, int type) {
|
||||||
case DIV_SYSTEM_GB: {
|
case DIV_SYSTEM_GB: {
|
||||||
DivPlatformGB::Channel* ch=(DivPlatformGB::Channel*)data;
|
DivPlatformGB::Channel* ch=(DivPlatformGB::Channel*)data;
|
||||||
ImGui::Text("> GameBoy");
|
ImGui::Text("> GameBoy");
|
||||||
ImGui::Text("* freq: %d",ch->freq);
|
COMMON_CHAN_DEBUG;
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq);
|
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch);
|
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2);
|
|
||||||
ImGui::Text("- note: %d",ch->note);
|
|
||||||
ImGui::Text("- ins: %d",ch->ins);
|
|
||||||
ImGui::Text("- duty: %d",ch->duty);
|
ImGui::Text("- duty: %d",ch->duty);
|
||||||
ImGui::Text("- sweep: %.2x",ch->sweep);
|
ImGui::Text("- sweep: %.2x",ch->sweep);
|
||||||
ImGui::Text("- vol: %.2x",ch->vol);
|
|
||||||
ImGui::Text("- outVol: %.2x",ch->outVol);
|
|
||||||
ImGui::Text("- wave: %d",ch->wave);
|
ImGui::Text("- wave: %d",ch->wave);
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active");
|
COMMON_CHAN_DEBUG_BOOL;
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged");
|
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged");
|
|
||||||
ImGui::TextColored(ch->sweepChanged?colorOn:colorOff,">> SweepChanged");
|
ImGui::TextColored(ch->sweepChanged?colorOn:colorOff,">> SweepChanged");
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn");
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff");
|
|
||||||
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta");
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case DIV_SYSTEM_PCE: {
|
case DIV_SYSTEM_PCE: {
|
||||||
DivPlatformPCE::Channel* ch=(DivPlatformPCE::Channel*)data;
|
DivPlatformPCE::Channel* ch=(DivPlatformPCE::Channel*)data;
|
||||||
ImGui::Text("> PCEngine");
|
ImGui::Text("> PCEngine");
|
||||||
ImGui::Text("* freq: %d",ch->freq);
|
COMMON_CHAN_DEBUG;
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq);
|
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch);
|
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2);
|
|
||||||
ImGui::Text("- note: %d",ch->note);
|
|
||||||
ImGui::Text("* DAC:");
|
ImGui::Text("* DAC:");
|
||||||
ImGui::Text(" - period: %d",ch->dacPeriod);
|
ImGui::Text(" - period: %d",ch->dacPeriod);
|
||||||
ImGui::Text(" - rate: %d",ch->dacRate);
|
ImGui::Text(" - rate: %d",ch->dacRate);
|
||||||
ImGui::Text(" - pos: %d",ch->dacPos);
|
ImGui::Text(" - pos: %d",ch->dacPos);
|
||||||
ImGui::Text(" - out: %d",ch->dacOut);
|
ImGui::Text(" - out: %d",ch->dacOut);
|
||||||
ImGui::Text(" - sample: %d",ch->dacSample);
|
ImGui::Text(" - sample: %d",ch->dacSample);
|
||||||
ImGui::Text("- ins: %d",ch->ins);
|
|
||||||
ImGui::Text("- pan: %.2x",ch->pan);
|
ImGui::Text("- pan: %.2x",ch->pan);
|
||||||
ImGui::Text("- vol: %.2x",ch->vol);
|
|
||||||
ImGui::Text("- outVol: %.2x",ch->outVol);
|
|
||||||
ImGui::Text("- wave: %d",ch->wave);
|
ImGui::Text("- wave: %d",ch->wave);
|
||||||
ImGui::Text("- macroVolMul: %d",ch->macroVolMul);
|
ImGui::Text("- macroVolMul: %d",ch->macroVolMul);
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active");
|
COMMON_CHAN_DEBUG_BOOL;
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged");
|
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged");
|
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn");
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff");
|
|
||||||
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta");
|
|
||||||
ImGui::TextColored(ch->noise?colorOn:colorOff,">> Noise");
|
ImGui::TextColored(ch->noise?colorOn:colorOff,">> Noise");
|
||||||
ImGui::TextColored(ch->pcm?colorOn:colorOff,">> DAC");
|
ImGui::TextColored(ch->pcm?colorOn:colorOff,">> DAC");
|
||||||
ImGui::TextColored(ch->furnaceDac?colorOn:colorOff,">> FurnaceDAC");
|
ImGui::TextColored(ch->furnaceDac?colorOn:colorOff,">> FurnaceDAC");
|
||||||
|
@ -731,52 +640,28 @@ void putDispatchChan(void* data, int chanNum, int type) {
|
||||||
case DIV_SYSTEM_NES: {
|
case DIV_SYSTEM_NES: {
|
||||||
DivPlatformNES::Channel* ch=(DivPlatformNES::Channel*)data;
|
DivPlatformNES::Channel* ch=(DivPlatformNES::Channel*)data;
|
||||||
ImGui::Text("> NES");
|
ImGui::Text("> NES");
|
||||||
ImGui::Text("* freq: %d",ch->freq);
|
COMMON_CHAN_DEBUG;
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq);
|
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch);
|
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2);
|
|
||||||
ImGui::Text(" - prev: %d",ch->prevFreq);
|
ImGui::Text(" - prev: %d",ch->prevFreq);
|
||||||
ImGui::Text("- note: %d",ch->note);
|
|
||||||
ImGui::Text("- ins: %d",ch->ins);
|
|
||||||
ImGui::Text("- duty: %d",ch->duty);
|
ImGui::Text("- duty: %d",ch->duty);
|
||||||
ImGui::Text("- sweep: %.2x",ch->sweep);
|
ImGui::Text("- sweep: %.2x",ch->sweep);
|
||||||
ImGui::Text("- vol: %.2x",ch->vol);
|
|
||||||
ImGui::Text("- outVol: %.2x",ch->outVol);
|
|
||||||
ImGui::Text("- wave: %d",ch->wave);
|
ImGui::Text("- wave: %d",ch->wave);
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active");
|
COMMON_CHAN_DEBUG_BOOL;
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged");
|
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged");
|
|
||||||
ImGui::TextColored(ch->sweepChanged?colorOn:colorOff,">> SweepChanged");
|
ImGui::TextColored(ch->sweepChanged?colorOn:colorOff,">> SweepChanged");
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn");
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff");
|
|
||||||
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta");
|
|
||||||
ImGui::TextColored(ch->furnaceDac?colorOn:colorOff,">> FurnaceDAC");
|
ImGui::TextColored(ch->furnaceDac?colorOn:colorOff,">> FurnaceDAC");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case DIV_SYSTEM_C64_6581: case DIV_SYSTEM_C64_8580: {
|
case DIV_SYSTEM_C64_6581: case DIV_SYSTEM_C64_8580: {
|
||||||
DivPlatformC64::Channel* ch=(DivPlatformC64::Channel*)data;
|
DivPlatformC64::Channel* ch=(DivPlatformC64::Channel*)data;
|
||||||
ImGui::Text("> C64");
|
ImGui::Text("> C64");
|
||||||
ImGui::Text("* freq: %d",ch->freq);
|
COMMON_CHAN_DEBUG;
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq);
|
ImGui::Text("- prevFreq: %d",ch->prevFreq);
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch);
|
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2);
|
|
||||||
ImGui::Text(" - prev: %d",ch->prevFreq);
|
|
||||||
ImGui::Text("- testWhen: %d",ch->testWhen);
|
ImGui::Text("- testWhen: %d",ch->testWhen);
|
||||||
ImGui::Text("- note: %d",ch->note);
|
|
||||||
ImGui::Text("- ins: %d",ch->ins);
|
|
||||||
ImGui::Text("- duty: %d",ch->duty);
|
ImGui::Text("- duty: %d",ch->duty);
|
||||||
ImGui::Text("- sweep: %.2x",ch->sweep);
|
ImGui::Text("- sweep: %.2x",ch->sweep);
|
||||||
ImGui::Text("- wave: %.1x",ch->wave);
|
ImGui::Text("- wave: %.1x",ch->wave);
|
||||||
ImGui::Text("- ADSR: %.1x %.1x %.1x %.1x",ch->attack,ch->decay,ch->sustain,ch->release);
|
ImGui::Text("- ADSR: %.1x %.1x %.1x %.1x",ch->attack,ch->decay,ch->sustain,ch->release);
|
||||||
ImGui::Text("- vol: %.2x",ch->vol);
|
COMMON_CHAN_DEBUG_BOOL;
|
||||||
ImGui::Text("- outVol: %.2x",ch->outVol);
|
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active");
|
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged");
|
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged");
|
|
||||||
ImGui::TextColored(ch->sweepChanged?colorOn:colorOff,">> SweepChanged");
|
ImGui::TextColored(ch->sweepChanged?colorOn:colorOff,">> SweepChanged");
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn");
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff");
|
|
||||||
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta");
|
|
||||||
ImGui::TextColored(ch->filter?colorOn:colorOff,">> Filter");
|
ImGui::TextColored(ch->filter?colorOn:colorOff,">> Filter");
|
||||||
ImGui::TextColored(ch->resetMask?colorOn:colorOff,">> ResetMask");
|
ImGui::TextColored(ch->resetMask?colorOn:colorOff,">> ResetMask");
|
||||||
ImGui::TextColored(ch->resetFilter?colorOn:colorOff,">> ResetFilter");
|
ImGui::TextColored(ch->resetFilter?colorOn:colorOff,">> ResetFilter");
|
||||||
|
@ -790,68 +675,37 @@ void putDispatchChan(void* data, int chanNum, int type) {
|
||||||
DivPlatformArcade::Channel* ch=(DivPlatformArcade::Channel*)data;
|
DivPlatformArcade::Channel* ch=(DivPlatformArcade::Channel*)data;
|
||||||
ImGui::Text("> YM2151");
|
ImGui::Text("> YM2151");
|
||||||
ImGui::Text("- freqHL: %.2x%.2x",ch->freqH,ch->freqL);
|
ImGui::Text("- freqHL: %.2x%.2x",ch->freqH,ch->freqL);
|
||||||
ImGui::Text("* freq: %d",ch->freq);
|
COMMON_CHAN_DEBUG;
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq);
|
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch);
|
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2);
|
|
||||||
ImGui::Text("- note: %d",ch->note);
|
|
||||||
ImGui::Text("- ins: %d",ch->ins);
|
|
||||||
ImGui::Text("- KOnCycles: %d",ch->konCycles);
|
ImGui::Text("- KOnCycles: %d",ch->konCycles);
|
||||||
ImGui::Text("- vol: %.2x",ch->vol);
|
|
||||||
ImGui::Text("- outVol: %.2x",ch->outVol);
|
|
||||||
ImGui::Text("- chVolL: %.2x",ch->chVolL);
|
ImGui::Text("- chVolL: %.2x",ch->chVolL);
|
||||||
ImGui::Text("- chVolR: %.2x",ch->chVolR);
|
ImGui::Text("- chVolR: %.2x",ch->chVolR);
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active");
|
COMMON_CHAN_DEBUG_BOOL;
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged");
|
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged");
|
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn");
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff");
|
|
||||||
ImGui::TextColored(ch->portaPause?colorOn:colorOff,">> PortaPause");
|
|
||||||
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta");
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case DIV_SYSTEM_SEGAPCM:
|
case DIV_SYSTEM_SEGAPCM:
|
||||||
case DIV_SYSTEM_SEGAPCM_COMPAT: {
|
case DIV_SYSTEM_SEGAPCM_COMPAT: {
|
||||||
DivPlatformSegaPCM::Channel* ch=(DivPlatformSegaPCM::Channel*)data;
|
DivPlatformSegaPCM::Channel* ch=(DivPlatformSegaPCM::Channel*)data;
|
||||||
ImGui::Text("> SegaPCM");
|
ImGui::Text("> SegaPCM");
|
||||||
ImGui::Text("* freq: %d",ch->freq);
|
COMMON_CHAN_DEBUG;
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq);
|
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch);
|
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2);
|
|
||||||
ImGui::Text("- note: %d",ch->note);
|
|
||||||
ImGui::Text("- ins: %d",ch->ins);
|
|
||||||
ImGui::Text("* PCM:");
|
ImGui::Text("* PCM:");
|
||||||
ImGui::Text(" - sample: %d",ch->pcm.sample);
|
ImGui::Text(" - sample: %d",ch->pcm.sample);
|
||||||
ImGui::Text(" - pos: %d",ch->pcm.pos);
|
ImGui::Text(" - pos: %d",ch->pcm.pos);
|
||||||
ImGui::Text(" - len: %d",ch->pcm.len);
|
ImGui::Text(" - len: %d",ch->pcm.len);
|
||||||
ImGui::Text(" - freq: %d",ch->pcm.freq);
|
ImGui::Text(" - freq: %d",ch->pcm.freq);
|
||||||
ImGui::Text("- vol: %.2x",ch->vol);
|
|
||||||
ImGui::Text("- outVol: %.2x",ch->outVol);
|
|
||||||
ImGui::Text("- chVolL: %.2x",ch->chVolL);
|
ImGui::Text("- chVolL: %.2x",ch->chVolL);
|
||||||
ImGui::Text("- chVolR: %.2x",ch->chVolR);
|
ImGui::Text("- chVolR: %.2x",ch->chVolR);
|
||||||
ImGui::Text("- chPanL: %.2x",ch->chPanL);
|
ImGui::Text("- chPanL: %.2x",ch->chPanL);
|
||||||
ImGui::Text("- chPanR: %.2x",ch->chPanR);
|
ImGui::Text("- chPanR: %.2x",ch->chPanR);
|
||||||
ImGui::Text("- macroVolMul: %.2x",ch->macroVolMul);
|
ImGui::Text("- macroVolMul: %.2x",ch->macroVolMul);
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active");
|
COMMON_CHAN_DEBUG_BOOL;
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged");
|
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged");
|
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn");
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff");
|
|
||||||
ImGui::TextColored(ch->portaPause?colorOn:colorOff,">> PortaPause");
|
|
||||||
ImGui::TextColored(ch->furnacePCM?colorOn:colorOff,">> FurnacePCM");
|
ImGui::TextColored(ch->furnacePCM?colorOn:colorOff,">> FurnacePCM");
|
||||||
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta");
|
|
||||||
ImGui::TextColored(ch->isNewSegaPCM?colorOn:colorOff,">> IsNewSegaPCM");
|
ImGui::TextColored(ch->isNewSegaPCM?colorOn:colorOff,">> IsNewSegaPCM");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case DIV_SYSTEM_AY8910: {
|
case DIV_SYSTEM_AY8910: {
|
||||||
DivPlatformAY8910::Channel* ch=(DivPlatformAY8910::Channel*)data;
|
DivPlatformAY8910::Channel* ch=(DivPlatformAY8910::Channel*)data;
|
||||||
ImGui::Text("> AY-3-8910");
|
ImGui::Text("> AY-3-8910");
|
||||||
ImGui::Text("* freq: %d",ch->freq);
|
COMMON_CHAN_DEBUG;
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq);
|
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch);
|
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2);
|
|
||||||
ImGui::Text("- note: %d",ch->note);
|
|
||||||
ImGui::Text("- ins: %d",ch->ins);
|
|
||||||
ImGui::Text("* psgMode:");
|
ImGui::Text("* psgMode:");
|
||||||
ImGui::Text(" * curr:");
|
ImGui::Text(" * curr:");
|
||||||
ImGui::Text(" - tone: %d",ch->curPSGMode.tone);
|
ImGui::Text(" - tone: %d",ch->curPSGMode.tone);
|
||||||
|
@ -871,27 +725,14 @@ void putDispatchChan(void* data, int chanNum, int type) {
|
||||||
ImGui::Text(" - out: %d",ch->dac.out);
|
ImGui::Text(" - out: %d",ch->dac.out);
|
||||||
ImGui::Text("- autoEnvNum: %.2x",ch->autoEnvNum);
|
ImGui::Text("- autoEnvNum: %.2x",ch->autoEnvNum);
|
||||||
ImGui::Text("- autoEnvDen: %.2x",ch->autoEnvDen);
|
ImGui::Text("- autoEnvDen: %.2x",ch->autoEnvDen);
|
||||||
ImGui::Text("- vol: %.2x",ch->vol);
|
COMMON_CHAN_DEBUG_BOOL;
|
||||||
ImGui::Text("- outVol: %.2x",ch->outVol);
|
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active");
|
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged");
|
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged");
|
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn");
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff");
|
|
||||||
ImGui::TextColored(ch->portaPause?colorOn:colorOff,">> PortaPause");
|
|
||||||
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta");
|
|
||||||
ImGui::TextColored(ch->dac.furnaceDAC?colorOn:colorOff,">> furnaceDAC");
|
ImGui::TextColored(ch->dac.furnaceDAC?colorOn:colorOff,">> furnaceDAC");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case DIV_SYSTEM_AY8930: {
|
case DIV_SYSTEM_AY8930: {
|
||||||
DivPlatformAY8930::Channel* ch=(DivPlatformAY8930::Channel*)data;
|
DivPlatformAY8930::Channel* ch=(DivPlatformAY8930::Channel*)data;
|
||||||
ImGui::Text("> AY8930");
|
ImGui::Text("> AY8930");
|
||||||
ImGui::Text("* freq: %d",ch->freq);
|
COMMON_CHAN_DEBUG;
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq);
|
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch);
|
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2);
|
|
||||||
ImGui::Text("- note: %d",ch->note);
|
|
||||||
ImGui::Text("- ins: %d",ch->ins);
|
|
||||||
ImGui::Text("- duty: %d",ch->duty);
|
ImGui::Text("- duty: %d",ch->duty);
|
||||||
ImGui::Text("* envelope:");
|
ImGui::Text("* envelope:");
|
||||||
ImGui::Text(" - mode: %d",ch->envelope.mode);
|
ImGui::Text(" - mode: %d",ch->envelope.mode);
|
||||||
|
@ -917,39 +758,19 @@ void putDispatchChan(void* data, int chanNum, int type) {
|
||||||
ImGui::Text(" - out: %d",ch->dac.out);
|
ImGui::Text(" - out: %d",ch->dac.out);
|
||||||
ImGui::Text("- autoEnvNum: %.2x",ch->autoEnvNum);
|
ImGui::Text("- autoEnvNum: %.2x",ch->autoEnvNum);
|
||||||
ImGui::Text("- autoEnvDen: %.2x",ch->autoEnvDen);
|
ImGui::Text("- autoEnvDen: %.2x",ch->autoEnvDen);
|
||||||
ImGui::Text("- vol: %.2x",ch->vol);
|
COMMON_CHAN_DEBUG_BOOL;
|
||||||
ImGui::Text("- outVol: %.2x",ch->outVol);
|
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active");
|
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged");
|
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged");
|
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn");
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff");
|
|
||||||
ImGui::TextColored(ch->portaPause?colorOn:colorOff,">> PortaPause");
|
|
||||||
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta");
|
|
||||||
ImGui::TextColored(ch->dac.furnaceDAC?colorOn:colorOff,">> furnaceDAC");
|
ImGui::TextColored(ch->dac.furnaceDAC?colorOn:colorOff,">> furnaceDAC");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case DIV_SYSTEM_QSOUND: {
|
case DIV_SYSTEM_QSOUND: {
|
||||||
DivPlatformQSound::Channel* ch=(DivPlatformQSound::Channel*)data;
|
DivPlatformQSound::Channel* ch=(DivPlatformQSound::Channel*)data;
|
||||||
ImGui::Text("> QSound");
|
ImGui::Text("> QSound");
|
||||||
ImGui::Text("* freq: %d",ch->freq);
|
COMMON_CHAN_DEBUG;
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq);
|
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch);
|
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2);
|
|
||||||
ImGui::Text("- note: %d",ch->note);
|
|
||||||
ImGui::Text("- ins: %d",ch->ins);
|
|
||||||
ImGui::Text("- sample: %d",ch->sample);
|
ImGui::Text("- sample: %d",ch->sample);
|
||||||
ImGui::Text("- echo: %d",ch->echo);
|
ImGui::Text("- echo: %d",ch->echo);
|
||||||
ImGui::Text("- panning: %d",ch->panning);
|
ImGui::Text("- panning: %d",ch->panning);
|
||||||
ImGui::Text("- vol: %.2x",ch->vol);
|
|
||||||
ImGui::Text("- outVol: %.2x",ch->outVol);
|
|
||||||
ImGui::Text("- resVol: %.2x",ch->resVol);
|
ImGui::Text("- resVol: %.2x",ch->resVol);
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active");
|
COMMON_CHAN_DEBUG_BOOL;
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged");
|
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged");
|
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn");
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff");
|
|
||||||
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta");
|
|
||||||
ImGui::TextColored(ch->useWave?colorOn:colorOff,">> UseWave");
|
ImGui::TextColored(ch->useWave?colorOn:colorOff,">> UseWave");
|
||||||
ImGui::TextColored(ch->surround?colorOn:colorOff,">> Surround");
|
ImGui::TextColored(ch->surround?colorOn:colorOff,">> Surround");
|
||||||
ImGui::TextColored(ch->isNewQSound?colorOn:colorOff,">> IsNewQSound");
|
ImGui::TextColored(ch->isNewQSound?colorOn:colorOff,">> IsNewQSound");
|
||||||
|
@ -958,14 +779,9 @@ void putDispatchChan(void* data, int chanNum, int type) {
|
||||||
case DIV_SYSTEM_X1_010: {
|
case DIV_SYSTEM_X1_010: {
|
||||||
DivPlatformX1_010::Channel* ch=(DivPlatformX1_010::Channel*)data;
|
DivPlatformX1_010::Channel* ch=(DivPlatformX1_010::Channel*)data;
|
||||||
ImGui::Text("> X1-010");
|
ImGui::Text("> X1-010");
|
||||||
ImGui::Text("* freq: %.4x",ch->freq);
|
COMMON_CHAN_DEBUG;
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq);
|
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch);
|
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2);
|
|
||||||
ImGui::Text("- note: %d",ch->note);
|
|
||||||
ImGui::Text("- wave: %d",ch->wave);
|
ImGui::Text("- wave: %d",ch->wave);
|
||||||
ImGui::Text("- sample: %d",ch->sample);
|
ImGui::Text("- sample: %d",ch->sample);
|
||||||
ImGui::Text("- ins: %d",ch->ins);
|
|
||||||
ImGui::Text("- pan: %d",ch->pan);
|
ImGui::Text("- pan: %d",ch->pan);
|
||||||
ImGui::Text("* envelope:");
|
ImGui::Text("* envelope:");
|
||||||
ImGui::Text(" - shape: %d",ch->env.shape);
|
ImGui::Text(" - shape: %d",ch->env.shape);
|
||||||
|
@ -976,17 +792,10 @@ void putDispatchChan(void* data, int chanNum, int type) {
|
||||||
ImGui::Text(" - autoEnvDen: %.2x",ch->autoEnvDen);
|
ImGui::Text(" - autoEnvDen: %.2x",ch->autoEnvDen);
|
||||||
ImGui::Text("- WaveBank: %d",ch->waveBank);
|
ImGui::Text("- WaveBank: %d",ch->waveBank);
|
||||||
ImGui::Text("- bankSlot: %d",ch->bankSlot);
|
ImGui::Text("- bankSlot: %d",ch->bankSlot);
|
||||||
ImGui::Text("- vol: %.2x",ch->vol);
|
|
||||||
ImGui::Text("- outVol: %.2x",ch->outVol);
|
|
||||||
ImGui::Text("- Lvol: %.2x",ch->lvol);
|
ImGui::Text("- Lvol: %.2x",ch->lvol);
|
||||||
ImGui::Text("- Rvol: %.2x",ch->rvol);
|
ImGui::Text("- Rvol: %.2x",ch->rvol);
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active");
|
COMMON_CHAN_DEBUG_BOOL;
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged");
|
|
||||||
ImGui::TextColored(ch->envChanged?colorOn:colorOff,">> EnvChanged");
|
ImGui::TextColored(ch->envChanged?colorOn:colorOff,">> EnvChanged");
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged");
|
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn");
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff");
|
|
||||||
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta");
|
|
||||||
ImGui::TextColored(ch->furnacePCM?colorOn:colorOff,">> FurnacePCM");
|
ImGui::TextColored(ch->furnacePCM?colorOn:colorOff,">> FurnacePCM");
|
||||||
ImGui::TextColored(ch->pcm?colorOn:colorOff,">> PCM");
|
ImGui::TextColored(ch->pcm?colorOn:colorOff,">> PCM");
|
||||||
ImGui::TextColored(ch->env.flag.envEnable?colorOn:colorOff,">> EnvEnable");
|
ImGui::TextColored(ch->env.flag.envEnable?colorOn:colorOff,">> EnvEnable");
|
||||||
|
@ -1001,11 +810,7 @@ void putDispatchChan(void* data, int chanNum, int type) {
|
||||||
case DIV_SYSTEM_N163: {
|
case DIV_SYSTEM_N163: {
|
||||||
DivPlatformN163::Channel* ch=(DivPlatformN163::Channel*)data;
|
DivPlatformN163::Channel* ch=(DivPlatformN163::Channel*)data;
|
||||||
ImGui::Text("> N163");
|
ImGui::Text("> N163");
|
||||||
ImGui::Text("* freq: %.4x",ch->freq);
|
COMMON_CHAN_DEBUG;
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq);
|
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch);
|
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2);
|
|
||||||
ImGui::Text("- note: %d",ch->note);
|
|
||||||
ImGui::Text("- wave: %d",ch->wave);
|
ImGui::Text("- wave: %d",ch->wave);
|
||||||
ImGui::Text("- wavepos: %d",ch->wavePos);
|
ImGui::Text("- wavepos: %d",ch->wavePos);
|
||||||
ImGui::Text("- wavelen: %d",ch->waveLen);
|
ImGui::Text("- wavelen: %d",ch->waveLen);
|
||||||
|
@ -1014,45 +819,25 @@ void putDispatchChan(void* data, int chanNum, int type) {
|
||||||
ImGui::Text("- loadpos: %d",ch->loadPos);
|
ImGui::Text("- loadpos: %d",ch->loadPos);
|
||||||
ImGui::Text("- loadlen: %d",ch->loadLen);
|
ImGui::Text("- loadlen: %d",ch->loadLen);
|
||||||
ImGui::Text("- loadmode: %d",ch->loadMode);
|
ImGui::Text("- loadmode: %d",ch->loadMode);
|
||||||
ImGui::Text("- ins: %d",ch->ins);
|
|
||||||
ImGui::Text("- vol: %.2x",ch->vol);
|
|
||||||
ImGui::Text("- outVol: %.2x",ch->outVol);
|
|
||||||
ImGui::Text("- resVol: %.2x",ch->resVol);
|
ImGui::Text("- resVol: %.2x",ch->resVol);
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active");
|
COMMON_CHAN_DEBUG_BOOL;
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged");
|
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged");
|
|
||||||
ImGui::TextColored(ch->volumeChanged?colorOn:colorOff,">> VolumeChanged");
|
ImGui::TextColored(ch->volumeChanged?colorOn:colorOff,">> VolumeChanged");
|
||||||
ImGui::TextColored(ch->waveChanged?colorOn:colorOff,">> WaveChanged");
|
ImGui::TextColored(ch->waveChanged?colorOn:colorOff,">> WaveChanged");
|
||||||
ImGui::TextColored(ch->waveUpdated?colorOn:colorOff,">> WaveUpdated");
|
ImGui::TextColored(ch->waveUpdated?colorOn:colorOff,">> WaveUpdated");
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn");
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff");
|
|
||||||
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta");
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case DIV_SYSTEM_VRC6: {
|
case DIV_SYSTEM_VRC6: {
|
||||||
DivPlatformVRC6::Channel* ch=(DivPlatformVRC6::Channel*)data;
|
DivPlatformVRC6::Channel* ch=(DivPlatformVRC6::Channel*)data;
|
||||||
ImGui::Text("> VRC6");
|
ImGui::Text("> VRC6");
|
||||||
ImGui::Text("* freq: %d",ch->freq);
|
COMMON_CHAN_DEBUG;
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq);
|
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch);
|
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2);
|
|
||||||
ImGui::Text("- note: %d",ch->note);
|
|
||||||
ImGui::Text("* DAC:");
|
ImGui::Text("* DAC:");
|
||||||
ImGui::Text(" - period: %d",ch->dacPeriod);
|
ImGui::Text(" - period: %d",ch->dacPeriod);
|
||||||
ImGui::Text(" - rate: %d",ch->dacRate);
|
ImGui::Text(" - rate: %d",ch->dacRate);
|
||||||
ImGui::Text(" - out: %d",ch->dacOut);
|
ImGui::Text(" - out: %d",ch->dacOut);
|
||||||
ImGui::Text(" - pos: %d",ch->dacPos);
|
ImGui::Text(" - pos: %d",ch->dacPos);
|
||||||
ImGui::Text(" - sample: %d",ch->dacSample);
|
ImGui::Text(" - sample: %d",ch->dacSample);
|
||||||
ImGui::Text("- ins: %d",ch->ins);
|
|
||||||
ImGui::Text("- duty: %d",ch->duty);
|
ImGui::Text("- duty: %d",ch->duty);
|
||||||
ImGui::Text("- vol: %.2x",ch->vol);
|
COMMON_CHAN_DEBUG_BOOL;
|
||||||
ImGui::Text("- outVol: %.2x",ch->outVol);
|
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active");
|
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged");
|
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged");
|
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn");
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff");
|
|
||||||
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta");
|
|
||||||
ImGui::TextColored(ch->pcm?colorOn:colorOff,">> DAC");
|
ImGui::TextColored(ch->pcm?colorOn:colorOff,">> DAC");
|
||||||
ImGui::TextColored(ch->furnaceDac?colorOn:colorOff,">> FurnaceDAC");
|
ImGui::TextColored(ch->furnaceDac?colorOn:colorOff,">> FurnaceDAC");
|
||||||
break;
|
break;
|
||||||
|
@ -1060,46 +845,30 @@ void putDispatchChan(void* data, int chanNum, int type) {
|
||||||
case DIV_SYSTEM_LYNX: {
|
case DIV_SYSTEM_LYNX: {
|
||||||
DivPlatformLynx::Channel* ch=(DivPlatformLynx::Channel*)data;
|
DivPlatformLynx::Channel* ch=(DivPlatformLynx::Channel*)data;
|
||||||
ImGui::Text("> Lynx");
|
ImGui::Text("> Lynx");
|
||||||
ImGui::Text("* freq:");
|
COMMON_CHAN_DEBUG;
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq);
|
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch);
|
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2);
|
|
||||||
ImGui::Text("* FreqDiv:");
|
ImGui::Text("* FreqDiv:");
|
||||||
ImGui::Text(" - clockDivider: %d",ch->fd.clockDivider);
|
ImGui::Text(" - clockDivider: %d",ch->fd.clockDivider);
|
||||||
ImGui::Text(" - backup: %d",ch->fd.backup);
|
ImGui::Text(" - backup: %d",ch->fd.backup);
|
||||||
ImGui::Text("* note: %d",ch->note);
|
ImGui::Text("- actualNote: %d",ch->actualNote);
|
||||||
ImGui::Text(" - actualNote: %d",ch->actualNote);
|
|
||||||
ImGui::Text("* Sample:");
|
ImGui::Text("* Sample:");
|
||||||
ImGui::Text(" - sample: %d",ch->sample);
|
ImGui::Text(" - sample: %d",ch->sample);
|
||||||
ImGui::Text(" - pos: %d",ch->samplePos);
|
ImGui::Text(" - pos: %d",ch->samplePos);
|
||||||
ImGui::Text(" - accum: %d",ch->sampleAccum);
|
ImGui::Text(" - accum: %d",ch->sampleAccum);
|
||||||
ImGui::Text(" * freq: %d",ch->sampleFreq);
|
ImGui::Text(" * freq: %d",ch->sampleFreq);
|
||||||
ImGui::Text(" - base: %d",ch->sampleBaseFreq);
|
ImGui::Text(" - base: %d",ch->sampleBaseFreq);
|
||||||
ImGui::Text("- ins: %d",ch->ins);
|
|
||||||
ImGui::Text("* duty:");
|
ImGui::Text("* duty:");
|
||||||
ImGui::Text(" - int_feedback7: %d",ch->duty.int_feedback7);
|
ImGui::Text(" - int_feedback7: %d",ch->duty.int_feedback7);
|
||||||
ImGui::Text(" - feedback: %d",ch->duty.feedback);
|
ImGui::Text(" - feedback: %d",ch->duty.feedback);
|
||||||
ImGui::Text("- pan: %.2x",ch->pan);
|
ImGui::Text("- pan: %.2x",ch->pan);
|
||||||
ImGui::Text("- vol: %.2x",ch->vol);
|
|
||||||
ImGui::Text("- outVol: %.2x",ch->outVol);
|
|
||||||
ImGui::Text("- macroVolMul: %.2x",ch->macroVolMul);
|
ImGui::Text("- macroVolMul: %.2x",ch->macroVolMul);
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active");
|
COMMON_CHAN_DEBUG_BOOL;
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged");
|
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged");
|
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn");
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff");
|
|
||||||
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta");
|
|
||||||
ImGui::TextColored(ch->pcm?colorOn:colorOff,">> DAC");
|
ImGui::TextColored(ch->pcm?colorOn:colorOff,">> DAC");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case DIV_SYSTEM_PCM_DAC: {
|
case DIV_SYSTEM_PCM_DAC: {
|
||||||
DivPlatformPCMDAC::Channel* ch=(DivPlatformPCMDAC::Channel*)data;
|
DivPlatformPCMDAC::Channel* ch=(DivPlatformPCMDAC::Channel*)data;
|
||||||
ImGui::Text("> PCM DAC");
|
ImGui::Text("> PCM DAC");
|
||||||
ImGui::Text("* freq:");
|
COMMON_CHAN_DEBUG;
|
||||||
ImGui::Text(" - base: %d",ch->baseFreq);
|
|
||||||
ImGui::Text(" - pitch: %d",ch->pitch);
|
|
||||||
ImGui::Text(" - pitch2: %d",ch->pitch2);
|
|
||||||
ImGui::Text("* note: %d",ch->note);
|
|
||||||
ImGui::Text("* Sample: %d",ch->sample);
|
ImGui::Text("* Sample: %d",ch->sample);
|
||||||
ImGui::Text(" - dir: %d",ch->audDir);
|
ImGui::Text(" - dir: %d",ch->audDir);
|
||||||
ImGui::Text(" - loc: %d",ch->audLoc);
|
ImGui::Text(" - loc: %d",ch->audLoc);
|
||||||
|
@ -1107,17 +876,10 @@ void putDispatchChan(void* data, int chanNum, int type) {
|
||||||
ImGui::Text(" * pos: %d",ch->audPos);
|
ImGui::Text(" * pos: %d",ch->audPos);
|
||||||
ImGui::Text(" - sub: %d",ch->audSub);
|
ImGui::Text(" - sub: %d",ch->audSub);
|
||||||
ImGui::Text("- wave: %d",ch->wave);
|
ImGui::Text("- wave: %d",ch->wave);
|
||||||
ImGui::Text("- ins: %d",ch->ins);
|
|
||||||
ImGui::Text("- panL: %.2x",ch->panL);
|
ImGui::Text("- panL: %.2x",ch->panL);
|
||||||
ImGui::Text("- panR: %.2x",ch->panR);
|
ImGui::Text("- panR: %.2x",ch->panR);
|
||||||
ImGui::Text("- vol: %.2x",ch->vol);
|
|
||||||
ImGui::Text("- envVol: %.2x",ch->envVol);
|
ImGui::Text("- envVol: %.2x",ch->envVol);
|
||||||
ImGui::TextColored(ch->active?colorOn:colorOff,">> Active");
|
COMMON_CHAN_DEBUG_BOOL;
|
||||||
ImGui::TextColored(ch->insChanged?colorOn:colorOff,">> InsChanged");
|
|
||||||
ImGui::TextColored(ch->freqChanged?colorOn:colorOff,">> FreqChanged");
|
|
||||||
ImGui::TextColored(ch->keyOn?colorOn:colorOff,">> KeyOn");
|
|
||||||
ImGui::TextColored(ch->keyOff?colorOn:colorOff,">> KeyOff");
|
|
||||||
ImGui::TextColored(ch->inPorta?colorOn:colorOff,">> InPorta");
|
|
||||||
ImGui::TextColored(ch->useWave?colorOn:colorOff,">> UseWave");
|
ImGui::TextColored(ch->useWave?colorOn:colorOff,">> UseWave");
|
||||||
ImGui::TextColored(ch->setPos?colorOn:colorOff,">> SetPos");
|
ImGui::TextColored(ch->setPos?colorOn:colorOff,">> SetPos");
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in a new issue