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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? nfsdrv.c

?? Tornado平臺下
?? C
?? 第 1 頁 / 共 4 頁
字號:
    if ((pNfsDev = (NFS_DEV *) KHEAP_ALLOC(sizeof (NFS_DEV) + nfsMaxPath - 1)) 	   == NULL)	return (ERROR);    /* perform an nfs mount of the directory */    if (nfsDirMount (host, fileSystem, &fileHandle) != OK)	{	KHEAP_FREE((char *) pNfsDev);	return (ERROR);	}    /* fill in the nfs device descripter */    (void) strcpy (pNfsDev->host, host);    (void) strcpy (pNfsDev->fileSystem, fileSystem);    bcopy ((char *) &fileHandle, (char *) &pNfsDev->fileHandle, sizeof(nfs_fh));    /*     * If no device name was specified, use the name of the file system     * being mounted.  For instance, if the file system is called "/d0",     * the corresponding nfs device will be named "/d0".     */    if (localName == NULL)	localName = fileSystem;		/* name the same as remote fs */    /* add device to I/O system */    if (iosDevAdd ((DEV_HDR *) pNfsDev, localName, nfsDrvNum) != OK)	{	KHEAP_FREE((char *) pNfsDev);	return (ERROR);	}    return (OK);    }/********************************************************************************* nfsMountAll - mount all file systems exported by a specified host** This routine mounts the file systems exported by the host <pHostName>* which are accessible by <pClientName>. A <pClientName> entry of NULL* will only mount file systems that are accessible by any client. * The nfsMount() routine is called to mount each file system. It creates* a local device for each mount that has the same name as the remote file* system.** If the <quietFlag> setting is FALSE, each file system is printed on* standard output after it is mounted successfully.** RETURNS: OK, or ERROR if any mount fails.** SEE ALSO: nfsMount()*/STATUS nfsMountAll    (    char *pHostName, 	/* name of remote host */    char *pClientName, 	/* name of a client specified in access list, if any */    BOOL quietFlag      /* FALSE = print name of each mounted file system */    )    {    exports	nfsExportBody;    exports 	pExport;    groups 	pGroup;    BOOL	accessFlag;    STATUS	status = OK;    if (nfsExportRead (pHostName, &nfsExportBody) != OK)        return (ERROR);    if (nfsExportBody)        {        /* Attempt to mount each file system in export list */        pExport = nfsExportBody;        while (pExport != NULL)            {            accessFlag = TRUE;      /* Allow mounting if not restricted. */            pGroup = pExport->ex_groups;            if (pGroup != NULL)                {                accessFlag = FALSE;    /* Limit mount to matching clients. */                if (pClientName != NULL)                    {                    /* Check for match with client name. */                    while (!accessFlag && pGroup != NULL)                        {                        if (strcmp (pGroup->gr_name, pClientName))                            pGroup = pGroup->gr_next;                        else                            accessFlag = TRUE;                        }                    }                }            if (accessFlag)                {                if (nfsMount (pHostName, pExport->ex_dir, (char *) NULL) != OK)                    status = ERROR;                else                    {                    if (!quietFlag)                        printf ("%s\n", pExport->ex_dir);                    }                }            pExport = pExport->ex_next;            }	}    nfsExportFree (&nfsExportBody);    return (status);    }/********************************************************************************* nfsDevShow - display the mounted NFS devices** This routine displays the device names and their associated NFS file systems.** EXAMPLE:* .CS*     -> nfsDevShow*     device name          file system*     -----------          -----------*     /yuba1/              yuba:/yuba1*     /wrs1/               wrs:/wrs1* .CE** RETURNS: N/A*/void nfsDevShow (void)    {    char    *fileSysName;    DEV_HDR *pDev0 = NULL;    DEV_HDR *pDev1;    if ((fileSysName = (char *) alloca (nfsMaxPath)) == NULL)	{	printf ("Memory allocation error\n");	return;	}    printf ("%-20.20s %-50.50s\n", "device name", "file system");    printf ("%-20.20s %-50.50s\n", "-----------", "-----------");    /* get entries from the I/O system's device list */    while ((pDev1 = iosNextDevGet (pDev0)) != NULL)	{	if (pDev1->drvNum == nfsDrvNum)	    {	    /* found an nfs device, print information */	    (void) strcpy (fileSysName, ((NFS_DEV *) pDev1)->host);	    (void) strcat (fileSysName, ":");	    (void) strcat (fileSysName, ((NFS_DEV *) pDev1)->fileSystem);	    printf ("%-20.20s %-50.50s\n", pDev1->name, fileSysName);	    }	pDev0 = pDev1;	}    }/********************************************************************************* nfsUnmount - unmount an NFS device** This routine unmounts file systems that were previously mounted via NFS.** RETURNS: OK, or ERROR if <localName> is not an NFS device or cannot* be mounted.* * SEE ALSO: nfsMount()*/STATUS nfsUnmount    (    char *localName     /* local of nfs device */    )    {    FAST NFS_DEV *pNfsDev;    char *dummy;    /* find the device in the I/O system */#ifdef _WRS_VXWORKS_5_X    if ((pNfsDev = (NFS_DEV *) iosDevFind (localName,                                            (char **)&dummy)) == NULL)#else    if ((pNfsDev = (NFS_DEV *) iosDevFind (localName,                                            (const char **)&dummy)) == NULL)#endif /* _WRS_VXWORKS_5_X */        	{	return (ERROR);	}    /* make sure device is an nfs driver and the names match exactly */    if ((pNfsDev->devHdr.drvNum != nfsDrvNum) ||	(strcmp (pNfsDev->devHdr.name, localName) != 0))	{	errnoSet (S_nfsDrv_NOT_AN_NFS_DEVICE);	return (ERROR);	}    /* perform an nfs unmount of the directory */    if (nfsDirUnmount (pNfsDev->host, pNfsDev->fileSystem) == ERROR)	return (ERROR);    /* delete the device from the I/O system */    iosDevDelete ((DEV_HDR *) pNfsDev);    KHEAP_FREE((char *) pNfsDev);    return (OK);    }/********************************************************************************* nfsDevListGet - create list of all the NFS devices in the system** This routine fills the array <nfsDevlist> up to <listSize>, with handles to* NFS devices currently in the system.** RETURNS: The number of entries filled in the <nfsDevList> array.* * SEE ALSO: nfsDevInfoGet()*/int nfsDevListGet    (    unsigned long nfsDevList[],	/* NFS dev list of handles */    int           listSize	/* number of elements available in the list */    )    {    int       numMounted;    DEV_HDR * pDev0 = NULL;    DEV_HDR * pDev1;    /*  Collect information of all the NFS currently mounted.  */    numMounted = 0;    while ((numMounted < listSize) && ((pDev1 = iosNextDevGet (pDev0)) != NULL))        {        if (pDev1->drvNum == nfsDrvNum)            {            /* found an nfs device, save pointer to the device */            nfsDevList [numMounted] = (unsigned long) pDev1;            numMounted++;            }        pDev0 = pDev1;        }    return (numMounted);    }/********************************************************************************* nfsDevInfoGet - read configuration information from the requested NFS device** This routine accesses the NFS device specified in the parameter <nfsDevHandle>* and fills in the structure pointed to by <pnfsInfo>. The calling function * should allocate memory for <pnfsInfo> and for the two character buffers,* 'remFileSys' and 'locFileSys', that are part of <pnfsInfo>. These buffers * should have a size of 'nfsMaxPath'.** RETURNS: OK if <pnfsInfo> information is valid, otherwise ERROR.* * SEE ALSO: nfsDevListGet()*/STATUS nfsDevInfoGet    (    unsigned long   nfsDevHandle,	/* NFS device handle */    NFS_DEV_INFO  * pnfsInfo		/* ptr to struct to hold config info */    )    {    NFS_DEV *pnfsDev;    DEV_HDR *pDev0;    DEV_HDR *pDev1;    if (pnfsInfo == NULL)	return (ERROR);    /* Intialize pointer variables */    pnfsDev = NULL;    pDev0   = NULL;    /* Verify that the device is still in the list of devices */    while ((pDev1 = iosNextDevGet (pDev0)) != NULL)        {        if (pDev1 == (DEV_HDR *) nfsDevHandle)	    {	    pnfsDev = (NFS_DEV *) pDev1;	    break;				/* Found Device */	    }        pDev0 = pDev1;        }     if (pnfsDev != NULL)	{	strcpy (pnfsInfo->hostName,   pnfsDev->host);	strcpy (pnfsInfo->remFileSys, pnfsDev->fileSystem);	strcpy (pnfsInfo->locFileSys, pnfsDev->devHdr.name);	return (OK);	}    return (ERROR);    }/* routines supplied to the I/O system *//********************************************************************************* nfsCreate - create a remote NFS file** Returns an open nfs file descriptor.** Used for creating files only, not directories.* Called only by the I/O system.** To give the file a particular mode (UNIX chmod() style), use nfsOpen().** RETURNS: Pointer to NFS file descriptor, or ERROR.*/LOCAL int nfsCreate    (    NFS_DEV *pNfsDev,   /* pointer to nfs device */    char *fileName,     /* nfs file name (relative to mount point) */    int mode            /* mode (O_RDONLY, O_WRONLY, or O_RDWR) */    )    {    /* file descriptor mode legality is checked for in nfsOpen */    /* don't allow null filenames */    if (fileName [0] == EOS)	{	errnoSet (S_ioLib_NO_FILENAME);	return (ERROR);	}    /* open the file being created,       give the file default UNIX file permissions */    return (nfsOpen (pNfsDev, fileName , O_CREAT | O_TRUNC | mode,                     DEFAULT_FILE_PERM));    }/********************************************************************************* nfsDelete - delete a remote file** Deletes a file on a remote system.* Called only by the I/O system.** RETURNS: OK or ERROR.*/LOCAL int nfsDelete    (    NFS_DEV *pNfsDev,   /* pointer to nfs device */    char *fileName      /* remote file name */    )    {    /* don't allow null filenames */    if (fileName [0] == EOS)	{	errnoSet (S_ioLib_NO_FILENAME);	return (ERROR);	}    return (nfsFileRemove (pNfsDev->host, &pNfsDev->fileHandle, fileName));    }/********************************************************************************* nfsChkFilePerms - check the NFS file permissions with a given permission.** This routine compares the NFS file permissions with a given permission.** This routine is basically designed for nfsOpen() to verify* the target file's permission prior to deleting it due to O_TRUNC.** The parameter "perm" will take 4(read), 2(write), 1(execute), or* combinations of them.** OK means the file has valid permission whichever group is.* FOLLOW_LINK means this path name contains link.  ERROR means* the file doesn't have matched permissions.* * Called only by the I/O system.** RETURNS: OK, FOLLOW_LINK, ERROR*/LOCAL int nfsChkFilePerms    (    NFS_DEV *	pNfsDev,		/* pointer to nfs device */

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品国产乱码久久蜜臀| 国产日韩精品久久久| 日韩欧美精品在线视频| 久久久国产精华| 亚洲欧美精品午睡沙发| 久久99久久精品欧美| 波多野结衣亚洲一区| 欧美夫妻性生活| 国产精品久久久久三级| 视频一区二区不卡| 99精品视频在线免费观看| 欧美一卡2卡3卡4卡| 亚洲私人影院在线观看| 国产在线视频一区二区| 日本大香伊一区二区三区| 久久影院电视剧免费观看| 一区二区三区在线观看网站| 开心九九激情九九欧美日韩精美视频电影| 懂色av一区二区三区蜜臀| 欧美日韩一区二区在线观看视频| 久久蜜桃av一区精品变态类天堂| 亚洲欧美电影院| 成人中文字幕合集| 精品噜噜噜噜久久久久久久久试看| 国产精品国产三级国产专播品爱网 | 91精品国模一区二区三区| 中文av一区特黄| 国产成人一区二区精品非洲| 在线观看亚洲精品| 国产精品久久久久9999吃药| 国产一区二区三区免费观看| 日韩欧美久久久| 丝袜美腿成人在线| 欧美三级乱人伦电影| 亚洲精品久久嫩草网站秘色| www.av亚洲| 国产精品嫩草影院av蜜臀| 国产呦萝稀缺另类资源| 精品区一区二区| 婷婷亚洲久悠悠色悠在线播放| 不卡视频在线看| 国产精品三级视频| 成人免费电影视频| 日本一区二区电影| 99视频国产精品| 国产精品剧情在线亚洲| 成人国产精品视频| 成人欧美一区二区三区黑人麻豆| 国产成人在线影院| 精品精品欲导航| 麻豆精品国产传媒mv男同| 欧美精品第1页| 午夜在线成人av| 日韩欧美一级特黄在线播放| 国产一区二区三区日韩| 中文字幕高清一区| 色综合一区二区| 亚洲综合在线视频| 制服丝袜日韩国产| 精品一区二区三区香蕉蜜桃 | 久久久久国产精品免费免费搜索| 美腿丝袜亚洲色图| 亚洲精品一区二区在线观看| 国产福利不卡视频| 中文字幕一区二区三区视频 | 99久久99久久精品国产片果冻| 亚洲欧美一区二区三区久本道91| 99精品黄色片免费大全| 亚洲图片欧美视频| 欧美成人在线直播| 成人av网址在线| 亚洲风情在线资源站| 日韩精品一区国产麻豆| 丁香五精品蜜臀久久久久99网站 | 亚洲香肠在线观看| 欧美一区三区二区| 国产91丝袜在线播放| 国产精品视频免费看| 欧美另类z0zxhd电影| 国产精品综合二区| 夜夜嗨av一区二区三区网页| 欧美一区日韩一区| 精品一区二区成人精品| 综合激情成人伊人| 欧美日韩三级一区二区| 国产精品一区二区91| 亚洲欧美日韩久久| 日韩精品中文字幕一区二区三区| av一二三不卡影片| 日韩电影在线观看一区| 日本一区二区三级电影在线观看| 欧美日本视频在线| 成人av资源在线| 亚洲成av人片一区二区| 亚洲国产精品二十页| 99精品视频在线观看免费| 天堂一区二区在线| 国产精品国产三级国产普通话蜜臀 | 成人国产视频在线观看| 日韩国产精品久久久| 中文字幕欧美激情| 日韩欧美在线观看一区二区三区| 日本韩国欧美在线| 国产在线精品国自产拍免费| 午夜精品一区二区三区免费视频| 综合网在线视频| 精品粉嫩aⅴ一区二区三区四区| 欧美日韩精品欧美日韩精品一 | 国产精品全国免费观看高清 | 国产精品久久福利| 久久综合av免费| 欧美一区二区三区视频在线 | 精品国产第一区二区三区观看体验| 91捆绑美女网站| 国产成人精品一区二区三区四区| 日日摸夜夜添夜夜添亚洲女人| 综合激情网...| 青青国产91久久久久久 | 欧美成人福利视频| 2欧美一区二区三区在线观看视频| 国产高清在线观看免费不卡| 亚洲一区二区三区四区在线免费观看| 精品福利在线导航| 国产精品国产三级国产普通话三级| 久久综合成人精品亚洲另类欧美| 欧美精品丝袜中出| 欧美一级电影网站| 国内成人精品2018免费看| 国产欧美在线观看一区| 欧美日韩午夜在线视频| 色久综合一二码| 国产精品一区二区91| 亚洲午夜日本在线观看| 欧美日韩在线不卡| xfplay精品久久| 日韩欧美中文字幕一区| 欧美一区二区三区四区五区| 亚洲国产激情av| 亚洲成人av中文| 男女性色大片免费观看一区二区 | 亚洲视频一区二区在线观看| 亚洲色图色小说| 美腿丝袜亚洲色图| 在线观看91精品国产入口| 波多野结衣在线aⅴ中文字幕不卡| 91国模大尺度私拍在线视频| 精品欧美乱码久久久久久| 一区二区三区蜜桃| av成人动漫在线观看| 日韩精品一区国产麻豆| 亚洲精品五月天| 成人在线综合网| 国产亚洲一区二区三区| 首页亚洲欧美制服丝腿| 91黄色小视频| 亚洲一区在线观看免费| 欧亚一区二区三区| 国产精品素人视频| 麻豆精品在线看| 久久久久久久久一| 精品中文av资源站在线观看| 日韩欧美国产wwwww| 久久成人久久爱| 亚洲精品在线观| 成人午夜视频在线| 亚洲另类色综合网站| 日本高清免费不卡视频| 欧美激情一区二区在线| 亚洲电影欧美电影有声小说| 欧美美女bb生活片| 懂色av中文字幕一区二区三区| 久久久久久久久久久黄色| 奇米精品一区二区三区在线观看一| 欧美丰满嫩嫩电影| 懂色av中文字幕一区二区三区| 中文字幕一区二区三区在线播放 | 972aa.com艺术欧美| 亚洲妇女屁股眼交7| 精品国产百合女同互慰| 国产91精品一区二区麻豆亚洲| 亚洲黄色av一区| 日韩va亚洲va欧美va久久| 免费人成黄页网站在线一区二区| 成人av在线影院| 人妖欧美一区二区| 国产日韩三级在线| 欧美日韩一区二区在线观看视频| 国产精品资源在线观看| 国产调教视频一区| 欧美一级黄色大片| 欧美成人vr18sexvr| 欧美www视频| 中文字幕精品一区 | 国产精品色婷婷| 欧美日韩一区二区在线观看| 欧美午夜电影一区| 欧美精品三级日韩久久| 久久久久久影视| 亚洲一区二区三区小说| 久久国产日韩欧美精品|