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

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

?? sdiocontrollerbase.h

?? 三星2440 cpu WINCE 5.00板級支持包
?? H
?? 第 1 頁 / 共 2 頁
字號:
//
// Copyright (c) Microsoft Corporation.  All rights reserved.
//
//
// Use of this source code is subject to the terms of the Microsoft end-user
// license agreement (EULA) under which you licensed this SOFTWARE PRODUCT.
// If you did not accept the terms of the EULA, you are not authorized to use
// this source code. For a copy of the EULA, please see the LICENSE.RTF on your
// install media.
//

// Copyright (c) 2002 BSQUARE Corporation.  All rights reserved.
// DO NOT REMOVE --- BEGIN EXTERNALLY DEVELOPED SOURCE CODE ID 40973--- DO NOT REMOVE

#ifndef __SDIOCONTROLLER_H
#define __SDIOCONTROLLER_H

//#################################### Register Constants/Masks/etc. ######################################

// NOTE: The theoretical maximum speed is 25.3 Mhz (prescaler register set to 0), but this is above the 
//       maximum allowed value of 25 MHz.  The next lower value allowed by the prescaler register on the 
//       SC2440 hardware is 12687500 Hz (prescaler register set to 1)
#define MAX_SDI_BUS_TRANSFER_SPEED		12687500				// 12.7 Mhz

#define BYTES_PER_SECTOR				512
#define SDI_CONTROLLER_FIFO_SIZE		64

//----- Register definitions for SDICON control register (global config register) -----
#define LITTLE_ENDIAN_BYTE_ORDER		0x00000000
#define SDIO_INTERRUPT_ENABLE			0x00000008 
#define SDIO_READ_WAIT_ENABLE			0x00000004 
#define SDIO_SDMCC_RESET				0x00000100
#define SDIO_CLK_TYPE_MCC				0x00000020
#define SDIO_BYTE_ORDER_B				0x00000010
#define SDIOCON_RSV1					0x00000002 
#define CLOCK_ENABLE					0x00000001				


//----- Register definitions for SDICCON control register (command config register) -----
//		NOTE:  Lowest 8 bits are used for the actual command's opcode
#define SDIO_ABORT_COMMAND				0x00001000				// Works for CMD12 and CMD52
#define SDIO_COMMAND_WITH_DATA			0x00000800
#define LONG_RESPONSE					0x00000400				
#define WAIT_FOR_RESPONSE				0x00000200				
#define START_COMMAND					0x00000100				

#define COMMAND_START_BIT				0x00000040				// Commands are 6 bits, but the 7th bit must be set!
#define MAX_CMD_VALUE					0x0000007F				// In SD/MMC clock cycles
#define	NULL_CMD_ARGUMENT				0x00000000
															
//----- Register definitions for SDICSTA control register (command status register) -----
//		NOTE:  Lowest 8 bits indicate the command's response code
#define CRC_CHECK_FAILED				0x00001000				
#define COMMAND_SENT					0x00000800
#define COMMAND_TIMED_OUT				0x00000400				
#define RESPONSE_RECEIVED				0x00000200				
#define COMMAND_IN_PROGRESS				0x00000100				

#define SHORT_RESPONSE_LENGTH			0x00000006				// In bytes
#define LONG_RESPONSE_LENGTH			0x00000010				// In bytes


//----- Register definitions for SDIDTIMER control register (data/busy config register) -----
//		NOTES:	1) Valid range		= 0-65536
//				2) Default value	= 0x2000 
#define NO_DATABUSY_TIMEOUT				0
#define MAX_DATABUSY_TIMEOUT			0x0000FFFF

//----- Register definitions for SDIDCON control register (transfer config register) -----
//		NOTE:  Lowest 12 bits are used for the block number (don't care in stream mode)
/*enable burst4 mode in DMA mode.this bit should be set only when data size is word*/
#define SDIO_BURST4_ENABLE				0x01000000
/*indicates the size of the transfer with FIFO,which is typically byte,halfword or word*/
#define SDIO_DATA_SIZE_BYTE			0x00000000
#define SDIO_DATA_SIZE_HALFW			0x00400000
#define SDIO_DATA_SIZE_WORD			0x00800000
#define SDIO_INTERRUPT_PERIOD_TYPE		0x00200000				// 0 = 2 cycles, 1 = more than 2 cycles
#define TRANSMIT_AFTER_RESPONSE			0x00100000
#define RECEIVE_AFTER_COMMAND			0x00080000
#define BUSY_AFTER_COMMAND				0x00040000
#define TRANSFER_BLOCK_MODE				0x00020000				// Clearing this bit enables stream mode
#define WIDE_BUS_ENABLE					0x00010000				
#define DMA_ENABLE						0x00008000				
#define DATA_TRANSFER_START					0x00004000
#define DATA_TRANSMIT_MODE				0x00003000
#define DATA_RECEIVE_MODE				0x00002000

// Bits 12-13 are used to determine transfer mode:
#define DATA_TRANSMIT_START				0x00003000
#define DATA_RECEIVE_START				0x00002000
#define DATA_BUSY						0x00001000
#define DATA_READY						0x00000000


//----- Register definitions for SDIDSTA control register (transfer status register) -----
#define READ_WAIT_REQUEST_OCCURED		0x00000400				
#define SDIO_INTERRUPT_DETECTED			0x00000200
#define DATA_STATS_RSV8					0x00000100
#define DATA_TRANSMIT_CRC_ERROR			0x00000080
#define DATA_RECEIVE_CRC_ERROR			0x00000040
#define DATA_TIME_OUT					0x00000020
#define DATA_TRANSMIT_FINISHED			0x00000010
#define BUSY_CHECKS_FINISH				0x00000008
#define START_BIT_ERROR					0x00000004
#define DATA_TRANSMIT_IN_PROGRESS		0x00000002
#define DATA_RECIEVE_IN_PROGRESS		0x00000001

//----- Register definitions for SDIFSTA control register (FIFO status register) -----
//		NOTE:  Lowest 7 bits indicate the number of data bytes in the FIFO
#define RESET_FIFO						0x00010000
//FIFO fail error when FIFO occurs overrun/underrun data saving. This flag is cleared by setting to one these bits.
#define FIFO_FAIL_ERROR					0x00004000	//FIFO fail
#define FIFO_FAIL_LAST_TX				0x00008000	//FIFO fail in the last transfer(only FIFO reset need)
#define FIFO_AVAIL_FOR_TX				0x00002000
#define FIFO_AVAIL_FOR_RX				0x00001000
#define TX_FIFO_HALF_FULL				0x00000800				// < 33 bytes
#define TX_FIFO_EMPTY					0x00000400				// = 0 bytes
#define RX_FIFO_LAST_DATA_READY			0x00000200
#define RX_FIFO_FULL					0x00000100				// = 64 bytes
#define RX_FIFO_HALF_FULL				0x00000080				// > 33 bytes


//----- Register definitions for SDIIMSK control register (interrupt mask register) -----
#define SDIO_NO_BUSY_INT				0x00040000
#define RESPONSE_CRC_ERROR_INT			0x00020000				
#define COMMAND_SENT_INT				0x00010000				
#define COMMAND_RESPONSE_TIMEOUT_INT	0x00008000				
#define COMMAND_RESPONSE_REC_INT		0x00004000				
#define READ_WAIT_REQUEST_INT			0x00002000				
#define SDIO_HOST_IO_INT				0x00001000				
#define FIFO_FAIL_ERROR_INT				0x00000800				
#define CRC_STATUS_ERROR_INT			0x00000400				
#define DATA_CRC_FAIL_INT				0x00000200				
#define DATA_TIMEOUT_INT				0x00000100				
#define DATA_COUNTER_ZERO_INT			0x00000080				
#define BUSY_CHECKS_COMPLETE_INT		0x00000040				
#define START_BIT_ERROR_INT				0x00000020				
#define TX_FIFO_HALF_FULL_INT			0x00000010				// < 33 bytes
#define TX_FIFO_EMPTY_INT				0x00000008				// = 0 bytes
#define RX_FIFO_LAST_DATA_READY_INT		0x00000004				
#define RX_FIFO_FULL_INT				0x00000002				// = 64 bytes
#define RX_FIFO_HALF_FULL_INT			0x00000001				// > 33 bytes

#define ERROR_INTERRUPTS_HANDLED		COMMAND_RESPONSE_TIMEOUT_INT | DATA_TIMEOUT_INT 


//###################################### Hardware Controller Structures ##################################
typedef enum {
    Idle				= -1,
    CommandSent			= 1,
    CommandComplete		= 2,
    ResponseWait		= 3,
    WriteDataTransfer	= 4,
    WriteDataTransferDone = 5,
    ProgramWait			= 6,
    WriteDataDone		= 7,
    ReadDataTransfer	= 8,
    ReadDataTransferDone = 9,
    ReadDataDone		= 10,

} SDHCDSTATE;

class CSDIOControllerBase
{
public:
    explicit CSDIOControllerBase( PSDCARD_HC_CONTEXT pHCContext );
    virtual ~CSDIOControllerBase();

    PSDCARD_HC_CONTEXT GetHostContext() const;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
av在线播放成人| 国产精品欧美精品| 国产区在线观看成人精品| 亚洲制服丝袜一区| 国产**成人网毛片九色 | 欧美一区二区三区在线观看| 欧美极品另类videosde| 麻豆国产精品一区二区三区 | 日本一区二区三区免费乱视频| 亚洲电影一区二区| 91一区在线观看| 欧美激情在线一区二区| 久久国产生活片100| 欧美美女bb生活片| 亚洲日本va在线观看| 丰满岳乱妇一区二区三区| 欧美一区二区福利视频| 亚洲国产日韩av| 99国产精品99久久久久久| 久久久久久久综合日本| 久草精品在线观看| 日韩欧美二区三区| 日韩av一区二区在线影视| 在线观看日韩电影| 亚洲精品视频一区二区| av亚洲精华国产精华精华| 国产日韩av一区二区| 国产一区二区三区四| 日韩三级av在线播放| 日韩激情视频在线观看| 91精品国产色综合久久不卡蜜臀| 亚洲国产日韩a在线播放性色| 色综合中文字幕| 亚洲精品免费电影| 一本大道久久a久久精品综合| 国产精品大尺度| 99视频有精品| 亚洲男同性视频| 91视频免费看| 午夜精品一区二区三区免费视频| 精品视频999| 婷婷成人激情在线网| 777久久久精品| 精品一区二区av| 国产精品免费网站在线观看| 不卡一卡二卡三乱码免费网站 | 日韩你懂的在线播放| 美女网站在线免费欧美精品| 日韩精品影音先锋| 国产成人综合在线| 亚洲手机成人高清视频| 在线视频一区二区免费| 无码av免费一区二区三区试看 | 国产日韩欧美激情| 91视视频在线观看入口直接观看www | aaa欧美日韩| 一区二区三区在线观看视频| 欧美熟乱第一页| 韩国成人福利片在线播放| 日本一区二区三级电影在线观看| 色哟哟一区二区在线观看| 午夜欧美电影在线观看| 久久久久国产一区二区三区四区 | 欧美人与z0zoxxxx视频| 卡一卡二国产精品| 亚洲欧洲日产国产综合网| 欧美三级视频在线| 国产乱人伦精品一区二区在线观看 | 91精品国产免费久久综合| 久久99精品久久久久婷婷| 国产精品国产三级国产aⅴ入口| 欧美吞精做爰啪啪高潮| 黄页网站大全一区二区| 亚洲免费av观看| wwwwxxxxx欧美| 欧洲一区二区三区免费视频| 国模冰冰炮一区二区| 亚洲最新视频在线观看| 精品成人私密视频| 欧美色手机在线观看| 国产一区二区三区最好精华液| 亚洲精品你懂的| 欧美极品xxx| 欧美mv日韩mv| 欧美日本免费一区二区三区| 不卡的av电影在线观看| 日韩成人一区二区| 一区二区三区四区视频精品免费| 久久久久久夜精品精品免费| 欧美肥妇bbw| 日本福利一区二区| eeuss鲁片一区二区三区在线观看| 日韩中文字幕1| 亚洲视频电影在线| 欧美精品一区二区三区在线播放| 欧美四级电影网| 色综合久久久网| 成人三级伦理片| 韩国一区二区在线观看| 天天综合网天天综合色| 亚洲国产精品一区二区www| 国产精品久久久爽爽爽麻豆色哟哟| 正在播放一区二区| 欧美日韩黄色一区二区| 在线视频一区二区三| 99精品欧美一区二区三区小说 | 日韩福利视频网| 亚洲成a天堂v人片| 亚洲一区二区四区蜜桃| 亚洲欧美区自拍先锋| 136国产福利精品导航| 国产精品久久毛片| 国产精品久久久久久久久搜平片| 国产亚洲综合av| 国产欧美一区二区三区沐欲| 精品国产91久久久久久久妲己 | 亚洲欧美一区二区久久| 国产精品三级av| 日韩伦理av电影| 亚洲在线观看免费| 丝袜国产日韩另类美女| 日韩va亚洲va欧美va久久| 免费人成黄页网站在线一区二区| 偷拍一区二区三区| 老司机精品视频一区二区三区| 久草中文综合在线| 国产成人精品免费视频网站| 成人av资源网站| 欧美亚洲动漫精品| 欧美一区二区精美| 国产欧美日韩久久| 亚洲欧美区自拍先锋| 亚洲成a人v欧美综合天堂下载| 视频一区中文字幕| 国产成人在线影院 | 日韩一级在线观看| 精品美女在线播放| 国产精品剧情在线亚洲| 一区二区三区精品久久久| 日本最新不卡在线| 国产高清精品网站| 91福利视频久久久久| 日韩亚洲欧美综合| 成人欧美一区二区三区黑人麻豆| 一区二区高清视频在线观看| 首页综合国产亚洲丝袜| 国产成人精品影院| 在线精品视频一区二区| 日韩免费观看2025年上映的电影 | 亚洲一区在线观看免费观看电影高清 | 日本不卡视频一二三区| 国产成人aaaa| 欧美日本一道本在线视频| 久久久青草青青国产亚洲免观| 亚洲色图一区二区三区| 男男视频亚洲欧美| 91麻豆精品视频| 亚洲精品一区二区三区精华液| 亚洲精选免费视频| 国产精品一区二区视频| 欧美亚洲一区三区| 久久久久成人黄色影片| 偷偷要91色婷婷| 99久精品国产| 国产人成一区二区三区影院| 五月婷婷久久丁香| 一本到一区二区三区| 精品999久久久| 无码av免费一区二区三区试看| 成人一级黄色片| 日韩欧美成人午夜| 午夜精品成人在线| 91麻豆国产在线观看| 国产蜜臀av在线一区二区三区| 天堂在线一区二区| 色琪琪一区二区三区亚洲区| 久久久久久久久久久久电影| 日精品一区二区三区| 一本到高清视频免费精品| 国产女人18水真多18精品一级做| 三级在线观看一区二区| 在线影视一区二区三区| 欧美国产精品一区二区三区| 久久99热国产| 91精品国产aⅴ一区二区| 一级女性全黄久久生活片免费| 成人sese在线| 国产精品国产三级国产aⅴ原创| 国内精品自线一区二区三区视频| 欧美日韩精品欧美日韩精品一 | 欧美视频一二三区| 亚洲欧美另类综合偷拍| 97超碰欧美中文字幕| 中文字幕一区二区三区乱码在线| 蜜桃av一区二区在线观看| 在线播放中文一区| 亚洲国产日韩一级| 在线不卡免费欧美| 日韩精品乱码av一区二区| 欧美日韩欧美一区二区|