Subversion Repositories NaviCtrl

Rev

Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
41 ingob 1
#ifndef _FAT16_H
2
#define _FAT16_H
1 ingob 3
 
4
 
5
//________________________________________________________________________________________________________________________________________
6
// 
41 ingob 7
// Definitions
1 ingob 8
//                              
9
//________________________________________________________________________________________________________________________________________
10
 
211 killagreg 11
#define FILE_MAX_OPEN   4                               // The number of files that can accessed simultaneously. 
41 ingob 12
#define SEEK_SET        0
13
#define SEEK_CUR        1
14
#define SEEK_END        2
15
#define EOF     (-1) 
16
#define BYTES_PER_SECTOR        512
17
/*
18
________________________________________________________________________________________________________________________________________
19
 
20
        Structure of a filepointer
21
________________________________________________________________________________________________________________________________________
22
*/
23
typedef struct
24 StephanB 24
{
41 ingob 25
        u32 FirstSectorOfFirstCluster;  // First sector of the first cluster of the file.
26
        u32 FirstSectorOfCurrCluster;   // First sector of the cluster which is edited at the moment.
380 holgerb 27
        u32 FirstSectorOfLastCluster;   // First sector of the last cluster of the file
41 ingob 28
        u8      SectorOfCurrCluster;            // The sector within the current cluster.
29
        u16 ByteOfCurrSector;                   // The byte location within the current sector.
30
        u8      Mode;                                           // Mode of fileoperation (read,write)
31
        u32 Size;                                               // The size of the opend file in bytes.
32
        u32 Position;                                   // Pointer to a character within the file 0 < fileposition < filesize
33
        u32 DirectorySector;                    // the sectorposition where the directoryentry has been made.
34
        u16     DirectoryIndex;                         // The index to the directoryentry within the specified sector.
35
        u8      Attribute;                                      // The attribute of the file opened.
36
        u8  Cache[BYTES_PER_SECTOR];    // Cache for read and write operation from or to the sd-card.
37
        u32 SectorInCache;                              // The last sector read, which is still in the sector cache.
38
        u8      State;                                          // State of the filepointer (used/unused/...) 
39
} File_t;
1 ingob 40
 
427 killagreg 41
// attribute definitions          
379 holgerb 42
#define ATTR_NONE               0x00    // normal file
43
#define ATTR_READONLY           0x01    // file is readonly
44
#define ATTR_HIDDEN                     0x02    // file is hidden
45
#define ATTR_SYSTEM                     0x04    // file is a system file
46
#define ATTR_VOLUMELABEL        0x08    // entry is a volume label
47
#define ATTR_LONG_FILENAME      0x0F    // this is a long filename entry
48
#define ATTR_SUBDIRECTORY       0x10    // entry is a directory name
49
#define ATTR_ARCHIVE            0x20    // file is new or modified
50
#define ATTR_ANY_FILE           0x3F    // all files
349 ingob 51
 
379 holgerb 52
 
53
 
1 ingob 54
//________________________________________________________________________________________________________________________________________
379 holgerb 55
//
56
//      Structure of an item used by functions findfirst and findnext
57
//________________________________________________________________________________________________________________________________________
58
 
59
typedef struct
60
{
61
        File_t  fp;                                             // filepointer used to get access to the filesystemstructure
427 killagreg 62
        s8              searchstring[12];               // findfirst and findnext will only return elements within the specified directory matching this searchstring (8+3 + Terminator).
379 holgerb 63
        s8              name[13];                               // the name of the element found within the specified directory
64
        u8              active;                                 // if the attribute active is set the name and the attributes of an element found within DirectoryEntryExist will be entered into the structure 
65
        u8              attribfilter;                  
66
        u8              attribmask;
67
} __attribute__((packed)) Find_t;
68
 
433 ingob 69
 
70
 
71
typedef struct
72
{
73
        u8      IsValid;                                // 0 means invalid, else valid
74
        u8      SectorsPerCluster;              // how many sectors does a cluster contain?
75
        u8      FatCopies;                              // Numbers of copies of the FAT
76
        u16     MaxRootEntries;                 // Possible number of entries in the root directory.
77
        u16     SectorsPerFat;                  // how many sectors does a fat16 contain?
78
        u32 FirstFatSector;                     // sector of the start of the fat
79
        u32 FirstRootDirSector;         // sector of the rootdirectory
80
        u32 FirstDataSector;            // sector of the first cluster containing data (cluster2).
81
        u32 LastDataSector;                     // the last data sector of the partition
82
        u8  VolumeLabel[12];        // the volume label
83
        u32     CurrentWorkingDirectory;// A pointer to the directory we are actual using
84
        s8      PathToCwd[256];                 // a string containing the complete path to the current working directory
85
}   __attribute__((packed)) Partition_t;
86
 
87
extern Partition_t      Partition;              // Structure holds partition information
88
 
379 holgerb 89
//________________________________________________________________________________________________________________________________________
1 ingob 90
// 
91
// API to the FAT16 filesystem
92
//                              
93
//________________________________________________________________________________________________________________________________________
94
 
427 killagreg 95
// File System Funtions
41 ingob 96
u8              Fat16_Init(void);
97
u8              Fat16_Deinit(void);
90 killagreg 98
u8              Fat16_IsValid(void);
210 killagreg 99
s8*             FAT16_GetVolumeLabel(void);
427 killagreg 100
 
101
// File Function        
102
File_t *fopen_(s8* const filename, const s8 mode);
103
s16     fclose_(File_t * const file);
104
u8              fexist_(s8* const filename);
89 killagreg 105
s16             fflush_(File_t * const file);
106
s16     fseek_(File_t * const file, s32 offset, s16 origin);
107
s16             fgetc_(File_t * const file);
108
s16             fputc_(s8 c, File_t * const file);
109
u32     fread_(void *buffer, u32 size, u32 count, File_t * const file);
110
u32     fwrite_(void *buffer, u32 size, u32 count, File_t * const file);
90 killagreg 111
s16             fputs_(s8 * const string, File_t * const file);
89 killagreg 112
s8 *    fgets_(s8 * const string, s16 length, File_t * const file);
113
u8              feof_(File_t * const file);
427 killagreg 114
u8              fdelete_(s8* const filepath);
115
 
116
// Directory Functions
117
s8              *getcwd_(void);
379 holgerb 118
u8              findfirst_(const s8* name, u8 attribmask, Find_t *);
119
u8              findnext_(Find_t *);
427 killagreg 120
u8              chdir_(s8* const dirpath);
121
u8              mkdir_(s8* const dirpath);
122
u8              rmdir_(s8* const dirpath);
1 ingob 123
 
24 StephanB 124
 
125
 
379 holgerb 126
 
41 ingob 127
#endif //_FAT16_H
1 ingob 128
 
129
 
130
 
131