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

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

?? tarlib.c

?? VxWorks BSP框架源代碼包含頭文件和驅動
?? C
?? 第 1 頁 / 共 2 頁
字號:
	    cnt = pCtrl->bFactor - pCtrl->bValid ;	    cnt = min( (ULONG)cnt, nBlocks );	    bcopy( pBuf, (char *) (pCtrl->pBuf + pCtrl->bValid), cnt*TBLOCK );	    pBuf += cnt*TBLOCK;	    nBlocks -= cnt ;	    pCtrl->bValid += cnt ;	    }	if( pCtrl->bValid == pCtrl->bFactor  )	    {	    /* one full blocked buffer, write to tape */	    rc = write( pCtrl->fd, (char *) pCtrl->pBuf,			pCtrl->bFactor*TBLOCK ) ;	    if ( rc == ERROR )		return ERROR ;	    /* adjust count and pointer */	    pCtrl->bValid = 0 ;	    }	} /* while */    return OK;    }/********************************************************************************* tarCreateHdr - build a tar header block ** NOTE:* SunOS tar(5) man page is not accurate, this function* was built using empiric methods with that tar(1) command.* RETURNS: file size in bytes*/LOCAL int tarCreateHdr    (    MT_TAR_SOFT *pCtrl,		/* control structure */    const char  *name,		/* file/dir name */    struct stat *pStat,		/* file stats */    MT_HBLOCK *	pBlk		/* block buffer for header */    )    {    int	chksum;    strncpy( pBlk->dbuf.name, name, NAMSIZ );    if( S_ISDIR(pStat->st_mode) )	{	pStat->st_mode |= 0200 ;	pStat->st_size = 0 ;	}    sprintf( pBlk->dbuf.mode, "%6o ", pStat->st_mode );    sprintf( pBlk->dbuf.uid, "%6o ", pStat->st_uid );    sprintf( pBlk->dbuf.gid, "%6o ", pStat->st_gid );    sprintf( pBlk->dbuf.size, "%11lo ", pStat->st_size );    sprintf( pBlk->dbuf.mtime, "%11lo ", pStat->st_mtime );    pBlk->dbuf.linkflag = '0';    bfill( pBlk->dbuf.chksum, 8, ' ');		/* fill blanks */    chksum = mtChecksum( pBlk->dummy, TBLOCK ) ;    sprintf( pBlk->dbuf.chksum, "%6o", chksum);    return( pStat->st_size );    }/********************************************************************************* tarArchDo - archive a file/dir onto tape (recursive)** Handle one file or one directory, in case of directory,* write the dir entry and recurse.** RETURNS: OK or ERROR.*/LOCAL STATUS tarArchDo    (    MT_TAR_SOFT *pCtrl,		/* control structure */    BOOL	verbose,	/* verbosity flag */    char *	name		/* file/dir name */    )    {    MT_HBLOCK	hblock;		/* header block */    struct stat	st;		/* file/dir stat */    register int rc;    bzero ( (char *) &hblock, sizeof( MT_HBLOCK ) );    if( strlen( name ) >= (NAMSIZ-1))	{	printErr("tar: name too long %s, skip.\n", name );	return ERROR;	}    rc = stat( name, &st );    if ( rc == ERROR)	{	perror("tar: stat error ");	return ERROR ;	}    if ( pCtrl->recurseCnt++ > MAXLEVEL )	{	printErr("tar: nesting too deep, skipping %s\n", name);	goto abort ;	}    if( S_ISDIR(st.st_mode) )	{	char	fn [ NAMSIZ ];	/* subdir name */	register DIR *	pDir;	struct dirent *	pDirEnt ;	/* handle directory */	strncpy( fn, name, NAMSIZ-2 );	strcat( fn, "/" );	/* write directory header block to tape */	tarCreateHdr( pCtrl, fn, &st, &hblock ) ;	if( verbose )	    printErr("tar: writing directory %s\n", name );	if (tarWrtBlks( pCtrl, (char *) &hblock, 1 ) == ERROR )	    {	    perror("tar: error writing header to tape ");	    goto abort;	    }	/* recurse on every directory member */	pDir = opendir( name ) ;	if( pDir == NULL )	    {	    perror((sprintf(fn,"tar: error opening directory %s ", name),fn));	    goto abort;	    }	for( pDirEnt = readdir(pDir); pDirEnt != NULL ;			pDirEnt = readdir(pDir))	    {	    /* Skip the "." and ".." entries */	    if ( strcmp( pDirEnt->d_name, ".") == 0)		continue ;	    if ( strcmp( pDirEnt->d_name, "..") == 0)		continue ;	    /* build the new name by concatenating */	    strncpy( fn, name, NAMSIZ-2 );	    strcat( fn, "/" );	    strcat( fn, pDirEnt->d_name );	    /* recurse ! nesting level of MAXLEVEL maximum */	    (void )tarArchDo( pCtrl, verbose, fn ) ;	    }	closedir( pDir );	}    else if( S_ISREG(st.st_mode) )	{	int		fileFd = -1 ;	register int fileSize ;	register int rc ;	register char *	pFileBuf ;	unsigned bufSize = pCtrl->bFactor*TBLOCK;	unsigned nBlocks = 0 ;	/* handle plain file */	/* write file header to tape */	fileSize = tarCreateHdr( pCtrl, name, &st, &hblock ) ;	/* write the file itself to tape */	pFileBuf = KHEAP_ALLOC( bufSize );	if( pFileBuf == NULL )	    {	    printErr("tar: not enough memory\n" );	    goto abort;	    }	fileFd = open( name, O_RDONLY, 0);	if( fileFd == ERROR )	    {	    perror((sprintf(pFileBuf,"tar: file open error %s, ", name),			pFileBuf));	    KHEAP_FREE(((char *) pFileBuf) ); 	    goto abort;	    }	/* Handle Regular File - calculate number of blocks */	if( fileSize > 0 )	    nBlocks = ( fileSize / TBLOCK ) +  ((fileSize % TBLOCK)? 1 : 0 ) ;	if( verbose )	    printErr("tar: writing file %s, size %d bytes, %d blocks\n",			name, fileSize, nBlocks );	if (tarWrtBlks( pCtrl, (char *) &hblock, 1 ) == ERROR )	    {	    perror("tar: error writing header to tape ");	    KHEAP_FREE(((char *) pFileBuf) ); 	    goto abort;	    }	while( nBlocks > 0 )	    {	    /* try to optimize into direct tape writing here */	    rc = read( fileFd, pFileBuf,		bufSize - (pCtrl->bValid*TBLOCK) ) ;	    if( rc == ERROR )		{		perror((sprintf(pFileBuf,"tar: file read error %s, ", name),			pFileBuf));		rc = 1;		}	    else if( rc == 0 )		{		printErr("tar: file changed size!\n");		rc = 1; 		}	    else		{		/* recalculate read count in blocks */		rc = ( rc / TBLOCK ) +  ((rc % TBLOCK)? 1 : 0 ) ;		}	    /* Now write the file blocks to tape */	    tarWrtBlks( pCtrl, pFileBuf, rc );	    nBlocks -= rc ;	    }/*while*/	close( fileFd );	KHEAP_FREE(((char *) pFileBuf));	} /* end of regular file handling */    else	{	printErr("tar: not a regular file nor a directory %s, skipped\n",		name );	goto abort;	}    pCtrl->recurseCnt --;    return OK;abort:    pCtrl->recurseCnt --;    return ERROR;    }/********************************************************************************* tarArchive - archive named file/dir onto tape in tar format** This function creates a UNIX compatible tar formatted archives* which contain entire file hierarchies from disk file systems.* Files and directories are archived with mode and time information* as returned by stat().** The <tape> argument can be any tape drive device name or a name of any* file that will be created if necessary, and will contain the archive.* If <tape> is set to "-", standard output will be used.* If <tape> is NULL (unspecified from Shell), the default archive file* name stored in global variable <TAPE> will be used.** Each write() of the archive file will be exactly <bfactor>*512 bytes* long, hence on tapes in variable mode, this will be the physical* block size on the tape. With Fixed Mode tapes this is only a performance* matter. If <bfactor> is 0, or unspecified from Shell, it will be set* to the default value of 20.** The <verbose> argument is a boolean, if set to 1, will cause informative* messages to be printed to standard error whenever an action is taken,* otherwise, only errors are reported.** The <name> argument is the path of the hierarchy to be archived.* if NULL (or unspecified from the Shell), the current directory path "."* will be used.  This is the path as seen from the target, not from * the Tornado host.** All informative and error message are printed to standard error.** NOTE* Refrain from specifying absolute path names in <path>, such archives* tend to be either difficult to extract or can cause unexpected* damage to existing files if such exist under the same absolute name.** There is no way of specifying a number of hierarchies to dump.*/STATUS tarArchive    (    char *	pTape,		/* tape device name */    int		bfactor,	/* requested blocking factor */    BOOL	verbose,	/* if TRUE print progress info */    char *	pName		/* file/dir name to archive */    )    {    MT_TAR_SOFT	ctrl;		/* control structure */    STATUS	retval = OK;    /* Set defaults */    if( pTape == NULL )	pTape = TAPE ;    if( bfactor == 0 )	bfactor = 20 ;    if( pName == NULL )	pName = "." ;    if( verbose )	printErr("Archiving to %s\n", pTape );    bzero( (char *)&ctrl, sizeof(ctrl) );    bzero( bZero, sizeof(bZero) );	/* not harmful for reentrancy */    /* Open tape device and initialize control structure */    if( strcmp(pTape, "-") == 0)	ctrl.fd = STD_OUT;    else	ctrl.fd = open( pTape, O_CREAT | O_WRONLY, 0644) ;    if ( ctrl.fd < 0 )	{	printErr("Failed to open tape: %s\n", strerror(errnoGet()) );	return ERROR;	}        ctrl.bValid = 0 ;    ctrl.bFactor = bfactor ;    ctrl.pBuf = KHEAP_ALLOC( bfactor * TBLOCK ) ;    if ( ctrl.pBuf == NULL )	{	printErr("Not enough memory, exiting.\n" );	if ( ctrl.fd != STD_OUT)	    close( ctrl.fd );	return ERROR ;	}    /* all exits from now via goto in order to free the buffer */    retval = tarArchDo( &ctrl, verbose, pName ) ;    /* at end of tape, write at least two zero blocks */    if( verbose )	printErr("tar: writing end of tape.\n");    tarWrtBlks( &ctrl, bZero, 1 );    tarWrtBlks( &ctrl, bZero, 1 );    /* and fill the last blocked block until written to tape */    while( ctrl.bValid > 0 )	tarWrtBlks( &ctrl, bZero, 1 );        if( ctrl.fd != STD_OUT )	close( ctrl.fd );    KHEAP_FREE(((char *) ctrl.pBuf));    return( retval );    }/********************************************************************************* tarTocFile - display one file or directory from tar tape** Called from tarToc for every file/dir found on tape.** RETURNS: OK or ERROR*/LOCAL STATUS tarTocFile    (    MT_TAR_SOFT	*pCtrl,		/* control structure */    MT_HBLOCK	*pBlk		/* header block */    )    {    register	int rc ;    int		sum = -1 ;		/* checksum */    int		size = 0 ;		/* file size in bytes */    int		nblks = 0;		/* file size in TBLOCKs */    int		mode ;    char *	fn ;			/* file/dir name */    /* Check the checksum of this header */    rc = sscanf( pBlk->dbuf.chksum, "%o", &sum ) ;	/* extract checksum */    bfill( pBlk->dbuf.chksum, 8, ' ');		/* fill blanks */    if( mtChecksum( pBlk->dummy, TBLOCK ) != sum )	{	printErr("bad checksum %d != %d\n",		mtChecksum( pBlk->dummy, TBLOCK), sum );	return ERROR;	}    /* Parse all fields of header that we need, and store them safely */    sscanf( pBlk->dbuf.mode, "%o", &mode );    sscanf( pBlk->dbuf.size, "%12o", &size );    fn = pBlk->dbuf.name ;    /* Handle directory */    if( (size == 0) || ( fn[ strlen(fn) - 1 ] == '/' ) )	{	printErr("directory %s.\n", fn );	}    /* Filter out links etc */    if ((pBlk->dbuf.linkflag != '\0') &&    	(pBlk->dbuf.linkflag != '0') &&	(pBlk->dbuf.linkflag != ' '))	{	printErr("we do not support links, %s skipped\n", fn );	return OK;	}    /* Handle Regular File - calculate number of blocks */    if( size > 0 )	nblks = ( size / TBLOCK ) +  ((size % TBLOCK)? 1 : 0 ) ;    printErr("file %s, size %d bytes, %d blocks\n",		fn, size, nblks );    /* Loop until entire file skipped */    while (size > 0)	{	MT_HBLOCK *pBuf;	rc = tarRdBlks( pCtrl, &pBuf, nblks) ;	if ( rc < 0 )	    {	    printErr("error reading tape\n");	    return ERROR;	    }	size -= rc*TBLOCK ;	nblks -= rc ;	}    return( OK );    }/********************************************************************************* tarToc - display all contents of a tar formatted tape** This is a UNIX-tar compatible utility that displays entire* file hierarchies from tar-formatted media, e.g. tape.** The <tape> argument may be any tape device name or file name* that contains a tar formatted archive. If <tape> is equal "-",* standard input is used. If <tape> is NULL (or unspecified from Shell)* the default archive file name stored in global variable <TAPE> is used.** The <bfactor> dictates the blocking factor the tape was written with.* If 0, or unspecified from Shell, default of 20 is used.** Archive contents are displayed on standard output, while* all informative and eror message are printed to standard error.**/STATUS tarToc    (    char *	tape,		/* tape device name */    int		bfactor 	/* requested blocking factor */    )    {    register 	int rc ;		/* return codes */    MT_TAR_SOFT	ctrl ;		/* control structure */    STATUS	retval = OK;    /* Set defaults */    if( tape == NULL )	tape = TAPE ;    if( bfactor == 0 )	bfactor = 20 ;    printErr("Contents from %s\n", tape );    bzero( (char *)&ctrl, sizeof(ctrl) );    bzero( bZero, sizeof(bZero) );	/* not harmful for reentrancy */    /* Open tape device and initialize control structure */    if( strcmp(tape, "-") == 0)	ctrl.fd = STD_IN;    else	ctrl.fd = open( tape, O_RDONLY, 0) ;    if ( ctrl.fd < 0 )	{	printErr("Failed to open tape: %s\n", strerror(errnoGet()) );	return ERROR;	}        ctrl.bFactor = bfactor ;    ctrl.pBuf = KHEAP_ALLOC( bfactor * TBLOCK ) ;    if ( ctrl.pBuf == NULL )	{	printErr("Not enough memory, exiting.\n" );	if ( ctrl.fd != STD_IN )	    close( ctrl.fd );	return ERROR ;	}    /* all exits from now via goto in order to free the buffer */    /* Read the first block and adjust blocking factor */    rc = read( ctrl.fd, ctrl.pBuf->dummy, ctrl.bFactor*TBLOCK ) ;    if ( rc == ERROR )	{	printErr("read error at the beginning of tape, exiting.\n" );	retval = ERROR ;	goto finish;	}    else if( rc == 0 )	{	printErr("empty tape file, exiting.\n" );	goto finish;	}    else if( (rc % TBLOCK) != 0 )	{	printErr("tape block not multiple of %d, exiting.\n", TBLOCK);	retval = ERROR ;	goto finish;	}    ctrl.bValid = rc / TBLOCK ;    ctrl.pBnext = ctrl.pBuf ;    if ( ctrl.bFactor != ctrl.bValid )	{	printErr("adjusting blocking factor to %d\n", ctrl.bValid );	ctrl.bFactor = ctrl.bValid ;	}    /* End of overture, start processing files until end of tape */    FOREVER	{	MT_HBLOCK *	pBlk ;	if ( tarRdBlks( &ctrl, &pBlk, 1) != 1 )	    {	    retval = ERROR ;	    goto finish;	    }	if ( bcmp( pBlk->dummy, bZero, TBLOCK) == 0 )	    {	    printErr("end of tape encountered, read until eof...\n");	    while( tarRdBlks( &ctrl, &pBlk, 1) > 0) ;	    printErr("done.\n");	    retval = OK ;	    goto finish;	    }	if ( tarTocFile( &ctrl, pBlk) == ERROR )	    {	    retval = ERROR;	    goto finish;	    }	} /* end of FOREVER */    finish:	if ( ctrl.fd != STD_IN )	    close( ctrl.fd );	KHEAP_FREE((char *) ctrl.pBuf );	return( retval );    }/* End of File */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美国产一区二区在线观看| 亚洲精品水蜜桃| 色婷婷香蕉在线一区二区| 青青草国产精品亚洲专区无| 中文字幕亚洲欧美在线不卡| 欧美不卡一区二区三区| 欧美三级韩国三级日本三斤| 成人蜜臀av电影| 国产一区二区三区免费在线观看| 亚洲一区在线看| 成人免费一区二区三区视频| 久久久久国产成人精品亚洲午夜| 欧美日韩亚洲不卡| 成人不卡免费av| 激情综合色播激情啊| 午夜伦欧美伦电影理论片| 国产精品国产a| 久久免费的精品国产v∧| 欧美精品一二三区| 色婷婷久久一区二区三区麻豆| 国产1区2区3区精品美女| 精品一区二区三区在线观看| 舔着乳尖日韩一区| 亚洲成人免费视| 亚洲精品视频自拍| 综合欧美亚洲日本| 国产精品国产精品国产专区不片| 久久精品视频一区二区| 欧美成人精品二区三区99精品| 欧美喷潮久久久xxxxx| 欧美视频在线观看一区| 欧美三级在线视频| 欧美亚洲综合网| 欧美视频第二页| 欧美亚洲国产怡红院影院| 一本色道亚洲精品aⅴ| 91麻豆产精品久久久久久 | 丝袜美腿亚洲色图| 一级女性全黄久久生活片免费| 亚洲特级片在线| 自拍偷拍欧美激情| 亚洲精品国产a| 亚洲网友自拍偷拍| 婷婷开心久久网| 美女视频免费一区| 久久99精品久久久久婷婷| 久久精品国产亚洲高清剧情介绍| 久久aⅴ国产欧美74aaa| 狠狠色狠狠色综合| 福利一区二区在线| 99久久精品久久久久久清纯| 91啪亚洲精品| 欧美午夜理伦三级在线观看| 欧美精品久久一区| 日韩精品一区二区三区三区免费| 久久亚洲春色中文字幕久久久| 日本一区二区三区久久久久久久久不 | 美女视频免费一区| 精品一区二区三区蜜桃| 精品一区二区三区视频在线观看| 国产一区二区三区视频在线播放| 粉嫩一区二区三区性色av| 91色婷婷久久久久合中文| 欧美日韩另类国产亚洲欧美一级| 日韩欧美一级二级三级| 久久久99精品免费观看不卡| 日本一区二区不卡视频| 亚洲一区二区三区四区在线| 日韩国产欧美三级| 东方欧美亚洲色图在线| 91极品视觉盛宴| 欧美xxx久久| 国产精品久久久久精k8| 亚洲成人精品一区二区| 极品少妇xxxx精品少妇| 97se亚洲国产综合自在线不卡| 欧美日韩一区二区三区免费看| 日韩女优毛片在线| 国产精品午夜免费| 日韩av不卡一区二区| 粉嫩在线一区二区三区视频| 欧美日韩精品综合在线| 久久色视频免费观看| 亚洲精品自拍动漫在线| 国内成+人亚洲+欧美+综合在线| 99久久久国产精品| 精品国内二区三区| 亚洲另类色综合网站| 韩国毛片一区二区三区| 欧美亚洲综合久久| 亚洲国产精品成人久久综合一区| 午夜精品久久一牛影视| 99综合电影在线视频| 欧美成人video| 亚洲成人激情自拍| 成人18视频日本| 精品国产一区二区三区不卡| 夜夜精品浪潮av一区二区三区| 国产剧情在线观看一区二区| 欧美区一区二区三区| 成人免费视频在线观看| 久久精品国产99久久6| 欧美色倩网站大全免费| 国产精品福利一区二区三区| 精久久久久久久久久久| 欧美群妇大交群中文字幕| 亚洲人成精品久久久久| 国产精品一区二区在线播放| 欧美一区二区在线观看| 亚洲欧美电影一区二区| 成人免费观看av| 久久午夜羞羞影院免费观看| 蜜臀久久99精品久久久画质超高清| 一本色道a无线码一区v| 中文字幕欧美一| 国产成人免费高清| 精品粉嫩超白一线天av| 天堂资源在线中文精品| 色欧美片视频在线观看在线视频| 国产视频在线观看一区二区三区 | 蜜桃视频在线一区| 欧美老人xxxx18| 亚洲一区二区三区中文字幕| 91麻豆精品在线观看| 亚洲三级在线免费| av在线播放成人| 国产精品电影一区二区| 懂色av一区二区夜夜嗨| 日本一区二区三级电影在线观看| 国产精品综合久久| 2024国产精品| 国产大片一区二区| 国产精品欧美精品| 不卡的电影网站| 亚洲欧美一区二区久久| 91蜜桃在线免费视频| 亚洲欧美日韩国产一区二区三区| 91色在线porny| 一区二区三区电影在线播| 在线亚洲精品福利网址导航| 亚洲激情中文1区| 欧美天天综合网| 无码av免费一区二区三区试看| 538在线一区二区精品国产| 日韩电影在线一区| 精品国产一区二区三区久久影院| 国产一区二区三区在线看麻豆| 久久久无码精品亚洲日韩按摩| 国产成人免费视频| 自拍偷自拍亚洲精品播放| 91福利精品视频| 日韩av中文字幕一区二区 | 一区av在线播放| 在线不卡欧美精品一区二区三区| 日精品一区二区三区| 精品乱人伦小说| 不卡的电影网站| 亚洲综合男人的天堂| 欧美一区二区女人| 国产麻豆一精品一av一免费| 中文字幕日韩精品一区| 欧美日韩mp4| 国产福利一区二区| 亚洲美女一区二区三区| 91精品国产欧美一区二区成人| 国产精品一区二区你懂的| 亚洲欧美视频在线观看| 日韩视频一区在线观看| 国产99久久精品| 亚洲va韩国va欧美va精品| 26uuu欧美日本| 91色porny| 精品一区二区三区欧美| 亚洲欧美日韩一区二区| 日韩一区二区免费在线观看| 成人91在线观看| 偷拍与自拍一区| 中文字幕欧美激情一区| 欧美日韩免费电影| 粉嫩13p一区二区三区| 日韩av中文字幕一区二区三区| 国产精品水嫩水嫩| 欧美精品久久天天躁| 成人性视频网站| 日本午夜一本久久久综合| 最新中文字幕一区二区三区| 91精品国产麻豆| 色综合久久88色综合天天 | caoporn国产一区二区| 青青青伊人色综合久久| 亚洲欧美在线高清| 欧美va亚洲va香蕉在线| 欧美专区亚洲专区| 波多野洁衣一区| 蜜臀久久久99精品久久久久久| 亚洲欧美福利一区二区| 国产日韩av一区| 91精品国产综合久久精品图片 | 国产精品免费视频一区| 日韩欧美一区二区视频|