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

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

?? s3c2440_flash.c

?? s3c 2440 vivi源代碼
?? C
字號(hào):
/* * 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;}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美成人一区二区三区片免费 | 自拍偷拍欧美精品| 欧美日韩国产美| 成人一级片网址| 奇米色一区二区| 综合在线观看色| 国产女人18毛片水真多成人如厕| 7777精品久久久大香线蕉| 大尺度一区二区| 国产一区中文字幕| 天天操天天干天天综合网| 亚洲欧洲三级电影| 久久久亚洲精品石原莉奈| 日韩一区二区视频| 欧美色综合影院| 91在线丨porny丨国产| 国产剧情一区二区| 国内欧美视频一区二区| 天天综合色天天综合| 亚洲激情在线播放| 亚洲欧洲av另类| 国产嫩草影院久久久久| 精品乱人伦小说| 日韩一区二区三区四区| 欧美精品日韩综合在线| 欧美婷婷六月丁香综合色| 91蜜桃视频在线| 99在线精品免费| eeuss鲁片一区二区三区在线观看| 国产真实精品久久二三区| 欧美aaaaa成人免费观看视频| 亚洲大片免费看| 亚洲成人手机在线| 日韩制服丝袜av| 天天影视涩香欲综合网| 日韩国产欧美三级| 美女www一区二区| 麻豆精品在线看| 美女视频一区二区三区| 久久99久久久欧美国产| 久久9热精品视频| 国产裸体歌舞团一区二区| 国产在线不卡视频| 粗大黑人巨茎大战欧美成人| 成人毛片老司机大片| 91网站黄www| 在线观看av一区| 欧美精品精品一区| 日韩三级电影网址| 久久免费看少妇高潮| 91免费视频观看| 青青草国产精品亚洲专区无| 夜夜揉揉日日人人青青一国产精品| 国产日韩欧美a| 中文字幕高清不卡| 亚洲欧美日韩国产手机在线| 亚洲另类在线制服丝袜| 日韩中文字幕区一区有砖一区 | 成人免费一区二区三区视频 | 日韩精品一区第一页| 久久精品国产亚洲aⅴ| 国产一区二区三区在线观看免费视频| 国内精品在线播放| www.日韩精品| 欧美日韩国产免费| 亚洲尤物在线视频观看| 亚洲国产成人高清精品| 捆绑调教美女网站视频一区| 国产成人精品综合在线观看| 91老司机福利 在线| 欧美日本在线视频| 欧美成人精品二区三区99精品| 中文字幕av不卡| 亚洲高清免费一级二级三级| 久久91精品国产91久久小草| 成人国产精品免费观看| 欧美色中文字幕| 久久综合久久综合九色| 一区二区三区免费| 国内精品视频一区二区三区八戒 | 成人动漫一区二区三区| 欧美视频一区二区三区在线观看| 26uuu精品一区二区| 亚洲色图一区二区| 精品一区精品二区高清| 色综合天天做天天爱| 日韩精品一区二区三区四区| 亚洲色大成网站www久久九九| 秋霞午夜av一区二区三区| 99精品欧美一区| 欧美成人欧美edvon| 亚洲一区二区三区不卡国产欧美 | gogo大胆日本视频一区| 日韩欧美国产wwwww| 亚洲欧美日韩一区二区 | 亚洲午夜一区二区三区| 国产成人夜色高潮福利影视| 欧美日韩国产中文| 亚洲欧美在线另类| 久久99精品久久久久婷婷| 欧美体内she精视频| 国产精品久久久久久亚洲毛片| 日韩精品每日更新| 99免费精品在线观看| 久久无码av三级| 免费一级片91| 欧美日韩欧美一区二区| 1000精品久久久久久久久| 国产精品羞羞答答xxdd| 日韩一卡二卡三卡国产欧美| 亚洲黄色av一区| jlzzjlzz亚洲日本少妇| 国产情人综合久久777777| 日韩精品1区2区3区| 精品视频在线免费看| 亚洲欧洲三级电影| 成人sese在线| 国产亚洲欧美日韩在线一区| 狠狠色丁香久久婷婷综合_中| 欧美三级一区二区| 亚洲一区二区三区三| 色婷婷综合五月| 亚洲男人天堂av网| 92精品国产成人观看免费| 国产精品不卡在线观看| 成人国产免费视频| 国产精品久久久久影视| 高清日韩电视剧大全免费| 精品国产91亚洲一区二区三区婷婷| 日韩av一二三| 日韩一级高清毛片| 激情成人午夜视频| 精品国产乱码久久久久久久久 | 色香蕉成人二区免费| 专区另类欧美日韩| 91亚洲精品乱码久久久久久蜜桃| 国产精品久久久久永久免费观看| 成人高清免费观看| 亚洲丝袜制服诱惑| 色噜噜夜夜夜综合网| 午夜一区二区三区视频| 91精品国产色综合久久不卡电影 | 欧美高清精品3d| 日本vs亚洲vs韩国一区三区二区| 在线播放中文一区| 久久国产生活片100| 久久中文字幕电影| 国产91精品免费| 亚洲天堂av老司机| 欧美丝袜丝交足nylons图片| 日韩精品91亚洲二区在线观看| 日韩欧美www| 国产精品一区在线| 最新久久zyz资源站| 欧美中文字幕亚洲一区二区va在线 | 日本电影亚洲天堂一区| 一个色综合网站| 91精品国模一区二区三区| 老司机精品视频一区二区三区| 久久婷婷成人综合色| 成人一区二区在线观看| 亚洲欧美精品午睡沙发| 欧美巨大另类极品videosbest| 激情综合网av| 亚洲色图清纯唯美| 欧美一区二区网站| 国产99久久精品| 亚洲成av人片观看| 久久久久久久久97黄色工厂| 91亚洲精品乱码久久久久久蜜桃 | 久久狠狠亚洲综合| 亚洲色图20p| 欧美成人vr18sexvr| 处破女av一区二区| 亚洲成人福利片| 国产亚洲综合av| 欧美在线小视频| 国产激情一区二区三区四区 | 欧美人体做爰大胆视频| 国产精品白丝jk黑袜喷水| 一区二区成人在线| 久久日韩精品一区二区五区| 91国偷自产一区二区使用方法| 蜜桃av噜噜一区二区三区小说| 国产精品久久久久久久久免费桃花| 欧美另类z0zxhd电影| 大白屁股一区二区视频| 日韩av网站免费在线| 亚洲视频每日更新| 久久久午夜精品理论片中文字幕| 欧美日韩一区二区三区在线| 国产一区999| 日韩avvvv在线播放| 亚洲人成小说网站色在线| 精品99一区二区| 欧美日韩国产片| 一本大道综合伊人精品热热| 国产一区二区三区在线观看精品| 亚洲国产精品一区二区www| 中文字幕亚洲精品在线观看|