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

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

?? bvd-ezx_mmc.c

?? 包含MMC協(xié)議,驅(qū)動源碼. 在LINUX操作系統(tǒng)下通過.
?? C
字號:
/* * drivers/mmc/bvd-ezx_mmc.c * Mainstone (bulverde-based) board-level MMC driver * * Copyright 2003 MontaVista Software Inc. * Author: MontaVista Software, Inc. *	   source@mvista.com * *  This program is free software; you can redistribute	 it and/or modify it *  under  the terms of	 the GNU General  Public License as published by the *  Free Software Foundation;  either version 2 of the	License, or (at your *  option) any later version. * *  THIS  SOFTWARE  IS PROVIDED	  ``AS	IS'' AND   ANY	EXPRESS OR IMPLIED *  WARRANTIES,	  INCLUDING, BUT NOT  LIMITED  TO, THE IMPLIED WARRANTIES OF *  MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.  IN *  NO	EVENT  SHALL   THE AUTHOR  BE	 LIABLE FOR ANY	  DIRECT, INDIRECT, *  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT *  NOT LIMITED	  TO, PROCUREMENT OF  SUBSTITUTE GOODS	OR SERVICES; LOSS OF *  USE, DATA,	OR PROFITS; OR	BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON *  ANY THEORY OF LIABILITY, WHETHER IN	 CONTRACT, STRICT LIABILITY, OR TORT *  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF *  THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * *  You should have received a copy of the  GNU General Public License along *  with this program; if not, write  to the Free Software Foundation, Inc., *  675 Mass Ave, Cambridge, MA 02139, USA. * * References to technical documents used in comments: * [1] - Intel(R) HCDDBVA0 Development Platform for Intel(R) PCA User's Guide * [2] - Intel(R) Bulverde Processor (B-Stepping) Developer's Manual *//* * Copyright 2003-2005 Motorola, Inc. All Rights Reserved. * Revision History:                    Modification     Changed by            Date             Description of Changes----------------   ------------      -------------------------Zhou Qiong          12/22/2003         modify for Motorola EZX platformjiang Lili          04/12/2005         modify for mmc card detect and 4 bit modejiang Lili          05/11/2005         remove warningLiu Anyu            11/15/2005         fix card detect GPIO issue*/#include <linux/module.h>#include <linux/version.h>#include <linux/init.h>#include <linux/sched.h>#include <linux/interrupt.h>#include <linux/mmc/mmc_ll.h>#include <asm/irq.h>        #include <asm/unaligned.h>#include <asm/io.h>#include <asm/arch/ezx.h>#include <asm/arch/hardware.h>#include "../misc/ssp_pcap.h"#include <linux/power_ic.h>#define VAP_MMC		0x00000B00#define VAP_MMC_MASK	0xFFFFF0FF/* Generic Bulverde MMC driver externals */extern void bvd_mmc_slot_up(void);extern void bvd_mmc_slot_down(void);extern int  bvd_mmc_slot_init(void);extern void bvd_mmc_slot_cleanup(void);extern void bvd_mmc_send_command(struct mmc_request *request);extern int  bvd_mmc_set_clock(u32 rate);static struct timer_list ezx_detection;extern int first_have_card;extern int mmc_slot_enable;enum {	MMC_CARD_REMOVED,	MMC_CARD_INSERTED} slot_state = MMC_CARD_REMOVED;u8 ezx_mmc_get_slot_state(void){    if (slot_state == MMC_CARD_REMOVED)    {        return 0;    }    else    {        return 1;    }}   EXPORT_SYMBOL(ezx_mmc_get_slot_state);/* Initialize the h/w to up the slot, assuming the card is in slot */static void ezx_mmc_slot_up(void) {	MOD_INC_USE_COUNT;	DEBUG(2, "Init MMC h/w\n");		bvd_mmc_slot_up();	slot_state = MMC_CARD_INSERTED;	DEBUG(2, "MMC h/w initialized\n");}/* Shut down the slot h/w */static void ezx_mmc_slot_down(void){	DEBUG(2, "down MMC h/w\n");		/* Disable the Bulverde MMC controller */	bvd_mmc_slot_down();		slot_state = MMC_CARD_REMOVED;	MOD_DEC_USE_COUNT;}/* Returns true if MMC slot is empty */static int ezx_mmc_slot_is_empty(int slot){	unsigned long	gpioval;	#ifdef CONFIG_ARCH_EZXBASE    gpioval = GPLR(GPIO_MMC_DETECT) & GPIO_bit(GPIO_MMC_DETECT);    if (gpioval)    {    	DEBUG(2, "check if triflash exist %lx is not empty.\n", gpioval);    	return 0;    }    else    {    	DEBUG(2, "check if triflash exist %lx is empty.\n", gpioval);    	return 1;    }#else		/* Check DAT3 for triflash card detection */	gpioval = GPLR(GPIO_MMC_DATA3) & GPIO_bit(GPIO_MMC_DATA3);	DEBUG(2, "check if triflash exist %lx\n", gpioval);		/* if triflash DAT3 is high, there is triflash card    */	if( GPLR(GPIO_MMC_DATA3) & GPIO_bit(GPIO_MMC_DATA3) )              	return 0;	else		return 1;#endif		}/* Called when MMC card is inserted into / removed from slot */void ezx_detect_handler(unsigned long data){        int empty;        DEBUG(2, "card detect handler\n");        empty = ezx_mmc_slot_is_empty(0);        if (slot_state == MMC_CARD_INSERTED && empty) {                DEBUG(2, "no card in slot\n");                mmc_slot_enable = 0;                ezx_mmc_slot_down();                mmc_eject(0);         } else if (slot_state == MMC_CARD_REMOVED && !empty) {                DEBUG(2, "found the card in slot\n");                ezx_mmc_slot_up();                mmc_insert(0);         }}static void ezx_detect_int(int irq, void *dev, struct pt_regs *regs){        DEBUG(0, ":card detect IRQ\n");        mod_timer(&ezx_detection, jiffies + HZ);}/* Initialize the slot and prepare software layer to operate with it */static int ezx_mmc_slot_init(void){	int retval;	retval = bvd_mmc_slot_init();	if (retval)		return retval;#ifdef CONFIG_ARCH_EZXBASE set_GPIO_mode(GPIO_MMC_DETECT | GPIO_IN);#ifndef CONFIG_ARCH_EZX_HAINAN		/* GPIO IRQ detection: GPIO 11 (SD_nCD) */	set_GPIO_IRQ_edge( GPIO_MMC_DETECT, GPIO_FALLING_EDGE | GPIO_RISING_EDGE);        /* Request card detect interrupt */	retval = request_irq(IRQ_GPIO(GPIO_MMC_DETECT), ezx_detect_int,			             SA_INTERRUPT | SA_SAMPLE_RANDOM, "MMC/SD card detect", (void*)1);         if(retval)         {                printk(KERN_ERR "MMC/SD: can't request MMC card detect IRQ\n");                 bvd_mmc_slot_cleanup();                 return -1;         }#endif#else		set_GPIO_mode(GPIO_MMC_DATA3 | GPIO_IN);        set_GPIO_IRQ_edge(GPIO_MMC_DATA3, GPIO_FALLING_EDGE | GPIO_RISING_EDGE);	if (GPLR(GPIO_MMC_DATA3) & 0x8000)        {            DEBUG(0,":GPIO 111 defaut is high\n");        }else            DEBUG(0,":GPIO 111 default is low\n");         	retval = request_irq(IRQ_GPIO(GPIO_MMC_DATA3), ezx_detect_int,                         SA_INTERRUPT | SA_SAMPLE_RANDOM, "MMC card detect", (void *)1);	 if(retval)	 {			 	printk(KERN_ERR "MMC/SD: can't request MMC card detect IRQ\n");	         bvd_mmc_slot_cleanup();        	 return -1;         }#endif		/* Making slot usable if the card present */#ifndef CONFIG_ARCH_EZX_HAINAN	if (!ezx_mmc_slot_is_empty(0)) 	{		first_have_card = 1;		ezx_mmc_slot_up();	}#else       if (!ezx_mmc_slot_is_empty(0))        {//has card           first_have_card = 1;           ezx_mmc_slot_up();           mmc_insert(0);       }       else //no card       {           mmc_slot_enable = 0;           ezx_mmc_slot_down();       }#endif	DEBUG(2, "MMC initialized\n");	return 0;}/* Shut down the slot and relax software about MMC slot */static void ezx_mmc_slot_cleanup(void){        long flags;        local_irq_save(flags); 	/* Shut down the slot */	ezx_mmc_slot_down();	bvd_mmc_slot_cleanup();	#ifdef CONFIG_ARCH_EZXBASE    free_irq(IRQ_GPIO(GPIO_MMC_DETECT),(void *)1);#else	free_irq(IRQ_GPIO(GPIO_MMC_DATA3),(void *)1);#endif	        local_irq_restore(flags);}static struct mmc_slot_driver ezx_dops = {	owner:		THIS_MODULE,	name:		"HCDDBBVA0 (Ezx) MMC/SD",	ocr:		1 << 15,  /* triflash voltage is 2.775V */	flags:		MMC_SDFLAG_MMC_MODE | MMC_SDFLAG_SD_MODE,	init:		ezx_mmc_slot_init,	cleanup:	ezx_mmc_slot_cleanup,	is_empty:	ezx_mmc_slot_is_empty,	send_cmd:	bvd_mmc_send_command,	set_clock:	bvd_mmc_set_clock,};int __init ezx_mmc_init(void){	int retval;	#ifdef CONFIG_ARCH_EZX_A780	unsigned long ssp_pcap_register_val;		/* close VAP_MMC (PCAP_VAUX3) */	SSP_PCAP_bit_clean(SSP_PCAP_ADJ_BIT_AUX_VREG_VAUX3_EN);	SSP_PCAP_bit_clean(SSP_PCAP_ADJ_BIT_AUX_VREG_VAUX3_EN);	mdelay(10);	/* open VAP_MMC (PCAP VAUX3) */	SSP_PCAP_read_data_from_PCAP(SSP_PCAP_ADJ_AUX_VREG_REGISTER, &ssp_pcap_register_val);		DEBUG(2, "\nSSP_PCAP_ADJ_AUX_VREG_REGISTER=0x%x\n", ssp_pcap_register_val);		ssp_pcap_register_val = (ssp_pcap_register_val & VAP_MMC_MASK) | VAP_MMC;	SSP_PCAP_write_data_to_PCAP(SSP_PCAP_ADJ_AUX_VREG_REGISTER, ssp_pcap_register_val);	SSP_PCAP_write_data_to_PCAP(SSP_PCAP_ADJ_AUX_VREG_REGISTER, ssp_pcap_register_val);	SSP_PCAP_bit_set(SSP_PCAP_ADJ_BIT_AUX_VREG_VAUX3_EN);	SSP_PCAP_bit_set(SSP_PCAP_ADJ_BIT_AUX_VREG_VAUX3_EN);		SSP_PCAP_read_data_from_PCAP(SSP_PCAP_ADJ_AUX_VREG_REGISTER, &ssp_pcap_register_val);		DEBUG(2, "SSP_PCAP_ADJ_AUX_VREG_REGISTER=0x%x\n", ssp_pcap_register_val);#else//	power_ic_periph_set_flash_card_on(POWER_IC_PERIPH_OFF);//	mdelay(10);			//PCAP restart done in arch_reset() system.h	power_ic_periph_set_flash_card_on(POWER_IC_PERIPH_ON);	udelay(1000);#endif		 init_timer(&ezx_detection);         ezx_detection.function = ezx_detect_handler;			PGSR(GPIO_MMC_CLK)  |=  GPIO_bit(GPIO_MMC_CLK);        PGSR(GPIO_MMC_CMD)  |=  GPIO_bit(GPIO_MMC_CMD);        PGSR(GPIO_MMC_DATA0)  |=  GPIO_bit(GPIO_MMC_DATA0);        PGSR(GPIO_MMC_DATA1)  |=  GPIO_bit(GPIO_MMC_DATA1);        PGSR(GPIO_MMC_DATA2)  |=  GPIO_bit(GPIO_MMC_DATA2);        PGSR(GPIO_MMC_DATA3)  |=  GPIO_bit(GPIO_MMC_DATA3);		/* The MMC clock is stopped at this point */	retval = mmc_register_slot_driver(&ezx_dops, 1);	if (retval < 0)		printk(KERN_INFO "MMC/SD: unable to register slot "		       "driver, error %d\n", retval);	DEBUG(3, "slot driver registered\n");	return retval;}void __exit ezx_mmc_exit(void){	mmc_unregister_slot_driver(&ezx_dops);		/* close VAP_MMC (PCAP_VAUX3) */#ifdef CONFIG_ARCH_EZX_A780 		SSP_PCAP_bit_clean(SSP_PCAP_ADJ_BIT_AUX_VREG_VAUX3_EN);	SSP_PCAP_bit_clean(SSP_PCAP_ADJ_BIT_AUX_VREG_VAUX3_EN);#else		power_ic_periph_set_flash_card_on(POWER_IC_PERIPH_OFF);#endif	DEBUG(3, "slot driver unregistered\n");}module_init(ezx_mmc_init);module_exit(ezx_mmc_exit);MODULE_AUTHOR("MontaVista Software, Inc. <source@mvista.com>");MODULE_DESCRIPTION("Motorola A780 triflash/MMC/SD driver");MODULE_LICENSE("GPL");

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩av不卡在线观看| 一区精品在线播放| 老鸭窝一区二区久久精品| 欧美一区二区三区在线看| 免费黄网站欧美| 久久午夜羞羞影院免费观看| 国产·精品毛片| 日韩伦理电影网| 欧美日韩亚洲综合| 九色综合国产一区二区三区| 亚洲高清在线精品| 欧美一级xxx| 韩国女主播成人在线观看| 国产欧美日韩一区二区三区在线观看| 成人avav影音| 性做久久久久久| 国产视频一区不卡| 欧美影视一区二区三区| 久久爱www久久做| 中文字幕人成不卡一区| 欧美精品自拍偷拍动漫精品| 国产主播一区二区| 一区二区三区国产精华| 精品日韩成人av| 不卡的av中国片| 日韩av午夜在线观看| 国产精品灌醉下药二区| 这里只有精品视频在线观看| 国产成a人亚洲| 日日摸夜夜添夜夜添国产精品| 久久日韩精品一区二区五区| 色94色欧美sute亚洲线路一ni | 久久一区二区三区国产精品| av网站免费线看精品| 午夜亚洲福利老司机| 国产亚洲一区二区三区在线观看| 在线视频一区二区三| 国产精品综合二区| 日韩电影在线一区| 亚洲另类中文字| 欧美成人午夜电影| 色爱区综合激月婷婷| 国产精品自在在线| 偷拍日韩校园综合在线| 自拍偷自拍亚洲精品播放| 欧美一区二区女人| 91一区二区三区在线观看| 另类人妖一区二区av| 亚洲国产精品一区二区www| 国产免费久久精品| 日韩欧美激情在线| 欧美日韩精品一区二区三区 | 国产精品影视在线| 日韩在线观看一区二区| 国产精品传媒入口麻豆| 2017欧美狠狠色| 欧美一区二区三区四区在线观看| 欧美系列一区二区| 色婷婷综合久色| 成人免费的视频| 国产在线精品免费| 精品制服美女丁香| 久草精品在线观看| 久国产精品韩国三级视频| 日日欢夜夜爽一区| 亚洲国产成人av网| 国产91富婆露脸刺激对白| 美女高潮久久久| 日韩 欧美一区二区三区| 性做久久久久久免费观看| 亚洲在线观看免费| 一区二区三区四区亚洲| 亚洲欧美日韩电影| 亚洲黄色免费电影| 国产精品国产三级国产专播品爱网 | 一区二区三区欧美| 一区二区三区日韩精品视频| 自拍偷拍国产精品| 国产精品久久毛片| 中文字幕综合网| 亚洲一区二区在线免费观看视频| 亚洲一卡二卡三卡四卡无卡久久 | 成人av网站在线观看| 成人黄色777网| 91亚洲国产成人精品一区二区三 | 国产99精品在线观看| 粉嫩欧美一区二区三区高清影视| 国产白丝精品91爽爽久久| 粗大黑人巨茎大战欧美成人| 不卡av免费在线观看| 日本丶国产丶欧美色综合| 欧美美女一区二区在线观看| 91精品国产91久久久久久一区二区 | 五月婷婷激情综合网| 五月天婷婷综合| 激情文学综合丁香| 波多野结衣中文一区| 日本高清成人免费播放| 欧美久久一二区| 精品国产伦一区二区三区观看体验| 久久精品日产第一区二区三区高清版| 国产欧美日韩在线| 一区二区在线免费观看| 日韩电影在线观看一区| 黄一区二区三区| 成人网在线免费视频| 欧美日韩国产一级二级| 精品成人a区在线观看| 国产精品久久久久天堂| 亚洲男帅同性gay1069| 丁香婷婷综合色啪| 精品视频999| 国产日韩影视精品| 一区二区三区精密机械公司| 美女视频一区二区| 91原创在线视频| 日韩一级黄色大片| 亚洲色图第一区| 免费黄网站欧美| 91丨九色丨尤物| 精品国产精品网麻豆系列| 亚洲色图一区二区| 麻豆精品在线看| 色噜噜狠狠成人网p站| 欧美大片在线观看一区二区| 亚洲乱码中文字幕| 国产一区二区美女诱惑| 欧美三级电影在线观看| 国产午夜亚洲精品羞羞网站| 午夜精品爽啪视频| 不卡在线视频中文字幕| 欧美变态口味重另类| 一区二区三区欧美激情| 国产成人综合在线观看| 日韩亚洲欧美一区| 一区二区高清视频在线观看| 国产成人在线看| 欧美一卡二卡三卡| 亚洲一区二区影院| www.av亚洲| 久久精品人人爽人人爽| 青青草成人在线观看| 欧美视频三区在线播放| 亚洲视频狠狠干| 成人午夜精品在线| 国产亚洲欧洲997久久综合 | jlzzjlzz国产精品久久| 精品黑人一区二区三区久久| 午夜精品久久久| 在线观看亚洲精品视频| 国产精品久久毛片av大全日韩| 精品无人区卡一卡二卡三乱码免费卡| 欧美日韩一二三| 亚洲一区在线观看网站| 91免费观看国产| 亚洲天堂精品在线观看| 高潮精品一区videoshd| 26uuu亚洲综合色欧美| 麻豆精品国产91久久久久久| 在线播放一区二区三区| 亚洲一二三区视频在线观看| 色8久久精品久久久久久蜜| 成人免费视频在线观看| 成人黄色电影在线| 中文字幕一区二区三区精华液| 欧美一级在线免费| 婷婷六月综合亚洲| 欧美精品v国产精品v日韩精品 | 亚洲成人免费影院| 欧美三级乱人伦电影| 夜夜嗨av一区二区三区| 在线观看免费一区| 亚洲电影你懂得| 日韩午夜在线影院| 日韩精品成人一区二区在线| 欧美电影在线免费观看| 免费不卡在线观看| 久久一日本道色综合| 成人深夜在线观看| 亚洲日本乱码在线观看| 色婷婷av一区二区三区大白胸 | 日本一区二区三区免费乱视频| 国产成人精品免费视频网站| 国产精品国产三级国产a| 在线精品视频小说1| 亚洲国产视频一区二区| 日韩视频免费直播| 福利一区二区在线| 亚洲精品videosex极品| 欧美一区二区三区爱爱| 国产激情一区二区三区| 亚洲免费成人av| 欧美一级片免费看| 国产iv一区二区三区| 一区二区三区丝袜| 日韩女同互慰一区二区| 成人黄色国产精品网站大全在线免费观看| 亚洲美女一区二区三区| 日韩一级二级三级精品视频| 国产成人在线视频免费播放|