2012-03-23 10:43:39 +00:00
|
|
|
struct APU : Thread {
|
Update to v098r06 release.
byuu says:
Changelog:
- emulation cores now refresh video from host thread instead of
cothreads (fix AMD crash)
- SFC: fixed another bug with leap year months in SharpRTC emulation
- SFC: cleaned up camelCase on function names for
armdsp,epsonrtc,hitachidsp,mcc,nss,sharprtc classes
- GB: added MBC1M emulation (requires manually setting mapper=MBC1M in
manifest.bml for now, sorry)
- audio: implemented Emulator::Audio mixer and effects processor
- audio: implemented Emulator::Stream interface
- it is now possible to have more than two audio streams: eg SNES
+ SGB + MSU1 + Voicer-Kun (eventually)
- audio: added reverb delay + reverb level settings; exposed balance
configuration in UI
- video: reworked palette generation to re-enable saturation, gamma,
luminance adjustments
- higan/emulator.cpp is gone since there was nothing left in it
I know you guys are going to say the color adjust/balance/reverb stuff
is pointless. And indeed it mostly is. But I like the idea of allowing
some fun special effects and configurability that isn't system-wide.
Note: there seems to be some kind of added audio lag in the SGB
emulation now, and I don't really understand why. The code should be
effectively identical to what I had before. The only main thing is that
I'm sampling things to 48000hz instead of 32040hz before mixing. There's
no point where I'm intentionally introducing added latency though. I'm
kind of stumped, so if anyone wouldn't mind taking a look at it, it'd be
much appreciated :/
I don't have an MSU1 test ROM, but the latency issue may affect MSU1 as
well, and that would be very bad.
2016-04-22 13:35:51 +00:00
|
|
|
shared_pointer<Emulator::Stream> stream;
|
|
|
|
|
Update to v103r01 release.
byuu says:
Changelog:
- nall/dsp: improve one pole coefficient calculations [Fatbag]
- higan/audio: reworked filters to support selection of either one
pole (first-order) or biquad (second-order) filters
- note: the design is not stable yet; so forks should not put too
much effort into synchronizing with this change yet
- fc: added first-order filters as per NESdev wiki (90hz lowpass +
440hz lowpass + 14khz highpass)
- fc: created separate NTSC-J and NTSC-U regions
- NESdev wiki says the Japanese Famicom uses a separate audio
filtering strategy, but details are fuzzy
- there's also cartridge audio output being disabled on NES units;
and differences with controllers
- this stuff will be supported in the future, just adding the
support for it now
- gba: corrected serious bugs in PSG wave channel emulation [Cydrak]
- note that if there are still bugs here, it's my fault
- md/psg,ym2612: added first-order low-pass 2840hz filter to match
VA3-VA6 Mega Drives
- md/psg: lowered volume relative to the YM2612
- using 0x1400; multiple people agreed it was the closest to the
hardware recordings against a VA6
- ms,md/psg: don't serialize the volume levels array
- md/vdp: Hblank bit acts the same during Vblank as outside of it (it
isn't always set during Vblank)
- md/vdp: return isPAL in bit 0 of control port reads
- tomoko: change command-line option separator from : to |
- [Editor's note: This change was present in the public v103,
but it's in this changelog because it was made after the v103 WIP]
- higan/all: change the 20hz high-pass filters from second-order
three-pass to first-order one-pass
- these filters are meant to remove DC bias, but I honestly can't
hear a difference with or without them
- so there's really no sense wasting CPU power with an extremely
powerful filter here
Things I did not do:
- change icarus install rule
- work on 8-bit Mega Drive SRAM
- work on Famicom or Mega Drive region detection heuristics in icarus
My long-term dream plan is to devise a special user-configurable
filtering system where you can set relative volumes and create your own
list of filters (any number of them in any order at any frequency), that
way people can make the systems sound however they want.
Right now, the sanest place to put this information is inside the
$system.sys/manifest.bml files. But that's not very user friendly, and
upgrading to new versions will lose these changes if you don't copy them
over manually. Of course, cluttering the GUI with a fancy filter editor
is probably supreme overkill for 99% of users, so maybe that's fine.
2017-06-26 01:41:58 +00:00
|
|
|
inline auto rate() const -> uint { return Region::PAL() ? 16 : 12; }
|
2017-06-22 06:04:07 +00:00
|
|
|
|
|
|
|
//apu.cpp
|
2015-12-05 05:44:49 +00:00
|
|
|
APU();
|
2011-09-12 10:30:44 +00:00
|
|
|
|
2016-02-09 11:51:12 +00:00
|
|
|
static auto Enter() -> void;
|
2015-12-05 05:44:49 +00:00
|
|
|
auto main() -> void;
|
|
|
|
auto tick() -> void;
|
2016-06-27 13:07:57 +00:00
|
|
|
auto setIRQ() -> void;
|
|
|
|
auto setSample(int16 sample) -> void;
|
2011-09-12 10:30:44 +00:00
|
|
|
|
Update to v105r1 release.
byuu says:
Changelog:
- higan: readded support for soft-reset to Famicom, Super Famicom,
Mega Drive cores (work in progress)
- handhelds lack soft reset obviously
- the PC Engine also lacks a physical reset button
- the Master System's reset button acts like a gamepad button, so
can't show up in the menu
- Mega Drive: power cycle wasn't initializing CPU (M68K) or APU (Z80)
RAM
- Super Famicom: fix SPC700 opcode 0x3b regression; fixes Majuu Ou
[Jonas Quinn]
- Super Famicom: fix SharpRTC save regression; fixes Dai Kaijuu
Monogatari II's real-time clock [Talarubi]
- Super Famicom: fix EpsonRTC save regression; fixes Tengai Makyou
Zero's real-time clock [Talarubi]
- Super Famicom: removed `*::init()` functions, as they were never used
- Super Famicom: removed all but two `*::load()` functions, as they
were not used
- higan: added option to auto-save backup RAM every five seconds
(enabled by default)
- this is in case the emulator crashes, or there's a power outage;
turn it off under advanced settings if you want
- libco: updated license from public domain to ISC, for consistency
with nall, ruby, hiro
- nall: Linux compiler defaults to g++; override with g++-version if
g++ is <= 4.8
- FreeBSD compiler default is going to remain g++49 until my dev
box OS ships with g++ >= 4.9
Errata: I have weird RAM initialization constants, thanks to hex_usr
and onethirdxcubed for both finding this:
http://wiki.nesdev.com/w/index.php?title=CPU_power_up_state&diff=11711&oldid=11184
I'll remove this in the next WIP.
2017-11-06 22:05:54 +00:00
|
|
|
auto power(bool reset) -> void;
|
2011-09-12 10:30:44 +00:00
|
|
|
|
Update to v099r04 release.
byuu says:
Changelog:
- lots of code cleanups to processor/r6502 (the switch.cpp file is only
halfway done ...)
- lots of code cleanups to fc/cpu
- removed fc/input
- implemented fc/controller
hex_usr, you may not like this, but I want to keep the controller port
and expansion port interface separate, like I do with the SNES. I realize
the NES' is used more for controllers, and the SNES' more for hardware
expansions, but ... they're not compatible pinouts and you can't really
connect one to the other.
Right now, I've only implemented the controller portion. I'll have to
get to the peripheral portion later.
Also, the gamepad implementation there now may be wrong. It's based off
the Super Famicom version obviously. I'm not sure if the Famicom has
different behavior with latching $4016 writes, or not. But, it works in
Mega Man II, so it's a start.
Everyone, be sure to remap your controls, and then set port 1 -> gamepad
after loading your first Famicom game with the new WIP.
2016-06-18 06:04:32 +00:00
|
|
|
auto readIO(uint16 addr) -> uint8;
|
|
|
|
auto writeIO(uint16 addr, uint8 data) -> void;
|
2015-12-05 05:44:49 +00:00
|
|
|
|
2017-06-22 06:04:07 +00:00
|
|
|
//serialization.cpp
|
2015-12-05 05:44:49 +00:00
|
|
|
auto serialize(serializer&) -> void;
|
2011-09-15 12:33:26 +00:00
|
|
|
|
2016-06-27 13:07:57 +00:00
|
|
|
struct Envelope {
|
|
|
|
auto volume() const -> uint;
|
|
|
|
auto clock() -> void;
|
|
|
|
|
|
|
|
auto power() -> void;
|
|
|
|
|
|
|
|
auto serialize(serializer&) -> void;
|
|
|
|
|
|
|
|
uint4 speed;
|
|
|
|
bool useSpeedAsVolume;
|
|
|
|
bool loopMode;
|
|
|
|
|
|
|
|
bool reloadDecay;
|
|
|
|
uint8 decayCounter;
|
|
|
|
uint4 decayVolume;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct Sweep {
|
|
|
|
auto checkPeriod() -> bool;
|
|
|
|
auto clock(uint channel) -> void;
|
|
|
|
|
|
|
|
auto power() -> void;
|
|
|
|
|
|
|
|
auto serialize(serializer&) -> void;
|
|
|
|
|
|
|
|
uint8 shift;
|
|
|
|
bool decrement;
|
|
|
|
uint3 period;
|
|
|
|
uint8 counter;
|
|
|
|
bool enable;
|
|
|
|
bool reload;
|
|
|
|
uint11 pulsePeriod;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct Pulse {
|
|
|
|
auto clockLength() -> void;
|
|
|
|
auto checkPeriod() -> bool;
|
|
|
|
auto clock() -> uint8;
|
|
|
|
|
|
|
|
auto power() -> void;
|
|
|
|
|
|
|
|
auto serialize(serializer&) -> void;
|
|
|
|
|
|
|
|
uint lengthCounter;
|
|
|
|
|
|
|
|
Envelope envelope;
|
|
|
|
Sweep sweep;
|
|
|
|
|
|
|
|
uint2 duty;
|
|
|
|
uint3 dutyCounter;
|
|
|
|
|
|
|
|
uint11 period;
|
|
|
|
uint periodCounter;
|
|
|
|
} pulse[2];
|
|
|
|
|
|
|
|
struct Triangle {
|
|
|
|
auto clockLength() -> void;
|
|
|
|
auto clockLinearLength() -> void;
|
|
|
|
auto clock() -> uint8;
|
|
|
|
|
|
|
|
auto power() -> void;
|
|
|
|
|
|
|
|
auto serialize(serializer&) -> void;
|
|
|
|
|
|
|
|
uint lengthCounter;
|
|
|
|
|
|
|
|
uint8 linearLength;
|
|
|
|
bool haltLengthCounter;
|
|
|
|
|
|
|
|
uint11 period;
|
|
|
|
uint periodCounter;
|
|
|
|
|
|
|
|
uint5 stepCounter;
|
|
|
|
uint8 linearLengthCounter;
|
|
|
|
bool reloadLinear;
|
|
|
|
} triangle;
|
|
|
|
|
|
|
|
struct Noise {
|
|
|
|
auto clockLength() -> void;
|
|
|
|
auto clock() -> uint8;
|
|
|
|
|
|
|
|
auto power() -> void;
|
|
|
|
|
|
|
|
auto serialize(serializer&) -> void;
|
|
|
|
|
|
|
|
uint lengthCounter;
|
|
|
|
|
|
|
|
Envelope envelope;
|
|
|
|
|
|
|
|
uint4 period;
|
|
|
|
uint periodCounter;
|
|
|
|
|
|
|
|
bool shortMode;
|
|
|
|
uint15 lfsr;
|
|
|
|
} noise;
|
|
|
|
|
|
|
|
struct DMC {
|
|
|
|
auto start() -> void;
|
|
|
|
auto stop() -> void;
|
|
|
|
auto clock() -> uint8;
|
|
|
|
|
|
|
|
auto power() -> void;
|
|
|
|
|
|
|
|
auto serialize(serializer&) -> void;
|
|
|
|
|
|
|
|
uint lengthCounter;
|
|
|
|
bool irqPending;
|
|
|
|
|
|
|
|
uint4 period;
|
|
|
|
uint periodCounter;
|
|
|
|
|
|
|
|
bool irqEnable;
|
|
|
|
bool loopMode;
|
|
|
|
|
|
|
|
uint8 dacLatch;
|
|
|
|
uint8 addrLatch;
|
|
|
|
uint8 lengthLatch;
|
|
|
|
|
|
|
|
uint15 readAddr;
|
|
|
|
uint dmaDelayCounter;
|
|
|
|
|
|
|
|
uint3 bitCounter;
|
|
|
|
bool dmaBufferValid;
|
|
|
|
uint8 dmaBuffer;
|
|
|
|
|
|
|
|
bool sampleValid;
|
|
|
|
uint8 sample;
|
|
|
|
} dmc;
|
2011-09-15 12:33:26 +00:00
|
|
|
|
|
|
|
struct FrameCounter {
|
2015-12-05 05:44:49 +00:00
|
|
|
auto serialize(serializer&) -> void;
|
|
|
|
|
|
|
|
enum : uint { NtscPeriod = 14915 }; //~(21.477MHz / 6 / 240hz)
|
2011-09-16 11:44:07 +00:00
|
|
|
|
2016-06-27 13:07:57 +00:00
|
|
|
bool irqPending;
|
2011-09-16 11:44:07 +00:00
|
|
|
|
2011-09-15 12:33:26 +00:00
|
|
|
uint2 mode;
|
|
|
|
uint2 counter;
|
2015-12-05 05:44:49 +00:00
|
|
|
int divider;
|
|
|
|
};
|
2011-09-23 11:13:57 +00:00
|
|
|
|
2016-06-27 13:07:57 +00:00
|
|
|
auto clockFrameCounter() -> void;
|
|
|
|
auto clockFrameCounterDivider() -> void;
|
2011-09-15 12:33:26 +00:00
|
|
|
|
2015-12-05 05:44:49 +00:00
|
|
|
FrameCounter frame;
|
2011-09-15 12:33:26 +00:00
|
|
|
|
2016-06-27 13:07:57 +00:00
|
|
|
uint8 enabledChannels;
|
|
|
|
int16 cartridgeSample;
|
2011-09-15 12:33:26 +00:00
|
|
|
|
2016-06-27 13:07:57 +00:00
|
|
|
int16 pulseDAC[32];
|
|
|
|
int16 dmcTriangleNoiseDAC[128][16][16];
|
2011-09-15 12:33:26 +00:00
|
|
|
|
2016-06-27 13:07:57 +00:00
|
|
|
static const uint8 lengthCounterTable[32];
|
|
|
|
static const uint16 dmcPeriodTableNTSC[16];
|
|
|
|
static const uint16 dmcPeriodTablePAL[16];
|
|
|
|
static const uint16 noisePeriodTableNTSC[16];
|
|
|
|
static const uint16 noisePeriodTablePAL[16];
|
2011-09-12 10:30:44 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
extern APU apu;
|