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

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

?? s3c2410_flash.c

?? 編譯通過的s3c2410vivi源代碼
?? 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一区二区三区免费野_久草精品视频
国产精品久久一级| 日本精品裸体写真集在线观看| 不卡的av电影在线观看| 欧美精品一区二区精品网| 日韩av一区二| 欧美一区二区三区日韩视频| 蜜臀va亚洲va欧美va天堂 | ww久久中文字幕| 青青草伊人久久| 日韩欧美国产小视频| 蜜桃av噜噜一区二区三区小说| 91精品国产综合久久小美女| 一区二区三区欧美日韩| 欧日韩精品视频| 日韩专区中文字幕一区二区| 日韩一区二区电影网| 韩国理伦片一区二区三区在线播放 | 色综合天天做天天爱| 亚洲三级久久久| 欧美视频中文字幕| 日日夜夜一区二区| 欧美一二三区在线| 视频一区国产视频| 欧美一区二区播放| 丁香激情综合五月| 亚洲精品水蜜桃| 777a∨成人精品桃花网| 韩日av一区二区| 国产精品久久久久久一区二区三区| 99久久综合精品| 亚洲一区二区三区四区不卡| 欧美一区二区大片| 粉嫩av亚洲一区二区图片| 亚洲精品国久久99热| 欧美精品日韩一本| 国产激情偷乱视频一区二区三区| 国产欧美精品日韩区二区麻豆天美| 高清国产一区二区三区| 夜夜操天天操亚洲| 欧美成人video| www.在线成人| 日韩vs国产vs欧美| 中文字幕一区二区三区在线观看| 欧美日韩综合一区| 国产精品一区二区三区乱码| 一区二区三区视频在线看| 日韩久久久久久| heyzo一本久久综合| 首页综合国产亚洲丝袜| 精品乱人伦小说| 色综合天天综合色综合av| 蜜臀av性久久久久蜜臀aⅴ流畅| 国产精品免费视频一区| 欧美一级视频精品观看| caoporn国产精品| 美女视频黄 久久| 亚洲欧美日韩综合aⅴ视频| 精品国产三级电影在线观看| 91官网在线观看| 国产成人av自拍| 男女男精品网站| 一区二区三区欧美亚洲| 中文字幕在线一区免费| 精品国产一二三区| 91福利小视频| 天天影视涩香欲综合网| 国产亚洲成aⅴ人片在线观看 | 国产馆精品极品| 中文字幕在线不卡一区二区三区| 欧美日韩dvd在线观看| 91亚洲国产成人精品一区二三| 韩国av一区二区| 日韩不卡手机在线v区| 亚洲福利视频一区二区| 综合网在线视频| 久久久91精品国产一区二区精品 | 国产精品一区二区久久精品爱涩| 日日骚欧美日韩| 亚洲欧美电影院| 国产精品国产三级国产专播品爱网 | 亚洲人成精品久久久久| 国产女人aaa级久久久级| 日韩一区二区在线观看视频播放| 欧美日韩一区国产| 色婷婷综合中文久久一本| 成人黄色免费短视频| 日本女优在线视频一区二区| 亚洲夂夂婷婷色拍ww47| 一区二区三区日韩在线观看| 亚洲天堂av老司机| 成人免费一区二区三区在线观看| 国产欧美精品一区二区三区四区| 久久久国产午夜精品| 欧美嫩在线观看| 色婷婷av一区二区三区软件 | 久久国内精品视频| 免费在线一区观看| 精品一区二区三区在线播放视频| 蜜臀精品一区二区三区在线观看 | 欧美色精品在线视频| 欧美日韩精品一区二区在线播放| 欧美日韩国产高清一区二区三区| 欧美伊人久久久久久午夜久久久久| 91麻豆自制传媒国产之光| 成人精品国产一区二区4080| 91视频观看视频| 99久久精品国产导航| 日本道色综合久久| 欧美日韩国产一级片| 日韩欧美123| 久久看人人爽人人| 国产精品国产三级国产| 亚洲国产毛片aaaaa无费看| 亚洲成a人v欧美综合天堂| 男人的天堂亚洲一区| 国产露脸91国语对白| 国产精一品亚洲二区在线视频| 国产91在线观看| 日本韩国欧美在线| 欧美一卡2卡3卡4卡| 国产欧美一区二区精品久导航| 国产精品午夜电影| 亚洲一区二区三区激情| 蜜臀a∨国产成人精品| 国产美女在线观看一区| 成人动漫中文字幕| 欧美视频一区在线| 亚洲精品在线观看网站| 国产精品国产三级国产普通话三级 | 国产校园另类小说区| 亚洲美女区一区| 蜜桃视频在线观看一区二区| 顶级嫩模精品视频在线看| 欧美三级电影网站| 久久精品日韩一区二区三区| 亚洲午夜av在线| 亚洲成人自拍偷拍| 国产精品自产自拍| 欧美性视频一区二区三区| 2020国产精品自拍| 亚洲妇女屁股眼交7| 国产精品1024| 精品国产91洋老外米糕| 亚洲一级电影视频| 色综合久久天天| 中文字幕欧美日韩一区| 国产一区二区三区久久悠悠色av| 7777精品伊人久久久大香线蕉的 | 日韩国产一二三区| 欧美中文字幕不卡| 亚洲精品福利视频网站| 成人免费视频国产在线观看| 精品对白一区国产伦| 裸体一区二区三区| 91.com视频| 无吗不卡中文字幕| 在线观看欧美黄色| 亚洲蜜桃精久久久久久久| 99久久伊人久久99| 国产欧美一区二区三区鸳鸯浴| 精品一区二区三区的国产在线播放| 制服丝袜在线91| 日本亚洲最大的色成网站www| 欧美日韩另类一区| 日韩av中文字幕一区二区| 777xxx欧美| 激情五月婷婷综合| 精品少妇一区二区三区视频免付费| 日韩av中文在线观看| 日韩欧美高清一区| 国产在线精品视频| 久久久美女艺术照精彩视频福利播放| 极品少妇一区二区| 国产三级欧美三级| av电影在线不卡| 亚洲已满18点击进入久久| 色国产精品一区在线观看| 一个色在线综合| 777久久久精品| 国产一区二区三区不卡在线观看 | 国产亚洲短视频| 99国产精品视频免费观看| 亚洲视频一区二区免费在线观看| 91福利视频久久久久| 奇米色一区二区| 国产亚洲欧美日韩在线一区| eeuss鲁片一区二区三区在线观看| 亚洲欧美二区三区| 欧美一区二区免费观在线| 国产一区二三区| 成人欧美一区二区三区黑人麻豆 | 91亚洲精品一区二区乱码| 亚洲一区二区视频在线| 精品国精品国产| av亚洲精华国产精华| 日韩在线a电影| 中国av一区二区三区| 欧美日韩亚州综合| 国产精品自拍三区| 亚洲韩国一区二区三区|