Page MenuHomeFreeBSD

sound: Call vchan_destroy() on vchan_create() failure
AcceptedPublic

Authored by christos on Mon, Dec 23, 9:06 PM.
Tags
None
Referenced Files
Unknown Object (File)
Wed, Jan 8, 9:17 PM
Unknown Object (File)
Wed, Jan 8, 3:33 AM
Unknown Object (File)
Wed, Jan 1, 8:33 PM
Unknown Object (File)
Tue, Dec 31, 6:19 PM
Unknown Object (File)
Thu, Dec 26, 12:49 PM
Unknown Object (File)
Thu, Dec 26, 10:30 AM
Unknown Object (File)
Wed, Dec 25, 4:56 PM
Subscribers

Details

Summary

Sponsored by: The FreeBSD Foundation
MFC after: 1 week

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 61311
Build 58195: arc lint + arc unit

Event Timeline

sys/dev/sound/pcm/vchan.c
815

It looks like vchan_destroy() can fail. Should we assert here that it succeeds?

sys/dev/sound/pcm/vchan.c
815

We can, but I don't think it's important. vchan_destroy() is called once the vchan has been added to the children list, and the parent has CHN_F_BUSY set, so vchan_destroy() cannot fail in this case. I am aware this relies on the assumption that goto fail will always be used after those 2 conditions are met, but the alternative is to essentially duplicate vchan_destroy()'s code.

sys/dev/sound/pcm/vchan.c
815

I think that assumption is subtle enough to warrant an assertion, especially to help catch future mistakes. Assertions cost basically nothing anyway.

sys/dev/sound/pcm/vchan.c
815

Thinking a bit more about it, it might be better to modify vchan_destroy() instead so that it doesn't fail. That is, remove the CHN_F_BUSY check (not sure why we want it in the first place), and run the following block only if the list is not empty:

	if (CHN_EMPTY(parent, children))
		return (EINVAL);

	/* remove us from our parent's children list */
	CHN_REMOVE(parent, c, children);

	if (CHN_EMPTY(parent, children)) {
		parent->flags &= ~(CHN_F_BUSY | CHN_F_HAS_VCHAN);
		chn_reset(parent, parent->format, parent->speed);
	}

IMHO vchan_destroy() should be able to call chn_kill() regardless of whether we've added the vchan to the children list or not.

sys/dev/sound/pcm/vchan.c
815
This revision is now accepted and ready to land.Sat, Dec 28, 4:15 PM