1*b950503fSisaki /*	$NetBSD: audio_component.c,v 1.5 2019/05/08 13:40:19 isaki Exp $	*/
20cb85c34Spooka 
30cb85c34Spooka /*
40cb85c34Spooka  * Copyright (c) 2010 Antti Kantee.  All Rights Reserved.
50cb85c34Spooka  *
60cb85c34Spooka  * Redistribution and use in source and binary forms, with or without
70cb85c34Spooka  * modification, are permitted provided that the following conditions
80cb85c34Spooka  * are met:
90cb85c34Spooka  * 1. Redistributions of source code must retain the above copyright
100cb85c34Spooka  *    notice, this list of conditions and the following disclaimer.
110cb85c34Spooka  * 2. Redistributions in binary form must reproduce the above copyright
120cb85c34Spooka  *    notice, this list of conditions and the following disclaimer in the
130cb85c34Spooka  *    documentation and/or other materials provided with the distribution.
140cb85c34Spooka  *
150cb85c34Spooka  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
160cb85c34Spooka  * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
170cb85c34Spooka  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
180cb85c34Spooka  * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
190cb85c34Spooka  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
200cb85c34Spooka  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
210cb85c34Spooka  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
220cb85c34Spooka  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
230cb85c34Spooka  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
240cb85c34Spooka  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
250cb85c34Spooka  * SUCH DAMAGE.
260cb85c34Spooka  */
270cb85c34Spooka 
280cb85c34Spooka #include <sys/cdefs.h>
29*b950503fSisaki __KERNEL_RCSID(0, "$NetBSD: audio_component.c,v 1.5 2019/05/08 13:40:19 isaki Exp $");
300cb85c34Spooka 
310cb85c34Spooka #include <sys/param.h>
320cb85c34Spooka #include <sys/conf.h>
330cb85c34Spooka #include <sys/device.h>
340cb85c34Spooka #include <sys/mbuf.h>
350cb85c34Spooka #include <sys/stat.h>
360cb85c34Spooka 
37*b950503fSisaki #include <dev/audio/audio_if.h>
380cb85c34Spooka 
39ff225a39Spooka #include <rump-sys/kern.h>
40ff225a39Spooka #include <rump-sys/vfs.h>
410cb85c34Spooka 
RUMP_COMPONENT(RUMP_COMPONENT_DEV)420cb85c34Spooka RUMP_COMPONENT(RUMP_COMPONENT_DEV)
430cb85c34Spooka {
440cb85c34Spooka         extern const struct cdevsw audio_cdevsw;
45f309403eSpgoyette 	extern devmajor_t audio_bmajor, audio_cmajor;
460cb85c34Spooka 	int error;
470cb85c34Spooka 
48f309403eSpgoyette 	if ((error = devsw_attach("audio", NULL, &audio_bmajor,
49f309403eSpgoyette 	    &audio_cdevsw, &audio_cmajor)) != 0)
500cb85c34Spooka 		panic("audio devsw attach failed: %d", error);
510cb85c34Spooka 	if ((error = rump_vfs_makedevnodes(S_IFCHR, "/dev/audio", '0',
52f309403eSpgoyette 	    audio_cmajor, AUDIO_DEVICE, 4)) !=0)
530cb85c34Spooka 		panic("cannot create audio device nodes: %d", error);
5481dfe82fSpooka 	if ((error = rump_vfs_makesymlink("audio0", "/dev/audio")) != 0)
5581dfe82fSpooka 		panic("cannot create audio symlink: %d", error);
560cb85c34Spooka 	if ((error = rump_vfs_makedevnodes(S_IFCHR, "/dev/sound", '0',
57f309403eSpgoyette 	    audio_cmajor, SOUND_DEVICE, 4)) !=0)
580cb85c34Spooka 		panic("cannot create sound device nodes: %d", error);
5981dfe82fSpooka 	if ((error = rump_vfs_makesymlink("sound0", "/dev/sound")) != 0)
6081dfe82fSpooka 		panic("cannot create sound symlink: %d", error);
610cb85c34Spooka 	if ((error = rump_vfs_makedevnodes(S_IFCHR, "/dev/audioctl", '0',
62f309403eSpgoyette 	    audio_cmajor, AUDIOCTL_DEVICE, 4)) !=0)
630cb85c34Spooka 		panic("cannot create audioctl device nodes: %d", error);
6481dfe82fSpooka 	if ((error = rump_vfs_makesymlink("audioctl0", "/dev/audioctl")) != 0)
6581dfe82fSpooka 		panic("cannot create audioctl symlink: %d", error);
660cb85c34Spooka 	if ((error = rump_vfs_makedevnodes(S_IFCHR, "/dev/mixer", '0',
67f309403eSpgoyette 	    audio_cmajor, MIXER_DEVICE, 4)) !=0)
680cb85c34Spooka 		panic("cannot create mixer device nodes: %d", error);
6981dfe82fSpooka 	if ((error = rump_vfs_makesymlink("mixer0", "/dev/mixer")) != 0)
7081dfe82fSpooka 		panic("cannot create mixer symlink: %d", error);
71f309403eSpgoyette 	devsw_detach(NULL, &audio_cdevsw);
720cb85c34Spooka }
73