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

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

?? s3c2410_flash.c

?? 此代碼為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: 2004/02/04 10:37:37 $ * * $Revision: 1.1.1.1 $ * $Id: s3c2410_flash.c,v 1.1.1.1 2004/02/04 10:37:37 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_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一区二区三区免费野_久草精品视频
久久国产乱子精品免费女| 91视频国产资源| 美女网站色91| 日韩国产在线观看一区| 视频一区视频二区中文| 婷婷中文字幕综合| 日韩高清欧美激情| 毛片基地黄久久久久久天堂| 蜜桃视频在线观看一区二区| 免费美女久久99| 国产专区欧美精品| 丁香桃色午夜亚洲一区二区三区| 国产电影精品久久禁18| 9久草视频在线视频精品| 色综合网站在线| 精品视频在线免费| 日韩一区二区精品| 久久日韩粉嫩一区二区三区| 国产精品私人自拍| 日韩美女精品在线| 五月天激情综合网| 国产在线精品一区二区三区不卡| 国产成人免费高清| 91激情在线视频| 欧美一级欧美三级在线观看| 久久久久国产精品麻豆| 国产精品欧美综合在线| 一区二区三区中文在线观看| 日韩av在线发布| 国产精品69毛片高清亚洲| 91视频www| 91精品婷婷国产综合久久性色| 欧美mv日韩mv国产网站app| 国产调教视频一区| 亚洲伊人色欲综合网| 久久99最新地址| av高清不卡在线| 欧美疯狂性受xxxxx喷水图片| 精品欧美乱码久久久久久1区2区| 国产精品免费aⅴ片在线观看| 亚洲综合小说图片| 国产精品亚洲午夜一区二区三区| 91麻豆成人久久精品二区三区| 51精品视频一区二区三区| 久久久精品影视| 亚洲无人区一区| 国产精品资源在线观看| 色香蕉久久蜜桃| 精品国产一区二区三区久久久蜜月 | 久久久精品综合| 亚洲久草在线视频| 国产一区二区三区香蕉| 91国内精品野花午夜精品| 久久久综合九色合综国产精品| 亚洲精品免费在线| 国产一区欧美一区| 欧美日免费三级在线| 日本一区二区三区在线观看| 天天综合色天天综合| 成人app网站| 精品电影一区二区| 亚洲大片精品永久免费| 成人精品视频一区二区三区尤物| 91.成人天堂一区| 亚洲人成网站精品片在线观看 | 91精品久久久久久久久99蜜臂| 欧美激情一区二区三区不卡| 日韩av一区二区三区四区| 波多野结衣中文字幕一区| 久久综合久久综合亚洲| 婷婷中文字幕一区三区| 色婷婷激情综合| 中文字幕第一区二区| 国产一区二区在线观看免费| 91精品国产综合久久蜜臀| 亚洲一区二区欧美激情| 99在线视频精品| 日本一区二区三区电影| 国产曰批免费观看久久久| 欧美电影免费观看高清完整版在线观看| 亚洲欧美色综合| 成人免费看片app下载| 精品国产乱码久久久久久久久| 亚洲国产精品久久久久秋霞影院| 99久久国产综合精品色伊 | 欧美a一区二区| 欧美日韩一区二区三区四区五区| 国产精品国产三级国产普通话99 | 欧美亚洲日本一区| 亚洲视频在线一区二区| 不卡一区在线观看| 国产精品欧美一级免费| 国产精品一区二区久激情瑜伽| 精品国产乱码久久久久久闺蜜| 免费在线观看视频一区| 欧美电影免费观看高清完整版在| 午夜不卡在线视频| 91精品国产综合久久香蕉的特点| 丝袜美腿亚洲综合| 6080国产精品一区二区| 蜜桃视频免费观看一区| 欧美一区二区三区四区久久| 三级在线观看一区二区| 欧美一级电影网站| 精品在线免费观看| 久久久99精品免费观看| 东方欧美亚洲色图在线| 亚洲色图欧洲色图| 91在线观看美女| 亚洲欧美日韩综合aⅴ视频| 欧洲色大大久久| 午夜精品福利在线| 日韩午夜在线观看视频| 精品一区免费av| 国产日产欧美一区| 91亚洲国产成人精品一区二三| 亚洲美女一区二区三区| 91黄色小视频| 欧美a一区二区| 国产欧美一区二区在线| av中文字幕一区| 性感美女久久精品| 精品国产伦一区二区三区观看体验 | 136国产福利精品导航| 91国偷自产一区二区使用方法| 亚洲午夜精品在线| 欧美成人三级在线| 丁香婷婷综合网| 亚洲午夜在线观看视频在线| 欧美一二三四区在线| 国产不卡一区视频| 一区二区三区在线影院| 欧美一区日本一区韩国一区| 国产一区在线精品| 亚洲裸体在线观看| 欧美一区永久视频免费观看| 国产福利精品导航| 一区二区成人在线观看| 日韩女优av电影在线观看| 成人高清在线视频| 午夜精品久久久久久久久| 久久久美女艺术照精彩视频福利播放| 99热这里都是精品| 日韩国产一区二| 中文字幕欧美国产| 欧美精品免费视频| 成人午夜激情影院| 日韩专区一卡二卡| 国产精品色婷婷久久58| 678五月天丁香亚洲综合网| 国产99久久久国产精品免费看| 亚洲电影激情视频网站| 国产午夜亚洲精品理论片色戒| 欧美伊人久久久久久久久影院| 国产美女av一区二区三区| 一区二区三区日韩欧美精品 | 美女视频黄久久| 亚洲欧美一区二区三区孕妇| 日韩欧美一级在线播放| 色综合夜色一区| 国产经典欧美精品| 日本不卡的三区四区五区| 亚洲少妇最新在线视频| 2023国产精品视频| 3d成人h动漫网站入口| jvid福利写真一区二区三区| 久久精品国产一区二区三区免费看 | 亚洲欧美日韩国产中文在线| 欧美tk—视频vk| 欧美肥妇bbw| 91看片淫黄大片一级| 激情综合网av| 日韩在线一二三区| 亚洲色图欧美偷拍| 国产精品网站在线观看| 欧美成人高清电影在线| 欧美日韩一区三区四区| 色综合久久天天| 成人精品亚洲人成在线| 激情国产一区二区| 日韩不卡一区二区三区 | 丁香另类激情小说| 韩国中文字幕2020精品| 免费人成在线不卡| 亚洲成a人v欧美综合天堂下载| 亚洲欧美日韩在线| 亚洲国产高清不卡| 久久久精品天堂| 久久新电视剧免费观看| 日韩精品在线网站| 91精品国产综合久久蜜臀| 欧美日韩一区二区电影| 色婷婷久久久久swag精品| 91蜜桃免费观看视频| 北岛玲一区二区三区四区| 国产精品18久久久久久久久| 国产在线精品国自产拍免费| 国模无码大尺度一区二区三区| 狠狠色丁香久久婷婷综| 韩国v欧美v亚洲v日本v|