《基于S3C2440的嵌入式Linux开发实例》课件第4章.ppt

《基于S3C2440的嵌入式Linux开发实例》课件第4章.ppt

  1. 1、本文档共149页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多

if(mrq-data)

{

sdifsta=readl(host-base+S3C2410_SDIFSTA);

sdifsta|=S3C2410_SDICON_FIFORESET;

writel(sdifsta,host-base+S3C2410_SDIFSTA);

host-complete_what=COMPLETION_XFERFINISH_RSPFIN;

sdi_bsize=(1mrq-data-blksz_bits);sdi_dcon=(mrq-data-blocksS3C2410_SDIDCON_BLKNUM_MASK);

sdi_dcon|=S3C2410_SDIDCON_DMAEN;

sdi_dcon|=S3C2410_SDIDCON_DTST;

sdi_imsk|=S3C2410_SDIIMSK_FIFOFAIL;

sdi_imsk|=S3C2410_SDIIMSK_DATACRC;

sdi_imsk|=S3C2410_SDIIMSK_DATATIMEOUT;

sdi_imsk|=S3C2410_SDIIMSK_DATAFINISH;

sdi_imsk|=0xFFFFFFE0;if(host-bus_width==MMC_BUS_WIDTH_4)

{

DBG(PFX“MMC_BUS_WIDTH_4\n”);

sdi_dcon|=S3C2410_SDIDCON_WIDEBUS;

}if(!(mrq-data-flagsMMC_DATA_STREAM))

{

sdi_dcon|=S3C2410_SDIDCON_BLOCKMODE;

DBG(PFX“MMC_DATA_BLOCK\n”);

}

if(mrq-data-flagsMMC_DATA_WRITE)

{DBG(PFX“MMC_DATA_WRITE\n”);

sdi_dcon|=S3C2410_SDIDCON_TXAFTERRESP;

sdi_dcon|=S3C2410_SDIDCON_XFER_TXSTART;

sdi_dcon|=S3C2410_SDIDCON_DAT_WD;

sdi_dcon|=S3C2410_SDIDCON_BURST4;

}

if(mrq-data-flagsMMC_DATA_READ)

{DBG(PFX“MMC_DATA_READ\n”);

sdi_dcon|=S3C2410_SDIDCON_RXAFTERCMD;

sdi_dcon|=S3C2410_SDIDCON_XFER_RXSTART;

sdi_dcon|=S3C2410_SDIDCON_DAT_WD;

//sdi_dcon|=S3C2410_SDIDCON_BURST4;

}

s3c2410sdi_dma_setup(host,mrq-data-flagsMMC_DATA_WRITE?

S3C2410_DMASRC_MEM:S3C2410_DMASRC_HW);dma_len=dma_map_sg(pdev-dev,mrq-data-sg,mrq-data-sg_len,mrq-data-flags

MMC_DATA_READ?DMA_FROM_DEVICE:DMA_TO_DEVICE);

DBG(PFXdma_len:0x%08x\n,dma_len);

/*开始DMA*/

s3c2410_dma_enqueue(host-dma,(void*)host,

sg_dma_address(mrq-data-sg[0]),

(mrq-data-blocksmrq-data-blksz_bits));

}host-mrq=mrq;

init_completion(host-complete_request);

init_completion(host-complete_dma);

/*清除命令状态寄存器*/

writel(0xFFFFFFFF,host-base+S3C2410_SDICMDSTAT);

writel(0xFFFFFFFF,host-base+S3C2410_SDIDSTA);/*设置SDI控制器*/

writel(sdi_bsize,host-base+S3C2410_SDIBSIZE);

writel(sdi_timer,host-base+S3C2410_SDITIMER);

writel(sdi_imsk,host-base+S3C2410_SDIIMSK);

/*设置SDI命令参数和数据寄存器*/

wri

您可能关注的文档

文档评论(0)

酱酱 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档