mirror of
https://github.com/holub/mame
synced 2025-04-29 03:20:50 +03:00
flt_rc/flt_vol: update to new stream callbacks
This commit is contained in:
parent
b506c0a7a1
commit
acd6195487
@ -23,6 +23,7 @@ filter_rc_device::filter_rc_device(const machine_config &mconfig, const char *ta
|
|||||||
m_k(0),
|
m_k(0),
|
||||||
m_memory(0),
|
m_memory(0),
|
||||||
m_type(LOWPASS),
|
m_type(LOWPASS),
|
||||||
|
m_last_sample_rate(0),
|
||||||
m_R1(1),
|
m_R1(1),
|
||||||
m_R2(1),
|
m_R2(1),
|
||||||
m_R3(1),
|
m_R3(1),
|
||||||
@ -37,8 +38,8 @@ filter_rc_device::filter_rc_device(const machine_config &mconfig, const char *ta
|
|||||||
|
|
||||||
void filter_rc_device::device_start()
|
void filter_rc_device::device_start()
|
||||||
{
|
{
|
||||||
m_stream = stream_alloc_legacy(1, 1, machine().sample_rate());
|
m_stream = stream_alloc(1, 1, SAMPLE_RATE_OUTPUT_ADAPTIVE);
|
||||||
recalc();
|
m_last_sample_rate = 0;
|
||||||
|
|
||||||
save_item(NAME(m_k));
|
save_item(NAME(m_k));
|
||||||
save_item(NAME(m_memory));
|
save_item(NAME(m_memory));
|
||||||
@ -54,28 +55,34 @@ void filter_rc_device::device_start()
|
|||||||
// sound_stream_update_legacy - handle a stream update
|
// sound_stream_update_legacy - handle a stream update
|
||||||
//-------------------------------------------------
|
//-------------------------------------------------
|
||||||
|
|
||||||
void filter_rc_device::sound_stream_update_legacy(sound_stream &stream, stream_sample_t const * const *inputs, stream_sample_t * const *outputs, int samples)
|
void filter_rc_device::sound_stream_update(sound_stream &stream, std::vector<read_stream_view> const &inputs, std::vector<write_stream_view> &outputs)
|
||||||
{
|
{
|
||||||
stream_sample_t const *src = inputs[0];
|
auto &src = inputs[0];
|
||||||
stream_sample_t *dst = outputs[0];
|
auto &dst = outputs[0];
|
||||||
int memory = m_memory;
|
stream_buffer::sample_t memory = m_memory;
|
||||||
|
|
||||||
|
if (m_last_sample_rate != m_stream->sample_rate())
|
||||||
|
{
|
||||||
|
recalc();
|
||||||
|
m_last_sample_rate = m_stream->sample_rate();
|
||||||
|
}
|
||||||
|
|
||||||
switch (m_type)
|
switch (m_type)
|
||||||
{
|
{
|
||||||
case LOWPASS:
|
case LOWPASS:
|
||||||
case LOWPASS_2C:
|
case LOWPASS_2C:
|
||||||
while (samples--)
|
for (int sampindex = 0; sampindex < dst.samples(); sampindex++)
|
||||||
{
|
{
|
||||||
memory += ((*src++ - memory) * m_k) / 0x10000;
|
memory += (src.get(sampindex) - memory) * m_k;
|
||||||
*dst++ = memory;
|
dst.put(sampindex, memory);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case HIGHPASS:
|
case HIGHPASS:
|
||||||
case AC:
|
case AC:
|
||||||
while (samples--)
|
for (int sampindex = 0; sampindex < dst.samples(); sampindex++)
|
||||||
{
|
{
|
||||||
*dst++ = *src - memory;
|
dst.put(sampindex, src.get(sampindex) - memory);
|
||||||
memory += ((*src++ - memory) * m_k) / 0x10000;
|
memory += (src.get(sampindex) - memory) * m_k;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -93,8 +100,8 @@ void filter_rc_device::recalc()
|
|||||||
if (m_C == 0.0)
|
if (m_C == 0.0)
|
||||||
{
|
{
|
||||||
/* filter disabled */
|
/* filter disabled */
|
||||||
m_k = 0x10000;
|
m_k = 1.0;
|
||||||
m_memory = 0x0;
|
m_memory = 0;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
Req = (m_R1 * (m_R2 + m_R3)) / (m_R1 + m_R2 + m_R3);
|
Req = (m_R1 * (m_R2 + m_R3)) / (m_R1 + m_R2 + m_R3);
|
||||||
@ -103,8 +110,8 @@ void filter_rc_device::recalc()
|
|||||||
if (m_C == 0.0)
|
if (m_C == 0.0)
|
||||||
{
|
{
|
||||||
/* filter disabled */
|
/* filter disabled */
|
||||||
m_k = 0x10000;
|
m_k = 1.0;
|
||||||
m_memory = 0x0;
|
m_memory = 0;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
Req = m_R1;
|
Req = m_R1;
|
||||||
@ -114,8 +121,8 @@ void filter_rc_device::recalc()
|
|||||||
if (m_C == 0.0)
|
if (m_C == 0.0)
|
||||||
{
|
{
|
||||||
/* filter disabled */
|
/* filter disabled */
|
||||||
m_k = 0x0;
|
m_k = 0;
|
||||||
m_memory = 0x0;
|
m_memory = 0;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
Req = m_R1;
|
Req = m_R1;
|
||||||
@ -126,5 +133,5 @@ void filter_rc_device::recalc()
|
|||||||
|
|
||||||
/* Cut Frequency = 1/(2*Pi*Req*C) */
|
/* Cut Frequency = 1/(2*Pi*Req*C) */
|
||||||
/* k = (1-(EXP(-TIMEDELTA/RC))) */
|
/* k = (1-(EXP(-TIMEDELTA/RC))) */
|
||||||
m_k = 0x10000 - 0x10000 * (exp(-1 / (Req * m_C) / machine().sample_rate()));
|
m_k = 1.0 - exp(-1 / (Req * m_C) / m_stream->sample_rate());
|
||||||
}
|
}
|
||||||
|
@ -95,7 +95,7 @@ public:
|
|||||||
{
|
{
|
||||||
m_stream->update();
|
m_stream->update();
|
||||||
set_rc(type, R1, R2, R3, C);
|
set_rc(type, R1, R2, R3, C);
|
||||||
recalc();
|
m_last_sample_rate = 0;
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -109,16 +109,17 @@ protected:
|
|||||||
virtual void device_start() override;
|
virtual void device_start() override;
|
||||||
|
|
||||||
// sound stream update overrides
|
// sound stream update overrides
|
||||||
virtual void sound_stream_update_legacy(sound_stream &stream, stream_sample_t const * const *inputs, stream_sample_t * const *outputs, int samples) override;
|
virtual void sound_stream_update(sound_stream &stream, std::vector<read_stream_view> const &inputs, std::vector<write_stream_view> &outputs) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void recalc();
|
void recalc();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
sound_stream* m_stream;
|
sound_stream* m_stream;
|
||||||
int m_k;
|
stream_buffer::sample_t m_k;
|
||||||
int m_memory;
|
stream_buffer::sample_t m_memory;
|
||||||
int m_type;
|
int m_type;
|
||||||
|
int m_last_sample_rate;
|
||||||
double m_R1;
|
double m_R1;
|
||||||
double m_R2;
|
double m_R2;
|
||||||
double m_R3;
|
double m_R3;
|
||||||
|
@ -27,21 +27,19 @@ filter_volume_device::filter_volume_device(const machine_config &mconfig, const
|
|||||||
void filter_volume_device::device_start()
|
void filter_volume_device::device_start()
|
||||||
{
|
{
|
||||||
m_gain = 0x100;
|
m_gain = 0x100;
|
||||||
m_stream = stream_alloc_legacy(1, 1, machine().sample_rate());
|
m_stream = stream_alloc(1, 1, SAMPLE_RATE_OUTPUT_ADAPTIVE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//-------------------------------------------------
|
//-------------------------------------------------
|
||||||
// sound_stream_update_legacy - handle a stream update
|
// sound_stream_update - handle a stream update
|
||||||
//-------------------------------------------------
|
//-------------------------------------------------
|
||||||
|
|
||||||
void filter_volume_device::sound_stream_update_legacy(sound_stream &stream, stream_sample_t const * const *inputs, stream_sample_t * const *outputs, int samples)
|
void filter_volume_device::sound_stream_update(sound_stream &stream, std::vector<read_stream_view> const &inputs, std::vector<write_stream_view> &outputs)
|
||||||
{
|
{
|
||||||
stream_sample_t const *src = inputs[0];
|
// no need to work here; just copy input stream to output and apply gain
|
||||||
stream_sample_t *dst = outputs[0];
|
outputs[0] = inputs[0];
|
||||||
|
outputs[0].apply_gain(m_gain);
|
||||||
while (samples--)
|
|
||||||
*dst++ = (*src++ * m_gain) >> 8;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -49,5 +47,5 @@ void filter_volume_device::sound_stream_update_legacy(sound_stream &stream, stre
|
|||||||
void filter_volume_device::flt_volume_set_volume(float volume)
|
void filter_volume_device::flt_volume_set_volume(float volume)
|
||||||
{
|
{
|
||||||
m_stream->update();
|
m_stream->update();
|
||||||
m_gain = int(volume * 256);
|
m_gain = volume;
|
||||||
}
|
}
|
||||||
|
@ -24,11 +24,11 @@ protected:
|
|||||||
virtual void device_start() override;
|
virtual void device_start() override;
|
||||||
|
|
||||||
// sound stream update overrides
|
// sound stream update overrides
|
||||||
virtual void sound_stream_update_legacy(sound_stream &stream, stream_sample_t const * const *inputs, stream_sample_t * const *outputs, int samples) override;
|
virtual void sound_stream_update(sound_stream &stream, std::vector<read_stream_view> const &inputs, std::vector<write_stream_view> &outputs) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
sound_stream* m_stream;
|
sound_stream* m_stream;
|
||||||
int m_gain;
|
stream_buffer::sample_t m_gain;
|
||||||
};
|
};
|
||||||
|
|
||||||
DECLARE_DEVICE_TYPE(FILTER_VOLUME, filter_volume_device)
|
DECLARE_DEVICE_TYPE(FILTER_VOLUME, filter_volume_device)
|
||||||
|
Loading…
Reference in New Issue
Block a user