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

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

?? s3c2440_flash.c

?? vivi的源代碼
?? C
字號:
/* * vivi/drivers/mtd/maps/s3c2440-flash.c:  *   Flash memory access on SA11x0 based devices * * Copyright (C) 2002 MIZI Research, Inc. *  * Based on linux/drivers/mtd/maps/s3c2440-flash.c * * This code is GPL. *  * Author: Janghoon Lyu <nandy@mizi.com> * Date  : $Date: 2004/02/04 06:22:25 $ * * $Revision: 1.1.1.1 $ * $Id: s3c2440_flash.c,v 1.1.1.1 2004/02/04 06:22:25 laputa Exp $ * * * 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_S3C2440#error This is for S3C2440 architecture only#endifextern struct mtd_info *mymtd;#ifdef CONFIG_MTD_CFI#define WINDOW_ADDR	FLASH_UNCACHED_BASEstatic __u8 s3c2440_read8(struct map_info *map, unsigned long ofs){	return readb(map->map_priv_1 + ofs);}static __u16 s3c2440_read16(struct map_info *map, unsigned long ofs){	return readw(map->map_priv_1 + ofs);}static __u32 s3c2440_read32(struct map_info *map, unsigned long ofs){	return readl(map->map_priv_1 + ofs);}static void s3c2440_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 s3c2440_write8(struct map_info *map, __u8 d, unsigned long adr){	writeb(d, map->map_priv_1 + adr);}static void s3c2440_write16(struct map_info *map, __u16 d, unsigned long adr){	writew(d, map->map_priv_1 + adr);}static void s3c2440_write32(struct map_info *map, __u32 d, unsigned long adr){	writel(d, map->map_priv_1 + adr);}static void s3c2440_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 s3c2440_map = {	name:		"S3C2440 flash",	read8:		s3c2440_read8,	read16:		s3c2440_read16,	read32:		s3c2440_read32,	copy_from:	s3c2440_copy_from,	write8:		s3c2440_write8,	write16:	s3c2440_write16,	write32:	s3c2440_write32,	copy_to:	s3c2440_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 */	s3c2440_map.buswidth = FLASH_BUSWIDTH;	/* Default flash size */	s3c2440_map.size = FLASH_SIZE;	s3c2440_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("S3C2440 flash: probing %d-bit flash bus\n", s3c2440_map.buswidth*8);	mymtd = do_map_probe("cfi_probe", &s3c2440_map);	if (!mymtd) return -ENXIO;	return 0;}#endif /* CONFIG_MTD_CFI */#ifdef CONFIG_S3C2440_AMD_BOOTstatic __u8 s3c2440_read8(struct map_info *map, unsigned long ofs){	return readb(map->map_priv_1 + ofs);}static __u16 s3c2440_read16(struct map_info *map, unsigned long ofs){	return readw(map->map_priv_1 + ofs);}static __u32 s3c2440_read32(struct map_info *map, unsigned long ofs){	return readl(map->map_priv_1 + ofs);}static void s3c2440_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 s3c2440_write8(struct map_info *map, __u8 d, unsigned long adr){	writeb(d, map->map_priv_1 + adr);}static void s3c2440_write16(struct map_info *map, __u16 d, unsigned long adr){	writew(d, map->map_priv_1 + adr);}static void s3c2440_write32(struct map_info *map, __u32 d, unsigned long adr){	writel(d, map->map_priv_1 + adr);}static void s3c2440_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 s3c2440_map = {	name:		"S3C2440 amd flash",	read8:		s3c2440_read8,	read16:		s3c2440_read16,	read32:		s3c2440_read32,	copy_from:	s3c2440_copy_from,	write8:		s3c2440_write8,	write16:	s3c2440_write16,	write32:	s3c2440_write32,	copy_to:	s3c2440_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 */	s3c2440_map.buswidth = FLASH_BUSWIDTH;	/* Default flash size */	s3c2440_map.size = FLASH_SIZE;	s3c2440_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("S3C2440 flash: probing %d-bit flash bus\n", s3c2440_map.buswidth*8);	mymtd = do_map_probe("amd_flash", &s3c2440_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:							NFCONT &= ~NFCONT_nFCE_HIGH; 					break;	case NAND_CTL_CLRNCE:		NFCONT |= NFCONT_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;	case NAND_CTL_CLRRnB:					NFSTAT |= NFSTAT_RnB;					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 */	}}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 S3C2440.\n");		this->data_buf = NULL;		return -ENOMEM;    }    return 0;}static intsmc_init(void){	struct nand_chip *this;	//u_int16_t nfconf;	u_int16_t nfcont;	/* 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 S3C2440 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 */	nfcont = NFCONT;	/* NAND Flash controller enable */	nfcont |= NFCONT_FCTRL_EN;	nfcont |= NFCONT_ECC_INIT;	nfcont |= NFCONT_MAINECC_LOCK;	NFCONT = nfcont;			/* Set flash memory timing *///	nfconf &= ~NFCONF_TWRPH1;//	nfconf |=  NFCONF_TWRPH1_7;	//	nfconf &= ~NFCONF_TWRPH0;//	nfconf |=  NFCONF_TWRPH0_7;//	nfconf &= ~NFCONF_TACLS;//	nfconf &= ~NFCONF_TACLS_7;	//	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_S3C2440_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一区二区三区免费野_久草精品视频
2020国产成人综合网| 欧美老女人在线| 国内精品嫩模私拍在线| 亚洲午夜精品久久久久久久久| 国产亚洲欧美在线| 久久久精品国产99久久精品芒果| 久久综合九色综合欧美就去吻| 欧美大白屁股肥臀xxxxxx| 欧美精品aⅴ在线视频| 在线观看一区日韩| 欧美亚洲国产一区在线观看网站| 色婷婷久久综合| 欧美色偷偷大香| 91精品国产入口| 精品国产一区二区三区久久久蜜月| 精品国产一区二区亚洲人成毛片 | 老司机免费视频一区二区三区| 亚洲高清不卡在线| 青青草伊人久久| 久久99精品久久久久久动态图| 国产精品中文字幕欧美| 国产综合久久久久久鬼色| 成人在线综合网| 色婷婷av一区二区三区软件| 69堂国产成人免费视频| 久久这里都是精品| 亚洲综合色噜噜狠狠| 日韩vs国产vs欧美| 国产成人av电影在线观看| 日本久久电影网| 日韩欧美亚洲国产精品字幕久久久| 国产喷白浆一区二区三区| 亚洲另类春色国产| 久久成人av少妇免费| 99久精品国产| 精品奇米国产一区二区三区| 国产精品久久久久久久久搜平片| 一区二区三区国产| 国产毛片精品视频| 欧美性高清videossexo| 久久综合色之久久综合| 一卡二卡三卡日韩欧美| 国产成人综合在线| 欧美丰满少妇xxxbbb| 国产精品色婷婷久久58| 蜜桃av一区二区三区| 色综合中文字幕国产| 精品成人一区二区三区四区| 亚洲一区二区高清| 成人的网站免费观看| 欧美zozo另类异族| 视频一区视频二区中文| av在线播放不卡| 久久综合色综合88| 免费观看一级欧美片| 色噜噜偷拍精品综合在线| 久久久亚洲高清| 免费在线看成人av| 欧美日韩一区二区三区不卡| 国产精品久久久99| 粉嫩av亚洲一区二区图片| 欧美成人精品福利| 日韩二区在线观看| 欧美人妇做爰xxxⅹ性高电影| 中文字幕日韩一区| 国产.欧美.日韩| 国产亚洲综合av| 国产一区二区视频在线| 日韩精品影音先锋| 奇米精品一区二区三区在线观看一| 91国内精品野花午夜精品 | 国产成人精品免费一区二区| 91精品在线免费观看| 亚洲成人综合网站| 欧美写真视频网站| 亚洲一区二区精品3399| 欧美日韩一区三区四区| 亚洲国产精品久久久久婷婷884 | 欧美日韩精品综合在线| 亚洲国产sm捆绑调教视频| 日本高清不卡视频| 亚洲一二三区不卡| 制服丝袜一区二区三区| 青青草国产精品97视觉盛宴| 欧美成人精品二区三区99精品| 免费av成人在线| 精品国产乱码久久久久久影片| 另类小说色综合网站| 精品三级av在线| 国产91综合网| 亚洲欧美日韩中文字幕一区二区三区| 97久久超碰精品国产| 亚洲综合一区二区精品导航| 69堂国产成人免费视频| 国产精品中文字幕日韩精品| 中文字幕亚洲一区二区av在线| 99精品久久只有精品| 亚洲一二三区不卡| 精品久久国产字幕高潮| www.欧美色图| 天堂一区二区在线免费观看| 精品国内片67194| 91农村精品一区二区在线| 午夜精品成人在线视频| 精品卡一卡二卡三卡四在线| 高清成人在线观看| 亚洲高清视频中文字幕| 久久日韩粉嫩一区二区三区| 色哟哟一区二区在线观看| 免费看欧美女人艹b| 国产精品免费久久久久| 欧美老肥妇做.爰bbww视频| 国产在线精品免费| 亚洲精品国久久99热| 日韩欧美在线一区二区三区| gogogo免费视频观看亚洲一| 天堂久久一区二区三区| 日本一区二区三级电影在线观看 | 精品伦理精品一区| 91麻豆精品一区二区三区| 人人精品人人爱| 亚洲男人电影天堂| 久久综合成人精品亚洲另类欧美| 91香蕉视频黄| 国产在线视频一区二区三区| 亚洲永久免费视频| 国产日韩欧美制服另类| 91精品国产福利| 在线欧美一区二区| 成人福利在线看| 国产在线一区二区| 性做久久久久久免费观看| 国产精品久久久久久久久免费相片| 日韩精品一区在线| 欧美日韩成人激情| 91精品办公室少妇高潮对白| 久久er精品视频| 日韩电影在线观看网站| 一区二区三区欧美视频| 亚洲欧洲精品一区二区精品久久久| 欧美精品丝袜中出| 欧美日韩综合在线| 欧洲精品在线观看| 91国偷自产一区二区开放时间| zzijzzij亚洲日本少妇熟睡| 久久精品噜噜噜成人88aⅴ| 亚洲午夜羞羞片| 亚洲综合视频在线| 亚洲色图欧美激情| 一区二区中文视频| 亚洲男同1069视频| 亚洲最新视频在线观看| 亚洲视频香蕉人妖| 亚洲欧美另类在线| 一区二区三区中文免费| 亚洲一区二区三区在线播放| 亚洲精品大片www| 亚洲电影在线免费观看| 亚洲一区二区精品久久av| 亚洲成av人片在www色猫咪| 亚洲精品高清在线观看| 亚洲国产视频a| 一区二区欧美国产| 亚洲影视在线观看| 免费在线观看不卡| 狠狠色丁香婷婷综合久久片| 秋霞电影一区二区| 激情综合色播五月| 久久精品国产澳门| 久久精品国产网站| 国产电影一区在线| av福利精品导航| 欧美亚洲免费在线一区| 日韩欧美中文一区| 久久精品视频一区二区| 国产精品久久毛片a| 亚洲欧美日韩国产另类专区| 亚洲国产cao| 韩国v欧美v亚洲v日本v| 不卡高清视频专区| 欧美美女激情18p| www亚洲一区| 亚洲欧美韩国综合色| 蜜臀av性久久久久蜜臀av麻豆| 国产91富婆露脸刺激对白| 91在线观看美女| 欧美日韩国产高清一区二区三区| 日韩欧美在线一区二区三区| 国产精品麻豆视频| 丝袜美腿成人在线| 成人av电影在线网| 91精品国产综合久久精品图片 | 欧美日本在线播放| 国产欧美日韩麻豆91| 亚洲一二三专区| 高清av一区二区| 欧美久久久久久久久| 中文字幕乱码日本亚洲一区二区 | 欧美三级资源在线| 国产精品久久99|