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

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

?? devname.c

?? openmosix使用工具.mtop, mosmon, mps等。用于控制openmosix。openmosix 使用工具.mtop, mosmon, mps等。用于控制openmosix。openm
?? C
字號:
/* device name <-> number map system optimized for rapid, constant time lookup. * Copyright (C) 1996 Charles Blake, see ../COPYING.LIB for distribution * conditions. * Copyright (C) 1998 Michael K. Johnson */#include <errno.h>#include <stdio.h>#include <stdlib.h>#include <string.h>#include <sys/types.h>#include <sys/stat.h>#include <sys/mman.h>#include <dirent.h>#include <unistd.h>#include <fcntl.h>#define __KERNEL__#include <linux/kdev_t.h>#undef __KERNEL__#define DEVDIR		"/dev"#define DEVTAB		"psdevtab"static char *devtab_paths[] = {    "/etc/" DEVTAB,    "%s/."  DEVTAB,    NULL};#define DEVINITIALMODE	0664#define DEV_MAX_PATH	(5+256)#define DEV_NAME_MAX	8static dev_t major[] = { 2, 3, 4, 5, 19, 20, 22, 23, 24, 25, 32, 33,			46, 47, 48, 49 };#define Nminor		256#define Nmajor		(sizeof(major)/sizeof(dev_t))#define Ndev		(Nmajor*Nminor)#define Ndevtab		(Ndev*DEV_NAME_MAX)static char* devtab;	/* the memory buffer holding all the name strings *//* This macro evaluates to the address into the table of the string of   DEV_NAME_MAX chars for the device with major m, minor n. */#define TAB(m,n) (devtab + (m)*(Nminor*DEV_NAME_MAX) + (n)*DEV_NAME_MAX)static int devtab_initialized = 0;static char* name_to_path(char* name);	/* forward declarations */static int   init_devtab (void);/* Device Name -> Number Map   many-to-one: -1 on failed match.*/dev_t name_to_dev(char* name) {    static struct stat sbuf;    return (stat(name_to_path(name), &sbuf) < 0) ? -1 : sbuf.st_rdev;}/* find m in a[] assuming a is sorted into ascending order *//* in-line linear search placeholder until more majors warrant binary search */static __inline__ int lookup(dev_t m, dev_t* a, int n) {    int k;    for(k=0; k < n && a[k] != m; k++)	;    return (k < n) ? k : -1;}/* Device Number -> Name Map   one-to-many: first directory order match in DEVDIR, "" on failed match.*/char* dev_to_name(dev_t num) {    static char	rval[DEV_NAME_MAX+1];    dev_t m = MAJOR(num), n = MINOR(num), tmp;    if (!devtab_initialized && !init_devtab())	return "";    if ((tmp = lookup(m, major, Nmajor)) == (dev_t)-1)	return "";    strncpy(rval, TAB(tmp,n), DEV_NAME_MAX);    rval[DEV_NAME_MAX] = '\0';    return rval;}static int dev_to_devtab(int);static int init_devtab(void) {    static struct stat sbuf, lbuf;    static int fd;    char **fmt, path[64], *HOME = getenv("HOME") ? getenv("HOME") : "";    for (fmt = devtab_paths; *fmt; fmt++) {	snprintf(path, sizeof path, *fmt, HOME);	lbuf.st_ino = 0; /* initialize for test later */	if (lstat(path, &lbuf) >= 0 && S_ISLNK(lbuf.st_mode))	    /* don't follow symlinks */	    continue;	if ( (fd = open(path, O_RDONLY)) < 0	/* open DEVTAB file */	     || fstat(fd, &sbuf) < 0		/* fstat it */	     || (lbuf.st_ino && (sbuf.st_ino != lbuf.st_ino)) /* race */	     || sbuf.st_nlink > 1		/* hardlink attack */	     || sbuf.st_size != Ndevtab		/* make sure it's the right size */	     || (devtab = mmap(0, Ndevtab, PROT_READ, MAP_SHARED, fd, 0)) == (caddr_t) -1	     || close(fd) == -1)	    {	/* could not open for read, attempt to fix/create */		int oumsk = umask(0);		if (devtab)		    munmap(devtab, Ndevtab);		if (((fd = open(path, O_RDWR|O_TRUNC|O_CREAT, DEVINITIALMODE)) == -1 &&		     (unlink(path), fd = open(path, O_RDWR|O_TRUNC|O_CREAT, DEVINITIALMODE)) == -1)		     || !dev_to_devtab(fd)) {		    close(fd);          /* either both opens failed or the constructor failed */		    unlink(path);	/* in case we created but could not fill a file */		    umask(oumsk);		    continue;		} else {		    devtab_initialized = 1;		    close(fd);		    umask(oumsk);		    return 1;		}	    }	else	    return devtab_initialized = 1;    }    return devtab_initialized;}/* stat every file in DEVDIR saving its basename in devtab[] if it has   a MAJOR(st_rdev) in our list of majors. return 0 on error otherwise 1. */static int dev_to_devtab(int fd) {    static struct stat sbuf;    int i;    dev_t m;    struct dirent* ent;    DIR* dev;        if (!(dev = opendir(DEVDIR))) {	fprintf(stderr, "%s: %s\nCannot generate device number -> name mapping.\n",		DEVDIR, strerror(errno));	return 0;    }    if (!(devtab = malloc(Ndevtab))) {	fprintf(stderr, "%s: could not allocate memory\n", strerror(errno));	return 0;    }    memset((void*)devtab, 0, Ndevtab);    while ((ent = readdir(dev))) {	/* loop over all dirents in DEVDIR */	if (lstat(name_to_path(ent->d_name), &sbuf) < 0	    || !S_ISCHR(sbuf.st_mode))	    /* only look for char special devs */	    continue;			    /* due to overloading of majors */	m = MAJOR(sbuf.st_rdev);	    /* copy name to appropriate spot */	if ((i = lookup(m, major, Nmajor)) != -1)	    strncpy(TAB(i,MINOR(sbuf.st_rdev)), ent->d_name, DEV_NAME_MAX);    }    closedir(dev);    if (write(fd, devtab, Ndevtab) != Ndevtab) /* probably no disk space */	return 0;    return 1;}static char path[DEV_MAX_PATH];static char* name_to_path(char* name) {    static char* Path;    if (!Path) {	strcpy(path, DEVDIR);		/* copy DEVDIR */	path[sizeof(DEVDIR) - 1] = '/';	/* change NUL to '/' */	Path = path + sizeof(DEVDIR);	/* put Path at start of basename */    }    strncpy(Path, name, DEV_MAX_PATH - sizeof(DEVDIR));    return path;}#ifdef TEST_DEVNAMEint main(int argc, char** argv) {	/* usage: cmd [<major> <minor>|<name>] */    dev_t tmp;    if (argc < 2) {	printf("%s: [ maj min... | name ... ]\n", argv[0]);	return 0;    }    if (argv[1][0] >= '0' && argv[1][0] <= '9')	for(argv++ ; argv[0] && argv[1] ; argv+=2)	    printf("%s\n", dev_to_name(MKDEV( atoi(argv[0]), atoi(argv[1]) )));    else	for(argv++ ; *argv ; argv++) {	    tmp = name_to_dev(*argv);	    printf("%d, %d\n", MAJOR(tmp), MINOR(tmp));	}    return 0;}#endif/*Using this program on over 700 files in /dev to perform number->name resolutiontook well under 300 microsecs per device number pair on a Pentium 90.  It issomewhat tough to time because once the 3 pages have been mapped in, the time isalmost zero.  For things like top, this method may even be faster in the longrun.  Those interested can gprof it for me.  This system has the virtue of beingnearly perfectly adaptable to individual systems, self updating when /devchanges and pretty darn fast when it hasn't.  It will be slow for users withoutperms to change the psdevtab file, though.  So this is what I decided wasreasonable.  If the process does not have perms to create or update/etc/psdevtab and it is out of date, we try /tmp/psdevtab.  If /tmp/psdevtab iseither out of date or unreadable (malicious user creates it and chmods it),$HOME/.psdevtab is used.  This secondarily allows for per-user naming of ttys,but is really so that at most one user sees only a single delay per /devmodification.To do the timings I did something like this with zsh:    a=(`ls -l *(%^@/) | awk '{print $5 $6}' | sed 's/,/ /'`);    time ./test $aFinally, for lack of a better file for these to be in, I have collected theold algorithmic device number <-> device name mappings.  Let m = major device number and n = minor device number satisfy:    devno = m<<8 + n , m = devno>>8 , n = devno && 0x00FF, and let    char L[32]="pqrstuvwxyzABCDEFGHIJKLMNOPQRSTU", H[16]="01234567890abcdef";	DEVICE NUMBERS		SPECIAL FILE NAMES  OLD SYSTEM (64 pseudoterminal devices):	m=4:	    n=0..63:	tty + itoa_dec(n+1)	    n=128..191:	pty + L[(n-128)/16] + H[(n-128)%16]	    n=192..255:	tty + L[(n-192)/16] + H[(n-192)%16]  NEW SYSTEM (256/512 pseudoterminal devices):	m=2, n:		pty + L[n/16] + H[n%16]	m=3, n:		tty + L[n/16] + H[n%16]	m=4, n:		tty + itoa_dec(n+1)	m=49, n:	pty + L[16+n/16] + H[n%16]	m=50, n:	tty + L[16+n/16] + H[n%16]  (THE SAME IN EITHER SYSTEM)  CALL-UNIX AND CONTROLLING TERMINAL DEVICES	m=5:	    n=0:	tty	    n=64..128:	cua  + {'0' + (n-64)}  CYCLADES MULTIPORT:	m=19, n:	ttyC + itoa_hex(n)	m=20, n: cub + itoa_hex(n) *//* Re-implementation of old interface with the new generic functions. *//* This does exactly the same thing as name_to_dev only now a full "ttyXX"   specification will work as well.*/int tty_to_dev(char *tty) {    static char pref_name_1[32] = "tty", *pnam1 = pref_name_1 + 3,	        pref_name_2[32] = "cu",  *pnam2 = pref_name_2 + 2;    dev_t num;    if ((num = name_to_dev(tty)) != (dev_t) -1)	/* try tty straight up */	return num;    strncpy(pnam1, tty, 32 - 3);	/* try with "tty" prepended */    if ((num = name_to_dev(pref_name_1)) != (dev_t) -1)	return num;    strncpy(pnam2, tty, 32 - 2);	/* try with "cu" prepended */    if ((num = name_to_dev(pref_name_2)) != (dev_t) -1)	return num;    return -1;		/* no match */}/* new abstraction that can maybe be generalized a little better. */char* abbrev_of_tty(char *tty) {    static char temp[32];		/* return buf: good only until next call */    char *pos = strpbrk(tty, "yu");	/* end of (presumed) prefices: tty*, cu* */    temp[0] = 0;    if (tty && tty[0] && pos && pos[0] && pos[1])	sprintf(temp, "%*.*s", 3, 3, pos + 1);    else	strncpy(temp, " ? ", 31);    return temp;}/* Do in-place modification of the 4-buffer `tty' based upon `dev' */void dev_to_tty(char *tty, int dev) {    char* new = abbrev_of_tty(dev_to_name(dev));    strncpy(tty, new, 4);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一级一区二区| 中文一区二区在线观看| 国产日产欧美一区二区三区| 国产精品亲子伦对白| 亚洲6080在线| 欧美美女一区二区在线观看| 26uuuu精品一区二区| 亚洲一区国产视频| 成人av在线播放网址| 欧美www视频| 日本亚洲三级在线| 欧洲亚洲精品在线| 国产欧美一区二区精品忘忧草| 日本午夜一本久久久综合| 91久久免费观看| 中文字幕不卡的av| 国产精品99久久久久久似苏梦涵| 3d动漫精品啪啪一区二区竹菊 | 大白屁股一区二区视频| 91精品国产高清一区二区三区 | 国产98色在线|日韩| 91精品在线观看入口| 亚洲一区二区精品视频| 色综合亚洲欧洲| 国产精品电影院| fc2成人免费人成在线观看播放 | 欧美午夜免费电影| 中文字幕在线观看不卡| 成人动漫视频在线| 中文字幕不卡一区| 99免费精品视频| 亚洲三级视频在线观看| 日韩欧美国产高清| 天堂va蜜桃一区二区三区| 欧美性猛交xxxx乱大交退制版 | 精品乱人伦一区二区三区| 日本不卡在线视频| 欧美一区二区大片| 毛片一区二区三区| 精品精品欲导航| 国产精品一区二区无线| 国产亚洲精品资源在线26u| 国产精品123| 欧美国产1区2区| 99久久99久久精品免费看蜜桃| 国产精品不卡在线观看| 在线看国产一区二区| 亚洲6080在线| 欧美va在线播放| 高清成人免费视频| 亚洲免费大片在线观看| 337p亚洲精品色噜噜狠狠| 秋霞午夜鲁丝一区二区老狼| 精品免费日韩av| 成人av综合在线| 亚洲综合激情另类小说区| 欧美精品丝袜久久久中文字幕| 蜜桃视频第一区免费观看| 精品久久久久久综合日本欧美| 国产91精品一区二区麻豆亚洲| 国产精品国产三级国产aⅴ无密码| 色噜噜狠狠色综合欧洲selulu| 婷婷一区二区三区| 国产欧美一区二区在线| 色94色欧美sute亚洲线路二| 水野朝阳av一区二区三区| 26uuu国产电影一区二区| 91免费国产视频网站| 奇米精品一区二区三区在线观看| 久久精品这里都是精品| 91蜜桃视频在线| 韩国精品主播一区二区在线观看 | 欧美一区二区女人| 国产91露脸合集magnet| 日韩精品欧美成人高清一区二区| 久久女同性恋中文字幕| 欧美亚洲一区三区| 国产很黄免费观看久久| 亚洲小说春色综合另类电影| 欧美精品一区二区三区视频| 色婷婷久久久综合中文字幕| 久久精品国产成人一区二区三区 | 成人手机电影网| 日本亚洲电影天堂| 亚洲天堂成人在线观看| 精品美女在线播放| 欧美日本一区二区三区| www.在线欧美| 国产高清久久久| 日韩avvvv在线播放| 亚洲图片另类小说| 国产亚洲1区2区3区| 91精品国产色综合久久久蜜香臀| 不卡一区二区在线| 国产精品99久久久久久有的能看| 午夜久久久影院| 亚洲黄色片在线观看| 中文字幕av在线一区二区三区| 欧美绝品在线观看成人午夜影视| 色综合天天综合| 成人禁用看黄a在线| 国产一区91精品张津瑜| 蜜桃视频在线观看一区二区| 图片区小说区区亚洲影院| 亚洲精品免费在线观看| 国产精品国产三级国产普通话99 | 8x8x8国产精品| 91丨porny丨在线| 99久久精品免费看| 成人手机在线视频| 成人丝袜高跟foot| 99亚偷拍自图区亚洲| 菠萝蜜视频在线观看一区| 成人免费毛片app| 成人免费视频视频| va亚洲va日韩不卡在线观看| 成人97人人超碰人人99| 成人在线综合网| 成人黄页在线观看| 99久久久国产精品免费蜜臀| 成人av手机在线观看| 99久久免费精品高清特色大片| av福利精品导航| 色婷婷av一区二区三区软件| 色屁屁一区二区| 色欧美片视频在线观看在线视频| 在线一区二区观看| 欧美日韩在线一区二区| 欧美丰满嫩嫩电影| 精品免费一区二区三区| 久久精品欧美日韩| 中文字幕一区二区三区在线播放 | 黄色精品一二区| 国产在线精品一区二区夜色| 国产经典欧美精品| 91在线视频播放地址| 欧美专区在线观看一区| 91精品在线观看入口| 精品国精品自拍自在线| 亚洲国产岛国毛片在线| 一区二区三区四区在线| 日本伊人色综合网| 福利电影一区二区| 91久久精品国产91性色tv| 欧美一区二区三区四区五区| 国产欧美日韩另类一区| 亚洲综合男人的天堂| 国产在线视频不卡二| 94-欧美-setu| 日韩欧美一区二区久久婷婷| 中文字幕国产一区二区| 亚洲韩国精品一区| 国产毛片精品视频| 欧美熟乱第一页| 国产欧美视频一区二区三区| 亚洲一级不卡视频| 国产精品自拍三区| 欧美亚洲禁片免费| 久久久亚洲午夜电影| 亚洲成人激情综合网| 粉嫩一区二区三区性色av| 欧美日韩成人综合在线一区二区 | 亚洲天天做日日做天天谢日日欢| 视频一区欧美精品| aa级大片欧美| 日韩一区二区不卡| 亚洲美女在线国产| 国产99精品国产| 欧美日韩成人在线一区| 亚洲色图20p| 国产美女精品在线| 欧美一区二区三区四区高清| 中文字幕综合网| 韩国成人精品a∨在线观看| 欧美午夜精品理论片a级按摩| 国产日韩精品久久久| 免费高清在线视频一区·| 在线视频国内自拍亚洲视频| 久久久久久久久久久久久久久99| 午夜精品一区在线观看| 91视频.com| 国产精品久久久久婷婷 | 五月天久久比比资源色| 成人av网站免费| 国产日韩影视精品| 久久草av在线| 91精品国产色综合久久久蜜香臀| 亚洲尤物在线视频观看| jizzjizzjizz欧美| 国产欧美一区二区三区鸳鸯浴| 毛片av一区二区三区| 91精品国产欧美一区二区18| 亚洲宅男天堂在线观看无病毒| 91在线视频观看| 亚洲欧洲性图库| 国产·精品毛片| 久久久久久久综合日本| 国产一区二区三区免费在线观看| 欧美一区二区观看视频| 久久精工是国产品牌吗|