xref: /csrg-svn/sys/kern/tty_tty.c (revision 8522)
1*8522Sroot /*	tty_tty.c	4.11	82/10/13	*/
235Sbill 
335Sbill /*
43117Swnj  * Indirect driver for controlling tty.
54487Swnj  *
64487Swnj  * THIS IS GARBAGE: MUST SOON BE DONE WITH struct inode * IN PROC TABLE.
735Sbill  */
835Sbill #include "../h/param.h"
935Sbill #include "../h/systm.h"
1035Sbill #include "../h/conf.h"
1135Sbill #include "../h/dir.h"
1235Sbill #include "../h/user.h"
1335Sbill #include "../h/tty.h"
1435Sbill #include "../h/proc.h"
157824Sroot #include "../h/uio.h"
1635Sbill 
1735Sbill /*ARGSUSED*/
1835Sbill syopen(dev, flag)
1935Sbill {
2035Sbill 
215576Swnj 	if (u.u_ttyp == NULL) {
2235Sbill 		u.u_error = ENXIO;
2335Sbill 		return;
2435Sbill 	}
2535Sbill 	(*cdevsw[major(u.u_ttyd)].d_open)(u.u_ttyd, flag);
2635Sbill }
2735Sbill 
2835Sbill /*ARGSUSED*/
297824Sroot syread(dev, uio)
307824Sroot 	dev_t dev;
317824Sroot 	struct uio *uio;
3235Sbill {
3335Sbill 
34*8522Sroot 	if (u.u_ttyp == NULL)
35*8522Sroot 		return (ENXIO);
36*8522Sroot 	return ((*cdevsw[major(u.u_ttyd)].d_read)(u.u_ttyd, uio));
3735Sbill }
3835Sbill 
3935Sbill /*ARGSUSED*/
407824Sroot sywrite(dev, uio)
417824Sroot 	dev_t dev;
427824Sroot 	struct uio *uio;
4335Sbill {
4435Sbill 
45*8522Sroot 	if (u.u_ttyp == NULL)
46*8522Sroot 		return (ENXIO);
47*8522Sroot 	return ((*cdevsw[major(u.u_ttyd)].d_write)(u.u_ttyd, uio));
4835Sbill }
4935Sbill 
5035Sbill /*ARGSUSED*/
5135Sbill syioctl(dev, cmd, addr, flag)
525618Sroot 	dev_t dev;
535618Sroot 	int cmd;
545618Sroot 	caddr_t addr;
555618Sroot 	int flag;
5635Sbill {
5735Sbill 
585390Swnj 	if (cmd == TIOCNOTTY) {
595390Swnj 		u.u_ttyp = 0;
605390Swnj 		u.u_ttyd = 0;
615390Swnj 		u.u_procp->p_pgrp = 0;
625390Swnj 		return;
635390Swnj 	}
645576Swnj 	if (u.u_ttyp == NULL) {
652305Swnj 		u.u_error = ENXIO;
662305Swnj 		return;
672305Swnj 	}
6835Sbill 	(*cdevsw[major(u.u_ttyd)].d_ioctl)(u.u_ttyd, cmd, addr, flag);
6935Sbill }
704487Swnj 
714487Swnj syselect(dev, flag)
724487Swnj {
734487Swnj 
745576Swnj 	if (u.u_ttyp == NULL) {
754487Swnj 		u.u_error = ENXIO;
765390Swnj 		return (0);
774487Swnj 	}
786385Swnj 	return ((*cdevsw[major(u.u_ttyd)].d_select)(u.u_ttyd, flag));
794487Swnj }
80