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

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

?? s3c2410_flash.c

?? arm9的bootloader,適合通用2410x平臺 vivi.pal(20051228)支持tv輸出和vga輸出
?? 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一区二区三区免费野_久草精品视频
蜜桃久久精品一区二区| 亚洲国产精品t66y| 午夜精品久久久久久久久久| 精品婷婷伊人一区三区三| 亚洲成a天堂v人片| 日韩午夜激情av| 久久91精品久久久久久秒播| 久久久不卡影院| 丁香桃色午夜亚洲一区二区三区| 国产日韩欧美激情| 91香蕉视频污在线| 夜夜嗨av一区二区三区四季av | 一区在线观看免费| 91免费版在线| 日韩一区精品视频| 国产欧美中文在线| 99久久精品久久久久久清纯| 亚洲成av人在线观看| 精品国产91久久久久久久妲己| 成人免费黄色在线| 亚洲成人第一页| 国产亚洲人成网站| 欧洲精品一区二区| 激情欧美一区二区三区在线观看| 国产精品视频观看| 欧美亚洲国产一区二区三区va| 免费看日韩精品| 中文字幕精品三区| 91麻豆精品国产自产在线| 国产乱人伦偷精品视频免下载 | 亚洲精品写真福利| 日韩欧美久久一区| 色综合久久天天| 精品一区二区三区免费播放| 亚洲三级在线免费| 精品精品欲导航| 91女人视频在线观看| 久久精品国产亚洲高清剧情介绍| 亚洲视频小说图片| 久久亚洲捆绑美女| 精品视频一区三区九区| 大胆欧美人体老妇| 久久精品噜噜噜成人av农村| 亚洲精品自拍动漫在线| 久久嫩草精品久久久精品| 欧美女孩性生活视频| 97久久人人超碰| 国产成人一区在线| 美女精品自拍一二三四| 亚洲视频小说图片| 国产午夜精品久久久久久免费视| 欧美日韩免费在线视频| 99久久精品国产导航| 国产精品白丝jk黑袜喷水| 三级久久三级久久久| 亚洲综合av网| 亚洲欧美激情视频在线观看一区二区三区| 日韩一区二区三区精品视频| 欧美三级中文字幕| 色综合久久中文综合久久97| 成人综合婷婷国产精品久久| 精品一区二区三区免费毛片爱| 午夜精品久久久久久不卡8050| 亚洲欧美电影一区二区| 亚洲国产精品成人综合色在线婷婷| 日韩欧美亚洲国产精品字幕久久久| 欧美日韩国产成人在线免费| 在线观看一区日韩| 色狠狠一区二区| 在线观看av一区二区| 色素色在线综合| 色婷婷一区二区三区四区| 不卡的电视剧免费网站有什么| 国产精品亚洲综合一区在线观看| 精品中文av资源站在线观看| 久久国产精品第一页| 老司机精品视频线观看86| 日韩激情av在线| 日本三级亚洲精品| 免费在线欧美视频| 精品在线亚洲视频| 国产东北露脸精品视频| 国产成人综合亚洲网站| 国产福利一区二区三区视频| 国产成人午夜电影网| 福利一区二区在线观看| 成人app在线观看| 色综合久久88色综合天天6| 色综合久久久久| 欧美日韩精品久久久| 欧美精品高清视频| 日韩天堂在线观看| 久久免费视频色| 中文字幕在线观看不卡视频| 亚洲乱码国产乱码精品精的特点 | 在线观看国产日韩| 欧美久久久久久久久久| 欧美变态tickle挠乳网站| 亚洲精品在线电影| 国产精品大尺度| 午夜精品久久久久久久99樱桃| 麻豆成人免费电影| 成a人片国产精品| 欧美色成人综合| 欧美精品一区二区不卡| 中文字幕在线观看不卡视频| 亚洲国产你懂的| 久久国产福利国产秒拍| 不卡欧美aaaaa| 欧美精品丝袜中出| 久久久不卡网国产精品二区| 亚洲欧美综合另类在线卡通| 午夜精品一区二区三区免费视频| 精品一二线国产| 色婷婷综合久久久久中文一区二区 | 中文字幕亚洲在| 日韩专区中文字幕一区二区| 国产在线播精品第三| 99国产精品99久久久久久| 91精品国产欧美一区二区18| 国产免费观看久久| 婷婷成人激情在线网| 国产成人一区在线| 7777精品伊人久久久大香线蕉完整版| 久久先锋资源网| 午夜在线电影亚洲一区| 国产**成人网毛片九色 | 欧美一级理论片| 亚洲丝袜美腿综合| 狠狠色狠狠色合久久伊人| 欧美中文字幕一区二区三区| 久久久久久久久97黄色工厂| 亚洲成a人在线观看| 99视频有精品| 国产亚洲视频系列| 日本欧美大码aⅴ在线播放| 91影视在线播放| 久久天堂av综合合色蜜桃网| 视频在线观看一区二区三区| 99久久婷婷国产综合精品电影| 亚洲精品一区二区三区99| 香港成人在线视频| 色视频成人在线观看免| 国产精品入口麻豆原神| 韩国女主播成人在线| 欧美男同性恋视频网站| 一区二区三区电影在线播| zzijzzij亚洲日本少妇熟睡| 26uuu国产日韩综合| 日本aⅴ亚洲精品中文乱码| 91成人在线精品| 一区二区三区在线免费视频| 成人在线视频首页| 久久精品视频免费| 韩国三级中文字幕hd久久精品| 5月丁香婷婷综合| 视频在线观看91| 欧美日韩国产另类一区| 亚洲综合色噜噜狠狠| 色美美综合视频| 亚洲欧美日韩成人高清在线一区| 盗摄精品av一区二区三区| 久久精品水蜜桃av综合天堂| 国产一区欧美日韩| 久久久久久日产精品| 国产一区二区免费看| 久久亚洲一区二区三区四区| 久久91精品久久久久久秒播| 精品国产91乱码一区二区三区 | 国产中文字幕一区| 精品国产电影一区二区| 国产一区二区福利| 国产日韩精品久久久| 国产69精品久久777的优势| 日本一区二区三区四区| 成人ar影院免费观看视频| 自拍偷拍亚洲综合| 色狠狠一区二区三区香蕉| 亚洲午夜精品17c| 欧美日韩成人在线| 久久97超碰色| 欧美国产日韩精品免费观看| 日韩一二三区视频| 国产一区在线观看麻豆| 中文一区一区三区高中清不卡| 99re热视频这里只精品| 亚洲午夜一二三区视频| 在线成人av网站| 国产在线精品一区二区不卡了 | 亚洲欧美另类久久久精品| 91啦中文在线观看| 亚洲成av人**亚洲成av**| 91精品国产综合久久精品| 国产在线播精品第三| 国产精品久久久久影院色老大| 91老司机福利 在线| 日韩高清在线不卡| 精品久久一区二区| 99综合电影在线视频| 日本成人在线网站|