51单片机读写1G以上内存卡(不用模块) 10
展开全部
如果你纯以直接物理地址访问的话需要30根地址线。51本身提供的地址线16根,其余的14根可以通过以下几种方法得到:
1、由P1和P3直接提供,这样的话就最多只有2个IO可用,其余作为地址线访问内存。当然高位地址(大于64K)需要手动特殊处理比如访问0003ffffH可以这样操作:
MOV P3,#00H
MOV P1,#03H
MOV DPTR,#0FFFFH
MOVX A,@DPTR
2、扩展两个8位口来提供高位地址,这样在硬件上做些处理,可以节约一些IO口,这种方式软件处理起来麻烦一些。这里就不做例子了。
1、由P1和P3直接提供,这样的话就最多只有2个IO可用,其余作为地址线访问内存。当然高位地址(大于64K)需要手动特殊处理比如访问0003ffffH可以这样操作:
MOV P3,#00H
MOV P1,#03H
MOV DPTR,#0FFFFH
MOVX A,@DPTR
2、扩展两个8位口来提供高位地址,这样在硬件上做些处理,可以节约一些IO口,这种方式软件处理起来麻烦一些。这里就不做例子了。
展开全部
我勒个去也!!!!!别让一楼把你害了!!!
内存卡,即常说的sd卡,还有tf卡mmc卡,他们都遵循一种标准规范,读写这种卡在底层物理协议上使用spi或者sd模式 spi即常说的spi总线,比如ds1302就是类似于spi总线。spi是串行总线,时序要求不高,没有硬件spi可以通过io模拟,而sd模式对时序要求比较高,还需要计算crc之类的,所以,一般不采用sd模式,除非你的芯片自带sd驱动器。
sd卡分为两种 sd和sdhc。低于4g一下的卡都为sd卡,寻址采用4字节的地址寻址,最大可寻址4gb,但由于sd卡最小读写单位是扇区(512B)所以这四个字节的有效数据是3个字节+7bit
sdhc为高速sd卡,sdhc也是由4字节的地址寻址,但是sdhc最小寻址区间是一个扇区。所以sdhc的寻址范围为4g*512B=2000多gb话说sd卡还没做到2t的吧?
内存卡,即常说的sd卡,还有tf卡mmc卡,他们都遵循一种标准规范,读写这种卡在底层物理协议上使用spi或者sd模式 spi即常说的spi总线,比如ds1302就是类似于spi总线。spi是串行总线,时序要求不高,没有硬件spi可以通过io模拟,而sd模式对时序要求比较高,还需要计算crc之类的,所以,一般不采用sd模式,除非你的芯片自带sd驱动器。
sd卡分为两种 sd和sdhc。低于4g一下的卡都为sd卡,寻址采用4字节的地址寻址,最大可寻址4gb,但由于sd卡最小读写单位是扇区(512B)所以这四个字节的有效数据是3个字节+7bit
sdhc为高速sd卡,sdhc也是由4字节的地址寻址,但是sdhc最小寻址区间是一个扇区。所以sdhc的寻址范围为4g*512B=2000多gb话说sd卡还没做到2t的吧?
追问
恩,穿行总线,这个才合理啊,DPTR就16位,怎么也读不了G单位的地址啊,呵呵!
能否提供关于SD卡资料的线索?网上搜了下,都是用SD模块实现的,这个没劲,像玩组装电脑一样。
追答
自己百度
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
串行通信
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |