Skip to content

Commit

Permalink
Fix crash/freezing after rendering when using soundio/JACK (#5681)
Browse files Browse the repository at this point in the history
  • Loading branch information
firewall1110 authored Oct 30, 2020
1 parent ec2e854 commit 435dbc5
Show file tree
Hide file tree
Showing 3 changed files with 36 additions and 5 deletions.
1 change: 1 addition & 0 deletions include/AudioSoundIo.h
Original file line number Diff line number Diff line change
Expand Up @@ -110,6 +110,7 @@ class AudioSoundIo : public AudioDevice
fpp_t m_outBufFrameIndex;

bool m_stopped;
bool m_outstreamStarted;

int m_disconnectErr;
void onBackendDisconnect(int err);
Expand Down
1 change: 1 addition & 0 deletions src/core/audio/AudioJack.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -204,6 +204,7 @@ void AudioJack::startProcessing()
{
if( m_active || m_client == NULL )
{
m_stopped = false;
return;
}

Expand Down
39 changes: 34 additions & 5 deletions src/core/audio/AudioSoundIo.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,7 @@ AudioSoundIo::AudioSoundIo( bool & outSuccessful, Mixer * _mixer ) :
m_outBufFrameIndex = 0;
m_outBufFramesTotal = 0;
m_stopped = true;
m_outstreamStarted = false;

m_soundio = soundio_create();
if (!m_soundio)
Expand Down Expand Up @@ -196,6 +197,12 @@ void AudioSoundIo::onBackendDisconnect(int err)
AudioSoundIo::~AudioSoundIo()
{
stopProcessing();

if (m_outstream)
{
soundio_outstream_destroy(m_outstream);
}

if (m_soundio)
{
soundio_destroy(m_soundio);
Expand All @@ -205,28 +212,50 @@ AudioSoundIo::~AudioSoundIo()

void AudioSoundIo::startProcessing()
{
int err;

m_outBufFrameIndex = 0;
m_outBufFramesTotal = 0;
m_outBufSize = mixer()->framesPerPeriod();

m_outBuf = new surroundSampleFrame[m_outBufSize];

if (! m_outstreamStarted)
{
if ((err = soundio_outstream_start(m_outstream)))
{
fprintf(stderr,
"AudioSoundIo::startProcessing() :: soundio unable to start stream: %s\n",
soundio_strerror(err));
} else {
m_outstreamStarted = true;
}
}

m_stopped = false;
int err;
if ((err = soundio_outstream_start(m_outstream)))

if ((err = soundio_outstream_pause(m_outstream, false)))
{
m_stopped = true;
fprintf(stderr, "soundio unable to start stream: %s\n", soundio_strerror(err));
fprintf(stderr,
"AudioSoundIo::startProcessing() :: resuming result error: %s\n",
soundio_strerror(err));
}
}

void AudioSoundIo::stopProcessing()
{
int err;

m_stopped = true;
if (m_outstream)
{
soundio_outstream_destroy(m_outstream);
m_outstream = NULL;
if (err = soundio_outstream_pause(m_outstream, true))

This comment has been minimized.

Copy link
@tresf

tresf Oct 30, 2020

Member

@firewall1110 I think this needs an extra set of parentheses. Travis-CI is failing with the following:

/home/travis/build/LMMS/lmms/src/core/audio/AudioSoundIo.cpp:253:55: error: suggest parentheses around assignment used as truth value [-Werror=parentheses]
   if (err = soundio_outstream_pause(m_outstream, true))

This comment has been minimized.

Copy link
@firewall1110

firewall1110 via email Oct 30, 2020

Author Contributor

This comment has been minimized.

Copy link
@zonkmachine

zonkmachine Oct 30, 2020

Member

But what should I do now ? PR is merged ...

New fixup PR! :)

This comment has been minimized.

Copy link
@tresf

tresf Oct 31, 2020

Member

@firewall1110 I'll patch master directly.

This comment has been minimized.

Copy link
@tresf

tresf Oct 31, 2020

Member

Oh, you beat me to it, thanks!

{
fprintf(stderr,
"AudioSoundIo::stopProcessing() :: pausing result error: %s\n",
soundio_strerror(err));
}
}

if (m_outBuf)
Expand Down

0 comments on commit 435dbc5

Please sign in to comment.