我买的贵公司的ch375evt3 的评估板(PCB板),没有EEPROM的那个板子。把元器件全部焊接好了,当时通过P1 USB口连接电脑上,电脑没反应是怎么回事?还有怎么把程序下载进单片机啊(我用的AT89S52),说明上说先把JP8短路 再断开 当时没有任何用,请问我接下来需要做什么检查 我是毕业设计。急……
我们评估板上自带的单片机里面是有引导代码的,所以才能按照说明上下载方法下载,其他的单片机需要自己使用编程器下载,例外,AT89S52操作U盘的话,代码空间可能不够,我们的库需要13K左右的ROM
补充下:我只是把U 盘当作存储器应用,现在我把CH375EV1.C的程序下载进单片机了(改用的是STC89C52的,生成的HEX文件是7K),接下来需要做什么测试呢。了解的能留个QQ吗(公司技术员更好)?咨询方便些,谢谢了!
如果只是读写U盘物理扇区的话,参考CH375EV0.C,在操作U盘扇区的时候,要求RAM的大小至少应该是扇区大小的整数倍,一般U盘的扇区为512字节,先确定单片机的资源够不够。
你先看看资料,搞清楚每个程序是做什么用的,再去实验。我们程序里面都已经说明了每个C文件的功能是什么了。
好的,谢谢贵公司的热情帮助,我先熟悉下……
我现在把串口调试好了,串口通信没问题了。接下来,我需要测试CH375B,但是不知道具体怎么测试,是不是需要把相关程序下载进单片机(我用的STC89S52),然后用贵公司提供的CH375调试软件进行啊?如果是的话,需要下载哪个例程(贵公司提供的下载资料里有吗?)?谢谢!!
当然要下载到单片机里去运行,不需要什么调试软件,CH375EVT.ZIP根据需要选择相关的例程。
我把这个程序下载进单片机 插上U盘(2G) 通过串口返回的数据是A9 B7 4E 46 F1 90 A5 8A 14 49 C5 B3 4D A8 FC 是什么意思啊 下面附程序
#include #include "CH375INC.H" /* 定义CH375命令代码及返回状态 */ #include /* 以下定义适用于MCS-51单片机,其它单片机参照修改 */ #define UINT8 unsigned char #define UINT16 unsigned short #define UINT32 unsigned long #define UINT8X unsigned char xdata #define UINT8VX unsigned char volatile xdata UINT8VX CH375_CMD_PORT _at_ 0xBDF1; /* CH375命令端口的I/O地址 */ UINT8VX CH375_DAT_PORT _at_ 0xBCF0; /* CH375数据端口的I/O地址 */ #define CH375_INT_WIRE INT0 /* P3.2, 连接CH375的INT#引脚,用于查询中断状态 */ UINT8X DISK_BUFFER[512] _at_ 0x0000; /* 外部RAM数据缓冲区的起始地址,长度不少于一次读写的数据长度 */
UINT32 DiskStart; /* 逻辑盘的起始绝对扇区号LBA */ UINT8 SecPerClus; /* 逻辑盘的每簇扇区数 */ UINT8 RsvdSecCnt; /* 逻辑盘的保留扇区数 */ UINT16 FATSz16; /* FAT16逻辑盘的FAT表占用的扇区数 */
/* ********** 硬件USB接口层,无论如何这层省不掉,单片机总要与CH375接口吧 ************************************************************ */
void mDelaymS( UINT8 delay ) { /* 以毫秒为单位延时,不精确,适用于24MHz时钟MCS51 */ UINT8 i, j, c; for ( i = delay; i != 0; i -- ) { for ( j = 200; j != 0; j -- ) c += 3; /* 在24MHz时钟下延时500uS */ for ( j = 200; j != 0; j -- ) c += 3; /* 在24MHz时钟下延时500uS */ } }
void CH375_WR_CMD_PORT( UINT8 cmd ) { /* 向CH375的命令端口写入命令,周期不小于4uS,如果单片机较快则延时 */ CH375_CMD_PORT=cmd; for ( cmd = 2; cmd != 0; cmd -- ); /* 发出命令码前后应该各延时2uS,对于MCS51可以不需要延时 */ } void CH375_WR_DAT_PORT( UINT8 dat ) { /* 向CH375的数据端口写入数据,周期不小于1.5uS,如果单片机较快则延时 */ CH375_DAT_PORT=dat; /* 因为MCS51单片机较慢所以实际上无需延时 */ } UINT8 CH375_RD_DAT_PORT( void ) { /* 从CH375的数据端口读出数据,周期不小于1.5uS,如果单片机较快则延时 */ return( CH375_DAT_PORT ); /* 因为MCS51单片机较慢所以实际上无需延时 */ } UINT8 mWaitInterrupt( void ) { /* 等待CH375中断并获取状态,主机端等待操作完成,返回操作状态 */ while( CH375_INT_WIRE ); /* 查询等待CH375操作完成中断(INT#低电平) */ CH375_WR_CMD_PORT( CMD_GET_STATUS ); /* 产生操作完成中断,获取中断状态 */ return( CH375_RD_DAT_PORT( ) ); }
/* ********** BulkOnly传输协议层,被CH375内置了,无需编写单片机程序 ************************************************************ */
/* ********** RBC/SCSI命令层,虽然被CH375内置了,但是要写程序发出命令及收发数据 ************************************************************ */
UINT8 mInitDisk( void ) { /* 初始化磁盘 */ UINT8 Status,i,j=0; CH375_WR_CMD_PORT( CMD_GET_STATUS ); /* 产生操作完成中断, 获取中断状态 */ Status = CH375_RD_DAT_PORT( ); if ( Status == USB_INT_DISCONNECT ) return( Status ); /* USB设备断开 */ CH375_WR_CMD_PORT( CMD_DISK_INIT ); /* 初始化USB存储器 */ Status = mWaitInterrupt( ); /* 等待中断并获取状态 */ if ( Status != USB_INT_SUCCESS ) return( Status ); /* 出现错误 */ while(1){j++; CH375_WR_CMD_PORT( CMD_DISK_SIZE ); /* 获取USB存储器的容量 */ Status = mWaitInterrupt( ); /* 等待中断并获取状态 */ if ( Status == USB_INT_SUCCESS ) break; /* 出现错误 */ /*这里需要加上这个之后才可以,正确的做法也是这样*/ CH375_WR_CMD_PORT( CMD_DISK_R_SENSE ); /* 获取USB存储器的容量 */ mDelaymS( 250 ); if(j==5) return(Status); } Status = mWaitInterrupt( ); /* 等待中断并获取状态 */ if ( Status == USB_INT_SUCCESS ){ /* 出现错误 */ for(i=0;i!=5;i++){ printf("Ready\n"); CH375_WR_CMD_PORT( CMD_DISK_READY ); /* 获取USB存储器的容量 */ Status = mWaitInterrupt( ); /* 等待中断并获取状态 */ if ( Status == USB_INT_SUCCESS ) break; /* 出现错误 */ CH375_WR_CMD_PORT( CMD_DISK_R_SENSE ); /* 获取USB存储器的容量 */ mDelaymS( 250 ); } } return( 0 ); /* U盘已经成功初始化 */ }
UINT8 mReadSector( UINT32 iLbaStart, UINT8 iSectorCount, UINT8X *oDataBuffer ) {/* 从U盘读取数据块到缓冲区 */ /* iLbaStart 起始扇区号, iSectorCount 扇区数, oDataBuffer 缓冲区起址 */ UINT16 mBlockCount; UINT8 c; CH375_WR_CMD_PORT( CMD_DISK_READ ); /* 从USB存储器读数据块 */ CH375_WR_DAT_PORT( (UINT8)iLbaStart ); /* LBA的最低8位 */ CH375_WR_DAT_PORT( (UINT8)( iLbaStart >> 8 ) ); CH375_WR_DAT_PORT( (UINT8)( iLbaStart >> 16 ) ); CH375_WR_DAT_PORT( (UINT8)( iLbaStart >> 24 ) ); /* LBA的最高8位 */ CH375_WR_DAT_PORT( iSectorCount ); /* 扇区数 */ for ( mBlockCount = iSectorCount * 8; mBlockCount != 0; mBlockCount -- ) { /* 数据块计数 */ c = mWaitInterrupt( ); /* 等待中断并获取状态 */ if ( c == USB_INT_DISK_READ ) { /* 等待中断并获取状态,USB存储器读数据块,请求数据读出 */ CH375_WR_CMD_PORT( CMD_RD_USB_DATA ); /* 从CH375缓冲区读取数据块 */ c = CH375_RD_DAT_PORT( ); /* 后续数据的长度 */ while ( c -- ) *oDataBuffer++ = CH375_RD_DAT_PORT( ); /* 根据长度读取数据并保存 */ CH375_WR_CMD_PORT( CMD_DISK_RD_GO ); /* 继续执行USB存储器的读操作 */ } else break; /* 返回错误状态 */ } if ( mBlockCount == 0 ) { c = mWaitInterrupt( ); /* 等待中断并获取状态 */ if ( c== USB_INT_SUCCESS ) return( 0 ); /* 操作成功 */ } return( c ); /* 操作失败 */ } /* 将缓冲区中的多个扇区的数据块写入U盘 */ unsigned char mWriteSector( unsigned long iLbaStart, unsigned char iSectorCount,unsigned char *mBufferPoint ) /* iLbaStart 是写入的线起始性扇区号, iSectorCount 是写入的扇区数 */ { unsigned char mIntStatus; unsigned int mBlockCount; unsigned char mLength; CH375_WR_CMD_PORT( CMD_DISK_WRITE ); /* 向USB存储器写数据块 */ CH375_WR_DAT_PORT( (unsigned char)iLbaStart ); /* LBA的最低8位 */ CH375_WR_DAT_PORT( (unsigned char)( iLbaStart >> 8 ) ); CH375_WR_DAT_PORT( (unsigned char)( iLbaStart >> 16 ) ); CH375_WR_DAT_PORT( (unsigned char)( iLbaStart >> 24 ) ); /* LBA的最高8位 */ CH375_WR_DAT_PORT( iSectorCount ); /* 扇区数 */ // mBufferPoint = DISK_BUFFER; /* 指向缓冲区起始地址 */ for ( mBlockCount = iSectorCount *8; mBlockCount != 0; mBlockCount -- ) { /* 数据块计数 */ mIntStatus = mWaitInterrupt( ); /* 等待中断并获取状态 */ if ( mIntStatus == USB_INT_DISK_WRITE ) { /* USB存储器写数据块,请求数据写入 */ CH375_WR_CMD_PORT( CMD_WR_USB_DATA7 ); /* 向CH375缓冲区写入数据块 */ mLength = 64; CH375_WR_DAT_PORT( mLength ); /* 后续数据的长度 */ do { CH375_WR_DAT_PORT( *mBufferPoint ); mBufferPoint ++; } while ( -- mLength ); CH375_WR_CMD_PORT( CMD_DISK_WR_GO ); /* 继续执行USB存储器的写操作 */ } else break; /* 返回错误状态 */ } if ( mBlockCount == 0 ) { mIntStatus = mWaitInterrupt( ); /* 等待中断并获取状态 */ if ( mIntStatus == USB_INT_SUCCESS ) return( 0 ); /* 操作成功 */ } return( mIntStatus ); /* 操作失败 */ }
/* ********** FAT文件系统层,这层程序量实际较大,不过,该程序仅演示极简单的功能,所以精简 ************************************************************ */
UINT16 mGetPointWord( UINT8X *iAddr ) { /* 获取字数据,因为MCS51是大端格式,U盘FAT通常是小端格式,所以转换 */ return( iAddr[0] | (UINT16)iAddr[1] << 8 ); }
UINT8 mIdenDisk( void ) { /* 识别分析当前逻辑盘 */ UINT8 Status; DiskStart = 0; /* 以下是非常简单的FAT文件系统的分析,正式应用绝对不应该如此简单,否则兼容性和容错性差 */ Status = mReadSector( 0, 1, DISK_BUFFER ); /* 读取逻辑盘引导信息 */printf("1\n"); if ( Status != 0 ) return( Status ); if ( DISK_BUFFER[0] != 0xEB && DISK_BUFFER[0] != 0xE9 ) { /* 不是逻辑引导扇区 */ DiskStart = DISK_BUFFER[0x1C6] | (UINT16)DISK_BUFFER[0x1C7] << 8 | (UINT32)DISK_BUFFER[0x1C8] << 16 | (UINT32)DISK_BUFFER[0x1C9] << 24; Status = mReadSector( DiskStart, 1, DISK_BUFFER ); /* 根据新的起始扇区号读取逻辑盘引导信息 */ if ( Status != 0 ) return( Status ); } SecPerClus = DISK_BUFFER[0x0D]; /* 每簇扇区数 */ RsvdSecCnt = DISK_BUFFER[0x0E]; /* 逻辑盘的保留扇区数 */ FATSz16 = mGetPointWord( &DISK_BUFFER[0x16] ); /* FAT表占用扇区数 */ return( 0 ); /* 成功 */ }
UINT16 mLinkCluster( UINT16 iCluster ) { /* 获得指定簇号的链接簇 */ /* 输入: iCluster 当前簇号, 返回: 原链接簇号, 如果为0则说明错误 */ UINT8 Status; Status = mReadSector( DiskStart + RsvdSecCnt + iCluster / 256, 1, DISK_BUFFE
串口的波特率是9600,你拿串口调试软件把波特率设置成9600同时采用字符串形式的数据输出就可以看到我们跟踪的效果了。
我按照你(hcn { M } )说的的设置后,从串口传回的是乱码啊!而且还一直传送数据!这是为什么啊?还有就是我直接把CH375EVT\PUB\MCS51C\FILELIB4\EXAM4的程序下载到单片机,串口显示为82错误 是为什么啊?我查看了下头文件 说82是U盘未连接或已经断开,我用的金士顿2G的U盘,U盘没问题,不知问题出在哪?
串口输出乱码,那是波特率的设置问题,返回0x82,看一下中断引脚的连接有没有问题,以及U盘供电是否为5V.
你好_study_ { M } ,波特率确实没问题,当时U盘供电存在有问题,我用5v电源供电,各个芯片都是4.8-4.96V,当然USB口空载是也是4.8-4.96V,但是插接上U盘时,各个芯片电压不变,U盘电压降为3.32V 是怎么回事啊,和我用的USB口限流电阻R1阻值有关系吗?(由于没找到3.3欧的贴片电阻,我用的100欧的代替的)谢谢!!
有错别字“当时U盘供电存在有问题”更改为“但是……”
U盘的供电必须是5V才可以正常工作,限流电阻太大,可以不加。