公司没办法上QQ。要回家才能上哎。
现在可以了,设置好必须要保存.UploadImages/20081231144937100.rar
通过你的指导,大部分警告消除了.单还是有几个问题导致连接不了.请看: Program Size: data=44.4 xdata=620 code=12135 LINK/LOCATE RUN COMPLETE. 4 WARNING(S), 0 ERROR(S)
*** WARNING L14: INCOMPATIBLE MEMORY MODEL MODULE: E:\8051单片机\单片机开发板\USB\程序\USB\CH375HFC.LIB (CH375BYT) MODEL: LARGE
*** WARNING L16: UNCALLED SEGMENT, IGNORED FOR OVERLAY PROCESS SEGMENT: ?PR?CH375FILEENUMER?CH375HFT
*** WARNING L16: UNCALLED SEGMENT, IGNORED FOR OVERLAY PROCESS SEGMENT: ?PR?CH375FILEQUERY?CH375HFT
*** WARNING L16: UNCALLED SEGMENT, IGNORED FOR OVERLAY PROCESS SEGMENT: ?PR?CH375BYTEREAD?CH375BYT
*** FATAL ERROR L250: CODE SIZE LIMIT IN RESTRICTED VERSION EXCEEDED MODULE: E:\8051单片机\单片机开发板\USB\程序\USB\CH375HFC.LIB (-----) LIMIT: 1000H BYTE Download cancelled. 我的理解是1:矛盾的存储器模式.是不是LIB调用的不对? 2跟3就不管了. 4严重的警告.内存不够? 麻烦你帮我看一下我应该怎么解决.谢谢! 我是直接调用的CH375LIB下面的MSC51里面的CH375LIBC.我的C8051F020数字口并口直接与CH375相连.AO,CS,RD,WD,INT#等都是用的PO口控制.
进入project-->Tool Chain....--->Compiler--->Customize--->Variable-->Large project-->Tool Chain....--->Compiler--->Customize--->Code Size --->64K 试试上面的设置.
呵呵现在编译连接都没问题了。但是我的程序好像进入了一个死循环。我在开始用来每一步都用了一个LED灯显示。结果是两灯一闪一闪的。不管我屏蔽掉任何语句。他都不往下面走。搞不懂。麻烦你帮我看看。我全部是按例子做的。只是改了端口。如果我串口初始化不好的话是不是就不能用Printf? /* 2008.12.27 **************************************** ** Copyright (C) W.ch 1999-2004 ** ** Web: http://www.winchiphead.com ** **************************************** ** USB Host File Interface for CH375 ** ** TC2.0@PC, KC7.0@MCS51 ** **************************************** */ /* CH375 主机文件系统接口 */ /* 支持: FAT12/FAT16/FAT32 */
/* MCS-51单片机C语言的U盘文件读写示例程序 */ /* 用于以下情况的MCS51单片机 1. 高速MCS51单片机,机器周期小于0.3uS,或者在机器周期为12个时钟时的时钟频率大于40MHz 2. 非总线MCS51单片机,用普通I/O引脚模拟8位并行总线读写,与CH375之间采用并口连接 3. 单片机与CH375之间采用串口连接 */ /* 本程序用于演示将ADC模数采集的数据保存到U盘文件MY_ADC.TXT中 */ /* CH375的INT#引脚采用查询方式处理,本例用普通I/O引脚模拟8位并行总线读写,同时提供串口连接示例, 以字节为单位读写U盘文件,读写速度较扇区模式慢,但是由于字节模式读写文件不需要文件数据缓冲区FILE_DATA_BUF, 所以总共只需要600字节的RAM,适用于单片机硬件资源有限、数据量小并且读写速度要求不高的系统 */
/* C51 CH375HFT.C */ /* LX51 CH375HFT.OBJ , CH375HFC.LIB */ /* OHX51 CH375HFT */
#include #include #include
//#define MAX_BYTE_IO 35 /* 以字节为单位单次读写文件时的最大长度,默认值是29,值大则占用内存多,值小则超过该长度必须分多次读写 */
/* 以下定义的详细说明请看CH375HFC.H文件 */ #define LIB_CFG_FILE_IO 1 /* 文件读写的数据的复制方式,0为"外部子程序",1为"内部复制" */ #define LIB_CFG_INT_EN 0 /* CH375的INT#引脚连接方式,0为"查询方式",1为"中断方式" */ /*#define LIB_CFG_UPD_SIZE 1*/ /* 在添加数据后是否自动更新文件长度: 0为"不更新",1为"自动更新" */ /* 默认情况下,如果扇区数/字节数不为0那么CH375FileWrite/CH375ByteWrite只负责写入数据而不修改文件长度, 如果需要每次写完数据后会自动修改/更新文件长度,那么可以使全局变量CH375LibConfig的位4为1, 如果长时间不写入数据则应该更新文件长度,防止突然断电后前面写入的数据与文件长度不相符, 如果确定不会突然断电或者后面很快有数据不断写入则不必更新文件长度,可以提高速度并减少U盘损耗(U盘内部的内存寿命有限,不宜频繁改写) */
/* 只使用单片机内置的1KB外部RAM: 0000H-01FFH 为磁盘读写缓冲区, 以字节为单位读写文件不需要文件数据读写缓冲区FILE_DATA_BUF */ #define DISK_BASE_BUF_ADDR 0x0000 /* 外部RAM的磁盘数据缓冲区的起始地址,从该单元开始的缓冲区长度为SECTOR_SIZE */ //#define FILE_DATA_BUF_ADDR 0x0000 /* 外部RAM的文件数据缓冲区的起始地址,缓冲区长度不小于一次读写的数据长度,字节模式不用该缓冲区 */ /* 由于单片机内置的外部RAM只有1KB, 有些单片机还要去掉256字节内部RAM, 只剩下768字节的外部RAM, 其中前512字节由CH375子程序用于磁盘数据缓冲 */ //#define FILE_DATA_BUF_LEN 0x0200 /* 外部RAM的文件数据缓冲区,缓冲区长度不小于一次读写的数据长度,字节模式不用该缓冲区 */ /* 如果准备使用双缓冲区交替读写,那么不要定义FILE_DATA_BUF_LEN,而是在参数中指定缓冲区起址,用CH375FileReadX代替CH375FileRead,用CH375FileWriteX代替CH375FileWrite */
//#define CH375_INT_WIRE INT0 /* P3.2, INT0, CH375的中断线INT#引脚,连接CH375的INT#引脚,用于查询中断状态 */
#define NO_DEFAULT_CH375_F_ENUM 1 /* 未调用CH375FileEnumer程序故禁止以节约代码 */ #define NO_DEFAULT_CH375_F_QUERY 1 /* 未调用CH375FileQuery程序故禁止以节约代码 */
//#include "..\CH375HFC.H"
/* 在P1.4连接一个LED用于监控演示程序的进度,低电平LED亮,当U盘插入后亮 */ //sbit P1_4 = P1^4; //#define LED_OUT_INIT( ) { P1_4 = 1; } /* P1.4 高电平 */ //#define LED_OUT_ACT( ) { P1_4 = 0; } /* P1.4 低电平驱动LED显示 */ //#define LED_OUT_INACT( ) { P1_4 = 1; } /* P1.4 低电平驱动LED显示 */ //sbit P1_5 = P1^5; /* 在P1.5连接一个LED用于监控演示程序的进度,低电平LED亮,当对U盘操作时亮 */ //#define LED_RUN_ACT( ) { P1_5 = 0; } /* P1.5 低电平驱动LED显示 */ //#define LED_RUN_INACT( ) { P1_5 = 1; } /* P1.5 低电平驱动LED显示 */ //sbit P1_6 = P1^6; /* 在P1.6连接一个LED用于监控演示程序的进度,低电平LED亮,当对U盘写操作时亮 */ //#define LED_WR_ACT( ) { P1_6 = 0; } /* P1.6 低电平驱动LED显示 */ //#define LED_WR_INACT( ) { P1_6 = 1; } /* P1.6 低电平驱动LED显示 */
/* 本例用I/O引脚模拟产生CH375的并口读写时序 */ /* 本例中的硬件连接方式如下(实际应用电路可以参照修改下述3个并口读写子程序) */ /* 单片机的引脚 CH375芯片的引脚 P2.5 INT# P4.5 A0 P2.2 CS# 如果模拟出的并口上只有CH375,那么CS#可以直接接低电平,强制片选 P4.7 WR# P4.6 RD# P5(8位端口) D7-D0 */ sbit CH375_CS = P2^2; sbit CH375_INT_WIRE = P2^5;
void mDelay1_2uS( ) /* 至少延时1.2uS,根据单片机主频调整 */ { return; }
void CH375_PORT_INIT( ) /* 由于使用通用I/O模块并口读写时序,所以进行初始化 */ { CH375_CS = 0;/*CH375_CS = 1;*/ P4 = 0xDF; /*CH375_WR = 1;CH375_RD = 1;CH375_A0 = 0;P0 = 0xFF; */ P6 = 0xFF; /* 并口输入 */ }
void xWriteCH375Cmd( UINT8 mCmd ) /* 外部定义的被CH375程序库调用的子程序,向CH375写命令 */ { //*(UINT8XV *)0XBDF1 = mCmd; //return; mDelay1_2uS( ); mDelay1_2uS( ); /* 至少延时1uS */ P6 = mCmd; /* 向CH375的并口输出数据 */ CH375_CS = 0; P4 = 0x7F; /* 输出有效写控制信号, 写CH375芯片的命令端口 */ CH375_CS = 0; /* 该操作无意义,仅作延时,CH375要求读写脉冲宽度大于100nS */ P4 = 0xDF; /* 输出无效的控制信号, 完成操作CH375芯片 */ CH375_CS = 1; P6 = 0xFF; /* 禁止数据输出 */ mDelay1_2uS( ); mDelay1_2uS( ); /* 至少延时2uS */ }
void xWriteCH375Data( UINT8 mData ) /* 外部定义的被CH375程序库调用的子程序,向CH375写数据 */ { //*(UINT8XV *)0XBCF0 = mData; //return; P6 = mData; /* 向CH375的并口输出数据 */ CH375_CS = 0; P4 = 0x5F; /* 输出有效写控制信号, 写CH375芯片的数据端口 */ CH375_CS = 0; /* 该操作无意义,仅作延时,CH375要求读写脉冲宽度大于100nS */ P4 = 0xDF;; /* 输出无效的控制信号, 完成操作CH375芯片 */ CH375_CS = 1; P6 = 0xFF; /* 禁止数据输出 */ mDelay1_2uS( ); /* 至少延时1.2uS */ }
UINT8 xReadCH375Data( void ) /* 外部定义的被CH375程序库调用的子程序,从CH375读数据 */ { UINT8 mData; //return( *(UINT8XV *)0XBCF0 ); mDelay1_2uS( ); /* 至少延时1.2uS */ P6 = 0xFF; /* 输入 */ CH375_CS = 0; P4=0x9F; /* 输出有效写控制信号, 读CH375芯片的数据端口 */ CH375_CS = 0; /* 该操作无意义,仅作延时,CH375要求读写脉冲宽度大于100nS */ mData = P0; /* 从CH375的并口输入数据 */ P4 = 0xDF;; /* 输出无效的控制信号, 完成操作CH375芯片 */ CH375_CS = 1; return( mData ); }
/* 如果单片机与CH375是串口连接,那么参考下面的子程序 void CH375_PORT_INIT( ) { SCON = 0xD0; 设置串口为9位数据 设置波特率和其它串口参数 }
void xWriteCH375Cmd( UINT8 mCmd ) { TI = 0; TB8 = 1; SBUF = mCmd; while ( TI == 0 ); }
void xWriteCH375Data( UINT8 mData ) { TI = 0; TB8 = 0; SBUF = mData; while ( TI == 0 ); }
UINT8 xReadCH375Data( void ) { while ( RI == 0 ); RI = 0; return( SBUF ); } */
/* 以毫秒为单位延时,不精确,适用于24MHz时钟 */ void mDelaymS( UINT8 delay ) { unsigned char 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 */ } }
/* 将程序空间的字符串复制到外部RAM中,返回字符串长度 */ UINT8 mCopyCodeStringToXRAM( UINT8 xdata *iDestination, UINT8 code *iSource ) { UINT8 i = 0; while ( *iDestination = *iSource ) { iDestination ++; iSource ++; i ++; } return( i ); }
/* 检查操作状态,如果错误则显示错误代码并停机 */ void mStopIfError( UINT8 iError ) { if ( iError == ERR_SUCCESS ) return; /* 操作成功 */ printf( "Error: %02X\n", (UINT16)iError ); /* 显示错误 */ while ( 1 ) { // LED_OUT_ACT( ); /* LED闪烁 */ mDelaymS( 100 ); // LED_OUT_INACT( ); // mDelaymS( 100 ); } }
/* 为printf和getkey输入输出初始化串口 */ void mInitSTDIO( ) { SCON0 = 0x50; PCON = 0x80; TMOD = 0x20; TH1 = 0xf3; /* 24MHz晶振, 9600
#include 这个位置请不要改动,一定要在你屏蔽的位置的地方.否则肯定会有问题. 然后去做测试命令,看能不能正常通过.详细参考CH375DS1 我们的例子程序是在普通的51MCU下面的,你不能把串口直接搬到你上面去,这是必然的.
研究了半天总算是明白了。谢谢了!
红桃六,你再帮我好好看一下.我仔细的检查了一下串口设置是没问题的.头文件的位置我也改了.可还是一样的现象.死循环.Printf还是不可用...谢谢!
出现错误就会死循环的,你看看错误状态是什么,测试命令做了吗?返回值是否正确呢,那你现在先自己另外建立一个工程,不用我们的程序,printf能成功吗
没有错误出现。。。我是自己建立的工程。程序是在CH375LIB下面找的那个CH375HFT.只改了端口跟串口程序。一旦到Printf它就不动了。我做了测试命令是正确的。
我现在也在用CH375B,老是出现问题,不知道怎么解决, CH375Reset( ); Delay(10); i = CH375LibInit( ); /* 初始化CH375程序库和CH375芯片,操作成功返回0 */ mStopIfError( i ); while ( 1 ) { // while ( CH375DiskStatus != DISK_CONNECT ) xQueryInterrupt( ); /* 查询CH375中断并更新中断状态,等待U盘插入 */ while ( CH375DiskStatus < DISK_CONNECT ) { // 查询CH375中断并更新中断状态,等待U盘插入 CH375DiskConnect( ); Delay(10); } Delay(10); /* 延时,可选操作,有的USB存储器需要几十毫秒的延时 */
/* 检查U盘是否准备好,有些U盘不需要这一步,但是某些U盘必须要执行这一步才能工作 */ for ( i = 0; i < 5; i ++ ) /* 有的U盘总是返回未准备好,不过可以被忽略 */ { Delay(10); j = CH375DiskReady( ); if ( j == ERR_SUCCESS ) break; /* 查询磁盘是否准备好 */ } 在调用CH375DiskReady( );函数时就跑飞了程序,
我也遇到这些问题!CH375init()跑飞,编译有警告!请问是怎样解决的?是怎样消除这些警告的
int CH375_Write_To_UP( )
{ UINT8 i, c, SecCount; UINT16 NewSize, count; /* 因为RAM容量有限,所以NewSize限制为16位,实际上如果文件较大,应该分几次读写并且将NewSize改为UINT32以便累计 */ UINT8 *pCodeStr; CH375_PORT_INIT( ); LED_OUT_INIT( ); LED_OUT_ACT( ); /* 开机后LED亮一下以示工作 */ mDelaymS( 100 ); /* 延时100毫秒 */ LED_OUT_INACT( ); // mInitSTDIO( ); /* 为了让计算机通过串口监控演示过程 */ //printf( "Start\n" );
i = CH375LibInit( ); /* 初始化CH375程序库和CH375芯片,操作成功返回0 */ mStopIfError( i ); /* 其它电路初始化 */
while ( 1 ) { //printf( "Wait Udisk\n" ); //while ( CH375DiskStatus != DISK_CONNECT ) xQueryInterrupt( ); /* 查询CH375中断并更新中断状态,等待U盘插入 */ while ( CH375DiskStatus < DISK_CONNECT ) { /* 查询CH375中断并更新中断状态,等待U盘插入 */ if ( CH375DiskConnect( ) == ERR_SUCCESS ) break; /* 有设备连接则返回成功,CH375DiskConnect同时会更新全局变量CH375DiskStatus */ mDelaymS( 100 ); } LED_OUT_ACT( ); /* LED亮 */ mDelaymS( 200 ); /* 延时,可选操作,有的USB存储器需要几十毫秒的延时 */
/* 检查U盘是否准备好,有些U盘不需要这一步,但是某些U盘必须要执行这一步才能工作 */ for ( i = 0; i < 10; i ++ ) { /* 有的U盘总是返回未准备好,不过可以被忽略 */ mDelaymS( 100 ); //printf( "Ready ?\n" ); if ( CH375DiskReady( ) == ERR_SUCCESS ) break; /* 查询磁盘是否准备好 */
} break; } strcpy( (char *)mCmdParam.Create.mPathName, "/NEWFILE.TXT" ); /* 新文件名,在根目录下 */ i = CH375FileCreate( ); /* 新建文件并打开,如果文件已经存在则先删除后再新建 */ mStopIfError( i ); 我太明白程序 为什么 跑到 mStopIfError( i ); i总是不等于 成功 (i != ERR_SUCCESS) return ;
问题 :总是无法 新建文件 我用的是 并口 外部中断 用INT# 低电平 进中断 这个没有问题 就是无法新建文件 是文件格式有问题 还有什么地方出错了 希望大虾们帮我看看 谢谢了 还有我不 Print()函数全删除了 因为 keil-MDK 好像不支持 因为程序一 跑到 Print()就停止了 所以我把所以的 Print()都删除了
//printf( "Write\n" );
int CH375_Write_To_UP( )
{ UINT8 i, c, SecCount; UINT16 NewSize, count; /* 因为RAM容量有限,所以NewSize限制为16位,实际上如果文件较大,应该分几次读写并且将NewSize改为UINT32以便累计 */ UINT8 *pCodeStr; CH375_PORT_INIT( ); LED_OUT_INIT( ); LED_OUT_ACT( ); /* 开机后LED亮一下以示工作 */ mDelaymS( 100 ); /* 延时100毫秒 */ LED_OUT_INACT( ); // mInitSTDIO( ); /* 为了让计算机通过串口监控演示过程 */ //printf( "Start\n" );
i = CH375LibInit( ); /* 初始化CH375程序库和CH375芯片,操作成功返回0 */ mStopIfError( i ); /* 其它电路初始化 */
while ( 1 ) { //printf( "Wait Udisk\n" ); //while ( CH375DiskStatus != DISK_CONNECT ) xQueryInterrupt( ); /* 查询CH375中断并更新中断状态,等待U盘插入 */ while ( CH375DiskStatus < DISK_CONNECT ) { /* 查询CH375中断并更新中断状态,等待U盘插入 */ if ( CH375DiskConnect( ) == ERR_SUCCESS ) break; /* 有设备连接则返回成功,CH375DiskConnect同时会更新全局变量CH375DiskStatus */ mDelaymS( 100 ); } LED_OUT_ACT( ); /* LED亮 */ mDelaymS( 200 ); /* 延时,可选操作,有的USB存储器需要几十毫秒的延时 */
/* 检查U盘是否准备好,有些U盘不需要这一步,但是某些U盘必须要执行这一步才能工作 */ for ( i = 0; i < 10; i ++ ) { /* 有的U盘总是返回未准备好,不过可以被忽略 */ mDelaymS( 100 ); //printf( "Ready ?\n" ); if ( CH375DiskReady( ) == ERR_SUCCESS ) break; /* 查询磁盘是否准备好 */
} break; } strcpy( (char *)mCmdParam.Create.mPathName, "/NEWFILE.TXT" ); /* 新文件名,在根目录下 */ i = CH375FileCreate( ); /* 新建文件并打开,如果文件已经存在则先删除后再新建 */ mStopIfError( i ); 我太明白程序 为什么 跑到 mStopIfError( i ); i总是不等于 成功 (i != ERR_SUCCESS) return ;
问题 :总是无法 新建文件 我用的是 并口 外部中断 用INT# 低电平 进中断 这个没有问题 就是无法新建文件 是文件格式有问题 还有什么地方出错了 希望大虾们帮我看看 谢谢了 还有我不 Print()函数全删除了 因为 keil-MDK 好像不支持 因为程序一 跑到 Print()就停止了 所以我把所以的 Print()都删除了
//printf( "Write\n" );
CH375DiskReady( )返回多少