OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4192|回复: 4

在TINY FAT表里面查找cluster的上一个簇号

[复制链接]

3

主题

62

帖子

0

精华

初级会员

Rank: 2

积分
95
金钱
95
注册时间
2013-7-18
在线时间
0 小时
发表于 2013-7-18 20:15:06 | 显示全部楼层 |阅读模式
原子哥,在FAT文件管理中,有个u32 FatTab_Prev_Cluster(unsigned long cluster)函数,里面的Copy_Fat_Table(tempclust);后面要不要加上cluster=tempclust一句,不加的话我总感觉有点问题啊,请指教一下,我的想法哪里错了
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2013-7-18 22:09:24 | 显示全部楼层
回复【楼主位】anglexuchao66:
---------------------------------
为什么呢?
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

3

主题

62

帖子

0

精华

初级会员

Rank: 2

积分
95
金钱
95
注册时间
2013-7-18
在线时间
0 小时
 楼主| 发表于 2013-7-19 09:59:58 | 显示全部楼层
u32 FatTab_Prev_Cluster(unsigned long cluster)
{
u8 t;  
u32 tempclust;
RSTP:
for(t=0;t<Fat_Table_Size;t++)
{
if(cluster><=(FAT_TAB.Fat_Base_Tab[t]+FAT_TAB.Fat_Base_Len[t]-1)&&cluster>=FAT_TAB.Fat_Base_Tab[t])break;
//在这个BASE内
}   
if(cluster==FAT_TAB.Fat_Base_Tab[t])//是在BASE,但是是第一个
{  
if(t==0)//这份FAT表 全部找完还没找到
{       
if(FAT_TAB.Fat_Head_Pos>0)//不超过范围
{
FAT_TAB.Fat_Head_Pos--;    //存储不同文件的表头
tempclust=FAT_TAB.Fat_Base_Head[FAT_TAB.Fat_Head_Pos];//拷贝上一个tinyFAT表的表头
}else return cluster;   //无法继续向上
Copy_Fat_Table(tempclust);//COPY 上一个tinyFAT表 

goto RSTP;
//return FAT_TAB.Fat_Base_Tab[Fat_Table_Size-1]+FAT_TAB.Fat_Base_Len[Fat_Table_Size-1]-1;
//返回上一个簇号  
}   
return FAT_TAB.Fat_Base_Tab[t-1]+FAT_TAB.Fat_Base_Len[t-1]-1;//上一个簇号
}else return --cluster;    //返回上一个簇   
}  
当该簇为文件的表头时,也就是t=0,依次将下个文件COPY 上一个tinyFAT表,接着执行goto RSTP;但是for中的条件都不满足啊,执行完之后t=10了,再执行if就会出现问题了啊
回复 支持 反对

使用道具 举报

3

主题

62

帖子

0

精华

初级会员

Rank: 2

积分
95
金钱
95
注册时间
2013-7-18
在线时间
0 小时
 楼主| 发表于 2013-7-19 10:02:57 | 显示全部楼层
回复【2楼】正点原子:
---------------------------------
u32 FatTab_Prev_Cluster(unsigned long cluster) 

u8 t;   
u32 tempclust; 
RSTP: 
for(t=0;t<Fat_Table_Size;t++) 

if(cluster><=(FAT_TAB.Fat_Base_Tab[t]+FAT_TAB.Fat_Base_Len[t]-1)&&cluster>=FAT_TAB.Fat_Base_Tab[t])break; 
//在这个BASE内 
}    
if(cluster==FAT_TAB.Fat_Base_Tab[t])//是在BASE,但是是第一个 
{   
if(t==0)//这份FAT表 全部找完还没找到 
{        
if(FAT_TAB.Fat_Head_Pos>0)//不超过范围 

FAT_TAB.Fat_Head_Pos--;    //存储不同文件的表头 
tempclust=FAT_TAB.Fat_Base_Head[FAT_TAB.Fat_Head_Pos];//拷贝上一个tinyFAT表的表头 
}else return cluster;   //无法继续向上 
Copy_Fat_Table(tempclust);//COPY 上一个tinyFAT表  

goto RSTP; 
//return FAT_TAB.Fat_Base_Tab[Fat_Table_Size-1]+FAT_TAB.Fat_Base_Len[Fat_Table_Size-1]-1; 
//返回上一个簇号   
}    
return FAT_TAB.Fat_Base_Tab[t-1]+FAT_TAB.Fat_Base_Len[t-1]-1;//上一个簇号 
}else return --cluster;    //返回上一个簇    
}   
当该簇为文件的表头时,也就是t=0,依次将下个文件COPY 上一个tinyFAT表,接着执行goto RSTP;但是for中的条件都不满足啊,执行完之后t=10了,再执行if就会出现问题了啊
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2013-7-19 11:09:30 | 显示全部楼层
t=0,cluster又是表头的时候.
if(FAT_TAB.Fat_Head_Pos>0)//不超过范围
这个条件会得不到满足.
那么直接就return cluster了
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-7-17 05:48

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表