📄 main.lss
字号:
{
mCmdParam.ReadX.mDataBuffer = &FILE_DATA_BUF[0]; /* 指向文件数据缓冲区 */
47a: 8d ec ldi r24, 0xCD ; 205
47c: 95 e0 ldi r25, 0x05 ; 5
47e: 90 93 b6 05 sts 0x05B6, r25
482: 80 93 b5 05 sts 0x05B5, r24
return( CH375FileReadX( ) );
486: 0e 94 e9 1c call 0x39d2 <CH375FileReadX>
}
48a: 99 27 eor r25, r25
48c: 08 95 ret
0000048e <CH375FileWrite>:
#ifdef EN_DISK_WRITE
UINT8 CH375FileWrite( void ) /* 向当前文件写入数据 */
{
mCmdParam.WriteX.mDataBuffer = &FILE_DATA_BUF[0]; /* 指向文件数据缓冲区 */
48e: 8d ec ldi r24, 0xCD ; 205
490: 95 e0 ldi r25, 0x05 ; 5
492: 90 93 b6 05 sts 0x05B6, r25
496: 80 93 b5 05 sts 0x05B5, r24
return( CH375FileWriteX( ) );
49a: 0e 94 d6 1d call 0x3bac <CH375FileWriteX>
}
49e: 99 27 eor r25, r25
4a0: 08 95 ret
000004a2 <xDelay100uS>:
#endif
#endif
/* 以下程序可以根据需要修改 */
#ifndef NO_DEFAULT_CH375_F_ENUM /* 在应用程序中定义NO_DEFAULT_CH375_F_ENUM可以禁止默认的枚举文件程序,然后用自行编写的程序代替它 */
UINT8 CH375FileEnumer( void ) /* 枚举文件 */
{
UINT8 status;
status = CH375FileOpen( );
if ( status == ERR_FOUND_NAME ) status = ERR_SUCCESS; /* 操作成功 */
return( status );
}
#endif
#ifndef NO_DEFAULT_CH375_F_QUERY /* 在应用程序中定义NO_DEFAULT_CH375_F_QUERY可以禁止默认的查询当前文件的信息程序,然后用自行编写的程序代替它 */
UINT8 CH375FileQuery( void ) /* 查询当前文件的信息 */
{
PUINT8 buf;
UINT8 count;
buf = (PUINT8)( & mCmdParam.Modify.mFileSize );
for ( count = sizeof( mCmdParam.Modify ); count != 0; count -- ) {
*buf = 0xFF; /* 输入参数全部无效,仅查询不修改 */
buf ++;
}
return( CH375FileModify( ) );
}
#endif
#ifndef NO_DEFAULT_CH375_INT /* 在应用程序中定义NO_DEFAULT_CH375_INT可以禁止默认的中断处理程序,然后用自行编写的程序代替它 */
#if LIB_CFG_INT_EN == 0 /* CH375的INT#引脚连接方式为"查询方式" */
void xQueryInterrupt( void ) /* 查询CH375中断并更新中断状态 */
{
while ( CH375_INT_WIRE ); /* 如果CH375的中断引脚输出高电平则等待 */
xWriteCH375Cmd( CMD_GET_STATUS ); /* 获取当前中断状态,发出命令后至少延时2uS */
CH375IntStatus = xReadCH375Data( ); /* 获取中断状态 */
if ( CH375IntStatus == USB_INT_DISCONNECT ) CH375DiskStatus = DISK_DISCONNECT; /* 检测到USB设备断开事件 */
else if ( CH375IntStatus == USB_INT_CONNECT ) CH375DiskStatus = DISK_CONNECT; /* 检测到USB设备连接事件 */
}
#else /* LIB_CFG_INT_EN != 0, CH375的INT#引脚连接方式为"中断方式" */
void xQueryInterrupt( void ) /* 查询中断状态,等待硬件中断 */
{
while ( CH375IntStatus == 0 ); /* 子程序库调用该子程序之前CH375IntStatus=0,硬件中断后,由中断服务程序置为非0的实际中断状态后返回 */
}
#ifndef CH375_INT_NO
#define CH375_INT_NO 2
#endif
#pragma interrupt_handler CH375Interrupt:CH375_INT_NO
void CH375Interrupt( void ) /* CH375中断服务程序,由CH375的INT#的低电平或者下降沿触发单片机中断 */
{
xWriteCH375Cmd( CMD_GET_STATUS ); /* 获取中断状态并取消中断请求 */
CH375IntStatus = xReadCH375Data( ); /* 获取中断状态 */
if ( CH375IntStatus == USB_INT_DISCONNECT ) CH375DiskStatus = DISK_DISCONNECT; /* 检测到USB设备断开事件 */
else if ( CH375IntStatus == USB_INT_CONNECT ) CH375DiskStatus = DISK_CONNECT; /* 检测到USB设备连接事件 */
#ifdef CLEAR_INT_MARK
CLEAR_INT_MARK( ); /* 某些单片机需要由软件清除中断标志 */
#endif
}
#endif
#endif
#ifndef NO_DEFAULT_DELAY_100US /* 在应用程序中定义NO_DEFAULT_DELAY_100US可以禁止默认的延时100uS子程序,然后用自行编写的程序代替它 */
void xDelay100uS( void ) /* 延时100uS */
{
UINT16 count;
for ( count = 330; count != 0; count -- ); /* 延时100uS,6x50nS@20MHz */
4a2: 8a e4 ldi r24, 0x4A ; 74
4a4: 91 e0 ldi r25, 0x01 ; 1
4a6: 4e 97 sbiw r24, 0x1e ; 30
4a8: f1 f7 brne .-4 ; 0x4a6 <xDelay100uS+0x4>
4aa: 08 95 ret
000004ac <xDelayAfterWrite>:
}
#endif
#ifdef EN_DISK_WRITE
#ifndef NO_DEFAULT_DELAY_WRITE /* 在应用程序中定义NO_DEFAULT_DELAY_WRITE可以禁止默认的写操作后延时程序,然后用自行编写的程序代替它 */
void xDelayAfterWrite( void ) /* 写操作后延时 */
{
UINT16 count;
for ( count = 650; count != 0; count -- ); /* 延时200uS左右 */
4ac: 8a e8 ldi r24, 0x8A ; 138
4ae: 92 e0 ldi r25, 0x02 ; 2
4b0: c2 97 sbiw r24, 0x32 ; 50
4b2: f1 f7 brne .-4 ; 0x4b0 <xDelayAfterWrite+0x4>
4b4: 08 95 ret
000004b6 <xFileNameEnumer>:
}
#endif
#endif
#ifndef NO_DEFAULT_FILE_ENUMER /* 在应用程序中定义NO_DEFAULT_FILE_ENUMER可以禁止默认的文件名枚举回调程序,然后用自行编写的程序代替它 */
void xFileNameEnumer( void ) /* 文件名枚举回调子程序 */
{
4b6: 08 95 ret
000004b8 <xWriteToExtBuf>:
/* 如果指定枚举序号CH375vFileSize为0xFFFFFFFF后调用FileOpen,那么每搜索到一个文件FileOpen都会调用本回调程序,
回调程序xFileNameEnumer返回后,FileOpen递减CH375vFileSize并继续枚举直到搜索不到文件或者目录。建议做法是,
在调用FileOpen之前定义一个全局变量为0,当FileOpen回调本程序后,本程序由CH375vFdtOffset得到结构FAT_DIR_INFO,
分析结构中的DIR_Attr以及DIR_Name判断是否为所需文件名或者目录名,记录相关信息,并将全局变量计数增量,
当FileOpen返回后,判断返回值如果是ERR_MISS_FILE或ERR_FOUND_NAME都视为操作成功,全局变量为搜索到的有效文件数。
如果在本回调程序xFileNameEnumer中将CH375vFileSize置为1,那么可以通知FileOpen提前结束搜索。以下是回调程序例子 */
#if 0
#ifdef FILE_DATA_BUF_LEN
UINT8 i;
UINT16 FileCount;
P_FAT_DIR_INFO pFileDir;
PUINT8 NameBuf;
pFileDir = (P_FAT_DIR_INFO)( (PUINT8)(&DISK_BASE_BUF[0]) + CH375vFdtOffset ); /* 当前FDT的起始地址 */
FileCount = (UINT16)( 0xFFFFFFFF - CH375vFileSize ); /* 当前文件名的枚举序号,CH375vFileSize初值是0xFFFFFFFF,找到文件名后递减 */
if ( FileCount < FILE_DATA_BUF_LEN / 12 ) { /* 检查缓冲区是否足够存放,假定每个文件名需占用12个字节存放 */
NameBuf = & FILE_DATA_BUF[ FileCount * 12 ]; /* 计算保存当前文件名的缓冲区地址 */
for ( i = 0; i < 11; i ++ ) NameBuf[ i ] = pFileDir -> DIR_Name[ i ]; /* 复制文件名,长度为11个字符,未处理空格 */
if ( pFileDir -> DIR_Attr & ATTR_DIRECTORY ) NameBuf[ i ] = 1; /* 判断是目录名 */
NameBuf[ i ] = 0; /* 文件名结束符 */
}
#endif
#endif
}
#endif
#ifdef EXT_BLK_INTERFACE
#if LIB_CFG_FILE_IO == 0 /* 文件读写的数据的复制方式为"外部子程序" */
#ifdef LIB_CFG_FILE_IO_DEFAULT /* 如果应用程序中定义该值则使用默认"外部子程序",否则应该自行编写程序代替 */
unsigned char *current_buffer; /* 保存文件数据读写时的缓冲区的当前指针,由应用程序在调用CH375FileReadX和CH375FileWriteX子程序前设置初值 */
void xWriteToExtBuf( UINT8 mLength ) /* 该子程序由CH375的子程序库调用,用于从CH375读取文件数据到外部缓冲区,被CH375FileReadX调用 */
{
/* if ( (UINT32)current_buffer + mLength >= (UINT32)&FILE_DATA_BUF + sizeof( FILE_DATA_BUF ) ) return;*/ /* 防止缓冲区溢出 */
if ( mLength ) {
do { /* 根据长度读取数据,实际上长度总是CH375_MAX_DATA_LEN,也就是64 */
*current_buffer = xReadCH375Data( ); /* 读出数据并保存,可以用这种方式将文件数据保存到单片机的各种串行存储器中 */
current_buffer ++;
} while ( -- mLength );
} /* 复制上述数据的总时间不得超过2mS */
else { /* 重试,恢复缓冲区起址,如果将文件数据读写的缓冲区的当前指针放在mCmdParam.ReadX.mDataBuffer中则会被自动恢复,无需下面的两行程序 */
current_buffer += (UINT16)mCmdParam.ReadX.mDataBuffer; /* mDataBuffer中为负值 */
mCmdParam.ReadX.mDataBuffer = 0; /* 为了支持重试,在调用CH375FileReadX之前也应该清0 */
}
}
#ifdef EN_DISK_WRITE
void xReadFromExtBuf( UINT8 mLength ) /* 该子程序由CH375的子程序库调用,用于从外部缓冲区读取文件数据到CH375,被CH375FileWriteX调用 */
{
if ( mLength ) {
do { /* 根据长度写入数据,实际上长度总是CH375_MAX_DATA_LEN,也就是64 */
xWriteCH375Data( *current_buffer ); /* 将数据写入,可以用这种方式从单片机的各种串行存储器中取出文件数据 */
current_buffer ++;
} while ( -- mLength );
} /* 复制上述数据的总时间不得超过2mS */
else { /* 重试,恢复缓冲区起址,如果将文件数据读写的缓冲区的当前指针放在mCmdParam.WriteX.mDataBuffer中则会被自动恢复,无需下面的两行程序 */
current_buffer += (UINT16)mCmdParam.WriteX.mDataBuffer; /* mDataBuffer中为负值 */
mCmdParam.WriteX.mDataBuffer = 0; /* 为了支持重试,在调用CH375FileWriteX之前也应该清0 */
}
}
#endif
#endif
#else /* LIB_CFG_FILE_IO != 0,文件读写的数据的复制方式不是"外部子程序" */
#ifdef FILE_DATA_BUF_LEN
void xWriteToExtBuf( UINT8 mLength ) /* 不会调用该子程序 */
{
4b8: 08 95 ret
000004ba <xReadFromExtBuf>:
mLength --; /* 该操作无意义,只是避免出现警告信息 */
}
#ifdef EN_DISK_WRITE
void xReadFromExtBuf( UINT8 mLength ) /* 不会调用该子程序 */
{
4ba: 08 95 ret
000004bc <CH375LibInit>:
mLength --; /* 该操作无意义,只是避免出现警告信息 */
}
#endif
#endif
#endif
#endif
UINT8 CH375LibInit( void ) /* 初始化CH375程序库和CH375芯片,操作成功返回0 */
{
CH375LibConfig = LIB_CFG_VALUE; /* CH375程序库配置值 */
4bc: 85 e0 ldi r24, 0x05 ; 5
4be: 80 93 cd 07 sts 0x07CD, r24
DISK_BASE_BUF[0] = 0; /* 该操作无意义,只是为了防止编译器优化时不产生DISK_BASE_BUF缓冲区 */
4c2: 10 92 ad 03 sts 0x03AD, r1
if ( CH375GetVer( ) < CH375_LIB_VER ) return( 0xFF ); /* 获取当前子程序库的版本号,版本太低则返回错误 */
4c6: 0e 94 9f 0a call 0x153e <CH375GetVer>
4ca: 80 33 cpi r24, 0x30 ; 48
4cc: 18 f4 brcc .+6 ; 0x4d4 <CH375LibInit+0x18>
4ce: 8f ef ldi r24, 0xFF ; 255
4d0: 90 e0 ldi r25, 0x00 ; 0
4d2: 08 95 ret
return( CH375Init( ) ); /* 初始化CH375 */
4d4: 0e 94 6a 0b call 0x16d4 <CH375Init>
4d8: 99 27 eor r25, r25
}
4da: 08 95 ret
000004dc <mDelay1uS1>:
#define CS_B (PORTB|= 0X10)
#define LED_1 (PORTC|= 0X80)
#define LED_0 (PORTC&= 0X7F)
void mDelay1uS1(void ) /* 至少延时1uS,根据单片机主频调整 */
{
4dc: 08 95 ret
000004de <xReadCH375Data>:
UINT8 i;
for ( i = 5; i != 0; i -- );
}
void CH375_PORT_INIT(void ) /* 由于使用通用I/O模块并口读写时序,所以进行初始化 */
{
DDRA = 0x00; /* 设置8位并口为输入 */
PORTD = 0x70; /* 设置CS,WR,RD默认为高电平 */
DDRD = 0xF0; /* 设置CS,WR,RD,A0为输出,设置INT#为输入 */
}
void xWriteCH375Cmd( UINT8 mCmd ) /* 外部定义的被CH375程序库调用的子程序,向CH375写命令 */
{
mDelay1uS1( ); mDelay1uS1( ); /* 至少延时1uS */
/* *(volatile unsigned char *)CH375_CMD_PORT_ADDR = mCmd; 通过并口直接读写CH375而非普通I/O模拟 */
PORTD |= 0x80; /* 输出A0=1 */
PORTA = mCmd; /* 向CH375的并口输出数据 */
DDRA = 0xFF; /* 并口D0-D7输出 */
PORTD &= 0x9F; /* 输出有效写控制信号, 写CH375芯片的命令端口, A0=1; CS=0; WR=0; RD=1; */
DDRA = 0xFF; /* 该操作无意义,仅作延时,CH375要求读写脉冲宽度大于100nS */
PORTD |= 0xF0; /* 输出无效的控制信号, 完成操作CH375芯片, A0=1; CS=1; WR=1; RD=1; */
DDRA = 0x00; /* 禁止数据输出 */
PORTD &= 0x7F; /* 输出A0=0; 可选操作 */
mDelay1uS1( ); mDelay1uS1( ); /* 至少延时2uS */
}
void xWriteCH375Data( UINT8 mData ) /* 外部定义的被CH375程序库调用的子程序,向CH375写数据 */
{
/* *(volatile unsigned char *)CH375_DAT_PORT_ADDR = mData; 通过并口直接读写CH375而非普通I/O模拟 */
PORTA = mData; /* 向CH375的并口输出数据 */
DDRA = 0xFF; /* 并口D0-D7输出 */
PORTD &= 0x1F; /* 输出有效写控制信号, 写CH375芯片的数据端口, A0=0; CS=0; WR=0; RD=1; */
DDRA = 0xFF; /* 该操作无意义,仅作延时,CH375要求读写脉冲宽度大于100nS */
PORTD |= 0x70; /* 输出无效的控制信号, 完成操作CH375芯片, A0=0; CS=1; WR=1; RD=1; */
DDRA = 0x00; /* 禁止数据输出 */
mDelay1uS1( ); /* 至少延时1.2uS */
}
UINT8 xReadCH375Data( void ) /* 外部定义的被CH375程序库调用的子程序,从CH375读数据 */
{
UINT8 mData;
/* mData = *(volatile unsigned char *)CH375_DAT_PORT_ADDR; 通过并口直接读写CH375而非普通I/O模拟 */
mDelay1uS1( ); /* 至少延时1.2uS */
DDRA = 0x00; /* 数据输入 */
4de: 1a ba out 0x1a, r1 ; 26
PORTD &= 0x2F; /* 输出有效读控制信号, 读CH375芯片的数据端口, A0=0; CS=0; WR=1; RD=0; */
4e0: 82 b3 in r24, 0x12 ; 18
4e2: 8f 72 andi r24, 0x2F ; 47
4e4: 82 bb out 0x12, r24 ; 18
DDRA = 0x00; /* 该操作无意义,仅作延时,CH375要求读写脉冲宽度大于100nS */
4e6: 1a ba out 0x1a, r1 ; 26
mData = PINA; /* 从CH375的并口PA输入数据 */
4e8: 99 b3 in r25, 0x19 ; 25
PORTD |= 0x70; /* 输出无效的控制信号, 完成操作CH375芯片, A0=0; CS=1; WR=1; RD=1; */
4ea: 82 b3 in r24, 0x12 ; 18
4ec: 80 67 ori r24, 0x70 ; 112
4ee: 82 bb out 0x12, r24 ; 18
return( mData );
}
4f0: 89 2f mov r24, r25
4f2: 99 27 eor r25, r25
4f4: 08 95 ret
000004f6 <xWriteCH375Cmd>:
4f6: 97 9a sbi 0x12, 7 ; 18
4f8: 8b bb out 0x1b, r24 ; 27
4fa: 9f ef ldi r25, 0xFF ; 255
4fc: 9a bb out 0x1a, r25 ; 26
4fe: 82 b3 in r24, 0x12 ; 18
500: 8f 79 andi r24, 0x9F ; 159
502: 82 bb out 0x12, r24 ; 18
504: 9a bb out 0x1a, r25 ; 26
506: 82 b3 in r24, 0x12 ; 18
508: 80 6f ori r24, 0xF0 ; 240
50a: 82 bb out 0x12, r24 ; 18
50c: 1a ba out 0x1a, r1 ; 26
50e: 97 98 cbi 0x12, 7 ; 18
510: 08 95 ret
00000512 <xQueryInterrupt>:
512: 82 99 sbic 0x10, 2 ; 16
514: fe cf rjmp .-4 ; 0x512 <xQueryInterrupt>
516: 82 e2 ldi r24, 0x22 ; 34
518: 0e 94 7b 02 call 0x4f6 <xWriteCH375Cmd>
51c: 0e 94 6f 02 call 0x4de <xReadCH375Data>
520: 80 93 db 07 sts 0x07DB, r24
524: 80 91 db 07 lds r24, 0x07DB
528: 86 31 cpi r24, 0x16 ; 22
52a: 21 f4 brne .+8 ; 0x534 <xQueryInterrupt+0x22>
52c: 81 e0 ldi r24, 0x01 ; 1
52e: 80 93 f5 07 sts 0x07F5, r24
532: 08 95 ret
534: 80 91 db 07 lds r24, 0x07DB
538: 85 31 cpi r24, 0x15 ; 21
53a: 19 f4 brne .+6 ; 0x542 <xQueryInterrupt+0x30>
53c: 82 e0 ldi r24, 0x02 ; 2
53e: 80 93 f5 07 sts 0x07F5, r24
542: 08 95 ret
00000544 <CH375_PORT_INIT>:
544: 1a ba out 0x1a, r1 ; 26
546: 80 e7 ldi r24, 0x70 ; 112
548: 82 bb out 0x12, r24 ; 18
54a: 80 ef ldi r24, 0xF0 ; 240
54c: 81 bb out 0x11, r24 ; 17
54e: 08 95 ret
00000550 <xWriteCH375Data>:
550: 8b bb out 0x1b, r24 ; 27
552: 9f ef ldi r25, 0xFF ; 255
554: 9a bb out 0x1a, r25 ; 26
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -