2 CASIO PV-1000 Emulator 'ePV-1000'
4 Author : Takeda.Toshiya
12 #include "../../types/util_sound.h"
15 #define PSG_VOLUME 8192
22 memset(ch, 0, sizeof(ch));
25 void PSG::write_io8(uint32_t addr, uint32_t data)
28 ch[addr & 3].period = 0x3f - (data & 0x3f);
31 void PSG::initialize_sound(int rate)
33 diff = (int)(1.3 * (double)CPU_CLOCKS / (double)rate + 0.5);
36 void PSG::mix(int32_t* buffer, int cnt)
38 // create sound buffer
39 for(int i = 0; i < cnt; i++) {
41 for(int j = 0; j < 3; j++) {
45 bool prev_signal = ch[j].signal;
46 int prev_count = ch[j].count;
49 ch[j].count += ch[j].period << 8;
50 ch[j].signal = !ch[j].signal;
52 int vol_tmp = (prev_signal != ch[j].signal && prev_count < diff) ? (PSG_VOLUME * (2 * prev_count - diff)) / diff : PSG_VOLUME;
53 vol += prev_signal ? vol_tmp : -vol_tmp;
55 *buffer++ += apply_volume(vol, volume_l); // L
56 *buffer++ += apply_volume(vol, volume_l); // R
60 void PSG::set_volume(int ch, int decibel_l, int decibel_r)
62 volume_l = decibel_to_volume(decibel_l);
63 volume_r = decibel_to_volume(decibel_r);
66 #define STATE_VERSION 1
68 bool PSG::process_state(FILEIO* state_fio, bool loading)
70 if(!state_fio->StateCheckUint32(STATE_VERSION)) {
73 if(!state_fio->StateCheckInt32(this_device_id)) {
76 for(int i = 0; i < 3; i++) {
77 state_fio->StateValue(ch[i].period);