jack: initialize JackData in jack_initDriver()
Over the lifetime of the jack AudioOutput object, we want a single valid JackData object, so we can persistently store data there (configuration etc.). Allocate JackData in jack_initDriver(). After that, we can safely remove all audioOutput->data==NULL checks (and replace them with assertions).
This commit is contained in:
parent
83215bf9ce
commit
806a9f02a1
@ -205,7 +205,7 @@ static int jack_initDriver(AudioOutput *audioOutput, ConfigParam *param)
|
|||||||
int val;
|
int val;
|
||||||
char *cp = NULL;
|
char *cp = NULL;
|
||||||
|
|
||||||
audioOutput->data = NULL;
|
audioOutput->data = newJackData();
|
||||||
|
|
||||||
DEBUG("jack_initDriver (pid=%d)\n", getpid());
|
DEBUG("jack_initDriver (pid=%d)\n", getpid());
|
||||||
if ( ! param ) return 0;
|
if ( ! param ) return 0;
|
||||||
@ -345,11 +345,7 @@ static int jack_openDevice(AudioOutput *audioOutput)
|
|||||||
{
|
{
|
||||||
JackData *jd = audioOutput->data;
|
JackData *jd = audioOutput->data;
|
||||||
|
|
||||||
if ( !jd ) {
|
assert(jd != NULL);
|
||||||
DEBUG("connect!\n");
|
|
||||||
jd = newJackData();
|
|
||||||
audioOutput->data = jd;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (jd->client == NULL && connect_jack(audioOutput) < 0) {
|
if (jd->client == NULL && connect_jack(audioOutput) < 0) {
|
||||||
freeJackClient(jd);
|
freeJackClient(jd);
|
||||||
|
Loading…
Reference in New Issue
Block a user