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

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

?? s3c2410_flash.c

?? VI 是2410的ARM9芯片的BOOTLOADER
?? C
字號:
/* * vivi/drivers/mtd/maps/s3c2410-flash.c:  *   Flash memory access on SA11x0 based devices * * Copyright (C) 2002 MIZI Research, Inc. *  * Based on linux/drivers/mtd/maps/s3c2410-flash.c * * This code is GPL. *  * Author: Janghoon Lyu <nandy@mizi.com> * Date  : $Date: 2002/08/29 06:10:23 $ * * $Revision: 1.6 $ * $Id: s3c2410_flash.c,v 1.6 2002/08/29 06:10:23 nandy Exp $ * * 扁拌俊 蝶扼 促弗 甘 瀝焊甫 撈儈秦輯 flash 皋葛府甫 檬扁拳茄促. * * History * * 2002-06-26: Janghoon Lyu <nandy@mizi.com> *    - Created this code * */#include "config.h"#include "machine.h"#include "mtd/mtd.h"#include "mtd/map.h"#include "io.h"#include "printk.h"#include "time.h"#ifdef CONFIG_MTD_SMC#include "mtd/nand.h"#include "heap.h"#endif#include <types.h>#include <errno.h>#ifndef CONFIG_ARCH_S3C2410#error This is for S3C2410 architecture only#endifextern struct mtd_info *mymtd;#ifdef CONFIG_MTD_CFI#define WINDOW_ADDR	FLASH_UNCACHED_BASEstatic __u8 s3c2410_read8(struct map_info *map, unsigned long ofs){	return readb(map->map_priv_1 + ofs);}static __u16 s3c2410_read16(struct map_info *map, unsigned long ofs){	return readw(map->map_priv_1 + ofs);}static __u32 s3c2410_read32(struct map_info *map, unsigned long ofs){	return readl(map->map_priv_1 + ofs);}static void s3c2410_copy_from(struct map_info *map, void *to, unsigned long from, ssize_t len){	memcpy(to, (void *)(map->map_priv_1 + from), len);}static void s3c2410_write8(struct map_info *map, __u8 d, unsigned long adr){	writeb(d, map->map_priv_1 + adr);}static void s3c2410_write16(struct map_info *map, __u16 d, unsigned long adr){	writew(d, map->map_priv_1 + adr);}static void s3c2410_write32(struct map_info *map, __u32 d, unsigned long adr){	writel(d, map->map_priv_1 + adr);}static void s3c2410_copy_to(struct map_info *map, unsigned long to, const void *from, ssize_t len){	memcpy((void *)(map->map_priv_1 + to), from, len);}static struct map_info s3c2410_map = {	name:		"S3C2410 flash",	read8:		s3c2410_read8,	read16:		s3c2410_read16,	read32:		s3c2410_read32,	copy_from:	s3c2410_copy_from,	write8:		s3c2410_write8,	write16:	s3c2410_write16,	write32:	s3c2410_write32,	copy_to:	s3c2410_copy_to,	map_priv_1:	WINDOW_ADDR,	map_priv_2:	-1,};extern void set_vpp(struct map_info *map, int vpp);static int cfi_init(void){	/* Default flash buswidth */	s3c2410_map.buswidth = FLASH_BUSWIDTH;	/* Default flash size */	s3c2410_map.size = FLASH_SIZE;	s3c2410_map.set_vpp = set_vpp;	/*	 * Now let's probe for the actual flash.  Do it here since	 * specific machine settings might have been set above.	 */	printk("S3C2410 flash: probing %d-bit flash bus\n", s3c2410_map.buswidth*8);	mymtd = do_map_probe("cfi_probe", &s3c2410_map);	if (!mymtd) return -ENXIO;	return 0;}#endif /* CONFIG_MTD_CFI */#ifdef CONFIG_S3C2410_AMD_BOOTstatic __u8 s3c2410_read8(struct map_info *map, unsigned long ofs){	return readb(map->map_priv_1 + ofs);}static __u16 s3c2410_read16(struct map_info *map, unsigned long ofs){	return readw(map->map_priv_1 + ofs);}static __u32 s3c2410_read32(struct map_info *map, unsigned long ofs){	return readl(map->map_priv_1 + ofs);}static void s3c2410_copy_from(struct map_info *map, void *to, unsigned long from, ssize_t len){	memcpy(to, (void *)(map->map_priv_1 + from), len);}static void s3c2410_write8(struct map_info *map, __u8 d, unsigned long adr){	writeb(d, map->map_priv_1 + adr);}static void s3c2410_write16(struct map_info *map, __u16 d, unsigned long adr){	writew(d, map->map_priv_1 + adr);}static void s3c2410_write32(struct map_info *map, __u32 d, unsigned long adr){	writel(d, map->map_priv_1 + adr);}static void s3c2410_copy_to(struct map_info *map, unsigned long to, const void *from, ssize_t len){	memcpy((void *)(map->map_priv_1 + to), from, len);}static struct map_info s3c2410_map = {	name:		"S3C2410 amd flash",	read8:		s3c2410_read8,	read16:		s3c2410_read16,	read32:		s3c2410_read32,	copy_from:	s3c2410_copy_from,	write8:		s3c2410_write8,	write16:	s3c2410_write16,	write32:	s3c2410_write32,	copy_to:	s3c2410_copy_to,	map_priv_1:	FLASH_UNCACHED_BASE,	//map_priv_1:	FLASH_BASE,	map_priv_2:	-1,};extern void set_vpp(struct map_info *map, int vpp);static int amd_init(void){	/* Default flash buswidth */	s3c2410_map.buswidth = FLASH_BUSWIDTH;	/* Default flash size */	s3c2410_map.size = FLASH_SIZE;	s3c2410_map.set_vpp = set_vpp;	/*	 * Now let's probe for the actual flash.  Do it here since	 * specific machine settings might have been set above.	 */	printk("S3C2410 flash: probing %d-bit flash bus\n", s3c2410_map.buswidth*8);	mymtd = do_map_probe("amd_flash", &s3c2410_map);	if (!mymtd) return -ENXIO;	return 0;}#endif /* CONFIG_MTD_CFI */#ifdef CONFIG_MTD_SMCstatic void smc_hwcontrol(int cmd) {	switch (cmd) {	case NAND_CTL_SETNCE:		NFCONF &= ~NFCONF_nFCE_HIGH; break;	case NAND_CTL_CLRNCE:		NFCONF |= NFCONF_nFCE_HIGH; break;	case NAND_CTL_SETCLE:		break;	case NAND_CTL_CLRCLE:		break;	case NAND_CTL_SETALE:		break;	case NAND_CTL_CLRALE:		break;	case NAND_CTL_DAT_IN:		break;	case NAND_CTL_DAT_OUT:		break;	}}static voidwrite_cmd(u_char val) {	NFCMD = (u_char)val;}static voidwrite_addr(u_char val) {	NFADDR = (u_char)val;}static u_charread_data(void) {	return (u_char)NFDATA;}static voidwrite_data(u_char val) {	NFDATA = (u_char)val;}static voidwait_for_ready(void) {	while (!(NFSTAT & NFSTAT_RnB)) {		/* Busy */		udelay(10);	}}inline intsmc_insert(struct nand_chip *this) {	/* Scan to find existance of the device */    if (smc_scan(mymtd)) {		return -ENXIO;    }    /* Allocate memory for internal data buffer */    this->data_buf = mmalloc(sizeof(u_char) *			     (mymtd->oobblock + mymtd->oobsize));    if (!this->data_buf) {		printk("Unable to allocate NAND data buffer for S3C2410.\n");		this->data_buf = NULL;		return -ENOMEM;    }    return 0;}static intsmc_init(void){	struct nand_chip *this;	u_int16_t nfconf;	/* Allocate memory for MTD device structure and private data */	mymtd = mmalloc(sizeof(struct mtd_info) + sizeof(struct nand_chip));	if (!mymtd) {		printk("Unable to allocate S3C2410 NAND MTD device structure.\n");		return -ENOMEM;	}	/* Get pointer to private data */	this = (struct nand_chip *)(&mymtd[1]);	/* Initialize structures */	memset((char *)mymtd, 0, sizeof(struct mtd_info));	memset((char *)this, 0, sizeof(struct nand_chip));	/* Link the private data with the MTD structure */	mymtd->priv = this;	/* set NAND Flash  controller */	nfconf = NFCONF;	/* NAND Flash controller enable */	nfconf |= NFCONF_FCTRL_EN;	/* Set flash memory timing */	nfconf &= ~NFCONF_TWRPH1;	/* 0x0 */	nfconf |= NFCONF_TWRPH0_3;	/* 0x3 */	nfconf &= ~NFCONF_TACLS;	/* 0x0 */	NFCONF = nfconf;	/* Set address of NAND IO lines */	this->hwcontrol = smc_hwcontrol;	this->write_cmd = write_cmd;	this->write_addr = write_addr;	this->read_data = read_data;	this->write_data = write_data;	this->wait_for_ready = wait_for_ready;	/* Chip Enable -> RESET -> Wait for Ready -> Chip Disable */	this->hwcontrol(NAND_CTL_SETNCE);	this->write_cmd(NAND_CMD_RESET);	this->wait_for_ready();	this->hwcontrol(NAND_CTL_CLRNCE);	smc_insert(this);	return 0;}#endif /* CONFIG_MTD_SMC */int mtd_init(void){	int ret;#ifdef CONFIG_MTD_CFI	ret = cfi_init();#endif#ifdef CONFIG_MTD_SMC	ret = smc_init();#endif#ifdef CONFIG_S3C2410_AMD_BOOT	ret = amd_init();#endif	if (ret) {		mymtd = NULL;		return ret;	}	return 0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
午夜视频在线观看一区二区三区| 国产大陆精品国产| 国精产品一区一区三区mba视频| 福利91精品一区二区三区| 欧美私模裸体表演在线观看| 中文在线免费一区三区高中清不卡| 午夜欧美在线一二页| youjizz久久| 26uuu国产在线精品一区二区| 亚洲福利视频三区| 色噜噜狠狠色综合中国| 国产日韩视频一区二区三区| 日本美女视频一区二区| 欧美性大战久久| 中文字幕一区二区5566日韩| 国产一区二区剧情av在线| 欧美精品粉嫩高潮一区二区| 亚洲精品免费播放| 91一区一区三区| 国产精品免费丝袜| 国产99精品国产| 久久综合九色综合欧美98| 久久精品国产99国产| 6080国产精品一区二区| 亚洲成人免费影院| 欧美情侣在线播放| 亚洲在线成人精品| 欧美日高清视频| 亚洲h精品动漫在线观看| 日本丶国产丶欧美色综合| 一区二区三区四区在线| 91啪亚洲精品| 一区二区三区在线免费| 欧美在线观看一区二区| 亚洲大片一区二区三区| 欧美日韩国产美女| 免费人成在线不卡| 精品播放一区二区| 国产福利一区二区| 中文字幕av在线一区二区三区| 成人久久18免费网站麻豆| 亚洲欧洲精品成人久久奇米网| 99视频超级精品| 一区二区三区中文免费| 4438x成人网最大色成网站| 日韩国产欧美视频| 久久精品人人做人人爽人人| 国产91在线看| 亚洲激情图片qvod| 在线播放欧美女士性生活| 麻豆国产欧美一区二区三区| 久久久久九九视频| 丁香另类激情小说| 亚洲一区在线观看免费| 日韩一区二区三区高清免费看看| 国产一区视频导航| 亚洲啪啪综合av一区二区三区| 欧美综合在线视频| 国产一区二区三区高清播放| 中文字幕一区三区| 欧美一级高清片在线观看| 国产一区二区不卡| 亚洲一卡二卡三卡四卡五卡| 日韩亚洲欧美高清| jiyouzz国产精品久久| 天堂一区二区在线免费观看| 精品国产3级a| 在线免费观看一区| 狠狠色狠狠色综合系列| 国产精品久久久久久久久快鸭 | 精品美女在线观看| 97精品国产97久久久久久久久久久久| 午夜精品aaa| 国产精品伦理一区二区| 777亚洲妇女| 波多野结衣一区二区三区 | 色爱区综合激月婷婷| 久草这里只有精品视频| 中文字幕日本不卡| 欧美成人a在线| 色琪琪一区二区三区亚洲区| 国内外成人在线视频| 性做久久久久久| 亚洲天堂2014| 久久青草国产手机看片福利盒子| 欧美日韩一区精品| av在线播放一区二区三区| 激情五月婷婷综合网| 亚洲高清免费在线| 亚洲激情中文1区| 国产精品久久久久久久久久免费看 | 在线播放日韩导航| 91网页版在线| 成人免费毛片片v| 国产成人丝袜美腿| 精东粉嫩av免费一区二区三区| 亚洲成av人综合在线观看| 中国av一区二区三区| 精品国产不卡一区二区三区| 欧美日韩一区二区在线观看| www.日韩大片| 粉嫩在线一区二区三区视频| 五月天一区二区| 亚洲男人的天堂在线观看| 国产日韩亚洲欧美综合| 久久伊人中文字幕| 欧美成人综合网站| 精品sm在线观看| 久久精品夜色噜噜亚洲a∨| 亚洲精品一区二区三区精华液| 日韩一区二区精品葵司在线| 91精品国产欧美一区二区成人| 欧洲激情一区二区| 欧美性生活一区| 在线看不卡av| 欧美伦理电影网| 在线成人av网站| 日韩精品在线网站| 久久综合色综合88| 国产日韩欧美电影| 国产精品美女一区二区三区| 国产精品免费丝袜| 一区二区三区在线视频免费观看| 一区二区三区国产豹纹内裤在线| 亚洲永久免费视频| 狠狠色综合播放一区二区| 九九视频精品免费| 韩日av一区二区| 成人aaaa免费全部观看| 91性感美女视频| 欧美午夜精品久久久| 91麻豆精品国产91久久久| 日韩区在线观看| 国产日韩欧美高清| 玉米视频成人免费看| 日韩av一区二区在线影视| 久久99精品久久久久久国产越南| 国产成人综合自拍| 91捆绑美女网站| 5858s免费视频成人| 久久久精品综合| 一区二区三区四区激情| 日本大胆欧美人术艺术动态| 国产一区二区三区日韩| 99久久精品免费看国产免费软件| 欧洲国产伦久久久久久久| 日韩一区二区三区四区| 国产精品欧美综合在线| 亚洲主播在线观看| 国产精品一区在线观看乱码| 色美美综合视频| 精品精品国产高清a毛片牛牛| 日本一区二区动态图| 日韩av不卡在线观看| 成人18视频日本| 日韩免费高清电影| 亚洲欧美日韩在线播放| 黄色精品一二区| 91豆麻精品91久久久久久| 精品理论电影在线观看| 亚洲精品乱码久久久久| 韩国欧美一区二区| 色欧美片视频在线观看| 久久久www免费人成精品| 亚洲第一在线综合网站| 国产一区二区在线看| 麻豆国产欧美日韩综合精品二区 | av在线不卡电影| 欧美成人免费网站| 亚洲国产aⅴ天堂久久| 成人性视频免费网站| 欧美tk—视频vk| 天天综合色天天综合| 91同城在线观看| 国产日韩av一区| 六月丁香综合在线视频| 欧美日韩成人在线| 亚洲色图欧洲色图| 国产1区2区3区精品美女| 日韩一二三区视频| 午夜精品成人在线| 91国产丝袜在线播放| 国产精品久久久久久久久免费樱桃| 日本欧美肥老太交大片| 欧美亚洲高清一区| 一区二区三区四区高清精品免费观看| 国产高清不卡一区二区| 日韩精品专区在线影院重磅| 丝袜诱惑亚洲看片| 欧美日韩精品欧美日韩精品一 | 国产精品一区专区| 久久天天做天天爱综合色| 青娱乐精品在线视频| 欧美男男青年gay1069videost | 国产精品欧美一区喷水| 国产精品自拍三区| 久久精品人人做人人爽人人| 国产激情精品久久久第一区二区| 精品福利一二区| 国产福利91精品一区|