virtual_oss(8): Make sndstat FD global

There is no reason to have per-profile copies, plus this way we open
/dev/sndstat multiple times if more than 1 profile is created.

Also close the FD on exit to avoid leaking.

Sponsored by:	The FreeBSD Foundation
MFC after:	1 week
Reviewed by:	jrm
Pull-Request:	https://ron-dev.freebsd.org/FreeBSD/src/pulls/41
This commit is contained in:
Christos Margiolis
2026-06-09 15:36:48 +02:00
parent 0bd5ef6b43
commit 93a234a694
2 changed files with 9 additions and 8 deletions
-1
View File
@@ -144,7 +144,6 @@ struct virtual_profile {
double rx_compressor_gain[VMAX_CHAN];
uint8_t synchronized;
uint32_t rec_delay;
int fd_sta;
struct {
const char * host;
const char * port;
+9 -7
View File
@@ -1640,6 +1640,7 @@ struct voss_backend *voss_tx_backend;
static int voss_dups;
static int voss_ntds;
static pthread_t *voss_tds;
static int voss_fd_sta = -1;
/* XXX I do not like the prefix argument... */
static struct voss_backend *
@@ -1845,7 +1846,7 @@ init_sndstat(vprofile_t *ptr)
warn("Failed to pack nvlist");
goto done;
}
err = ioctl(ptr->fd_sta, SNDSTIOC_ADD_USER_DEVS, &arg);
err = ioctl(voss_fd_sta, SNDSTIOC_ADD_USER_DEVS, &arg);
free(arg.buf);
if (err != 0) {
warn("Failed to issue ioctl(SNDSTIOC_ADD_USER_DEVS)");
@@ -1912,7 +1913,6 @@ dup_profile(vprofile_t *pvp, int *pamp, int pol, int rx_mute,
memcpy(ptr, pvp, sizeof(*ptr));
ptr->synchronized = synchronized;
ptr->fd_sta = -1;
TAILQ_INIT(&ptr->head);
for (x = 0; x != ptr->channels; x++) {
@@ -1953,12 +1953,13 @@ dup_profile(vprofile_t *pvp, int *pamp, int pol, int rx_mute,
ptr->oss_dev = pdev;
/* register to sndstat */
ptr->fd_sta = open("/dev/sndstat", O_WRONLY);
if (ptr->fd_sta < 0) {
warn("Could not open /dev/sndstat");
} else {
init_sndstat(ptr);
if (voss_fd_sta < 0) {
if ((voss_fd_sta = open("/dev/sndstat", O_WRONLY)) < 0) {
errstr = "Could not open /dev/sndstat";
goto err;
}
}
init_sndstat(ptr);
}
/* create WAV device */
if (ptr->wav_name[0] != 0) {
@@ -2678,6 +2679,7 @@ main(int argc, char **argv)
}
cuse_uninit();
close(voss_fd_sta);
return (0);
}