mirror of
https://github.com/TomHarte/CLK.git
synced 2025-01-22 19:31:27 +00:00
Turned audio quality up to the maximum, at least for now.
This commit is contained in:
parent
28e6517234
commit
e617bd2bb3
@ -67,10 +67,9 @@ void Machine::setup_output()
|
||||
_crt->set_output_device(Outputs::CRT::Monitor);
|
||||
|
||||
// The maximum output frequency is 62500Hz and all other permitted output frequencies are integral divisions of that;
|
||||
// nevertheless sampling only at 62500Hz may introduce aliasing errors as setting the speaker on or off can happen on
|
||||
// any 2Mhz cycle, and I've no idea whether it has an immediate effect or happens only on the next clock. If it turns
|
||||
// out that the former is the case, I'll need to turn this up to 2000000.
|
||||
_speaker.set_input_rate(62500);
|
||||
// however setting the speaker on or off can happen on any 2Mhz cycle, and probably (?) takes effect immediately. So
|
||||
// run the speaker at a 2000000Hz input rate, at least for the time being.
|
||||
_speaker.set_input_rate(2000000);
|
||||
}
|
||||
|
||||
unsigned int Machine::perform_bus_operation(CPU6502::BusOperation operation, uint16_t address, uint8_t *value)
|
||||
@ -431,7 +430,7 @@ unsigned int Machine::perform_bus_operation(CPU6502::BusOperation operation, uin
|
||||
_frameCycles = nextFrameCycles;
|
||||
}
|
||||
|
||||
if(!(_frameCycles&31))
|
||||
if(!(_frameCycles&16383))
|
||||
update_audio();
|
||||
_tape.run_for_cycles(cycles);
|
||||
|
||||
@ -495,9 +494,8 @@ inline void Machine::evaluate_interrupts()
|
||||
inline void Machine::update_audio()
|
||||
{
|
||||
int difference = (int)_frameCycles - _audioOutputPosition;
|
||||
_speaker.run_for_cycles(difference);
|
||||
_audioOutputPosition = (int)_frameCycles;
|
||||
_speaker.run_for_cycles((_audioOutputPositionError + difference) >> 5);
|
||||
_audioOutputPositionError = (_audioOutputPositionError + difference)&31;
|
||||
}
|
||||
|
||||
inline void Machine::start_pixel_line()
|
||||
@ -852,7 +850,7 @@ void Speaker::skip_samples(unsigned int number_of_samples)
|
||||
|
||||
void Speaker::set_divider(uint8_t divider)
|
||||
{
|
||||
_divider = divider;
|
||||
_divider = divider * 32;
|
||||
}
|
||||
|
||||
void Speaker::set_is_enabled(bool is_enabled)
|
||||
|
@ -128,7 +128,7 @@ class Speaker: public ::Outputs::Filter<Speaker> {
|
||||
|
||||
private:
|
||||
unsigned int _counter;
|
||||
uint8_t _divider;
|
||||
unsigned int _divider;
|
||||
bool _is_enabled;
|
||||
};
|
||||
|
||||
|
@ -60,7 +60,7 @@
|
||||
- (BOOL)setSpeakerDelegate:(Outputs::Speaker::Delegate *)delegate sampleRate:(int)sampleRate {
|
||||
@synchronized(self) {
|
||||
_electron.get_speaker()->set_output_rate(sampleRate, 256);
|
||||
_electron.get_speaker()->set_output_quality(15);
|
||||
_electron.get_speaker()->set_output_quality(47);
|
||||
_electron.get_speaker()->set_delegate(delegate);
|
||||
return YES;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user