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

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

?? psc_fifo_test.c

?? fsmlabs的real time linux的內核
?? C
字號:
/* * (C) Finite State Machine Labs Inc. 2000 business@fsmlabs.com * * Released under the terms of GPL 2. * Open RTLinux makes use of a patented process described in * US Patent 5,995,745. Use of this process is governed * by the Open RTLinux Patent License which can be obtained from * www.fsmlabs.com/PATENT or by sending email to * licensequestions@fsmlabs.com */#include <sys/types.h>#include <sys/stat.h>#include <sys/poll.h>#include <unistd.h>#include <stdio.h>#include <errno.h>#include <fcntl.h>#include <string.h>#include <stdlib.h>/*#include <signal.h>*/#include <rtlinux_signal.h>#define FIFOS_TO_TEST 10/* fifo size params */#define	MIN_SIZE	1#define	MAX_SIZE	65536/* this is set to 32 to make the test go faster; it will test fifos of size 1, * 32, 1024 and 32768 (even though the MAX_SIZE is 65536).  Set this number to * 2 or any other multiple of 2 smaller than 32 to make it be more thorough * and slow; set it to any multiple higher than 32 to make it go faster, but * be less thorough. */#define	MUL_SIZE	2char *construct_filename(int);int stat_test(const char *);int open_test_fail(const char *);int over_write_test(const char *, int);int over_read_test(const char *, int);char *read_test(const char *, int, int);int write_test(const char *, const char *, int, int);int write_read_test(const char *, int);char *get_random_str(int);int sig_handler_setup(void);void my_sahandler(int);int main(void){	int retval;	int test_nr, fifo_size, buf_size;	char *filename, *teststr, *resstr;	/* outer loop to test ALL the FIFOs */	for (test_nr = 0; test_nr < FIFOS_TO_TEST; test_nr += 30) {		if ((filename = construct_filename(test_nr)) == NULL)			return (-1);		fprintf(stderr, "Testing %s ", filename);		if ((stat_test(filename)) != 0) {			free(filename);			return (errno);		}		fprintf(stderr, ". ");		/* attempt to open while the FIFO is not created; this should 		 * fail internally */		if ((open_test_fail(filename)) != 0) {			free(filename);			return (errno);		}		fprintf(stderr, ". ");		/* inner loop to test different FIFO sizes */		for (fifo_size = MIN_SIZE; fifo_size <= MAX_SIZE;		     fifo_size *= MUL_SIZE) {			fprintf(stderr, "- ");			/* now we create the FIFO */			if ((rtf_create(test_nr, fifo_size)) != 0) {				return (-1);			}			/* one last inner loop to test different read/write			 * sizes to/from FIFO */			for (buf_size = 1; buf_size <= fifo_size;			     buf_size *= MUL_SIZE) {				/* write more than the size of the FIFO; should				 * fail internally */				if ((over_write_test(filename, fifo_size))				    != 0) {					rtf_destroy(test_nr);					free(filename);					return (-1);				}				/* read more than the size of the FIFO; should				 * fail internally */				if ((over_read_test(filename, fifo_size))				    != 0) {					rtf_destroy(test_nr);					free(filename);					return (-1);				}				/* get a random string for writing to the				 * FIFO */				if ((teststr = get_random_str(fifo_size))				    == NULL) {					rtf_destroy(test_nr);					free(filename);					return (errno);				}				/* write to the FIFO in buf_size chunks */				if (				    (write_test				     (filename, teststr, buf_size,				      fifo_size)) != 0) {					rtf_destroy(test_nr);					free(filename);					free(teststr);					return (errno);				}				/* and read from the FIFO in buf_size chunks */				if (				    (resstr =				     read_test(filename,					       buf_size,					       fifo_size)) == NULL) {					rtf_destroy(test_nr);					free(filename);					free(teststr);					return (errno);				}				/* compare string written to string read to				 * make sure they are the same */				if (				    (retval = memcmp				     (resstr, teststr, fifo_size)) != 0) {					fprintf(stderr,						"strings not the same: %s\t%s!\n",						resstr, teststr);					rtf_destroy(test_nr);					free(filename);					free(teststr);					free(resstr);					return (-1);				}				free(teststr);				free(resstr);				/* and do one last write/read test which				 * does its own internal string generation				 * and comparison */				if ((write_read_test(filename, buf_size))				    != 0) {					rtf_destroy(test_nr);					free(filename);					return (errno);				}			}	/* END buf_size loop */			/* now we try to unload the module */			if ((rtf_destroy(test_nr)) != 0) {				free(filename);				return (-1);			}			fprintf(stderr, "%d ", fifo_size);		}		/* END fifo_size loop */		fprintf(stderr, "passed.\n");		free(filename);	}			/* END all FIFOs loop */	/* now try testing to see how big a FIFO we can make */	/* don't do this -Nathan	   i = 1;	   retval = 0;	   while (retval == 0) {	   retval = install_handler(1, i);	   uninstall_handler(mysig);	   i *= 2;	   }	 */	return (0);}char *construct_filename(int i){	char *filename;	if ((filename = (char *) calloc(11, sizeof(char))) == NULL) {		fprintf(stderr, "calloc (11, sizeof (char)): %s\n",			strerror(errno));		return (NULL);	}	if ((snprintf(filename, 11, "/dev/rtf%d", i)) < 0) {		fprintf(stderr, "snprintf (filename, 11, /dev/rtf%d): %s",			i, strerror(errno));		free(filename);		return (NULL);	}	return (filename);}int stat_test(const char *filename){	struct stat file_stats;	if (stat(filename, &file_stats) != 0) {		fprintf(stderr, "stat (%s, &file_stats): %s\n", filename,			strerror(errno));		return (errno);	}	if (!(S_ISCHR(file_stats.st_mode))) {		fprintf(stderr, "%s is not a character device.\n",			filename);		return (-1);	}	return (0);}/* this function assumes the module is not already loaded */int open_test_fail(const char *filename){	int filedes;	if ((filedes = open(filename, O_RDONLY)) > 0) {		fprintf(stderr,			"Opened %s for read without module loaded!\n",			filename);		if ((close(filedes)) != 0) {			fprintf(stderr, "close (%d): %s\n", filedes,				strerror(errno));			return (errno);		}		return (-1);	}	if ((filedes = open(filename, O_WRONLY | O_NONBLOCK)) > 0) {		fprintf(stderr,			"Opened %s for write without module loaded!\n",			filename);		if ((close(filedes)) != 0) {			fprintf(stderr, "close (%d): %s\n", filedes,				strerror(errno));			return (errno);		}		return (-1);	}	if ((filedes = open(filename, O_RDWR)) > 0) {		fprintf(stderr,			"Opened %s for read/write without module loaded!\n",			filename);		if ((close(filedes)) != 0) {			fprintf(stderr, "close (%d): %s\n", filedes,				strerror(errno));			return (errno);		}		return (-1);	}	return (0);}int over_read_test(const char *filename, int size){	int filedes;	int read_size;	char *inbuf;	if ((inbuf = (char *) calloc(size + 1, sizeof(char))) == NULL) {		fprintf(stderr, "calloc (1, %d): %s\n", sizeof(char),			strerror(errno));		return (errno);	}	if ((filedes = open(filename, O_RDONLY | O_NONBLOCK)) < 0) {		fprintf(stderr, "open (%s, O_RDONLY): %s\n", filename,			strerror(errno));		free(inbuf);		return (errno);	}	if ((read_size = read(filedes, inbuf, size + 1)) > size) {		fprintf(stderr, "read %d bytes from %d size FIFO!\n",			read_size, size);		close(filedes);		free(inbuf);		return (-1);	}	free(inbuf);	if ((close(filedes)) != 0) {		fprintf(stderr, "close (%d): %s\n", filedes,			strerror(errno));		return (errno);	}	return (0);}char *read_test(const char *filename, int buf_size, int size){	int filedes;	int read_size;	int inbuf_size;	char *inbuf;	struct pollfd fifo_poll;	read_size = 1;	inbuf_size = 0;	if ((inbuf = (char *) calloc(size, sizeof(char))) == NULL) {		fprintf(stderr, "calloc (1, %d): %s\n", sizeof(char),			strerror(errno));		return (NULL);	}	if ((filedes = open(filename, O_RDONLY | O_NONBLOCK)) < 0) {		fprintf(stderr, "open (%s, O_RDONLY): %s\n", filename,			strerror(errno));		free(inbuf);		return (NULL);	}	/* wait for data to arrive in FIFO */	fifo_poll.fd = filedes;	fifo_poll.events = POLLIN;	if ((poll(&fifo_poll, 1, 5000)) <= 0) {		fprintf(stderr, "poll (&fifo_poll, 1, 5000): %s\n",			strerror(errno));		free(inbuf);		close(filedes);		return (NULL);	}	/* attempt to empty the FIFO buf_size blocks at a time */	while (inbuf_size < size) {		if (		    (read_size =		     read(filedes, inbuf + inbuf_size, buf_size)) < 0) {			fprintf(stderr, "read (%d, inbuf, %d): %s\n",				filedes, buf_size, strerror(errno));			close(filedes);			free(inbuf);			return (NULL);		}		inbuf_size += read_size;	}	if ((close(filedes)) != 0) {		fprintf(stderr, "close (%d): %s\n", filedes,			strerror(errno));		free(inbuf);		return (NULL);	}	return (inbuf);}int over_write_test(const char *filename, int size){	int filedes;	int write_size;	char *outbuf;	if ((outbuf = (char *) calloc(size + 1, sizeof(char))) == NULL) {		fprintf(stderr, "calloc (%d, %d): %s\n", 2 * size,			sizeof(char), strerror(errno));		return (errno);	}	if ((filedes = open(filename, O_WRONLY | O_NONBLOCK)) < 0) {		fprintf(stderr, "open (%s, O_RDONLY): %s\n", filename,			strerror(errno));		free(outbuf);		return (errno);	}	if ((write_size = write(filedes, outbuf, size + 1)) > size) {		fprintf(stderr, "wrote %d bytes to %d size FIFO!\n",			write_size, size);		free(outbuf);		close(filedes);		return (-1);	}	free(outbuf);	if ((close(filedes)) != 0) {		fprintf(stderr, "close (%d): %s\n", filedes,			strerror(errno));		return (errno);	}	return (0);}int write_test(const char *filename, const char *outbuf, int buf_size,	       int size){	int filedes;	int write_size;	int sofar;	struct pollfd fifo_poll;	write_size = 1;	sofar = 0;	if ((filedes = open(filename, O_WRONLY | O_NONBLOCK)) < 0) {		fprintf(stderr, "open (%s, O_RDONLY): %s\n", filename,			strerror(errno));		return (errno);	}	/* attempt to fill the FIFO buf_size chunks at a time */	fifo_poll.fd = filedes;	fifo_poll.events = POLLOUT;	while (sofar < size) {		if ((poll(&fifo_poll, 1, 5000)) <= 0) {			fprintf(stderr, "poll (&fifo_poll, 1, 5000): %s\n",				strerror(errno));			close(filedes);			return (errno);		}		if ((write_size = write(filedes, outbuf + sofar, buf_size))		    < 0) {			fprintf(stderr, "write (%d, outbuf, %d): %s\n",				filedes, buf_size, strerror(errno));			close(filedes);			return (errno);		}		sofar += write_size;	}	if ((close(filedes)) != 0) {		fprintf(stderr, "close (%d): %s\n", filedes,			strerror(errno));		return (errno);	}	return (0);}int write_read_test(const char *filename, int buf_size){	int filedes;	char *outbuf;	char inbuf[buf_size];	struct pollfd fifo_poll;	if ((outbuf = get_random_str(buf_size)) == NULL) {		return (-1);	}	if ((filedes = open(filename, O_RDWR | O_NONBLOCK)) < 0) {		fprintf(stderr, "open (%s, O_RDWR): %s\n", filename,			strerror(errno));		free(outbuf);		return (errno);	}	/* write some stuff to the FIFO */	fifo_poll.fd = filedes;	fifo_poll.events = POLLOUT;	if ((poll(&fifo_poll, 1, 5000)) <= 0) {		fprintf(stderr, "poll (&fifo_poll, 1, 5000): %s\n",			strerror(errno));		free(outbuf);		close(filedes);		return (errno);	}	if ((write(filedes, outbuf, buf_size)) < 0) {		fprintf(stderr, "write (%d, %s, %d): %s\n", filedes,			outbuf, buf_size, strerror(errno));		free(outbuf);		close(filedes);		return (errno);	}	/* wait for data to arrive in FIFO */	fifo_poll.events = POLLIN;	if ((poll(&fifo_poll, 1, 5000)) <= 0) {		fprintf(stderr, "poll (&fifo_poll, 1, 5000): %s\n",			strerror(errno));		free(outbuf);		close(filedes);		return (errno);	}	if ((read(filedes, inbuf, buf_size)) < 0) {		fprintf(stderr, "read (%d, inbuf, %d): %s\n", filedes,			buf_size, strerror(errno));		free(outbuf);		close(filedes);		return (errno);	}	if ((close(filedes)) != 0) {		fprintf(stderr, "close (%d): %s\n", filedes,			strerror(errno));		free(outbuf);		return (errno);	}	/* make sure what we read is the same as what was sent */	if ((memcmp(outbuf, inbuf, buf_size)) != 0) {		fprintf(stderr, "inbuf is not the same as outbuf\n");		free(outbuf);		return (-1);	}	free(outbuf);	return (0);}/* get random bytes from /dev/urandom and put them in a string *//* NOTE: this does NOT return NULL ("\0") terminated strings, so you  * cannot use strlen() on strings that this function returns without * adding your own terminating NULL or changing this function */char *get_random_str(int size){	char *randstr;	int randfile;	if ((randstr = (char *) calloc(size, sizeof(char))) == NULL) {		fprintf(stderr, "calloc (%d, %d): %s\n", size,			sizeof(char), strerror(errno));		return (NULL);	}	if ((randfile = open("/dev/urandom", O_RDONLY | O_NONBLOCK)) < 0) {		fprintf(stderr,			"open (\"/dev/urandom\", O_RDONLY | O_NONBLOCK): %s\n",			strerror(errno));		free(randstr);		return (NULL);	}	if ((read(randfile, randstr, size)) < size) {		fprintf(stderr, "read (randfile, randstr, %d): %s\n", size,			strerror(errno));		free(randstr);		close(randfile);		return (NULL);	}	if ((close(randfile)) != 0) {		fprintf(stderr, "close (%d): %s\n", randfile,			strerror(errno));		free(randstr);		return (NULL);	}	return (randstr);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人黄色片在线观看| 性欧美疯狂xxxxbbbb| 国产一区不卡视频| 久久久久久影视| 国产成人在线观看免费网站| 国产精品免费视频一区| 色av一区二区| 日韩在线播放一区二区| 精品国产青草久久久久福利| 国产成人精品免费一区二区| 中文字幕一区二区三区不卡| 欧美性生交片4| 久久99国产精品免费网站| 中文字幕国产一区二区| 欧美综合在线视频| 精品一区二区三区日韩| 综合网在线视频| 7777精品伊人久久久大香线蕉的| 精品在线播放免费| 中文字幕制服丝袜一区二区三区| 欧美艳星brazzers| 国产一区在线视频| 亚洲精选视频免费看| 欧美电影精品一区二区| 懂色av中文字幕一区二区三区| 一区二区三区欧美亚洲| 亚洲精品在线网站| 色哟哟在线观看一区二区三区| 青青草成人在线观看| 国产精品久久久一本精品| 欧美精品九九99久久| 成人少妇影院yyyy| 日本不卡一区二区三区| 国产精品女人毛片| 欧美一区二区在线播放| 91免费版pro下载短视频| 国内精品不卡在线| 亚洲成人第一页| 中文字幕日韩一区二区| 精品精品国产高清a毛片牛牛 | 国产精品系列在线| 欧美一区二区三区在| 91在线丨porny丨国产| 极品瑜伽女神91| 亚洲午夜久久久久久久久久久| 26uuu成人网一区二区三区| 欧美中文字幕亚洲一区二区va在线| 国产美女一区二区三区| 日欧美一区二区| 亚洲综合一区二区| 中文字幕一区二区三| 久久婷婷一区二区三区| 欧美福利视频导航| 色婷婷av久久久久久久| 成人免费观看视频| 国产成人午夜精品影院观看视频 | 久久精品国内一区二区三区| 亚洲综合图片区| 一区视频在线播放| 欧美国产在线观看| 久久综合五月天婷婷伊人| 91精品国产综合久久久久| 日韩一区二区精品| 欧美午夜精品久久久久久孕妇| 99免费精品视频| 成人99免费视频| 成人av电影免费观看| 成人午夜大片免费观看| 国产99久久久久久免费看农村| 国产综合一区二区| 国产一区二区精品在线观看| 精品一区二区三区视频在线观看| 免费日韩伦理电影| 九九九久久久精品| 国产在线国偷精品产拍免费yy| 久久精品国产99国产精品| 美女www一区二区| 看片的网站亚洲| 国产在线不卡一区| 国产成人午夜99999| 国产v综合v亚洲欧| www.爱久久.com| 99久久国产免费看| 91豆麻精品91久久久久久| 在线日韩一区二区| 在线电影一区二区三区| 56国语精品自产拍在线观看| 欧美一区二区在线播放| 久久亚洲欧美国产精品乐播 | 日本欧洲一区二区| 久久精品国产999大香线蕉| 精品一区二区在线视频| 国产91在线|亚洲| 91玉足脚交白嫩脚丫在线播放| 色综合久久久久| 欧美嫩在线观看| 精品国产乱码久久久久久老虎| 欧美激情一区二区三区蜜桃视频 | 国产欧美日韩在线视频| 中文字幕日韩欧美一区二区三区| 一片黄亚洲嫩模| 免费欧美高清视频| 粉嫩aⅴ一区二区三区四区| 在线亚洲高清视频| 欧美一级视频精品观看| 国产精品网曝门| 一级日本不卡的影视| 美女www一区二区| 97久久超碰国产精品电影| 69av一区二区三区| 日本一区二区三区免费乱视频| 亚洲一区二区三区美女| 国产在线观看一区二区| 在线观看国产91| 久久亚洲综合色一区二区三区| 亚洲免费观看高清完整版在线 | 99久久婷婷国产| 8v天堂国产在线一区二区| 欧美国产亚洲另类动漫| 午夜欧美一区二区三区在线播放| 国产传媒一区在线| 欧美人与z0zoxxxx视频| 亚洲欧洲在线观看av| 喷白浆一区二区| 99v久久综合狠狠综合久久| 欧美成人一区二区三区片免费| 18成人在线观看| 国产一区久久久| 欧美另类变人与禽xxxxx| 欧美韩国日本一区| 美女网站在线免费欧美精品| 一本大道久久a久久综合婷婷| 精品国产凹凸成av人网站| 亚洲午夜电影在线| 成年人午夜久久久| 久久久99久久精品欧美| 午夜精品免费在线观看| 91麻豆国产自产在线观看| 国产午夜精品一区二区| 免费av网站大全久久| 欧美午夜不卡视频| 亚洲丝袜自拍清纯另类| 国产福利一区二区| 精品久久人人做人人爽| 日本中文字幕一区二区有限公司| eeuss国产一区二区三区| 精品久久久久久最新网址| 日韩精品三区四区| 欧美日韩极品在线观看一区| 一区二区三区视频在线观看| av不卡免费在线观看| 国产精品卡一卡二| 国产成人综合亚洲网站| 亚洲精品一区二区三区四区高清| 日韩av一二三| 在线成人小视频| 亚瑟在线精品视频| 欧美午夜电影一区| 亚洲va在线va天堂| 精品视频1区2区3区| 亚洲美女视频在线观看| 97精品国产露脸对白| 中文字幕一区二区三区乱码在线| 成人激情av网| 中文字幕一区二区视频| 成人一道本在线| 国产精品乱码久久久久久| 国产精品影视在线| 国产日本欧洲亚洲| av资源网一区| 亚洲欧美视频一区| 在线免费观看不卡av| 亚洲国产精品久久久久婷婷884| 色综合久久天天| 亚洲主播在线观看| 欧美欧美欧美欧美首页| 琪琪一区二区三区| 精品久久久久久久久久久久久久久久久| 久久电影网电视剧免费观看| 日韩欧美亚洲国产另类| 国模少妇一区二区三区| 日韩精品一区二| 成人午夜免费电影| 亚洲色图丝袜美腿| 7777精品伊人久久久大香线蕉 | 国产亚洲成年网址在线观看| 成人美女视频在线观看| 亚洲欧美日韩国产综合| 欧美久久久一区| 国产一区二区三区不卡在线观看| 国产偷国产偷精品高清尤物| 99久久精品国产一区二区三区| 一区二区在线免费| 日韩一区二区三区视频在线| 国产乱码精品一区二区三区忘忧草| 国产精品区一区二区三区| 欧美午夜片在线观看| 久久超碰97人人做人人爱| 国产精品日日摸夜夜摸av| 欧美三级在线播放|