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

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

?? nfsdrv.c

?? VXWORKS源代碼
?? C
?? 第 1 頁(yè) / 共 4 頁(yè)
字號(hào):
    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
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91麻豆国产福利在线观看| av资源网一区| 亚洲免费观看高清完整版在线| 欧美日韩高清一区二区| 国产福利91精品一区二区三区| 亚洲香肠在线观看| 国产精品电影院| 91精品国产综合久久久久久 | 成人欧美一区二区三区在线播放| 欧美日韩免费一区二区三区 | 亚洲丝袜美腿综合| 精品久久99ma| 在线成人av网站| 色视频成人在线观看免| 国产原创一区二区三区| 日本欧洲一区二区| 亚洲一二三区不卡| 综合色天天鬼久久鬼色| 国产午夜亚洲精品羞羞网站| 3atv在线一区二区三区| 色综合天天综合在线视频| 国产精品伊人色| 久久99精品视频| 日韩国产高清在线| 亚洲国产精品久久人人爱蜜臀| 日本一区二区视频在线观看| 久久综合色一综合色88| 日韩你懂的在线观看| 欧美日本韩国一区二区三区视频| 91色porny| 成年人网站91| 成人av在线网站| 国产不卡在线视频| 国产一区二区美女| 激情另类小说区图片区视频区| 日韩在线观看一区二区| 亚洲午夜一区二区| 亚洲国产日产av| 亚洲一区二区三区免费视频| 亚洲欧美另类久久久精品| 国产精品福利影院| 亚洲欧美一区二区视频| 自拍偷自拍亚洲精品播放| 亚洲欧美综合在线精品| 亚洲欧美偷拍卡通变态| 亚洲综合成人网| 午夜日韩在线电影| 日本va欧美va精品发布| 日本麻豆一区二区三区视频| 蜜臀久久99精品久久久画质超高清 | 欧美日韩综合在线免费观看| 欧美三级电影在线看| 欧美男女性生活在线直播观看| 欧美日韩亚洲不卡| 91超碰这里只有精品国产| 欧美一卡2卡三卡4卡5免费| 91精品国产综合久久精品性色| 欧美一区二区三区视频免费| 欧美不卡一二三| 久久久精品黄色| 亚洲欧美韩国综合色| 亚洲午夜久久久| 热久久一区二区| 国产精品一线二线三线精华| 不卡的av在线播放| 欧美午夜理伦三级在线观看| 日韩午夜激情av| 日本一区二区三区电影| 亚洲欧美激情小说另类| 午夜精品久久久久久久蜜桃app| 三级精品在线观看| 国产一区 二区| 99精品欧美一区二区三区综合在线| 成人白浆超碰人人人人| 欧美午夜影院一区| 日韩欧美久久久| 国产精品视频九色porn| 亚洲国产精品久久不卡毛片| 老司机免费视频一区二区 | 日韩一级黄色大片| 国产丝袜美腿一区二区三区| 亚洲色图欧美在线| 美美哒免费高清在线观看视频一区二区 | 粉嫩欧美一区二区三区高清影视| 在线视频综合导航| 日韩三级中文字幕| 亚洲天堂成人网| 美女性感视频久久| 91亚洲国产成人精品一区二区三| 9191国产精品| 1000部国产精品成人观看| 蜜桃免费网站一区二区三区 | 5566中文字幕一区二区电影| 欧美国产日韩亚洲一区| 性做久久久久久久久| 国产成人免费xxxxxxxx| 欧美日韩精品二区第二页| 久久精品综合网| 亚洲成在人线在线播放| 成人激情午夜影院| 欧美一区二区精品在线| 一区二区三区中文字幕电影| 国产一区二区三区美女| 欧美曰成人黄网| 国产欧美va欧美不卡在线| 日本在线不卡视频一二三区| 9久草视频在线视频精品| 欧美成人精品3d动漫h| 亚洲人亚洲人成电影网站色| 韩日av一区二区| 欧美日韩电影在线播放| 国产精品久久777777| 久久se精品一区二区| 精品视频全国免费看| 国产精品久久久久精k8| 黑人精品欧美一区二区蜜桃| 91精品国产乱码| 亚洲高清免费一级二级三级| 波多野结衣欧美| 久久久久久久电影| 日本va欧美va精品发布| 欧美久久久久中文字幕| 亚洲精品国产无套在线观| av在线这里只有精品| 国产亚洲人成网站| 国内成人免费视频| 日韩一区二区三区电影在线观看| 亚洲福利视频一区| 色欧美乱欧美15图片| 亚洲欧美中日韩| 97久久精品人人澡人人爽| 国产精品乱人伦| 国产馆精品极品| 久久久精品天堂| 国产精品99久久久久久久女警| 精品国产露脸精彩对白| 青草国产精品久久久久久| 日韩亚洲欧美一区| 日韩国产高清在线| 欧美一区二区视频在线观看| 亚洲成年人影院| 欧美日韩电影在线| 日韩精品高清不卡| 日韩一区二区高清| 精品写真视频在线观看 | 国产欧美日韩视频在线观看| 国产在线视频一区二区三区| 精品国产成人在线影院| 国产又黄又大久久| 欧美激情综合五月色丁香| 高清国产午夜精品久久久久久| 久久精品免视看| 高清av一区二区| 亚洲视频一二区| 欧美性一级生活| 日本亚洲天堂网| 精品三级在线观看| 国产成人午夜视频| 国产精品电影一区二区| 在线视频中文字幕一区二区| 日韩精品一卡二卡三卡四卡无卡| 欧美一级欧美三级在线观看| 久久av资源网| 久久久www成人免费无遮挡大片| 国产乱子轮精品视频| 国产精品萝li| 欧美日韩视频在线观看一区二区三区 | 日韩一区二区三区免费看| 久久99这里只有精品| 欧美激情一区二区三区四区| 99精品视频一区二区三区| 一片黄亚洲嫩模| 日韩欧美高清在线| 成人动漫一区二区| 香蕉影视欧美成人| 久久久久久久久久久久久夜| av网站免费线看精品| 一区二区久久久久| 日韩久久免费av| 99国内精品久久| 日韩av一二三| 国产精品久久久一区麻豆最新章节| 欧美在线播放高清精品| 激情六月婷婷综合| 亚洲激情欧美激情| 26uuu亚洲综合色| 色哟哟国产精品| 精品无码三级在线观看视频| 亚洲欧美另类久久久精品2019| 日韩欧美国产系列| 97久久超碰国产精品电影| 免费高清在线一区| 亚洲精品久久久蜜桃| 久久午夜色播影院免费高清| 91福利资源站| 国产白丝精品91爽爽久久| 亚洲va欧美va人人爽| 中文字幕在线不卡视频| 精品999在线播放| 欧美性色欧美a在线播放|