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

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

?? blkmem.c

?? 單片機學習資料 適合初學者進行開發學習
?? C
?? 第 1 頁 / 共 5 頁
字號:
/* *	FLASH programming routine for the 29LVX00 device family. */static void flash_amd8_write(struct arena_t * a, unsigned long pos, unsigned long length, char * buffer){  volatile unsigned char *address;  unsigned long flags, fbase = a->address;  unsigned char *wbuf, status;  int i;  #if 0  printk("%s(%d): flash_amd8_write(a=%x,pos=%x,length=%d,buf=%x)\n",	__FILE__, __LINE__, (int) a, (int) pos, (int) length, (int) buffer);#endif  down(&spare_lock);#if defined(CONFIG_WATCHDOG)  watchdog_disable();#endif  address = (unsigned volatile char *) (fbase + pos);  wbuf = (unsigned char *) buffer;  for (; (length > 0); length--, address++, wbuf++) {      if (*address != *wbuf) {      save_flags(flags); cli();      *((volatile unsigned char *) (fbase | 0xaaa)) = 0xaa;      *((volatile unsigned char *) (fbase | 0x555)) = 0x55;      *((volatile unsigned char *) (fbase | 0xaaa)) = 0xa0;      *address = *wbuf;      for (i = 0; (i < FTIMEOUT); i++) {	status = *address;	if (status == *wbuf) {	  /* Program complete */	  break;	}      }      if (*address != *wbuf) {          printk("%s(%d): FLASH write failed i=%d, address %p -> %x(%x)\n",		__FILE__, __LINE__, i, address, *wbuf, *address);          *((unsigned volatile char *) fbase) = 0xf0; /* Reset */      }      restore_flags(flags);    }  }#if defined(CONFIG_WATCHDOG)  watchdog_enable();#endif  up(&spare_lock);}/* *	Program a complete FLASH image. This runs from DRAM, so no *	need to worry about writing to what we are running from... */static void flash_amd8_writeall(struct arena_t * a, struct blkmem_program_t * prog){  unsigned long		base, offset, erased;  unsigned long		ptr, min, max;  unsigned char		*w, status;  int			failures;  int			i, j, l;#if defined(CONFIG_WATCHDOG)  watchdog_disable();#endif  #if 0  printk("FLASH: programming");#endif  failures = 0;  erased = 0;  cli();    for (i = 0; (i < prog->blocks); i++) {#if 0    printk("%s(%d): block=%d address=%x pos=%x length=%x range=%x-%x\n",      __FILE__, __LINE__, i, (int) a->address, (int) prog->block[i].pos,      (int) prog->block[i].length, (int) (prog->block[i].pos + a->address),      (int) (prog->block[i].pos + prog->block[i].length - 1 + a->address));#endif    /*     *	Erase FLASH sectors for this program block...     */    for (l = prog->block[i].pos / a->blksize;	l <= ((prog->block[i].pos+prog->block[i].length-1) / a->blksize);	l++) {      if (erased & (0x1 << l))	continue;      ptr = l * a->blksize;      offset = ptr % a->unitsize;      base = ptr - offset;	      base += a->address;      ptr += a->address;      j = 0;flash_redo:#if 0      printk("%s(%d): ERASE BLOCK sector=%d base=%x offset=%x ptr=%x\n",	  __FILE__, __LINE__, l, (int) base, (int) offset, (int) ptr);#endif      /* Erase this sector */      *((volatile unsigned char *) (base | 0xaaa)) = 0xaa;      *((volatile unsigned char *) (base | 0x555)) = 0x55;      *((volatile unsigned char *) (base | 0xaaa)) = 0x80;      *((volatile unsigned char *) (base | 0xaaa)) = 0xaa;      *((volatile unsigned char *) (base | 0x555)) = 0x55;      *((volatile unsigned char *) ptr) = 0x30;      for (;;) {	status = *((volatile unsigned char *) ptr);	if (status & 0x80) {	  /* Erase complete */	  break;	}	if (status & 0x20) {	  printk("FLASH: (%d) erase failed\n", __LINE__);	  /* Reset FLASH unit */	  *((volatile unsigned char *) base) = 0xf0;	  failures++;	  /* Continue (with unerased sector) */	  break;	}      }      /*       * Some flash have a set of small segments at the top or bottom.       * These need to be erased individually, even better, different       * devices uses different segment sizes :-(       * This code currently only handles bottom booters...       */      if ((ptr & FLASHMASK) < 64*1024) {	ptr += flash_bootsegs[j++];        if ((ptr - base) < a->length)	  goto flash_redo;      }      erased |= (0x1 << l);    }    /*     *	Program FLASH with the block data...     */    min = prog->block[i].pos+a->address;    max = prog->block[i].pos+prog->block[i].length+a->address;    w = (unsigned char *) prog->block[i].data;    /* Progress indicators... */    printk(".");#ifdef CONFIG_LEDMAN	if (i & 1) {		ledman_cmd(LEDMAN_CMD_OFF, LEDMAN_NVRAM_1);		ledman_cmd(LEDMAN_CMD_ON,  LEDMAN_NVRAM_2);	} else {		ledman_cmd(LEDMAN_CMD_ON,  LEDMAN_NVRAM_1);		ledman_cmd(LEDMAN_CMD_OFF, LEDMAN_NVRAM_2);	}#endif#if 0    printk("%s(%d): PROGRAM BLOCK min=%x max=%x\n", __FILE__, __LINE__,      (int) min, (int) max);#endif    for (ptr = min; (ptr < max); ptr++, w++) {            offset = (ptr - a->address) % a->unitsize;      base = ptr - offset;#if 0      printk("%s(%d): PROGRAM base=%x offset=%x ptr=%x value=%x\n",	  __FILE__, __LINE__, (int) base, (int) offset, (int) ptr, (int) *w);#endif      *((volatile unsigned char *) (base | 0xaaa)) = 0xaa;      *((volatile unsigned char *) (base | 0x555)) = 0x55;      *((volatile unsigned char *) (base | 0xaaa)) = 0xa0;      *((volatile unsigned char *) ptr) = *w;      for (j = 0; (j < FTIMEOUT); j++) {	status = *((volatile unsigned char *) ptr);	if (status == *w) {	  /* Program complete */	  break;	}      }      status = *((volatile unsigned char *) ptr);      if (status != *w) {	printk("FLASH: (%d) write failed, addr=%x val=%x status=%x cnt=%d\n",		__LINE__, (int) ptr, *w, status, j);	/* Reset FLASH unit */	*((volatile unsigned char *) ptr) = 0xf0;	failures++;      }    }  }#ifdef CONFIG_LEDMAN  ledman_cmd(LEDMAN_CMD_RESET, LEDMAN_NVRAM_1);  ledman_cmd(LEDMAN_CMD_RESET, LEDMAN_NVRAM_2);#endif  if (failures > 0) {    printk("FLASH: %d failures programming FLASH!\n", failures);    return;  }#if 0  printk("\nFLASH: programming successful!\n");#endif  if (prog->reset) {    printk("FLASH: rebooting...\n\n");    HARD_RESET_NOW();  }}/****************************************************************************//*                            AMD 16bit FLASH                               *//****************************************************************************/#else/* *	FLASH erase routine for the AMD 29LVxxx family devices. */static void flash_amd16_erase(struct arena_t *a, unsigned long pos){  unsigned volatile short *address;  unsigned long fbase = a->address;  unsigned long flags;  unsigned short status;  int i;  #if 0  printk("%s(%d): flash_amd16_erase(a=%x,pos=%x)\n", __FILE__, __LINE__,    (int) a, (int) pos);#endif  if (pos >= a->length)    return;  address = (unsigned volatile short *) (fbase + pos);  /* Mutex all access to FLASH memory */  down(&spare_lock);  save_flags(flags); cli();#if defined(CONFIG_WATCHDOG)  watchdog_disable();#endif  /* Erase this sector */  *((volatile unsigned short *) (fbase | (0x555 << 1))) = 0xaaaa;  *((volatile unsigned short *) (fbase | (0x2aa << 1))) = 0x5555;  *((volatile unsigned short *) (fbase | (0x555 << 1))) = 0x8080;  *((volatile unsigned short *) (fbase | (0x555 << 1))) = 0xaaaa;  *((volatile unsigned short *) (fbase | (0x2aa << 1))) = 0x5555;  *address = 0x3030;  for (i = 0; (i < FTIMEOUT); i++) {    status = *address;    if ((status & 0x0080) || (status & 0x0020))      break;  }  if (*address != 0xffff) {     printk("%s(%d): FLASH erase failed, address %p iteration=%d status=%x\n",		__FILE__, __LINE__, address, i, status);     *((unsigned volatile short *) fbase) = 0xf0f0; /* Reset */  }#if defined(CONFIG_WATCHDOG)  watchdog_enable();#endif  restore_flags(flags);  up(&spare_lock);}/* *	FLASH programming routine for the 29LVxxx device family. */static void flash_amd16_write(struct arena_t * a, unsigned long pos, unsigned long length, char * buffer){  volatile unsigned short *address;  unsigned long flags, fbase = a->address;  unsigned short *wbuf, status;  int i;  #if 0  printk("%s(%d): flash_amd16_write(a=%x,pos=%x,length=%d,buf=%x)\n",	__FILE__, __LINE__, (int) a, (int) pos, (int) length, (int) buffer);#endif  down(&spare_lock);#if defined(CONFIG_WATCHDOG)  watchdog_disable();#endif  address = (unsigned volatile short *) (fbase + pos);  wbuf = (unsigned short *) buffer;  length += 1;   /* Fix it so that an odd number of bytes gets written correctly */  for (length >>= 1; (length > 0); length--, address++, wbuf++) {      if (*address != *wbuf) {      save_flags(flags); cli();      *((volatile unsigned short *) (fbase | (0x555 << 1))) = 0xaaaa;      *((volatile unsigned short *) (fbase | (0x2aa << 1))) = 0x5555;      *((volatile unsigned short *) (fbase | (0x555 << 1))) = 0xa0a0;      *address = *wbuf;      for (i = 0; (i < FTIMEOUT); i++) {	status = *address;	if (status == *wbuf) {	  /* Program complete */	  break;	}      }      if (*address != *wbuf) {          printk("%s(%d): FLASH write failed i=%d, address %p -> %x(%x)\n",		__FILE__, __LINE__, i, address, *wbuf, *address);          *((unsigned volatile short *) fbase) = 0xf0f0; /* Reset */      }      restore_flags(flags);    }  }#if defined(CONFIG_WATCHDOG)  watchdog_enable();#endif  up(&spare_lock);}/* *	Program a complete FLASH image. This runs from DRAM, so no *	need to worry about writing to what we are running from... */static void flash_amd16_writeall(struct arena_t * a, struct blkmem_program_t * prog){  unsigned long		base, offset, erased;  unsigned long		ptr, min, max;  unsigned short	*w, status;  int			failures;  int			i, j, l;#if defined(CONFIG_WATCHDOG)  watchdog_disable();#endif  #if 0  printk("FLASH: programming");#endif  failures = 0;  erased = 0;  cli();    for (i = 0; (i < prog->blocks); i++) {#if 0    printk("%s(%d): block=%d address=%x pos=%x length=%x range=%x-%x\n",      __FILE__, __LINE__, i, (int) a->address, (int) prog->block[i].pos,      (int) prog->block[i].length, (int) (prog->block[i].pos + a->address),      (int) (prog->block[i].pos + prog->block[i].length - 1 + a->address));#endif    /*     *	Erase FLASH sectors for this program block...     */    for (l = prog->block[i].pos / a->blksize;	l <= ((prog->block[i].pos+prog->block[i].length-1) / a->blksize);	l++) {      if (erased & (0x1 << l))	continue;      ptr = l * a->blksize;      offset = ptr % a->unitsize;      base = ptr - offset;	      base += a->address;      ptr += a->address;      j = 0;flash_redo:#if 0      printk("%s(%d): ERASE BLOCK sector=%d base=%x offset=%x ptr=%x\n",	  __FILE__, __LINE__, l, (int) base, (int) offset, (int) ptr);#endif      /* Erase this sector */      /* FIX: check which byte lane the value needs to be on */      *((volatile unsigned short *) (base | (0x555 << 1))) = 0xaaaa;      *((volatile unsigned short *) (base | (0x2aa << 1))) = 0x5555;      *((volatile unsigned short *) (base | (0x555 << 1))) = 0x8080;      *((volatile unsigned short *) (base | (0x555 << 1))) = 0xaaaa;      *((volatile unsigned short *) (base | (0x2aa << 1))) = 0x5555;      *((volatile unsigned short *) ptr) = 0x3030;      for (;;) {	status = *((volatile unsigned short *) ptr);	if (status & 0x0080) {	  /* Erase complete */	  break;	}	if (status & 0x0020) {	  printk("FLASH: (%d) erase failed\n", __LINE__);	  /* Reset FLASH unit */	  *((volatile unsigned short *) base) = 0xf0f0;	  failures++;	  /* Continue (with unerased sector) */	  break;	}      }      /*       * Some flash have a set of small segments at the top or bottom.       * These need to be erased individually, even better, different       * devices uses different segment sizes :-(       * This code currently only handles bottom booters...       */      if ((ptr & FLASHMASK) < 64*1024) {	ptr += flash_bootsegs[j++];        if ((ptr - base) < a->length)	  goto flash_redo;      }      erased |= (0x1 << l);    }    /*     *	Program FLASH with the block data...     */    min = prog->block[i].pos+a->address;    max = prog->block[i].pos+prog->block[i].length+a->address;    w = (unsigned short *) prog->block[i].data;    /* Progress indicators... */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91在线一区二区| 亚洲成av人**亚洲成av**| 成人午夜看片网址| 欧美一区二区三区免费观看视频| 亚洲欧美视频在线观看| 亚洲午夜久久久久久久久电影院| 白白色亚洲国产精品| 国产日产亚洲精品系列| 国产一区二三区| 久久一日本道色综合| 麻豆91在线播放| voyeur盗摄精品| 成人欧美一区二区三区在线播放| 成人免费看黄yyy456| 国产精品成人在线观看| 色偷偷久久人人79超碰人人澡| 国产精品久久久久久久裸模| 不卡的电视剧免费网站有什么| √…a在线天堂一区| 色先锋aa成人| 亚洲成人一二三| 日韩视频在线你懂得| 狠狠色狠狠色合久久伊人| 久久精品视频免费| 99视频精品全部免费在线| 亚洲日本va午夜在线电影| 在线观看欧美精品| 天天操天天色综合| 精品国产免费人成在线观看| 国产69精品久久777的优势| 最近日韩中文字幕| av一区二区三区四区| 亚洲亚洲精品在线观看| 日韩三区在线观看| 国产精品一区免费视频| 综合婷婷亚洲小说| 欧美乱熟臀69xxxxxx| 蜜桃视频在线观看一区二区| 国产亚洲欧美一区在线观看| 一本久道久久综合中文字幕| 五月综合激情网| 久久久99久久| 日本电影欧美片| 人人超碰91尤物精品国产| 在线91免费看| 不卡av电影在线播放| 国产精品久线观看视频| 欧美日韩精品福利| www.欧美色图| 久久99热这里只有精品| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆 | 不卡电影一区二区三区| 国产精品热久久久久夜色精品三区| 在线观看日韩一区| 成人美女在线观看| 蜜臀av一区二区三区| 亚洲精品网站在线观看| 26uuu亚洲综合色| 91小视频在线观看| 国产麻豆精品久久一二三| 亚洲小少妇裸体bbw| 亚洲国产成人私人影院tom| 8x8x8国产精品| 岛国一区二区在线观看| 日本亚洲视频在线| 一区二区三区在线视频播放| 久久美女艺术照精彩视频福利播放 | 日韩一区二区三区在线视频| 91色|porny| 国产98色在线|日韩| 免费看欧美美女黄的网站| 亚洲一区二区欧美日韩| 国产精品国产馆在线真实露脸 | 91精品国产品国语在线不卡| 91浏览器入口在线观看| 韩日欧美一区二区三区| 亚洲6080在线| 一区二区三区欧美| 自拍偷在线精品自拍偷无码专区| 亚洲精品一区二区三区蜜桃下载 | 成人深夜视频在线观看| 蜜桃视频在线观看一区| 五月天久久比比资源色| 18成人在线视频| 欧美国产精品专区| 国产亚洲婷婷免费| www激情久久| 欧美日本在线观看| 欧美日本在线播放| 欧美日韩国产片| 欧美精品久久天天躁| 欧美日韩国产另类一区| 欧美日韩亚洲另类| 欧美三级一区二区| 日本韩国一区二区三区视频| 91女人视频在线观看| 91亚洲精华国产精华精华液| 成人伦理片在线| 日韩和欧美的一区| 最好看的中文字幕久久| 亚洲综合免费观看高清在线观看| 亚洲最色的网站| 日韩国产在线观看| 丁香一区二区三区| 欧美亚洲国产bt| 精品精品欲导航| 国产精品乱人伦| 亚欧色一区w666天堂| 国内精品视频一区二区三区八戒| 丁香婷婷综合激情五月色| 91猫先生在线| 欧美zozo另类异族| 亚洲欧美日韩国产一区二区三区| 午夜激情一区二区三区| 国产成人综合在线播放| 色婷婷av一区二区三区gif| 欧美日韩一级黄| 久久精品男人的天堂| 亚洲成人三级小说| 国产成人在线影院| 欧美剧情电影在线观看完整版免费励志电影| 欧美一区二区三区白人| 国产精品福利一区二区三区| 午夜视频在线观看一区二区| 国产一区二区按摩在线观看| 欧美午夜精品一区| 国产精品美女一区二区在线观看| 香蕉久久一区二区不卡无毒影院| 国产成人精品一区二区三区四区| 欧美日韩一区二区在线观看视频| 国产欧美一区二区精品久导航| 亚洲国产成人av| av亚洲精华国产精华| 日韩免费观看高清完整版在线观看 | 美女尤物国产一区| 色综合天天综合在线视频| 欧美va亚洲va| 亚洲6080在线| 91极品美女在线| 国产精品毛片久久久久久| 美腿丝袜亚洲色图| 欧美色视频在线观看| 亚洲人成在线观看一区二区| 狠狠色综合日日| 日韩小视频在线观看专区| 亚洲成在人线免费| 91久久精品国产91性色tv| 国产精品欧美极品| 国产成人综合在线| 国产亚洲一区二区在线观看| 日韩av在线发布| 欧美精品色一区二区三区| 一区二区三区影院| 91视视频在线直接观看在线看网页在线看 | 精品污污网站免费看| 亚洲欧美日韩国产一区二区三区 | 91亚洲精品久久久蜜桃网站 | 666欧美在线视频| 亚洲综合色网站| 91视频观看免费| 自拍偷拍亚洲欧美日韩| av毛片久久久久**hd| 久久天天做天天爱综合色| 捆绑紧缚一区二区三区视频| 91精品国产一区二区三区蜜臀| 亚洲va韩国va欧美va| 欧美亚洲国产一区二区三区va| 亚洲精品国产高清久久伦理二区| 91麻豆国产精品久久| 亚洲一区在线观看网站| 在线观看日韩国产| 日韩精品成人一区二区在线| 欧美精品视频www在线观看| 蜜臀a∨国产成人精品| 精品福利视频一区二区三区| 国产在线视频一区二区三区| 国产日韩精品一区| 播五月开心婷婷综合| 亚洲欧洲在线观看av| 色狠狠一区二区| 日日夜夜免费精品| 日韩欧美一区二区视频| 国产美女视频一区| 国产精品的网站| 日本久久精品电影| 日一区二区三区| 久久久不卡影院| 99国产精品国产精品毛片| 一区二区三区四区高清精品免费观看| 在线精品观看国产| 蜜臂av日日欢夜夜爽一区| 国产亚洲一二三区| 欧洲精品视频在线观看| 日韩二区在线观看| 欧美高清在线视频| 欧美亚一区二区| 久久99精品久久久久久国产越南| 国产精品水嫩水嫩| 欧美日韩一区视频| 国产成人啪免费观看软件|