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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? fw_env.c

?? 最新版的u-boot,2008-10-18發(fā)布
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/* * (C) Copyright 2000-2008 * Wolfgang Denk, DENX Software Engineering, wd@denx.de. * * (C) Copyright 2008 * Guennadi Liakhovetski, DENX Software Engineering, lg@denx.de. * * See file CREDITS for list of people who contributed to this * project. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License as * published by the Free Software Foundation; either version 2 of * the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA */#include <errno.h>#include <fcntl.h>#include <stdio.h>#include <stdlib.h>#include <stddef.h>#include <string.h>#include <sys/types.h>#include <sys/ioctl.h>#include <sys/stat.h>#include <unistd.h>#ifdef MTD_OLD# include <stdint.h># include <linux/mtd/mtd.h>#else# define  __user	/* nothing */# include <mtd/mtd-user.h>#endif#include "fw_env.h"#define	CMD_GETENV	"fw_printenv"#define	CMD_SETENV	"fw_setenv"#define min(x, y) ({				\	typeof(x) _min1 = (x);			\	typeof(y) _min2 = (y);			\	(void) (&_min1 == &_min2);		\	_min1 < _min2 ? _min1 : _min2; })struct envdev_s {	char devname[16];		/* Device name */	ulong devoff;			/* Device offset */	ulong env_size;			/* environment size */	ulong erase_size;		/* device erase size */	ulong env_sectors;		/* number of environment sectors */	uint8_t mtd_type;		/* type of the MTD device */};static struct envdev_s envdevices[2] ={	{		.mtd_type = MTD_ABSENT,	}, {		.mtd_type = MTD_ABSENT,	},};static int dev_current;#define DEVNAME(i)    envdevices[(i)].devname#define DEVOFFSET(i)  envdevices[(i)].devoff#define ENVSIZE(i)    envdevices[(i)].env_size#define DEVESIZE(i)   envdevices[(i)].erase_size#define ENVSECTORS(i) envdevices[(i)].env_sectors#define DEVTYPE(i)    envdevices[(i)].mtd_type#define CONFIG_ENV_SIZE ENVSIZE(dev_current)#define ENV_SIZE      getenvsize()struct env_image_single {	uint32_t	crc;	/* CRC32 over data bytes    */	char		data[];};struct env_image_redundant {	uint32_t	crc;	/* CRC32 over data bytes    */	unsigned char	flags;	/* active or obsolete */	char		data[];};enum flag_scheme {	FLAG_NONE,	FLAG_BOOLEAN,	FLAG_INCREMENTAL,};struct environment {	void			*image;	uint32_t		*crc;	unsigned char		*flags;	char			*data;	enum flag_scheme	flag_scheme;};static struct environment environment = {	.flag_scheme = FLAG_NONE,};static int HaveRedundEnv = 0;static unsigned char active_flag = 1;/* obsolete_flag must be 0 to efficiently set it on NOR flash without erasing */static unsigned char obsolete_flag = 0;#define XMK_STR(x)	#x#define MK_STR(x)	XMK_STR(x)static char default_environment[] = {#if defined(CONFIG_BOOTARGS)	"bootargs=" CONFIG_BOOTARGS "\0"#endif#if defined(CONFIG_BOOTCOMMAND)	"bootcmd=" CONFIG_BOOTCOMMAND "\0"#endif#if defined(CONFIG_RAMBOOTCOMMAND)	"ramboot=" CONFIG_RAMBOOTCOMMAND "\0"#endif#if defined(CONFIG_NFSBOOTCOMMAND)	"nfsboot=" CONFIG_NFSBOOTCOMMAND "\0"#endif#if defined(CONFIG_BOOTDELAY) && (CONFIG_BOOTDELAY >= 0)	"bootdelay=" MK_STR (CONFIG_BOOTDELAY) "\0"#endif#if defined(CONFIG_BAUDRATE) && (CONFIG_BAUDRATE >= 0)	"baudrate=" MK_STR (CONFIG_BAUDRATE) "\0"#endif#ifdef	CONFIG_LOADS_ECHO	"loads_echo=" MK_STR (CONFIG_LOADS_ECHO) "\0"#endif#ifdef	CONFIG_ETHADDR	"ethaddr=" MK_STR (CONFIG_ETHADDR) "\0"#endif#ifdef	CONFIG_ETH1ADDR	"eth1addr=" MK_STR (CONFIG_ETH1ADDR) "\0"#endif#ifdef	CONFIG_ETH2ADDR	"eth2addr=" MK_STR (CONFIG_ETH2ADDR) "\0"#endif#ifdef	CONFIG_ETH3ADDR	"eth3addr=" MK_STR (CONFIG_ETH3ADDR) "\0"#endif#ifdef	CONFIG_ETHPRIME	"ethprime=" CONFIG_ETHPRIME "\0"#endif#ifdef	CONFIG_IPADDR	"ipaddr=" MK_STR (CONFIG_IPADDR) "\0"#endif#ifdef	CONFIG_SERVERIP	"serverip=" MK_STR (CONFIG_SERVERIP) "\0"#endif#ifdef	CFG_AUTOLOAD	"autoload=" CFG_AUTOLOAD "\0"#endif#ifdef	CONFIG_ROOTPATH	"rootpath=" MK_STR (CONFIG_ROOTPATH) "\0"#endif#ifdef	CONFIG_GATEWAYIP	"gatewayip=" MK_STR (CONFIG_GATEWAYIP) "\0"#endif#ifdef	CONFIG_NETMASK	"netmask=" MK_STR (CONFIG_NETMASK) "\0"#endif#ifdef	CONFIG_HOSTNAME	"hostname=" MK_STR (CONFIG_HOSTNAME) "\0"#endif#ifdef	CONFIG_BOOTFILE	"bootfile=" MK_STR (CONFIG_BOOTFILE) "\0"#endif#ifdef	CONFIG_LOADADDR	"loadaddr=" MK_STR (CONFIG_LOADADDR) "\0"#endif#ifdef	CONFIG_PREBOOT	"preboot=" CONFIG_PREBOOT "\0"#endif#ifdef	CONFIG_CLOCKS_IN_MHZ	"clocks_in_mhz=" "1" "\0"#endif#if defined(CONFIG_PCI_BOOTDELAY) && (CONFIG_PCI_BOOTDELAY > 0)	"pcidelay=" MK_STR (CONFIG_PCI_BOOTDELAY) "\0"#endif#ifdef  CONFIG_EXTRA_ENV_SETTINGS	CONFIG_EXTRA_ENV_SETTINGS#endif	"\0"		/* Termimate struct environment data with 2 NULs */};static int flash_io (int mode);static char *envmatch (char * s1, char * s2);static int env_init (void);static int parse_config (void);#if defined(CONFIG_FILE)static int get_config (char *);#endifstatic inline ulong getenvsize (void){	ulong rc = CONFIG_ENV_SIZE - sizeof (long);	if (HaveRedundEnv)		rc -= sizeof (char);	return rc;}/* * Search the environment for a variable. * Return the value, if found, or NULL, if not found. */char *fw_getenv (char *name){	char *env, *nxt;	if (env_init ())		return NULL;	for (env = environment.data; *env; env = nxt + 1) {		char *val;		for (nxt = env; *nxt; ++nxt) {			if (nxt >= &environment.data[ENV_SIZE]) {				fprintf (stderr, "## Error: "					"environment not terminated\n");				return NULL;			}		}		val = envmatch (name, env);		if (!val)			continue;		return val;	}	return NULL;}/* * Print the current definition of one, or more, or all * environment variables */int fw_printenv (int argc, char *argv[]){	char *env, *nxt;	int i, n_flag;	int rc = 0;	if (env_init ())		return -1;	if (argc == 1) {		/* Print all env variables  */		for (env = environment.data; *env; env = nxt + 1) {			for (nxt = env; *nxt; ++nxt) {				if (nxt >= &environment.data[ENV_SIZE]) {					fprintf (stderr, "## Error: "						"environment not terminated\n");					return -1;				}			}			printf ("%s\n", env);		}		return 0;	}	if (strcmp (argv[1], "-n") == 0) {		n_flag = 1;		++argv;		--argc;		if (argc != 2) {			fprintf (stderr, "## Error: "				"`-n' option requires exactly one argument\n");			return -1;		}	} else {		n_flag = 0;	}	for (i = 1; i < argc; ++i) {	/* print single env variables   */		char *name = argv[i];		char *val = NULL;		for (env = environment.data; *env; env = nxt + 1) {			for (nxt = env; *nxt; ++nxt) {				if (nxt >= &environment.data[ENV_SIZE]) {					fprintf (stderr, "## Error: "						"environment not terminated\n");					return -1;				}			}			val = envmatch (name, env);			if (val) {				if (!n_flag) {					fputs (name, stdout);					putc ('=', stdout);				}				puts (val);				break;			}		}		if (!val) {			fprintf (stderr, "## Error: \"%s\" not defined\n", name);			rc = -1;		}	}	return rc;}/* * Deletes or sets environment variables. Returns -1 and sets errno error codes: * 0	  - OK * EINVAL - need at least 1 argument * EROFS  - certain variables ("ethaddr", "serial#") cannot be *	    modified or deleted * */int fw_setenv (int argc, char *argv[]){	int i, len;	char *env, *nxt;	char *oldval = NULL;	char *name;	if (argc < 2) {		errno = EINVAL;		return -1;	}	if (env_init ())		return -1;	name = argv[1];	/*	 * search if variable with this name already exists	 */	for (nxt = env = environment.data; *env; env = nxt + 1) {		for (nxt = env; *nxt; ++nxt) {			if (nxt >= &environment.data[ENV_SIZE]) {				fprintf (stderr, "## Error: "					"environment not terminated\n");				errno = EINVAL;				return -1;			}		}		if ((oldval = envmatch (name, env)) != NULL)			break;	}	/*	 * Delete any existing definition	 */	if (oldval) {		/*		 * Ethernet Address and serial# can be set only once		 */		if ((strcmp (name, "ethaddr") == 0) ||			(strcmp (name, "serial#") == 0)) {			fprintf (stderr, "Can't overwrite \"%s\"\n", name);			errno = EROFS;			return -1;		}		if (*++nxt == '\0') {			*env = '\0';		} else {			for (;;) {				*env = *nxt++;				if ((*env == '\0') && (*nxt == '\0'))					break;				++env;			}		}		*++env = '\0';	}	/* Delete only ? */	if (argc < 3)		goto WRITE_FLASH;	/*	 * Append new definition at the end	 */	for (env = environment.data; *env || *(env + 1); ++env);	if (env > environment.data)		++env;	/*	 * Overflow when:	 * "name" + "=" + "val" +"\0\0"  > CONFIG_ENV_SIZE - (env-environment)	 */	len = strlen (name) + 2;	/* add '=' for first arg, ' ' for all others */	for (i = 2; i < argc; ++i) {		len += strlen (argv[i]) + 1;	}	if (len > (&environment.data[ENV_SIZE] - env)) {		fprintf (stderr,			"Error: environment overflow, \"%s\" deleted\n",			name);		return -1;	}	while ((*env = *name++) != '\0')		env++;	for (i = 2; i < argc; ++i) {		char *val = argv[i];		*env = (i == 2) ? '=' : ' ';		while ((*++env = *val++) != '\0');	}	/* end is marked with double '\0' */	*++env = '\0';  WRITE_FLASH:	/*	 * Update CRC	 */	*environment.crc = crc32 (0, (uint8_t *) environment.data, ENV_SIZE);	/* write environment back to flash */	if (flash_io (O_RDWR)) {		fprintf (stderr, "Error: can't write fw_env to flash\n");		return -1;	}	return 0;}/* * Test for bad block on NAND, just returns 0 on NOR, on NAND: * 0	- block is good * > 0	- block is bad * < 0	- failed to test */static int flash_bad_block (int fd, uint8_t mtd_type, loff_t *blockstart){	if (mtd_type == MTD_NANDFLASH) {		int badblock = ioctl (fd, MEMGETBADBLOCK, blockstart);		if (badblock < 0) {			perror ("Cannot read bad block mark");			return badblock;		}		if (badblock) {#ifdef DEBUG			fprintf (stderr, "Bad block at 0x%llx, "				 "skipping\n", *blockstart);#endif			return badblock;		}	}	return 0;}/* * Read data from flash at an offset into a provided buffer. On NAND it skips * bad blocks but makes sure it stays within ENVSECTORS (dev) starting from * the DEVOFFSET (dev) block. On NOR the loop is only run once. */static int flash_read_buf (int dev, int fd, void *buf, size_t count,			   off_t offset, uint8_t mtd_type){	size_t blocklen;	/* erase / write length - one block on NAND,				   0 on NOR */	size_t processed = 0;	/* progress counter */	size_t readlen = count;	/* current read length */	off_t top_of_range;	/* end of the last block we may use */	off_t block_seek;	/* offset inside the current block to the start				   of the data */	loff_t blockstart;	/* running start of the current block -				   MEMGETBADBLOCK needs 64 bits */	int rc;	/*	 * Start of the first block to be read, relies on the fact, that	 * erase sector size is always a power of 2	 */	blockstart = offset & ~(DEVESIZE (dev) - 1);	/* Offset inside a block */	block_seek = offset - blockstart;	if (mtd_type == MTD_NANDFLASH) {		/*		 * NAND: calculate which blocks we are reading. We have		 * to read one block at a time to skip bad blocks.		 */		blocklen = DEVESIZE (dev);		/*		 * To calculate the top of the range, we have to use the		 * global DEVOFFSET (dev), which can be different from offset		 */		top_of_range = (DEVOFFSET (dev) & ~(blocklen - 1)) +			ENVSECTORS (dev) * blocklen;		/* Limit to one block for the first read */		if (readlen > blocklen - block_seek)			readlen = blocklen - block_seek;	} else {		blocklen = 0;		top_of_range = offset + count;	}	/* This only runs once on NOR flash */	while (processed < count) {		rc = flash_bad_block (fd, mtd_type, &blockstart);		if (rc < 0)		/* block test failed */			return -1;		if (blockstart + block_seek + readlen > top_of_range) {			/* End of range is reached */			fprintf (stderr,				 "Too few good blocks within range\n");			return -1;		}		if (rc) {		/* block is bad */			blockstart += blocklen;			continue;		}		/*		 * If a block is bad, we retry in the next block at the same		 * offset - see common/env_nand.c::writeenv()		 */		lseek (fd, blockstart + block_seek, SEEK_SET);		rc = read (fd, buf + processed, readlen);		if (rc != readlen) {			fprintf (stderr, "Read error on %s: %s\n",				 DEVNAME (dev), strerror (errno));			return -1;		}#ifdef DEBUG		fprintf (stderr, "Read 0x%x bytes at 0x%llx\n",			 rc, blockstart + block_seek);#endif		processed += readlen;		readlen = min (blocklen, count - processed);		block_seek = 0;

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲另类中文字| 欧美日免费三级在线| 成人黄页在线观看| 91色综合久久久久婷婷| 中文字幕在线不卡| 亚洲欧美一区二区不卡| 亚洲成人在线网站| 久久99国产精品久久| 大胆欧美人体老妇| 欧美性感一区二区三区| 精品剧情v国产在线观看在线| 国产视频亚洲色图| 亚洲免费色视频| 日本不卡视频在线| 成人在线一区二区三区| 欧美日韩高清一区二区三区| 精品少妇一区二区三区免费观看 | 国产性天天综合网| 中文字幕亚洲成人| 日韩成人午夜电影| 懂色av一区二区三区免费看| 欧美日韩一区二区三区免费看| 欧美精品一区二区在线播放| 亚洲免费成人av| 麻豆精品国产传媒mv男同| 成人免费va视频| 91精品国产福利在线观看| 欧美国产日韩一二三区| 五月天久久比比资源色| 国产成a人无v码亚洲福利| 欧美日韩国产综合一区二区| 国产午夜亚洲精品羞羞网站| 午夜精品视频一区| 成年人午夜久久久| 欧美第一区第二区| 亚洲女子a中天字幕| 韩国av一区二区| 欧美日韩免费高清一区色橹橹| 欧美激情一二三区| 青青草国产成人av片免费 | 亚洲色图清纯唯美| 美腿丝袜亚洲色图| 在线观看www91| 国产精品欧美精品| 精品亚洲porn| 欧美日韩免费电影| 亚洲视频一区在线观看| 国产一区91精品张津瑜| 4hu四虎永久在线影院成人| 亚洲欧美一区二区三区极速播放| 国内精品在线播放| 欧美美女直播网站| 亚洲免费观看高清在线观看| 国产精品一区二区视频| 欧美精品自拍偷拍| 亚洲精品久久久久久国产精华液| 国产激情一区二区三区| 日韩欧美国产小视频| 亚洲成人在线观看视频| 91色在线porny| 国产精品视频你懂的| 国产乱人伦偷精品视频不卡| 日韩精品一区二区三区老鸭窝 | 欧美区在线观看| 亚洲精品国产品国语在线app| 高清成人在线观看| 亚洲精品一区二区在线观看| 美美哒免费高清在线观看视频一区二区| 欧美三级三级三级| 亚洲乱码国产乱码精品精98午夜| 日本一区二区三区四区| 国产一区二区在线免费观看| 欧美大胆人体bbbb| 人人爽香蕉精品| 9191国产精品| 日本特黄久久久高潮| 91精品国产综合久久精品性色 | 4438成人网| 天堂va蜜桃一区二区三区漫画版| 欧美性视频一区二区三区| 亚洲精品一二三| 在线免费观看不卡av| 一区二区三区在线视频免费观看 | 一区二区三区免费观看| 91年精品国产| 一区二区在线观看av| 在线视频你懂得一区| 亚洲色图色小说| 欧美最猛性xxxxx直播| 亚洲午夜日本在线观看| 欧美日韩国产区一| 日韩av一区二区三区| 日韩一区二区三区观看| 日本sm残虐另类| 久久久综合网站| 成人免费av网站| 亚洲综合色视频| 欧美日韩第一区日日骚| 蜜桃视频一区二区三区在线观看 | 欧美日韩国产系列| 美腿丝袜在线亚洲一区| 久久久久久久久久久久久久久99| 成人一区二区三区视频在线观看 | 国产传媒久久文化传媒| 国产精品伦理一区二区| 91福利在线播放| 舔着乳尖日韩一区| 日韩精品一区二区三区在线播放| 国产精品 日产精品 欧美精品| 中文字幕免费在线观看视频一区| 色婷婷精品久久二区二区蜜臀av| 五月天一区二区| 久久这里只精品最新地址| eeuss国产一区二区三区| 亚洲一区二区三区国产| 日韩免费电影网站| 国产成人精品1024| 一区二区三区鲁丝不卡| 91精品国产一区二区三区| 国产精品18久久久久久久久| 自拍av一区二区三区| 51久久夜色精品国产麻豆| 国产福利一区在线| 一区二区三区中文字幕电影 | 欧美日韩精品综合在线| 久久国产精品一区二区| 一区精品在线播放| 69p69国产精品| 成人亚洲一区二区一| 性做久久久久久久免费看| 久久亚洲综合色| 欧美影片第一页| 国产成人综合在线播放| 亚洲图片欧美一区| 久久欧美中文字幕| 欧美系列日韩一区| 国产精品一区专区| 亚洲国产va精品久久久不卡综合| 久久久亚洲欧洲日产国码αv| 在线亚洲+欧美+日本专区| 久久99久久久欧美国产| 亚洲综合丁香婷婷六月香| 久久女同互慰一区二区三区| 欧美撒尿777hd撒尿| 成人黄色777网| 久久国产剧场电影| 亚洲一区在线看| 国产精品乱人伦一区二区| 欧美一区二区三区四区五区 | 亚洲制服欧美中文字幕中文字幕| 精品捆绑美女sm三区| 欧美日韩一卡二卡三卡| av电影天堂一区二区在线| 久久综合综合久久综合| 亚洲午夜电影在线| 中文字幕av不卡| 欧美精品一区视频| 肉丝袜脚交视频一区二区| 中文字幕在线一区免费| 精品久久久久久无| 欧美精品色一区二区三区| 91麻豆免费观看| 成人h版在线观看| 国产精品一区二区在线播放| 久久精品久久综合| 亚洲成a人片综合在线| 亚洲精品日日夜夜| 亚洲国产精品成人综合| 久久伊人中文字幕| 日韩视频不卡中文| 欧美日韩aaa| 欧美日韩在线播| 在线视频一区二区免费| 99视频热这里只有精品免费| 国产精品中文欧美| 久久狠狠亚洲综合| 免费一级片91| 青青草原综合久久大伊人精品| 婷婷一区二区三区| 亚洲已满18点击进入久久| 亚洲精品一卡二卡| 亚洲欧美日韩在线| 亚洲视频免费看| 亚洲视频电影在线| 亚洲日本在线视频观看| 亚洲人成精品久久久久久| 国产精品国产馆在线真实露脸 | www.亚洲人| 成人av网站大全| av中文字幕亚洲| 色欲综合视频天天天| 日本高清免费不卡视频| 欧洲一区在线观看| 91久久人澡人人添人人爽欧美 | 亚洲一区二区在线播放相泽| 亚洲第一狼人社区| 香蕉av福利精品导航| 日韩avvvv在线播放| 蜜桃视频免费观看一区| 久久99国产精品久久99果冻传媒|