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

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

?? s3c2410_flash.c

?? vivi bootloader 主要是初始化內(nèi)核
?? C
字號(hào):
/* * 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;}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品亚洲aⅴ乱码一区二区三区| 欧美日韩成人激情| 国产精品亚洲一区二区三区在线| 石原莉奈一区二区三区在线观看| 亚洲一区中文日韩| 亚洲综合成人在线| 性做久久久久久免费观看欧美| 亚洲图片欧美色图| 亚洲成人午夜影院| 免费在线一区观看| 精品在线一区二区三区| 麻豆成人久久精品二区三区小说| 另类小说图片综合网| 国产一区二区三区最好精华液| 精品在线视频一区| 国产1区2区3区精品美女| 国产成人精品三级| www.欧美色图| 在线亚洲一区二区| 欧美日韩成人在线| 精品久久久久久久久久久院品网| 国产亚洲一二三区| 亚洲欧美在线高清| 亚洲国产综合91精品麻豆| 午夜精品久久久久久不卡8050| 日本中文字幕不卡| 国产尤物一区二区在线 | 99久久综合色| 91极品美女在线| 91精品国产综合久久久久久漫画| 欧美成人女星排行榜| 国产精品美女久久久久久久| 一区二区三区四区高清精品免费观看 | 欧美日韩卡一卡二| 欧美精品一区二区精品网| 国产日韩欧美麻豆| 亚洲午夜精品在线| 国产成人免费网站| 91久久线看在观草草青青| 欧美一卡二卡三卡四卡| 欧美激情一区三区| 午夜视频在线观看一区| 国产曰批免费观看久久久| 91成人在线观看喷潮| 精品国产91九色蝌蚪| 18欧美亚洲精品| 日韩高清欧美激情| 欧美日韩精品欧美日韩精品| 欧美成人精品福利| 亚洲欧美日韩国产另类专区| 免费在线观看一区| 色综合久久66| 精品国产乱码久久久久久牛牛| 亚洲欧美日韩国产另类专区| 久久超碰97人人做人人爱| 色综合久久综合网97色综合 | 精品国产乱子伦一区| 一区二区三区国产精华| 国产乱子伦视频一区二区三区| 日本久久电影网| 久久中文娱乐网| 亚洲一本大道在线| 99视频有精品| 2020国产精品| 五月婷婷欧美视频| 不卡一区在线观看| 精品欧美黑人一区二区三区| 亚洲精品成人a在线观看| 国产成人自拍在线| 精品国产一区二区三区不卡 | 欧美激情资源网| 免费观看日韩av| 在线欧美一区二区| 自拍偷拍欧美精品| 国产成人av在线影院| 欧美精品一区二区不卡 | aaa国产一区| 精品国产伦一区二区三区观看方式 | 日韩一级成人av| 亚洲一区二三区| 99精品视频在线播放观看| 日本一区二区三区免费乱视频| 六月婷婷色综合| 欧美一区欧美二区| 亚洲18女电影在线观看| 欧洲视频一区二区| 自拍视频在线观看一区二区| 国产精品1024| 久久久www成人免费毛片麻豆| 久热成人在线视频| 91精品中文字幕一区二区三区| 亚洲综合一二三区| 99re6这里只有精品视频在线观看| 久久精品人人做人人爽97| 国产中文字幕精品| 精品国产凹凸成av人网站| 免费成人在线播放| 日韩欧美电影在线| 蜜桃视频在线观看一区二区| 一区二区三区**美女毛片| 成人高清视频在线观看| 国产精品午夜免费| 成人三级伦理片| 国产女人18水真多18精品一级做| 国产呦精品一区二区三区网站| 精品成人一区二区| 国产专区综合网| 久久久久久久久久久久久久久99 | 樱桃国产成人精品视频| 色婷婷狠狠综合| 一片黄亚洲嫩模| 欧美午夜精品免费| 天天色 色综合| 4438x成人网最大色成网站| 蜜桃视频在线一区| 国产亚洲欧美一级| 99re视频这里只有精品| 亚洲免费观看高清完整版在线| 99在线精品观看| 亚洲无线码一区二区三区| 欧美一级一区二区| 国产自产视频一区二区三区| 国产精品视频观看| 日本久久一区二区| 日韩不卡在线观看日韩不卡视频| 欧美大片日本大片免费观看| 狠狠久久亚洲欧美| 中文字幕在线不卡国产视频| 91久久人澡人人添人人爽欧美| 日韩中文字幕不卡| 久久人人爽爽爽人久久久| av电影天堂一区二区在线观看| 亚洲精品日日夜夜| 日韩一级片网站| 成人午夜视频福利| 亚洲小少妇裸体bbw| 亚洲国产日产av| 日韩免费在线观看| 99久久er热在这里只有精品15| 亚洲网友自拍偷拍| 久久先锋影音av| 在线亚洲精品福利网址导航| 奇米777欧美一区二区| 日本一区二区视频在线观看| 欧美性受xxxx| 国产一区二区导航在线播放| 亚洲精品视频免费观看| xf在线a精品一区二区视频网站| 99这里只有久久精品视频| 日日夜夜精品视频免费| 亚洲国产经典视频| 3atv一区二区三区| 成人av免费观看| 日韩av在线发布| 亚洲视频一区在线观看| 精品粉嫩超白一线天av| 一本久久a久久精品亚洲| 极品少妇xxxx精品少妇| 亚洲精品久久7777| 久久精品亚洲乱码伦伦中文 | 亚洲天堂2016| 日韩欧美在线网站| 色婷婷久久综合| 国产真实精品久久二三区| 亚洲一区二区三区中文字幕| 久久久精品日韩欧美| 91麻豆精品国产自产在线观看一区 | 在线视频国内自拍亚洲视频| 国产一区欧美一区| 午夜免费久久看| 国产精品女人毛片| 精品国产露脸精彩对白| 欧美日韩久久久一区| 91在线你懂得| 国产精品一二三四五| 免费在线观看精品| 亚洲成国产人片在线观看| 中文字幕一区二区三区不卡在线| 精品久久久久久久久久久院品网| 欧美三级蜜桃2在线观看| aaa欧美日韩| 国产成人亚洲综合a∨婷婷图片| 男人的j进女人的j一区| 亚洲国产精品久久一线不卡| 国产精品电影院| 日本一区二区三区在线观看| 久久影院午夜片一区| 欧美一区二区三区日韩视频| 欧美色区777第一页| 日本高清不卡视频| 色吧成人激情小说| 91蜜桃免费观看视频| 国产乱码字幕精品高清av| 久久99国产精品成人| 美女视频一区二区三区| 日韩电影网1区2区| 日韩高清不卡在线| 免费不卡在线观看| 免费看欧美美女黄的网站| 天天射综合影视|