亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? fat.c

?? MMC interface and FAT File system
?? C
?? 第 1 頁 / 共 2 頁
字號:
//###########################################################
// File: fat.c
//
// For FAT12, FAT16 and FAT32
// FAT32 not tested yet
// Only for first Partition
// Only for drives with 512 bytes per sector (the most)
//
// Based on a White Paper from MS
// FAT: General Overview of On-Disk Format
// Version 1.03, December 6, 2000
//
// MBR MasterBootRecord
// PC intern 4
// M.Tischer
// Data Becker
//
// Organisation of a FAT formatted drive:
// ======================================
// MBR including Partitiontable's
// Hidden Sectors
//
// First Partition
// Bootsector 1
// Reserved Sectors
// FAT1
// FAT2
// ...
// FATn
// RootDirectory (not used if FAT32)
// Data Region
//
// Second Partition
// Bootsector 2
// Reserved Sectors
// .....
//
//#########################################################################
// Last change: 10.05.2003
//#########################################################################
// holger.klabunde@t-online.de
// http://home.t-online.de/home/holger.klabunde/homepage.htm
//#########################################################################
// Compiler: AVR-GCC 3.2
//#########################################################################
#include <stdlib.h>
#include <string.h>
#include <ctype.h>

#include "protos.h"
#include "dos.h"
#include "mydefs.h"
#include "serial.h"

unsigned long FirstDataSector;
unsigned long FirstRootSector;
unsigned long FirstFatSector;
unsigned long FATSz;
unsigned long FAT32RootCluster;
unsigned char FATtype;

unsigned char secPerCluster;
unsigned long CountofClusters;

unsigned long CurrentDirCluster;
unsigned long RootDirSectors;
unsigned int  RootEntrys;

//use some global variables for faster file access
unsigned long FileFirstCluster;     //first cluster of file
unsigned long FileCurrentSector;    //sector with last data read/written
unsigned long FileCurrentCluster;   //actual cluster in use
unsigned long File1stClusterSector; //1st sector of cluster in use
unsigned long FileClusterCount;     //clusters read
unsigned long FileBytePerCluster;   //bytes per cluster
unsigned long FileDirSector;        //sector with dir entry of file
unsigned char FileDirOffset;        //offset to file entry in FileDirSector
unsigned long FileSize;
unsigned long FilePosition;         //actual position when reading file         
unsigned char FileFlag;		    //read or write
unsigned char FileName[8];
unsigned char FileExt[3];

unsigned long CurrentSector;
unsigned long CurrentCluster;

unsigned long endofclusterchain; //value for END_OF_CLUSTERCHAIN 
unsigned char lo; //show long name entrys on=1;
unsigned long maxcluster;

//###########################################################
unsigned long AllocCluster(unsigned long currentcluster)
//###########################################################
{
 unsigned long cluster;

// do this if you want to search from beginning of FAT
// cluster=FindFreeCluster(0); //get next free cluster number
 cluster=FindFreeCluster(currentcluster); // get next free cluster number
 if(cluster!=DISK_FULL && cluster<=maxcluster) // disk full ?
  {
    // insert new cluster number into chain
    // currentcluster=0 means: this is a new cluster chain
    if(currentcluster>0) WriteClusterNumber(currentcluster,cluster);

   // mark end of cluster chain
   if(FATtype==FAT12) WriteClusterNumber(cluster,0xFFF); 
   if(FATtype==FAT16) WriteClusterNumber(cluster,0xFFFF); 
   if(FATtype==FAT32) WriteClusterNumber(cluster,0x0FFFFFFF); 
  }

 return cluster;
}

//###########################################################
// go through the FAT to find a free cluster
unsigned long FindFreeCluster(unsigned long currentcluster)
//###########################################################
{
 unsigned long cluster;

 cluster=currentcluster+1; // its a good idea to look here first
                           // maybe we do not need to search the whole FAT
                           // and can speed up free cluster search
                           // if you do not want this call FindFreeCluster(0)
// search til end of FAT
 while(cluster<maxcluster)
  {
   if(GetNextClusterNumber(cluster)==0) break;
   cluster++;
  }

// if we have not found a free cluster til end of FAT
// lets start a new search at beginning of FAT
 if(cluster>=maxcluster)
  {
   cluster=2; // first possible free cluster
   while(cluster<=currentcluster) // search til we come to where we have started
    {
     if(GetNextClusterNumber(cluster)==0) break;
     cluster++;
    }

   if(cluster>=currentcluster) return DISK_FULL; // no free cluster found
  }
  
 if(cluster>=maxcluster) return DISK_FULL;
    
 return cluster;
}

//############################################################
// write a cluster number into fat cluster chain
unsigned char WriteClusterNumber(unsigned long cluster, unsigned long number)
//############################################################
{
 unsigned int tmp, secoffset;
 unsigned long fatoffset, sector;
 unsigned char *p,lo,hi;
 
 if(cluster<maxcluster) //we need to check this ;-)
  {

   if(FATtype==FAT12)
    {
     //FAT12 has 1.5 Bytes per FAT entry
     fatoffset= (cluster * 3) >>1 ; //multiply by 1.5 (rounds down)
     secoffset = fatoffset % BYTE_PER_SEC; //we need this for later
     fatoffset= fatoffset / BYTE_PER_SEC; //sector offset from FirstFatSector
     sector=FirstFatSector + fatoffset;

     tmp=(unsigned int)number;
     if(cluster & 0x01) tmp<<=4; //shift to right position
     lo=(unsigned char)tmp;
     hi=(unsigned char)(tmp>>8);
     
     CFReadSector(sector,inbuff); //read FAT sector
     if(secoffset == (BYTE_PER_SEC-1)) //if this is the case, cluster number is
                                   //on a sector boundary. read the next sector too
      {
       p=&inbuff[BYTE_PER_SEC-1]; //keep first part of cluster number
       if(cluster & 0x01)
        {
         *p&=0x0F;
         *p|=lo;
        }
       else *p=lo;
        
       CFWriteSector(sector,inbuff);
   
       CFReadSector(sector+1,inbuff ); //read next FAT sector

       p=&inbuff[0]; //second part of cluster number
       if(cluster & 0x01) *p=hi;
       else
        {
         *p&=0xF0;
         *p|=hi;
        }

       CFWriteSector(sector+1,inbuff);
      }
     else
      {
       p=&inbuff[secoffset];
       if(cluster & 0x01)
        {
         *p&=0x0F;
         *p++|=lo;
         *p=hi;
        } 
       else
        {
         *p++=lo;
         *p&=0xF0;
         *p|=hi;
        } 
       CFWriteSector(sector,inbuff);
      } 

    }//if(FATtype==FAT12)

   if(FATtype==FAT16)
    {
     //two bytes per FAT entry
     sector=FirstFatSector + (cluster * 2) / BYTE_PER_SEC;
     CFReadSector(sector, inbuff);

     p=&inbuff[(cluster * 2) % BYTE_PER_SEC];
     *p++=(unsigned char)(number);
     *p  =(unsigned char)(number >> 8);
     CFWriteSector(sector, inbuff);
    }// if(FATtype==FAT16)

   if(FATtype==FAT32)
    {
     //four bytes per FAT entry
     sector=FirstFatSector + (cluster * 4) / BYTE_PER_SEC;
     CFReadSector(sector, inbuff);

     p=&inbuff[(cluster * 4) % BYTE_PER_SEC];
     number&=0x0FFFFFFF;
     
     *p++=(unsigned char)(number);
     *p++=(unsigned char)(number >> 8);
     *p++=(unsigned char)(number >> 16);
     *p  =(unsigned char)(number >> 24);
     CFWriteSector(sector, inbuff);
    }// if(FATtype==FAT32) 
  }

 return 0;
}

//############################################################
// get next clusternumber of fat cluster chain
unsigned long GetNextClusterNumber(unsigned long cluster)
//############################################################
{
 unsigned int tmp, secoffset;
 unsigned long fatoffset;
 union Convert *cv;

 if(cluster<maxcluster) //we need to check this ;-)
  {

   if(FATtype==FAT12)
    {
     //FAT12 has 1.5 Bytes per FAT entry
     fatoffset= (cluster * 3) >>1 ; //multiply by 1.5 (rounds down)
     secoffset = fatoffset % BYTE_PER_SEC; //we need this for later
     fatoffset= fatoffset / BYTE_PER_SEC; //sector offset from FirstFatSector
 

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
免费高清不卡av| 国产伦精品一区二区三区免费迷| 日韩欧美三级在线| 99久久精品99国产精品| 麻豆成人91精品二区三区| 成人免费一区二区三区在线观看| 欧美一区二区三区色| 欧洲中文字幕精品| 国产69精品久久久久毛片| 日本 国产 欧美色综合| 日韩毛片一二三区| 久久久99精品免费观看| 日韩精品中文字幕一区二区三区 | 欧美一级高清片在线观看| 波多野结衣一区二区三区 | 一区二区在线观看免费| 国产性色一区二区| 日韩欧美www| 欧美高清性hdvideosex| 日本道免费精品一区二区三区| 国产伦精一区二区三区| 久久国产三级精品| 五月婷婷欧美视频| 亚洲综合丝袜美腿| 亚洲丝袜制服诱惑| 国产精品卡一卡二卡三| 久久精品综合网| 久久夜色精品一区| 欧美成人r级一区二区三区| 欧美日韩精品久久久| 欧美午夜精品理论片a级按摩| 精品免费国产二区三区| 欧美精品tushy高清| 91国产免费观看| 91精品办公室少妇高潮对白| 成人a级免费电影| 成年人网站91| 粉嫩绯色av一区二区在线观看| 国产一区二区成人久久免费影院| 激情文学综合网| 看片网站欧美日韩| 老司机精品视频导航| 久久精品国产99| 国产精品资源在线看| 国产一区二区导航在线播放| 国产福利精品一区二区| 风间由美一区二区三区在线观看 | 亚洲欧洲一区二区在线播放| 中文字幕av不卡| 国产精品久久久久久久久久久免费看| 国产午夜精品一区二区三区嫩草| 国产日韩精品久久久| 国产精品国产三级国产有无不卡 | 欧美日韩精品一区二区三区| 9191国产精品| 日韩精品自拍偷拍| 国产午夜一区二区三区| 国产精品久久毛片av大全日韩| 18成人在线视频| 一区二区三区不卡在线观看| 亚洲一二三区在线观看| 蜜臀国产一区二区三区在线播放| 精品午夜一区二区三区在线观看| 国产精品亚洲第一区在线暖暖韩国| 国产.欧美.日韩| 色视频欧美一区二区三区| 欧美人妖巨大在线| 久久久久久久综合| 亚洲青青青在线视频| 亚洲国产视频a| 久久精品国产一区二区| 成人一区二区视频| 欧美日韩在线精品一区二区三区激情| 91精品国产综合久久香蕉的特点 | 日韩精品中文字幕一区| 国产精品久久一级| 亚洲福利一区二区三区| 久久91精品久久久久久秒播| 成人av综合在线| 6080国产精品一区二区| 国产欧美精品国产国产专区 | 午夜久久久久久久久| 国产麻豆91精品| 欧美系列在线观看| 国产午夜精品福利| 午夜精品久久久久久久99水蜜桃| 国产一区二区三区免费观看| 色婷婷久久久久swag精品| 日韩欧美一区二区在线视频| 国产精品久久久久久久浪潮网站| 亚洲成av人片www| 福利一区福利二区| 91精品国产综合久久久久| 国产精品妹子av| 麻豆成人91精品二区三区| 色先锋资源久久综合| 精品成人在线观看| 亚洲午夜精品在线| thepron国产精品| 日韩精品自拍偷拍| 亚洲国产另类av| 成人激情黄色小说| 精品久久久久av影院 | 亚洲一区成人在线| 粉嫩av亚洲一区二区图片| 91精品国产高清一区二区三区| 亚洲欧洲韩国日本视频| 国产精品一区专区| 欧美一区二区三区精品| 亚洲精品久久久蜜桃| 粉嫩蜜臀av国产精品网站| 日韩精品一区二区三区三区免费| 一区二区在线看| 不卡视频一二三| 久久精品男人的天堂| 毛片av一区二区三区| 欧美视频在线一区二区三区| 中文字幕一区二区三区在线观看| 国产一区 二区| 欧美刺激午夜性久久久久久久| 亚洲一线二线三线视频| 91首页免费视频| 国产精品网站在线| 国产aⅴ综合色| 国产欧美视频一区二区| 精品综合免费视频观看| 欧美日韩免费观看一区三区| 亚洲美女免费视频| caoporm超碰国产精品| 中文成人av在线| www.久久精品| 亚洲精品亚洲人成人网| 99久久精品久久久久久清纯| 欧美激情在线一区二区三区| 国产精品综合在线视频| 久久麻豆一区二区| 国产精品99精品久久免费| 国产视频一区二区三区在线观看| 国产麻豆欧美日韩一区| 国产偷国产偷精品高清尤物| 国产成人午夜视频| 国产精品久久午夜夜伦鲁鲁| 99久久婷婷国产| 有码一区二区三区| 欧美体内she精视频| 日韩中文字幕一区二区三区| 日韩无一区二区| 国产一区二区在线观看视频| 久久久亚洲午夜电影| 欧美人与禽zozo性伦| 日本在线播放一区二区三区| 日韩欧美一区二区免费| 国产高清无密码一区二区三区| 久久精品亚洲乱码伦伦中文| 国产69精品一区二区亚洲孕妇| 中文字幕中文字幕一区| 91成人在线免费观看| 无码av免费一区二区三区试看 | 欧美天天综合网| 日一区二区三区| 亚洲精品在线三区| 成人手机电影网| 一区二区三区精品在线| 日韩一区二区在线免费观看| 国产传媒日韩欧美成人| 亚洲欧美区自拍先锋| 欧美精品xxxxbbbb| 国产精品123| 亚洲在线一区二区三区| 欧美一激情一区二区三区| 福利视频网站一区二区三区| 一区二区三区.www| 日韩美女天天操| a亚洲天堂av| 男男gaygay亚洲| 国产精品久久久久久久蜜臀| 欧美日本免费一区二区三区| 国产一区在线看| 亚洲综合色婷婷| 26uuu亚洲| 欧美最新大片在线看| 国产一区二区不卡| 亚洲制服丝袜一区| 国产女人18水真多18精品一级做| 欧美主播一区二区三区| 国产精品自拍av| 日韩精品五月天| 《视频一区视频二区| 日韩欧美自拍偷拍| 在线精品观看国产| 东方欧美亚洲色图在线| 性做久久久久久久久| 国产精品久久久久9999吃药| 欧美一级高清片在线观看| 99久久精品国产观看| 国产在线不卡一卡二卡三卡四卡| 一区二区激情小说| 亚洲国产电影在线观看| 日韩午夜av一区| 在线观看www91|