亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? tty_io.c

?? linux 1.0 源代碼
?? C
?? 第 1 頁 / 共 4 頁
字號:
		{			/*			 * It worked. Mark the vt to switch to and			 * return. The process needs to send us a			 * VT_RELDISP ioctl to complete the switch.			 */			vt_cons[fg_console].vt_newvt = new_console;			return;		}		/*		 * The controlling process has died, so we revert back to		 * normal operation. In this case, we'll also change back		 * to KD_TEXT mode. I'm not sure if this is strictly correct		 * but it saves the agony when the X server dies and the screen		 * remains blanked due to KD_GRAPHICS! It would be nice to do		 * this outside of VT_PROCESS but there is no single process		 * to account for and tracking tty count may be undesirable.		 */		vt_cons[fg_console].vc_mode = KD_TEXT;		clr_vc_kbd_mode(kbd_table + fg_console, VC_RAW);		clr_vc_kbd_mode(kbd_table + fg_console, VC_MEDIUMRAW);		vt_cons[fg_console].vt_mode.mode = VT_AUTO;		vt_cons[fg_console].vt_mode.waitv = 0;		vt_cons[fg_console].vt_mode.relsig = 0;		vt_cons[fg_console].vt_mode.acqsig = 0;		vt_cons[fg_console].vt_mode.frsig = 0;		vt_cons[fg_console].vt_pid = -1;		vt_cons[fg_console].vt_newvt = -1;		/*		 * Fall through to normal (VT_AUTO) handling of the switch...		 */	}	/*	 * Ignore all switches in KD_GRAPHICS+VT_AUTO mode	 */	if (vt_cons[fg_console].vc_mode == KD_GRAPHICS)		return;	complete_change_console(new_console);}void wait_for_keypress(void){	sleep_on(&keypress_wait);}void stop_tty(struct tty_struct *tty){	if (tty->stopped)		return;	tty->stopped = 1;	if (tty->link && tty->link->packet) {		tty->ctrl_status &= ~TIOCPKT_START;		tty->ctrl_status |= TIOCPKT_STOP;		wake_up_interruptible(&tty->link->secondary.proc_list);	}	if (tty->stop)		(tty->stop)(tty);	if (IS_A_CONSOLE(tty->line)) {		set_vc_kbd_led(kbd_table + fg_console, VC_SCROLLOCK);		set_leds();	}}void start_tty(struct tty_struct *tty){	if (!tty->stopped)		return;	tty->stopped = 0;	if (tty->link && tty->link->packet) {		tty->ctrl_status &= ~TIOCPKT_STOP;		tty->ctrl_status |= TIOCPKT_START;		wake_up_interruptible(&tty->link->secondary.proc_list);	}	if (tty->start)		(tty->start)(tty);	TTY_WRITE_FLUSH(tty);	if (IS_A_CONSOLE(tty->line)) {		clr_vc_kbd_led(kbd_table + fg_console, VC_SCROLLOCK);		set_leds();	}}/* Perform OPOST processing.  Returns -1 when the write_q becomes full   and the character must be retried. */static int opost(unsigned char c, struct tty_struct *tty){	if (FULL(&tty->write_q))		return -1;	if (O_OPOST(tty)) {		switch (c) {		case '\n':			if (O_ONLRET(tty))				tty->column = 0;			if (O_ONLCR(tty)) {				if (LEFT(&tty->write_q) < 2)					return -1;				put_tty_queue('\r', &tty->write_q);				tty->column = 0;			}			tty->canon_column = tty->column;			break;		case '\r':			if (O_ONOCR(tty) && tty->column == 0)				return 0;			if (O_OCRNL(tty)) {				c = '\n';				if (O_ONLRET(tty))					tty->canon_column = tty->column = 0;				break;			}			tty->canon_column = tty->column = 0;			break;		case '\t':			if (O_TABDLY(tty) == XTABS) {				if (LEFT(&tty->write_q) < 8)					return -1;				do					put_tty_queue(' ', &tty->write_q);				while (++tty->column % 8);				return 0;			}			tty->column = (tty->column | 7) + 1;			break;		case '\b':			if (tty->column > 0)				tty->column--;			break;		default:			if (O_OLCUC(tty))				c = toupper(c);			if (!iscntrl(c))				tty->column++;			break;		}	}	put_tty_queue(c, &tty->write_q);	return 0;}/* Must be called only when L_ECHO(tty) is true. */static void echo_char(unsigned char c, struct tty_struct *tty){	if (L_ECHOCTL(tty) && iscntrl(c) && c != '\t') {		opost('^', tty);		opost(c ^ 0100, tty);	} else		opost(c, tty);}static void eraser(unsigned char c, struct tty_struct *tty){	enum { ERASE, WERASE, KILL } kill_type;	int seen_alnums;	if (tty->secondary.head == tty->canon_head) {		/* opost('\a', tty); */		/* what do you think? */		return;	}	if (c == ERASE_CHAR(tty))		kill_type = ERASE;	else if (c == WERASE_CHAR(tty))		kill_type = WERASE;	else {		if (!L_ECHO(tty)) {			tty->secondary.head = tty->canon_head;			return;		}		if (!L_ECHOK(tty) || !L_ECHOKE(tty)) {			tty->secondary.head = tty->canon_head;			if (tty->erasing) {				opost('/', tty);				tty->erasing = 0;			}			echo_char(KILL_CHAR(tty), tty);			/* Add a newline if ECHOK is on and ECHOKE is off. */			if (L_ECHOK(tty))				opost('\n', tty);			return;		}		kill_type = KILL;	}	seen_alnums = 0;	while (tty->secondary.head != tty->canon_head) {		c = LAST(&tty->secondary);		if (kill_type == WERASE) {			/* Equivalent to BSD's ALTWERASE. */			if (isalnum(c) || c == '_')				seen_alnums++;			else if (seen_alnums)				break;		}		DEC(tty->secondary.head);		if (L_ECHO(tty)) {			if (L_ECHOPRT(tty)) {				if (!tty->erasing) {					opost('\\', tty);					tty->erasing = 1;				}				echo_char(c, tty);			} else if (!L_ECHOE(tty)) {				echo_char(ERASE_CHAR(tty), tty);			} else if (c == '\t') {				unsigned int col = tty->canon_column;				unsigned long tail = tty->canon_head;				/* Find the column of the last char. */				while (tail != tty->secondary.head) {					c = tty->secondary.buf[tail];					if (c == '\t')						col = (col | 7) + 1;					else if (iscntrl(c)) {						if (L_ECHOCTL(tty))							col += 2;					} else						col++;					INC(tail);				}				/* Now backup to that column. */				while (tty->column > col) {					/* Can't use opost here. */					put_tty_queue('\b', &tty->write_q);					tty->column--;				}			} else {				if (iscntrl(c) && L_ECHOCTL(tty)) {					opost('\b', tty);					opost(' ', tty);					opost('\b', tty);				}				if (!iscntrl(c) || L_ECHOCTL(tty)) {					opost('\b', tty);					opost(' ', tty);					opost('\b', tty);				}			}		}		if (kill_type == ERASE)			break;	}	if (tty->erasing && tty->secondary.head == tty->canon_head) {		opost('/', tty);		tty->erasing = 0;	}}static void isig(int sig, struct tty_struct *tty){	kill_pg(tty->pgrp, sig, 1);	if (!L_NOFLSH(tty)) {		flush_input(tty);		flush_output(tty);	}}static void copy_to_cooked(struct tty_struct * tty){	int c, special_flag;	unsigned long flags;	if (!tty) {		printk("copy_to_cooked: called with NULL tty\n");		return;	}	if (!tty->write) {		printk("copy_to_cooked: tty %d has null write routine\n",		       tty->line);	}	while (1) {		/*		 * Check to see how much room we have left in the		 * secondary queue.  Send a throttle command or abort		 * if necessary.		 */		c = LEFT(&tty->secondary);		if (tty->throttle && (c < SQ_THRESHOLD_LW)		    && !set_bit(TTY_SQ_THROTTLED, &tty->flags))			tty->throttle(tty, TTY_THROTTLE_SQ_FULL);		if (c == 0)			break;		save_flags(flags); cli();		if (!EMPTY(&tty->read_q)) {			c = tty->read_q.buf[tty->read_q.tail];			special_flag = clear_bit(tty->read_q.tail,						 &tty->readq_flags);			INC(tty->read_q.tail);			restore_flags(flags);		} else {			restore_flags(flags);			break;		}		if (special_flag) {			tty->char_error = c;			continue;		}		if (tty->char_error) {			if (tty->char_error == TTY_BREAK) {				tty->char_error = 0;				if (I_IGNBRK(tty))					continue;				/* A break is handled by the lower levels. */				if (I_BRKINT(tty))					continue;				if (I_PARMRK(tty)) {					put_tty_queue('\377', &tty->secondary);					put_tty_queue('\0', &tty->secondary);				}				put_tty_queue('\0', &tty->secondary);				continue;			}			if (tty->char_error == TTY_OVERRUN) {				tty->char_error = 0;				printk("tty%d: input overrun\n", tty->line);				continue;			}			/* Must be a parity or frame error */			tty->char_error = 0;			if (I_IGNPAR(tty)) {				continue;			}			if (I_PARMRK(tty)) {				put_tty_queue('\377', &tty->secondary);				put_tty_queue('\0', &tty->secondary);				put_tty_queue(c, &tty->secondary);			} else				put_tty_queue('\0', &tty->secondary);			continue;		}		if (I_ISTRIP(tty))			c &= 0x7f;		if (!tty->lnext) {			if (c == '\r') {				if (I_IGNCR(tty))					continue;				if (I_ICRNL(tty))					c = '\n';			} else if (c == '\n' && I_INLCR(tty))				c = '\r';		}		if (I_IUCLC(tty) && L_IEXTEN(tty))			c=tolower(c);		if (c == __DISABLED_CHAR)			tty->lnext = 1;		if (L_ICANON(tty) && !tty->lnext) {			if (c == ERASE_CHAR(tty) || c == KILL_CHAR(tty) ||			    (c == WERASE_CHAR(tty) && L_IEXTEN(tty))) {				eraser(c, tty);				continue;			}			if (c == LNEXT_CHAR(tty) && L_IEXTEN(tty)) {				tty->lnext = 1;				if (L_ECHO(tty)) {					if (tty->erasing) {						opost('/', tty);						tty->erasing = 0;					}					if (L_ECHOCTL(tty)) {						opost('^', tty);						opost('\b', tty);					}				}				continue;			}			if (c == REPRINT_CHAR(tty) && L_ECHO(tty) &&			    L_IEXTEN(tty)) {				unsigned long tail = tty->canon_head;				if (tty->erasing) {					opost('/', tty);					tty->erasing = 0;				}				echo_char(c, tty);				opost('\n', tty);				while (tail != tty->secondary.head) {					echo_char(tty->secondary.buf[tail],						  tty);					INC(tail);				}				continue;			}		}		if (I_IXON(tty) && !tty->lnext) {			if ((tty->stopped && I_IXANY(tty) && L_IEXTEN(tty)) ||			    c == START_CHAR(tty)) {				start_tty(tty);				continue;			}			if (c == STOP_CHAR(tty)) {				stop_tty(tty);				continue;			}		}		if (L_ISIG(tty) && !tty->lnext) {			if (c == INTR_CHAR(tty)) {				isig(SIGINT, tty);				continue;			}			if (c == QUIT_CHAR(tty)) {				isig(SIGQUIT, tty);				continue;			}			if (c == SUSP_CHAR(tty)) {				if (!is_orphaned_pgrp(tty->pgrp))					isig(SIGTSTP, tty);				continue;			}		}		if (tty->erasing) {			opost('/', tty);			tty->erasing = 0;		}		if (c == '\n' && !tty->lnext) {			if (L_ECHO(tty) || (L_ICANON(tty) && L_ECHONL(tty)))				opost('\n', tty);		} else if (L_ECHO(tty)) {			/* Don't echo the EOF char in canonical mode.  Sun			   handles this differently by echoing the char and			   then backspacing, but that's a hack. */			if (c != EOF_CHAR(tty) || !L_ICANON(tty) ||			    tty->lnext) {				/* Record the column of first canon char. */				if (tty->canon_head == tty->secondary.head)					tty->canon_column = tty->column;				echo_char(c, tty);			}		}		if (I_PARMRK(tty) && c == (unsigned char) '\377' &&		    (c != EOF_CHAR(tty) || !L_ICANON(tty) || tty->lnext))			put_tty_queue(c, &tty->secondary);		if (L_ICANON(tty) && !tty->lnext &&		    (c == '\n' || c == EOF_CHAR(tty) || c == EOL_CHAR(tty) ||		     (c == EOL2_CHAR(tty) && L_IEXTEN(tty)))) {			if (c == EOF_CHAR(tty))				c = __DISABLED_CHAR;			set_bit(tty->secondary.head, &tty->secondary_flags);			put_tty_queue(c, &tty->secondary);			tty->canon_head = tty->secondary.head;			tty->canon_data++;		} else			put_tty_queue(c, &tty->secondary);		tty->lnext = 0;	}	if (!EMPTY(&tty->write_q))		TTY_WRITE_FLUSH(tty);	if (L_ICANON(tty) ? tty->canon_data : !EMPTY(&tty->secondary))		wake_up_interruptible(&tty->secondary.proc_list);	if (tty->throttle && (LEFT(&tty->read_q) >= RQ_THRESHOLD_HW)	    && clear_bit(TTY_RQ_THROTTLED, &tty->flags))		tty->throttle(tty, TTY_THROTTLE_RQ_AVAIL);}int is_ignored(int sig)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99精品久久只有精品| 欧美日韩国产高清一区二区三区 | 综合婷婷亚洲小说| 欧美一区二区三区电影| 91麻豆国产福利在线观看| 久久国产综合精品| 亚洲福利一区二区三区| 亚洲欧洲日本在线| 久久嫩草精品久久久久| 这里是久久伊人| 在线视频国内自拍亚洲视频| 国产成人精品一区二| 日本一区中文字幕| 亚洲一区二区三区精品在线| 亚洲国产成人在线| 2019国产精品| 日韩精品一区二| 欧美日韩免费观看一区二区三区| 国产.欧美.日韩| 国产在线视频不卡二| 日本va欧美va瓶| 亚洲成人免费在线观看| 亚洲三级在线免费| 综合av第一页| 一色屋精品亚洲香蕉网站| 国产欧美一区二区精品性色超碰| 日韩欧美另类在线| 欧美一区二区国产| 欧美一区二区视频在线观看2022| 欧美日韩精品电影| 欧美三级欧美一级| 欧美猛男超大videosgay| 在线视频观看一区| 色成年激情久久综合| 一本到一区二区三区| 色欧美88888久久久久久影院| 99精品视频在线免费观看| www.日韩精品| 99热99精品| 一本在线高清不卡dvd| 日本乱码高清不卡字幕| 在线一区二区三区做爰视频网站| 91丨porny丨户外露出| 欧美精品乱人伦久久久久久| 欧美日韩国产另类一区| 91精品久久久久久久久99蜜臂| 91精品国产一区二区三区蜜臀| 欧美日韩精品一区二区天天拍小说 | 韩国三级中文字幕hd久久精品| 日本美女视频一区二区| 男女男精品网站| 国产自产高清不卡| 成人av片在线观看| 色呦呦一区二区三区| 欧美日韩大陆一区二区| 欧美一区二区美女| 久久久久国产精品人| 国产精品福利一区二区| 亚洲欧美日韩在线不卡| 亚洲成人av福利| 乱一区二区av| 成人精品免费看| 91麻豆精东视频| 91精品国产综合久久福利| 久久久久88色偷偷免费| 亚洲日本韩国一区| 青青草国产成人av片免费| 国产福利91精品一区| 91美女在线视频| 欧美一区二区三级| 中文一区在线播放| 亚洲国产日韩精品| 国模少妇一区二区三区| 色综合久久精品| 欧美不卡一区二区三区四区| 国产精品亲子乱子伦xxxx裸| 亚洲福利视频一区| 国产露脸91国语对白| 日本电影欧美片| 精品日本一线二线三线不卡| 国产精品毛片久久久久久| 亚洲国产精品久久一线不卡| 国内久久精品视频| 欧美性videosxxxxx| 久久综合狠狠综合久久激情| 夜夜嗨av一区二区三区| 黑人精品欧美一区二区蜜桃| 久久精品这里都是精品| 一区二区三区四区在线| 国模娜娜一区二区三区| 欧美影片第一页| 国产欧美一区二区在线| 日韩和的一区二区| 一本久久精品一区二区| 久久免费视频一区| 日韩国产欧美视频| 色又黄又爽网站www久久| 久久精品视频网| 日本伊人色综合网| 欧美在线观看18| 国产精品女主播在线观看| 蜜臀国产一区二区三区在线播放| 色av综合在线| 欧美国产日韩a欧美在线观看| 日本成人中文字幕| 色偷偷88欧美精品久久久| 国产欧美视频在线观看| 免费在线欧美视频| 欧美日韩精品三区| 综合婷婷亚洲小说| 成人国产精品免费观看视频| 欧美成人aa大片| 青青草国产精品97视觉盛宴| 欧美专区亚洲专区| 亚洲欧美色一区| 成人白浆超碰人人人人| 久久精品人人做| 国产一区二区三区免费看| 91精品国产福利| 亚洲国产色一区| 色噜噜夜夜夜综合网| 亚洲欧洲成人精品av97| 成人av片在线观看| 国产精品国产三级国产专播品爱网| 九一久久久久久| 精品日产卡一卡二卡麻豆| 久久精品国产免费看久久精品| 欧美日韩激情一区| 午夜精品久久久| 欧美欧美午夜aⅴ在线观看| 亚洲高清视频中文字幕| 欧美色精品天天在线观看视频| 亚洲理论在线观看| 在线观看av一区二区| 亚洲国产日韩一级| 欧美另类久久久品| 日本在线不卡一区| 欧美成人性战久久| 国产福利91精品一区二区三区| 国产亚洲精品免费| 成人h精品动漫一区二区三区| 国产精品久久久久一区| 91精品综合久久久久久| 麻豆精品视频在线观看| 欧美精品一区二区三区四区 | 亚洲成av人在线观看| 欧美日韩成人激情| 美国十次了思思久久精品导航| 日韩欧美电影在线| 国产成人午夜高潮毛片| 亚洲日本乱码在线观看| 精品视频一区二区三区免费| 日韩精品一二三四| 2023国产精华国产精品| 不卡的电视剧免费网站有什么| 一区二区三区欧美久久| 91精品午夜视频| 国产成人午夜精品影院观看视频| 中文字幕在线不卡| 欧美美女喷水视频| 韩国v欧美v亚洲v日本v| 成人欧美一区二区三区视频网页 | 精品捆绑美女sm三区| 高清成人免费视频| 一区二区日韩av| 欧美一区二区三区爱爱| 国产精品一区二区视频| 一区二区三区四区视频精品免费| 欧美老肥妇做.爰bbww| 国产一区二区三区视频在线播放| 1区2区3区精品视频| 欧美精品视频www在线观看| 国产精品一区二区在线观看网站 | 欧美色图在线观看| 久久66热偷产精品| 亚洲人被黑人高潮完整版| 欧美电影一区二区三区| 成人免费视频视频| 偷窥国产亚洲免费视频 | 图片区日韩欧美亚洲| 久久久777精品电影网影网| 欧美在线免费观看视频| 久久国产生活片100| 国产精品你懂的| 欧美一区在线视频| 色婷婷激情综合| 国产一区二区三区久久悠悠色av| 亚洲综合色区另类av| 久久伊人蜜桃av一区二区| 欧美午夜电影一区| 国产美女精品一区二区三区| 亚洲小说欧美激情另类| 日本一区二区免费在线| 亚洲激情在线激情| 久久久青草青青国产亚洲免观| 欧美日韩成人在线一区| 99re成人在线| 国产在线观看免费一区| 亚洲电影一级片| 日本一区二区在线不卡|