RASVA

Kokeneet kirjoittajat eivät ole vielä tarkistaneet sivun nykyistä versiota, ja se voi poiketa merkittävästi 18.6.2022 tarkistetusta versiosta . tarkastukset vaativat 2 muokkausta .

FAT ( englanniksi  File Allocation Table "file allocation table") on klassinen tiedostojärjestelmäarkkitehtuuri , jota yksinkertaisuutensa vuoksi käytetään edelleen laajalti flash-asemissa . Käytetään levykkeissä , muistikorteissa ja joissakin muissa tallennusvälineissä. Aiemmin sitä käytettiin myös kiintolevyillä.

Bill Gatesin ja Mark McDonaldin kehittämä vuosina 1976-1977 [1] [2] . Sitä käytettiin päätiedostojärjestelmänä MS - DOS- ja Windows 9x -perheiden käyttöjärjestelmissä .

FAT-rakenne noudattaa ECMA-107-standardia, ja se määritellään yksityiskohtaisesti virallisessa Microsoft-spesifikaatiossa, joka tunnetaan nimellä FATGEN [3] .

FAT-järjestelmän versiot

FATista on neljä versiota - FAT12 , FAT16 , FAT32 ja exFAT (FAT64) . Ne eroavat levyrakenteen tietueiden bittimäärästä, eli klusterin numeron tallentamiseen varattujen bittien lukumäärästä. FAT12 käytetään pääasiassa levykkeille , FAT16 pienille levyille. FAT:iin perustuen kehitettiin uusi exFAT (extended FAT) -tiedostojärjestelmä, jota käytetään ensisijaisesti flash-asemille .

Aluksi FAT ei tukenut hierarkkista hakemistojärjestelmää - kaikki tiedostot sijaitsivat levyn juuressa. Tämä tehtiin yksinkertaisuuden vuoksi, koska yksipuolisilla levykkeillä, joiden kapasiteetti on vain 160–180 kt, ei yksinkertaisesti ollut järkevää lajitella muutamaa tiedostoa hakemistoihin. Vähintään 320 kilotavun levykkeiden leviämisen myötä kaikkien tiedostojen tallentaminen juureen osoittautui hankalaksi, lisäksi juurihakemiston pieni koko rajoitti levyllä olevien tiedostojen määrää. Hakemistot otettiin käyttöön MS-DOS 2.0:n julkaisun myötä.

Eri käyttöjärjestelmissä on myös toteutettu erilaisia ​​FAT-laajennuksia. Esimerkiksi DR-DOS :ssa on muita tiedostopääsymääritteitä; Windows 95 : ssä , Linuxissa  - tuki pitkille tiedostonimille (LFN) Unicode-muodossa (Virtual FAT - VFAT); OS/2 :  ssa kaikkien tiedostojen laajennetut attribuutit.

VFAT

VFAT  on FAT-laajennus, joka on otettu käyttöön Windows 95 :ssä . FAT-tiedostojen nimet ovat 8.3 -muodossa ja sisältävät vain ASCII-merkkejä . VFAT:iin lisättiin tuki pitkille (enintään 255 merkkiä) tiedostonimille ( Long File Name, LFN ) UTF- 16LE-koodauksessa ,  kun taas LFN:t tallennetaan samanaikaisesti nimien kanssa 8.3-muodossa, jota kutsutaan takautuvasti SFN:ksi ( englanniksi lyhyt tiedostonimi ). LFN:t eivät erota kirjainkoosta haettaessa, mutta toisin kuin SFN:t, jotka tallennetaan isoilla kirjaimilla, LFN:t säilyttävät tiedoston luomisen yhteydessä määritellyn kirjainkoon [4] [5] .  

FAT-järjestelmän rakenne

FAT-tiedostojärjestelmässä vierekkäiset levysektorit yhdistetään klusteriksi kutsuttuiksi yksiköiksi . Sektoreiden määrä klusterissa on yhtä suuri kuin kahden potenssi (katso alla). Tiedostotietojen tallentamiseen on varattu kokonaislukumäärä klustereita (vähintään yksi), joten jos tiedoston koko on esimerkiksi 40 tavua ja klusterin koko on 4 kt, vain 1 % sille varatusta tilasta tiedostotietojen varaama. Tällaisten tilanteiden välttämiseksi on suositeltavaa pienentää klusterien kokoa ja päinvastoin vähentää osoitetietojen määrää ja nopeuttaa tiedostotoimintoja. Käytännössä valitaan jokin kompromissi. Koska levyn kapasiteettia ei välttämättä ilmaista kokonaislukuna klustereita, yleensä taltion lopussa on ns. ylijäämäsektorit - klusterin kokoa pienempi "jäännös", jota käyttöjärjestelmä ei voi varata tietojen tallentamiseen.

FAT32-taltiotila on jaettu loogisesti kolmeen vierekkäiseen alueeseen:

FAT12:ssa ja FAT16:ssa on myös oma alue juurihakemistoa varten. Sillä on kiinteä sijainti (välittömästi FAT-taulukon viimeisen elementin jälkeen) ja kiinteä koko 32-tavuisissa elementeissä, eli osion käynnistystietueessa kuvattaessa nimenomaan 32-tavuisten elementtien lukumäärä ilmoitetaan. , joista jokainen kuvaa mitä tahansa juurihakemiston elementtiä (oli se sitten tiedosto tai muu alihakemisto).

Jos klusteri kuuluu tiedostoon, FAT-taulukon vastaava solu sisältää saman tiedoston seuraavan klusterin numeron. Jos solu vastaa tiedoston viimeistä klusteria, se sisältää erityisen arvon (0xFFFF FAT16:lle). Siten rakennetaan tiedostoklusteriketju. Nollat ​​vastaavat taulukon käyttämättömiä klustereita. "Huonoilla" klustereilla (jotka jätetään käsittelyn ulkopuolelle esimerkiksi siksi, että laitteen vastaava alue on lukukelvoton) on myös erityinen koodi (0xFFF7 FAT16:lle).

Kun tiedosto poistetaan, nimen ensimmäinen merkki korvataan erikoiskoodilla 0xE5 ja tiedoston klusteriketju varaustaulukossa nollataan. Koska tiedot tiedoston koosta (joka sijaitsee hakemistossa tiedostonimen vieressä) säilyvät ennallaan, jos tiedostoklusterit sijaitsivat peräkkäin levyllä eikä niitä ole kirjoitettu uusilla tiedoilla, poistettu tiedosto voidaan palauttaa.

Käynnistystietue

FAT-taltion ensimmäistä rakennetta kutsutaan nimellä BPB ( BIOS -  parametrilohko ) ja se sijaitsee varatulla alueella, sektorissa nolla. Tämä rakenne sisältää tietoja, jotka tunnistavat tiedostojärjestelmän tyypin ja tietovälineen (levyke tai kiintolevyosio) fyysiset ominaisuudet.

BIOS-parametrilohko (BPB)

BPB puuttui FATista, joka palveli MS-DOS 1.x:ää, koska tuolloin oletettiin vain kahta erityyppistä taltiota - yksipuolisia ja kaksipuolisia viiden tuuman 320 kt:n levykkeitä, ja taltion muodon määritti FAT-alueen ensimmäinen tavu. BPB otettiin käyttöön MS-DOS 2.x:ssä vuoden 1983 alussa pakollisena käynnistyssektorirakenteena, josta taltiomuoto määritetään vastedes; vanhaa FAT-ensimmäisen tavun tunnistusjärjestelmää ei enää tuettu. Myös MS-DOS 2.0:ssa otettiin käyttöön tiedostojen ja kansioiden hierarkia (ennen sitä kaikki tiedostot tallennettiin juurihakemistoon).

MS-DOS 2.x:n BPB-rakenne sisälsi 16-bittisen "sektorien kokonaismäärä" -kentän, mikä tarkoitti, että tämä FAT-versio ei pohjimmiltaan sovellu yli 2 16 = 65 536 sektorin, eli yli 32 Mt :n levyille. joiden vakiosektorin koko on 512 tavua. MS-DOS 4.0:ssa (1988) BPB-kenttä laajennettiin 32-bittiseksi, mikä tarkoitti teoreettisen volyymikoon kasvua 232 = 4 294 967 296 sektoriin, eli jopa 2 TB 512-tavuisella sektorilla.

Seuraava BPB:n modifikaatio ilmestyi Windows 95 OSR2:ssa, joka esitteli FAT32:n (elokuussa 1996). 2 Tt:n raja on poistettu, FAT32-taltion koko voi teoriassa olla jopa 8 TB. Kunkin yksittäisen tiedoston koko ei kuitenkaan saa ylittää 4 Gt. FAT32:n BIOS-parametrilohko toistaa FAT16:n BPB:n BPB_TotSec32-kenttään asti, minkä jälkeen erot ovat yhteensopivia FAT:n aikaisempien versioiden kanssa.

FAT32:n "käynnistyssektori" on itse asiassa kolme 512-tavuista sektoria - sektorit 0, 1 ja 2. Jokainen niistä sisältää allekirjoituksen 0xAA55 osoitteessa 0x1FE, eli kahdessa viimeisessä tavussa, jos sektorin koko on 512 tavua. Jos sektorin koko on yli 512 tavua, niin allekirjoitus sisältyy sekä osoitteeseen 0x1FE että nollasektorin kahteen viimeiseen tavuun, eli se kopioidaan.

FSIinfo

FAT32-osion käynnistystietue sisältää FSInfo -nimisen rakenteen , jota käytetään taltion vapaan klusterimäärän arvon tallentamiseen. FSInfo sijaitsee pääsääntöisesti sektorilla 1 (katso BPB_FSInfo-kenttä) ja sillä on seuraava rakenne (osoitteet suhteessa sektorin alkuun):

  • FSI_LeadSig. 4-tavuinen allekirjoitus 0x41615252 osoittaa, että sektoria käytetään FSIinfo-rakenteessa.
  • FSI_Varattu1. Sektorin väli 4–483 tavua, mukaan lukien, nollataan.
  • FSI_StrucSig. Toinen allekirjoitus sijaitsee osoitteessa 0x1E4 ja sisältää arvon 0x61417272.
  • FSI_Free_Count. 4-tavuinen kenttä osoitteessa 0x1E8 sisältää viimeisimmän järjestelmän tunteman aseman vapaita klustereita. Arvo 0xFFFFFFFF tarkoittaa, että vapaiden klustereiden määrä on tuntematon ja se on laskettava.
  • FSI_Nxt_Free. Osoitteessa 0x1EC oleva 4-tavuinen kenttä sisältää klusterin numeron, josta hakemistoosoitintaulukon vapaiden klustereiden etsintä tulee aloittaa. Yleensä tämä kenttä sisältää viimeisen tiedostojen tallennusta varten varatun FAT-klusterin numeron. Arvo 0xFFFFFFFF tarkoittaa, että vapaan klusterin haku tulee suorittaa FAT-taulukon alusta alkaen eli toisesta klusterista.
  • FSI_Varattu2. Varattu 12-tavuinen kenttä osoitteessa 0x1F0.
  • FSI_TrailSig. Allekirjoitus 0xAA550000 on FSInfo-sektorin 4 viimeistä tavua.

FSInfon käyttöönoton tarkoitus on optimoida järjestelmän toiminta, sillä FAT32:ssa indeksiosoittimen taulukko voi olla erittäin suuri ja sen tavu-tavuinen haku voi viedä huomattavasti aikaa. Kenttien FSI_Free_Count ja FSI_Nxt_Free arvot eivät kuitenkaan välttämättä vastaa todellisuutta, ja niiden riittävyys on tarkistettava. Lisäksi niitä ei edes päivitetä FSInfo-varmuuskopiossa, joka yleensä sijaitsee sektorissa 7.

FAT-tilavuuden tyypin määrittäminen

Käyttöjärjestelmä määrittää taltion FAT-tyypin (eli valinnan FAT12:n, FAT16:n ja FAT32:n välillä) taltion klustereiden lukumäärän perusteella, joka puolestaan ​​määritetään BPB-kentistä. Ensinnäkin lasketaan juurihakemiston sektoreiden määrä:

RootDirSectors = (BPB_RootEntCnt * 32) / BPB_BytsPerSec

Seuraavaksi määritetään, mitkä kentistä BPB_FATSz16/32 ja BPB_TotSec16/32 eivät ole yhtä suuria kuin nolla, ja niitä käytetään määritettäessä volyymidata-alueen sektoreiden lukumäärää:

DataSec = TotSec - (BPB_ResvdSecCnt + (BPB_NumFATs * FATSz) + RootDirSectors)

Lopuksi määritetään tietoalueklusterien lukumäärä:

CountofClusters = DataSec / BPB_SecPerClus

Klusterien lukumäärän mukaan tiedostojärjestelmän kanssa on yksi-yhteen vastaavuus:

  • Klusterien määrä < 4085 - FAT12
  • Klusterien määrä = 4085 ÷ 65524 - FAT16
  • Klusterien määrä > 65524 - FAT32

Virallisten määritelmien mukaan tämä on ainoa oikea tapa määrittää FAT-tyyppi. Määritettyjä kartoitussääntöjä rikkovan taltion luominen keinotekoisesti aiheuttaa sen, että Windows käsittelee sitä väärin. On kuitenkin suositeltavaa välttää CountofClusters-arvoja, jotka ovat lähellä kriittisiä arvoja (4085 ja 65525), jotta tiedostojärjestelmätyyppi voidaan määrittää oikein millä tahansa, usein väärin kirjoitetulla ohjaimilla.

FAT12 luodaan aina levykkeelle alustuksen yhteydessä. Mitä tulee kiintolevyihin ja flash-asemiin , jopa 512 Mt:n (512-tavuisella sektorilla) asemalla luodaan oletusarvoisesti FAT16, yli 512 Mt - FAT32. Klusterin koko määritetään muotoilun aikana tiedostojärjestelmän ja taltion koon perusteella.

Volyymin sarjanumero

Taltion sarjanumero (kenttä BS_VolID) Windows 98:ssa luodaan päivämäärän ja kellonajan muodossa siten, että niitä on mahdotonta palauttaa ilman lisätietoja.

FAT-taulukko

Seuraava tärkeä FAT-taltion rakenne on itse FAT-taulukko, joka vie erillisen loogisen alueen. Se määrittää luettelon (ketjun) klusteista, jotka isännöivät aseman tiedostoja ja kansioita. Taulukon klusterien ja indeksiosoittimien välillä on yksi yhteen vastaavuus - N:s osoitin vastaa klusteria, jolla on sama numero. Tietoalueen ensimmäiselle klusterille annetaan numero 2. Indeksiosoittimen arvo vastaa vastaavan klusterin tilaa. Seuraavat tilat ovat mahdollisia:

  • klusteri on vapaa — osoitin on nollattu;
  • klusterin varaa tiedosto, eikä se ole viimeinen tiedostoklusteri — osoitin sisältää seuraavan tiedostoklusterin numeron;
  • klusteri on tiedoston viimeinen klusteri — osoitin sisältää EOC (End Of Clusterchain) -tunnisteen, jonka arvo riippuu FAT-versiosta: FAT12:lle EOC-tunniste on mikä tahansa arvo, joka on suurempi tai yhtä suuri kuin 0x0FF8 (0x0FFF by oletusarvo); FAT16:lle — suurempi tai yhtä suuri kuin 0xFFF8 (oletus 0xFFFF); FAT32:lle mikä tahansa arvo, joka on suurempi tai yhtä suuri kuin 0x0FFFFFF8 (oletuksena 0x0FFFFFFFF);
  • klusteri on vioittunut — osoitin sisältää erityisen tunnisteen, jonka arvo on 0x0FF7 FAT12:lle, 0xFFF7 FAT16:lle ja 0x0FFFFFF7 FAT32:lle. Tiedostojärjestelmä ei voi käyttää vaurioitunutta klusteria tietojen tallentamiseen; vastaavat osoittimet eivät vaikuta äänenvoimakkuuden muotoiluun, kun kaikki muut osoittimet on asetettu nollaan;
  • klusteri on varattu "tulevaa standardointia varten" - osoitin sisältää arvon, joka on suurempi kuin CountofClusters, mutta pienempi kuin vaurioituneen klusterin nimike (eli 0xFFF6:aan asti FAT16:lle). Tässä tapauksessa klusteria, joka ei vastaa mitään todellista dataa, pidetään varattuna ja se ohitetaan haettaessa vapaata, mutta muuta tietoa siitä ei anneta.

FAT heijastaa klusterit 0 ja 1 erikseen. Klusterin nollaa vastaava indeksiosoitin (ensimmäinen FAT-taulukkoosoitin) sisältää BPB_Media-arvon alemmassa 8 bitissä; loput bitit on asetettu arvoon 1. Jos esimerkiksi BPB_Media = 0xF8 (kiintolevy), FAT[0] = 0x0FFFFFF8 FAT32:lle. Näin ollen muodollisesti FAT[0] = EOC, jota käytetään nollakokoisten tiedostojen käsittelyssä (katso alla).

Toinen varattu osoitin, FAT[1], asetetaan EOC-merkin arvoon alustuksen aikana. FAT12:ssa sitä ei enää käytetä millään tavalla, ja FAT16:ssa ja FAT32:ssa tämän osoittimen kaksi ylempää bittiä voivat sisältää merkin äänenvoimakkuuden tarkistamisen tarpeesta (ns. " likainen bitti ") ja kaikki muut bitit on asetettu arvoon 1. Likaisen bitin olemassaolo tarkistetaan Windowsin käynnistysprosessin autochk.exe-ohjelman aikana. Likainen bitti syntyy, kun levyä ei ole irrotettu kunnolla tai kun tietovälineessä on laitteistovirhe ja se saa vastaavasti kaksi mahdollista arvoa.

FAT32-indeksiosoitin on määritelmän mukaan 32 bittiä, mutta 4 ylintä bittiä jätetään huomioimatta, joten osoittimen arvo on itse asiassa 28 bittiä. Ainoa toiminto, joka toimii osoittimen neljällä ylimmällä bitillä, on äänenvoimakkuuden muotoilu, joka nollaa koko osoittimen. Tämä tarkoittaa, että esimerkiksi osoitinarvot 0x10000000, 0xF0000000 ja 0x00000000 vastaavat kaikki vapaata klusteria, koska ne eroavat vain 4 ylimmästä bitistä.

BPB FAT -taulukon koon arvo eli BPB_FATSz16/32 voi olla suurempi kuin todellinen, joten jokaisen FAT-taulukon lopussa voi olla sektoreita, jotka eivät vastaa mitään todellista tietoklusteria. Muotoilun aikana nämä sektorit nollataan, eikä niitä käytetä millään tavalla volyymin käytön aikana. Siksi FAT-taulukon viimeisen sektorin todellinen osoite, joka sisältää osoittimia todellisiin volyymiklusteriin, on aina laskettava tietoalueklusterien kokonaismäärästä, ei BPB_FATSz16/32-kentästä. Lisäksi viimeinen FAT-taulukon käyttämä sektori ei välttämättä ole kokonaan sen varaama - tässä tapauksessa sektorin ylimääräistä tilaa ei myöskään käytetä ja se täytetään nolilla taltiota formatoitaessa.

Tiedostotietueet

Välittömästi viimeisen FAT-taulukon lopussa on tietoalue, joka sisältää tiedostoja ja kansioita. FAT- hakemisto on tavallinen tiedosto, joka on merkitty erityisellä attribuutilla. Tällaisen tiedoston tiedot (sisältö) missä tahansa FAT-versiossa on 32-tavuisten tiedostotietueiden (hakemistotietueiden) ketju. Hakemisto ei yleensä voi sisältää kahta samannimistä tiedostoa. Jos tarkistuslevyohjelma löytää keinotekoisesti luodun parin identtisiä tiedostoja samasta hakemistosta, yksi niistä nimetään uudelleen.

Juurihakemisto

Ainoa hakemisto, jonka on oltava läsnä, on juurihakemisto. FAT12/FAT16:ssa juurihakemiston sektoreilla on kiinteä koko, joka lasketaan BPB_RootEntCnt:n arvosta, ja se seuraa levyllä olevaa FAT-taulukkoa.

FAT32:ssa juurihakemistolla, kuten kaikilla muillakin, on muuttuva koko ja se on ketju klustereita. Ensimmäisen juurihakemistoklusterin numero näkyy BPB_RootClusissa. Juurihakemisto eroaa muista FAT-taltioiden hakemistoista seuraavilla tavoilla:

  • siinä ei ole päivämäärä- ja aikaleimoja;
  • ei omaa nimeä (paitsi "\");
  • se ei sisällä tiedostoja nimeltä "." ja ".." (katso alla);
  • on ainoa hakemisto, joka voi normaalisti sisältää taltiotunnistetiedoston (katso alla).
Tiedostotietueen rakenne

FAT32-tiedostotietue koostuu seuraavista rakenteista:

  • DIR_Name. Suhteellisen osoitteen 0 11-tavuinen kenttä sisältää lyhyen tiedostonimen (8.3-standardin mukaisesti). Katso alta tiedostonimet.
  • DIR_Attr. Tavu osoitteessa 0x0B, vastaa tiedostomääritteistä.
  • DIR_NTRes. Tavu osoitteessa 0x0C, käytetään Windows NT:ssä.
  • DIR_CrtTimeTenth. Tavu osoitteessa 0x0D. Tiedoston luontiajan kymmenien millisekuntien määrä, kelvolliset arvot ovat 0–199. Kenttä jätetään usein tarpeettomasti huomiotta.
  • DIR_CrtTime. 2 tavua osoitteessa 0x0E. Tiedoston luontiaika on 2 sekuntia.
  • DIR_CrtDate. 2 tavua osoitteessa 0x10. Päivämäärä, jolloin tiedosto on luotu.
  • DIR_LstAccDate. 2 tavua osoitteessa 0x12. Päivämäärä, jolloin tiedostoa viimeksi käsiteltiin (eli viimeinen luku tai kirjoitus - jälkimmäisessä tapauksessa se on yhtä suuri kuin DIR_WrtDate). Vastaavaa aikakenttää ei ole olemassa.
  • DIR_FstClusHI. 2 tavua osoitteessa 0x14. Tiedoston ensimmäinen klusterin numero (korkea sana, nolla FAT12/FAT16-taltiolla).
  • DIR_WrtTime. 2 tavua osoitteessa 0x16. Tiedoston viimeisen tallennuksen (muokkauksen) aika, esimerkiksi sen luonti.
  • DIR_WrtDate. 2 tavua osoitteessa 0x18. Tiedoston viimeisen tallennuksen (muokkauksen) päivämäärä, luonti mukaan lukien.
  • DIR_FstClusLO. 2 tavua osoitteessa 0x1A. Tiedoston ensimmäisen klusterin numero (matala sana).
  • DIR_FileSize. DWORD, joka sisältää tiedoston koon arvon tavuina. FAT32:n perusrajoitus on, että suurin sallittu tiedostokoko on 0xFFFFFFFF (eli 4 Gt miinus 1 tavu).

Jos FAT-merkinnän ensimmäinen tavu (eli DIR_Name[0]) sisältää 0xE5 tai 0x05, tämä tarkoittaa, että merkintä on vapaa (vastaava tiedosto on poistettu). Nolla kohdassa DIR_Name[0] tarkoittaa, että tämä merkintä ei ole ilmainen, vaan myös kaikki myöhemmät hakemistomerkinnät; Windows ei jäsennä hakemiston loppuosaa nollatun merkinnän jälkeen.

Tiedoston nimi FATissa

DIR_Name-kenttä on loogisesti jaettu kahdeksaan ensimmäiseen merkkiin, jotka muodostavat tiedostonimen, ja viimeiseen kolmeen merkkiin, jotka muodostavat laajennuksen. Erotinjakso lisätään käyttöjärjestelmätasolla, eikä sitä tallenneta nimikenttään. Jos tiedoston nimi ja tunniste eivät täytä niille varattua tilaa, DIR_Name-kentän jäljellä olevat tavut täytetään välilyönneillä (0x20). Tiedostonimi ja tunniste voi sisältää minkä tahansa kirjainten, numeroiden tai merkkien yhdistelmän, jonka ASCII - koodi on suurempi kuin 127; erikoismerkit on jaettu kolmeen ryhmään:

  • Sallittu: ! # $ % & () - @ ^ _ ` { } ~ '
  • Kielletty: +.; =[]
  • Palvelu: * ? <: > / \ | "

Palvelumerkeillä on erityinen merkitys DOS:ssa ja Windowsissa, eivätkä ne voi olla osa tiedoston nimeä (merkit * ? ovat metamerkkejä ja merkkejä : / \ käytetään erottimina tiedostopoluissa , muut palvelumerkit ja laittomat merkit ovat komentorivitulkkien ohjausmerkkejä COMMAND. COM ja cmd.exe ), mutta kiellettyjä merkkejä voidaan silti sisällyttää tiedostonimeen LFN-merkinnän hinnalla (katso alla). Esimerkiksi hakemisto, jonka nimi alkaa pisteellä tai sisältää useita pisteitä, voidaan luoda komentorivitilassa ( mkdir .directory) tai komentotulkissa, kuten FAR Manager , Total Commander , WinRAR . Tiedostonimi ei voi alkaa tai päättyä välilyöntiin; ASCII-ohjausmerkkejä (eli 0x00-0x1F) ei sallita missään nimikentän tavussa, paitsi yllä määritellyssä koodissa 5. Nykyisen (tiedoston luomishetken) DOS- koodisivun tiedot eivät ole tallennettu, joten pääsy tiedostoihin, joiden nimet sisältävät laajennetun ASCII:n kansallisia koodeja (esimerkiksi kyrilliset merkit koodisivulta 866 ), eri koodisivuilla, voi olla ongelmallista tai mahdotonta (koska ennen tiedoston etsimistä hakemistosta, sen nimi muunnetaan isoilla kirjaimilla koodisivulla olevan taulukon mukaisesti). Tiedoston koko polku ei saa ylittää 80 tavua (3 on aseman kirjain; 64 on polku; 12 on tiedoston nimi, mukaan lukien erotinkohta; 1 on terminaalin tyhjämerkki).

Kaikki nimen 8,3 aakkosmerkkiä käännetään aina ja tallennetaan DIR_Name-kenttään isoin kirjaimin. DIR_NTRes-tavua käytetään säilyttämään Windows NT -nimen alkuperäinen kirjainkoko: 1 bitissä 3 kertoo nimen näkyvän pienillä kirjaimilla; Päätteestä vastaa bitti 4. Jos nimi tai tunniste sisältää molempien tapausten merkkejä, tällaiselle tiedostolle luodaan LFN-tietue (katso alla). Windows 9x luo aina LFN-merkinnän säilyttääkseen nimen ei-triviaalin kirjainkoon ja jättää huomiotta DIR_NTRes-kentän. Tämän seurauksena Windows 9x saattaa näyttää saman tiedoston nimen, johon ei liity LFN-merkintää, kokonaan isoilla kirjaimilla, mutta Windows NT (osittain) pienillä kirjaimilla.

Tiedoston attribuutit

Attribuuttitavussa kaksi ylintä bittiä on varattu ja ne on aina asetettava nollaan. Loput bitit jaetaan siten, että arvo 0x01 vastaa "vain luku" -attribuuttia, 0x02 - "piilotettu", 0x04 - "järjestelmä", 0x20 - "arkistoitu". Useiden attribuuttien joukko muodostetaan summaamalla perusarvot. Näiden vakiomääritteiden lisäksi käytetään seuraavia: 0x10 - osoittaa, että tiedosto on hakemisto (muiden tiedostojen säilö); 0x08 - ATTR_VOLUME_ID, juurihakemistossa olevan ainutlaatuisen nollakokoisen tiedoston erityinen attribuutti, jonka nimen katsotaan olevan taltion nimi. 11-merkkinen FAT-taltiotunnisterajoitus liittyy DIR_Name-kentän kokoon. Jos tiedostossa on READ_ONLY | PILOTTU | JÄRJESTELMÄ | VOLUME_ID (arvo 0x0F), tämä osoittaa, että merkintä ei vastaa erillistä tiedostoa, vaan sisältää osan toisen tiedoston pitkästä nimestä, joka ei sovi 8.3-kehykseen (katso alla).

Nollasta poikkeavan arvon keinotekoista määritystä DIR_Attr:n kahdelle ylemmälle bitille käytetään muodostamaan tiedostoja, joita ei voida poistaa tai nimetä uudelleen tiedostojärjestelmän standardikeinoilla ilman muotoilua. Tästä on hyötyä esimerkiksi taistettaessa Autorun.inf-viruksia (Panda USB ja AutoRun Vaccine -ohjelma). Toisaalta virukset itse voivat käyttää samaa työkalua. Arvo DIR_Attr = 0x40 on varattu sisäiseen käyttöön (laite).

Mitä tapahtuu, kun hakemisto luodaan

Kun hakemisto luodaan, sille asetetaan DIR_FileSize = 0 "elämän ajaksi". Hakemiston sisällön koko määritetään yksinkertaisesti seuraamalla klusteriketjuja ketjun päättymismerkkiin asti. Tiedostojärjestelmä rajoittaa itse hakemiston koon 65 535 32-tavuiseen merkintään (eli FAT-taulukon hakemistomerkinnät eivät saa ylittää 2 Mt). Tämän rajan tarkoituksena on nopeuttaa tiedostotoimintoja ja sallia useiden apuohjelmien käyttää 16-bittistä kokonaislukua (WORD) hakemiston merkintöjen laskemiseen (tämän seurauksena hakemistossa olevien tiedostojen määrälle on teoreettinen raja - 65 535, jos kaikki tiedostonimet noudattavat standardia 8.3). Hakemistolle on määritetty yksi tietoalueklusteri (ellei se ole FAT12/FAT16-juurihakemisto), ja DIR_FstClusHI / DIR_FstClusLO-kentät asetetaan kyseisen klusterin numeron arvoon. Tätä klusteria vastaavalle merkinnälle sijoitetaan FAT-taulukkoon EOC-tunniste, ja itse klusteri täytetään nolilla. Seuraavaksi luodaan kaksi erityistä tiedostoa, joita ilman FAT-hakemistoa pidetään vaurioituneena (kaksi ensimmäistä 32-tavuista merkintää klusterin tietoalueella) - nollakokoiset tiedostot, joiden nimi on "." (yksi piste, hakemiston tunniste) ja ".." (kaksi pistettä, osoitin päähakemistoon). Näiden tiedostojen päivämäärä- ja aikaleimat asetetaan itse hakemiston arvoihin luomishetkellä, eikä niitä päivitetä, kun hakemisto muuttuu. DIR_FstClusHI / DIR_FstClusLO-kentät "." sisältää sen sisältävän klusterin numeron arvon ja tiedosto ".." - annetun hakemiston ensimmäisen klusterin numeron. Siten tiedosto "." viittaa itse hakemistoon ja tiedosto ".." viittaa emohakemiston alkuperäiseen klusteriin; jos päähakemisto on juurihakemisto, alkuperäisen klusterin katsotaan olevan nolla.

Aika ja päivämäärä

Kaksitavuisella päivämääräleimalla on seuraava muoto:

  • bitit 0-4 - kuukauden päivä, arvot 1-31 ovat sallittuja;
  • bitit 5–8 - vuoden kuukausi, arvot 1–12 ovat sallittuja;
  • bitit 9-15 - vuosi, laskettuna vuodesta 1980 ("MS-DOS epoch"), arvot 0 - 127 mukaan lukien ovat mahdollisia, eli 1980-2107.

Kaksitavuisella aikaleimalla on seuraava muoto:

  • bitit 0-4 - sekuntilaskuri (kaksi kumpaakin), kelvolliset arvot ovat 0-29, eli 0-58 sekuntia;
  • bitit 5-10 ovat minuutteja, kelvolliset arvot ovat 0-59;
  • bitit 11-15 ovat tunteja, kelvolliset arvot ovat 0-23.

Päivämäärä- ja aikaleimoista vain viimeinen muokkausaika (eli DIR_WrtTime ja DIR_WrtDate) on kriittinen, monet järjestelmät eivät välttämättä tue muita; käytettäessä tiedostoa tällaisessa järjestelmässä (esimerkiksi DOS- tai Windows 3.1 -käyttöjärjestelmässä), nämä kentät ohitetaan. FAT tallentaa päivämäärä- ja aikaleimat paikallisen aikavyöhykkeen mukaan; kun se muuttuu, merkit eivät muutu.

Hakemistojen aikaleimat asetetaan, kun ne luodaan, eivätkä ne muutu, kun uusia tiedostoja kirjoitetaan hakemistoon, nimetään uudelleen tai sille varataan uusi klusteri.

Tiedoston viimeinen käyttöpäivä päivitetään aina, kun sitä käytetään, esimerkiksi kun tarkastellaan tiedoston ominaisuuksia, siirryttäessä toiseen taltioon (mutta ei taltion sisällä). Kun kopioit tiedoston Windows 98:ssa, alkuperäisen tiedoston viimeinen käyttöpäivä päivitetään, mutta ei Windows XP:ssä.

Tiedoston muokkauspäivämäärä-aika muuttuu aina, kun uutta sisältöä kirjoitetaan tietoalueelle (ei tiedostotietueelle). Toisin sanoen muokkauspäivämäärä-aika ei muutu, kun määritteitä muutetaan tai tiedosto nimetään uudelleen. Tiedoston siirtäminen tai kopioiminen säilyttää alkuperäisen muokkausmerkin.

Luontipäivämäärä ja -aika asetetaan, kun tiedostotietue varataan uudelle tiedostolle, jota ei aiemmin ollut olemassa. Toisin sanoen, kun tiedosto nimetään uudelleen tai siirretään, luomispäivämäärä ja -aika eivät muutu, mutta kopioitaessa uusi tiedosto saa uuden leiman. Siten tiedostoa kopioitaessa Windowsissa sen luontipäivämäärä voi olla myöhäisempi kuin muokkauspäivämäärä.

LFN-tietueet

FAT-tiedostojärjestelmä käsittelee tiedostoja ja hakemistoja, joilla on pitkä nimi (suurempi kuin 8.3), erityisellä tavalla. LFN (Long File Name) -tiedoston 32-tavuisen tietueen rakenne eroaa tavallisesta (SFN) tietueesta:

  • LDIR_Ord. Tiedon ensimmäistä tavua käytetään numeroimaan joukon merkinnät.
  • LDIR_Nimi1. 10-tavuinen kenttä osoitteessa 0x01 sisältää tiedostonimen viisi ensimmäistä merkkiä (tai pikemminkin sen nimen osan, joka näkyy tässä LFN-tietueessa).
  • LDIR_Attr. Attribuuttitavu osoitteessa 0x0B on 0x0F (ATTR_LONG_NAME).
  • LDIR_Tyyppi. Osoitteessa 0x0C oleva tavu on asetettu nollaan ja osoittaa lisäksi, että tämä FAT-taulukon merkintä viittaa tiedostoon, jolla on pitkä nimi.
  • LDIR_Chksum. Osoitteessa 0x0D oleva tavu sisältää LFN-tietueiden joukkoa vastaavan tiedostoaliaksen SFN-tarkistussumman.
  • LDIR_Nimi2. 12-tavuinen kenttä osoitteessa 0x0E, joka sisältää tiedostonimen merkit 6-11.
  • LDIR_FstClusLO. 2-tavuinen kenttä osoitteessa 0x1A on merkityksetön LFN-tietueen yhteydessä ja se on nolla.
  • LDIR_Nimi3. 4-tavuinen kenttä osoitteessa 0x1C, joka sisältää tiedostonimen 12. ja 13. merkin.

FAT-hakemiston LFN-merkintöjen joukko on aina liitettävä tavalliseen SFN-merkintään, jota edeltää fyysisesti levy. Joukkoa LFN-tietueita, jotka on löydetty ilman vastaavaa normaalia tietuetta, kutsutaan orpoksi ja tietue katsotaan korruptoituneeksi; tällainen tiedosto on täysin näkymätön vanhemmissa MS-DOS/Windows-versioissa.

LFN-tietueiden sarjassa jokaisella niistä on oma sarjanumeronsa, jonka määrittää ensimmäinen tavu (LDIR_Ord). 0x40-maski osoittaa, että tämä merkintä on viimeinen sitä seuraavan LFN-merkinnän rivillä (eli esimerkiksi rivin kolmannen LFN-merkinnän kohdalla LDIR_Ord-tavun arvo on 0x43, 17. - 0x51 ). Seuraavissa tietueissa tämä tavu muuttuu N:stä tilin N:nnen "pitkän" tietueen kohdalla vastaavasta normaalista 1:ksi lähimpänä normaalia tietuetta.

Pitkät tiedostonimet tallennetaan Unicode ( UTF-16 ) -koodauksella, jolloin syötetyt kirjaimet säilyvät. Jos tiettyä OEM- tai Unicode-nimen merkkiä ei voida muuntaa koodisivun merkiksi, se näytetään aina alaviivana "_" eikä varsinaista levylle tallennettua merkkiä muuteta.

Tarkistussummatavu lasketaan tietyn algoritmin mukaan, joka perustuu tavallisen tietueen 8.3-nimeen (pitkänimiselle tiedostolle tavallisen tietueen "nimeä" kutsutaan aliakseksi - aliakseksi) ja kopioidaan kaikkiin "pitkiin" " sitä vastaavat tietueet. Jos jokin arvoista on ristiriidassa tiedostonimen kanssa (esimerkiksi jos tiedosto nimettiin uudelleen MS-DOS:n/Windowsin varhaisessa versiossa), tapahtuu orpo.

Pitkän nimen SFN-tiedoston alias koostuu rungosta ja tarvittaessa digitaalisesta "hännästä". Jos tiedostolla on tunniste, sen kolme ensimmäistä merkkiä tallennetaan aliakseen. Vastaava nimi muodostetaan kääntämällä pitkän tiedostonimen merkit OEM-koodaukseen siten, että kaikki pitkän nimen välilyönnit jätetään huomioimatta ja merkit, jotka eivät ole OEM:ssä käännettävissä tai jotka ovat kiellettyjä lyhyen nimen yhteydessä, korvataan merkillä. alaviiva "_". Numeron häntä "~n", jossa n = 1 ÷ 999999, lisätään aliakseen, jos alun perin hankittu alias on ristiriidassa minkä tahansa tiedoston nimen kanssa samassa hakemistossa tai oli pidempi kuin standardi 8.3 määrittää, tai jos jokin merkki koodauksen vaihtaminen ei löytänyt OEM-vastinetta, ja se korvattiin alaviivalla. Siten muodostuu aliaksia kuten NEWFIL~1.DJV (LFN = uusi tiedosto minulle.djvulle). Tiedostojen alias-järjestelmä on optimoitu nopeuteen ja on siksi arvaamaton yksityiskohtaisesti.

Tiedostonimi, joka ei ole 13 merkin monikerta, ei täytä kokonaan FAT-taulukon LFN-merkintöjen nimikenttiä. Tässä tapauksessa tiedoston nimi päätetään keinotekoisesti NUL-merkillä (0x00), ja ylimääräiset tavut tukkeutuvat ykkösillä (eli 0xFF-merkeillä).

Pitkissä nimissä nimen pituus on rajoitettu 255 merkkiin ilman NUL-erotinta, ja koko polku on rajoitettu 260 merkkiin, mukaan lukien NUL. Pitkä nimi sallii myös kuuden erikoismerkin käytön, jotka ovat kiellettyjä lyhyissä nimissä: +,; =[]

Jos yrität luoda FAT32-taltiolle tiedoston tai hakemiston, jonka nimi sisältää tällaisen merkin, LFN-merkintä luodaan automaattisesti tiedostonimen pituudesta riippumatta. Samanlainen prosessi tapahtuu luotaessa tiedostoa/kansiota, jonka nimi sisältää muita kuin ASCII-merkkejä.

On mahdollista, että taltiotunnistetiedosto ei fyysisesti edelle kaikkia taltion pitkiä nimiä sisältäviä merkintöjä (kun taltiolla ei ole nimiötä tai nimiö on määritetty sen jälkeen, kun jokin pitkäniminen tiedosto oli kirjoitettu). Tällöin FAT12/FAT16:n taltionimike ei näy oikein, koska se otetaan lähimmästä LFN-tietueesta (koska siinä on myös VOLUME_ID-attribuutti), ja jos yrität vaihtaa taltiotunnistetta, vastaavan tiedoston nimi sitä todella rikotaan. LFN-tietueita sisältävän tiedoston poistaminen ei vaikuta jälkimmäisiin, ja niistä tulee orpoja. Uutta tiedostoa edelleen luotaessa mainittu orpo voi liittyä siihen virheellisesti, jos vanhan ja uuden tiedoston nimen tarkistussummat täsmäävät kuitenkin käytetyn tarkistussumman laskenta-algoritmin kanssa (tiedoston ensimmäisen merkin ASCII-koodi alias siirtyy syklisesti hieman oikealle ja seuraavan merkin koodi lisätään jne. d) tekee tästä todennäköisyydestä merkityksettömän.

Tiedostotoimintojen merkitys FAT:ssa

Taltion muotoilu  - indeksiosoittimen taulukko nollataan, paitsi kolme ensimmäistä (FAT[0] ja FAT[1] on varattu ja FAT[2] sisältää taltiotunnistetiedostoa vastaavan merkinnän, tai jos se puuttuu, EOC-merkki) ja tiedot vaurioituneista klusteista; juurihakemiston merkinnät asetetaan nollaan (paitsi taltion nimitiedosto, jos sellainen on), muuten tietoalue ei vaikuta.

Tiedoston poistaminen  - tiedostotietueen ensimmäinen merkki ja kaikki siihen liittyvät LFN-tietueet korvataan koodilla 0xE5; tiedoston käyttämät klusterit on merkitty vapaiksi FAT-taulukossa, mutta tietoalueen klusterit eivät vaikuta.

Tiedoston tai hakemiston luominen pikavalikon "Uusi"-komennolla - uudelle "tyhjälle" tiedostolle luodaan tiedostomerkintä, jolla on oletusnimi (esimerkiksi "Uusi kansio") ja tiedostotyypin määräämä koko; itse tiedosto, jos sen koko on nollasta poikkeava (mikä pätee lähes kaikkiin "tyhjiin" tiedostoihin, paitsi hakemistoihin ja tekstidokumentteihin), kirjoitetaan sille osoitettujen klustereiden tietoalueelle; vastaava klusteriketju luodaan FAT-taulukkoon. Kun tiedostolle on annettu kelvollinen nimi (ei oletusarvo), alun perin luotu tiedosto merkitään poistetuksi ja luodaan uusi.

Tiedoston uudelleennimeäminen  - uusi merkintä luodaan päivitetyllä nimellä; vanha merkintä on merkitty poistetuksi.

Tiedoston tallentaminen sovelluksesta (ei komentoriviltä) - luodaan tietue, joka sisältää kaikki kentät paitsi tiedoston koon ja alkuperäisen klusterin; Kun tiedosto on tallennettu, luodaan uusi tietue, joka sisältää kaikki kentät, ja vanha tietue poistetaan.

Tiedoston kopioiminen  - uuteen paikkaan luodaan identtinen tiedostotietue (mahdollisesti joitain aikaleimoja lukuun ottamatta, katso yllä), tiedostolle varataan ensimmäinen vapaa klusteri ja tiedoston sisältö kopioidaan uuteen sijaintiin samalla, kun tiedostoa kopioidaan. nykyinen klusteri, seuraavan vapaan klusterin etsiminen ja FAT-taulukon täyttäminen.

Tiedoston siirtäminen (eri taltioiden välillä) - tiedoston kopioiminen ja poistaminen alkuperäisestä sijainnistaan.

Tiedoston siirtäminen (taltion sisällä) - klusteriketju ei vaikuta, tiedostotietue kopioidaan muuttumattomana uuteen hakemistoon ja poistetaan sitten vanhasta.

Vapaan klusterin haku hakemistoosoittimien taulukosta uudelle tiedostolle allokointia varten ei yleensä aloita tietoalueen alusta (eli klusterista 2), vaan viimeisestä mille tahansa tiedostolle allokoidusta klusterista. joka on tallennettu FSIinfo-rakenteeseen. Toisin sanoen, jos tiedostolle 1 määritettiin klusteri 30 ja tiedostolle 2 klusteri 31 ja sitten tiedosto 1 poistettiin, silloin kun uusi tiedosto 3 luodaan, se todennäköisesti sijaitsee fyysisesti klusterista 32 alkaen.

Järjestelmän vikasietoisuus

Koska FAT-järjestelmä tallentaa tiedot tiedostoista ja tiedot vapaasta levytilasta samaan taulukkoon, tiedoston kirjoitustoiminto, joka perinteisesti koostuu kahdesta vaiheesta (varatun lohkon lisääminen varattujen luetteloon ja saman lohkon poistaminen ilmaiset), esiintyy FATissa yhdellä toiminnolla. Tästä johtuen FAT-järjestelmällä on luontainen vikasietoisuus, eli vika (esimerkiksi teho) luku- tai kirjoitustoiminnon aikana ei useimmissa tapauksissa johda tiedostojärjestelmän tuhoutumiseen. Tässä tapauksessa puhumme kuitenkin tiedostojärjestelmän eheydestä, emme itse tiedostoista.

Ominaisuudet [3]

FAT12 FAT16 FAT32
Kehittäjä Microsoft
Koko otsikko Tiedostojen jakotaulukko
(12-bittinen versio) (16-bittinen versio) (32-bittinen versio)
Esitetty 1980 ( Microsoft Disk BASIC ) Elokuu 1984 ( MS-DOS 3.00, typistetty)
täysi - Heinäkuu 1988, MS-DOS 4.0 [6]
Elokuu 1996 (Windows 95 OSR 2)
Volumen tunnus 0x01 ( MBR ) 0x04, 0x06, 0x0E (MBR) 0x0B , 0x0C (MBR)
EBD0A0A2-B9E5-4433-87C0-68B6B72699C7 ( GPT )
rakenteet
Hakemiston sisältö Pöytä
Tiedoston sijoitus Lineaarinen lista
Huonot lohkot Klusterimerkintä
Rajoitukset
Tiedoston koko 32 Mt _ 2GB_ _ 4 Gt
Klusterien lukumäärä 4084 65 524 268 435 445 (2 28 -12)
Tiedostonimen pituus 8.3 tai 255 merkkiä käytettäessä LFN
Tilavuuden koko 2 Mt (512 tavua sektoria kohti)

32 Mt (64 kt per klusteri)

2 Gt
4 Gt (64 kt per klusteri, ei tueta kaikkialla)
2 Tt
8 Tt (32 kt per sektori)
Ominaisuudet
Tallennetut päivämäärät Luominen, muokkaaminen, pääsy
Ajanjakso 1. tammikuuta 1980 - 31. joulukuuta 2107
Lisäinformaatio Aluksi ei tuettu
Tiedoston attribuutit Vain luku, piilotettu, järjestelmä, levyn nimi, alihakemisto, arkisto
Käyttöoikeuksien eriyttäminen Ei
Läpinäkyvä pakkaus Itsenäiset apuohjelmat ( Stacker , DoubleSpace , DriveSpace )
Läpinäkyvä salaus Kolmannen osapuolen apuohjelmat tai DOS-kloonit

Lisenssi

Jotkut FAT- ja VFAT-algoritmit ovat Microsoftin patentoimia.

Yhdysvalloissa uudelleenarvioinnissa[ milloin? ] päätettiin mitätöidä osa patenteista, mutta sitten se peruutettiin.

Lokakuussa 2006 Euroopan patenttiviraston [7] myöntämä VFAT-patentti mitätöitiin Saksassa ilmeisyyden vuoksi .

Ajan myötä FATia käytettiin laajalti eri laitteissa DOS:n, Windowsin, OS / 2:n ja Linuxin yhteensopivuuden varmistamiseksi. Microsoft ei ole osoittanut aikomusta pakottaa heitä lisensoimaan[ selventää ] [8] .

Helmikuussa 2009 Microsoft haastoi oikeuteen TomTomin , Linux -pohjaisten autonavigointijärjestelmien valmistajan patentinloukkauksesta [9] .

Jeremy Ellisonin mukaan[ selventää ] Microsoftin tavoitteena on antaa eri yrityksille mahdollisuus valita: solmia patenttisuojasopimus Microsoftin kanssa (kuten Novell teki sen kanssa marraskuussa 2006), mikä rikkoo GNU GPL:ää ja tekee Linuxin käytön mahdottomaksi. , tai olla tekemättä tällaista sopimusta ja tulla syytetyksi patenttien loukkaamisesta, joiden suoja annetaan sopimuksen tekemisen yhteydessä salassapitoehdon mukaisesti [10] [11] .

Maaliskuussa 2009 TomTom nosti vastakanteen patentinloukkauksesta [12] .

Katso myös

Muistiinpanot

  1. Arkistoitu kopio . Haettu 9. kesäkuuta 2009. Arkistoitu alkuperäisestä 16. heinäkuuta 2011.
  2. www.microsoft.com/mscorp/ip/tech/fathist.asp osoitteessa archive.org
  3. 1 2 Microsoft Extensible Firmware Initiative FAT32 File System Specification 1.03 (linkki ei ole käytettävissä) . Microsoft (6. joulukuuta 2000). — Asiakirja Microsoft Word -muodossa, 268 kt. Haettu 5. huhtikuuta 2010. Arkistoitu alkuperäisestä 22. elokuuta 2011. 
  4. Entä VFAT? (linkki ei saatavilla) . TechNet-arkisto . Microsoft (15. lokakuuta 1999). Haettu 5. huhtikuuta 2010. Arkistoitu alkuperäisestä 22. elokuuta 2011. 
  5. Älä sekoita VFAT-tiedostojärjestelmän laajennusta samannimiseen tiedostojärjestelmän ohjaimeen, joka esiintyi Windows for Workgroups 3.11:ssä ja on suunniteltu käsittelemään MS-DOS-toimintokutsuja (INT 21h) suojatussa tilassa (katso: KB126746: Windows for Workgroups -versiohistoria (ei saatavilla (linkki) VERSIO 3.11 → Muut kuin verkkoominaisuudet Microsoft (14. marraskuuta 2003) Haettu 5. huhtikuuta 2010. Arkistoitu alkuperäisestä 22. elokuuta 2011.  )
  6. MS-DOS-osion yhteenveto (downlink) . microsoft.com . Haettu 23. lokakuuta 2012. Arkistoitu alkuperäisestä 23. lokakuuta 2012. 
  7. Liittovaltion patenttituomioistuin julistaa Microsoftin FAT-patentin mitättömäksi  (englanniksi)  (linkki ei ole käytettävissä) . heise verkossa . Heise Zeitschriften Verlag (2. maaliskuuta 2007). Haettu 10. maaliskuuta 2009. Arkistoitu alkuperäisestä 22. elokuuta 2011.
  8. Brian Kahin. Microsoft pyörittää maailmaa FAT-patenteilla  (englanniksi)  (linkki ei saatavilla) . Huffington Post (10. maaliskuuta 2009). Haettu 10. maaliskuuta 2009. Arkistoitu alkuperäisestä 22. elokuuta 2011.
  9. Ryan Paul. FAT-patentteja koskeva Microsoft-puku voi avata OSS Pandora's Boxin  (eng.)  (linkki ei ole käytettävissä) . Ars Technica . Condé Nast -julkaisut (25. helmikuuta 2009). Haettu 9. maaliskuuta 2009. Arkistoitu alkuperäisestä 22. elokuuta 2011.
  10. Glyn Moody. Todellinen syy Microsoftin TomTom-oikeuteen  (englanniksi)  (linkki ei ole käytettävissä) . tietokonemaailma Iso-Britannia . IDG (5. maaliskuuta 2009). Haettu 9. maaliskuuta 2009. Arkistoitu alkuperäisestä 22. elokuuta 2011.
  11. Steven J. Vaughan-Nichols. Linux-yritykset allekirjoittavat Microsoftin patenttisuojasopimukset  (eng.)  (linkki ei saatavilla) . Computerworld -blogit . IDG (5. maaliskuuta 2009). Haettu 9. maaliskuuta 2009. Arkistoitu alkuperäisestä 22. elokuuta 2011.
  12. Erica Ogg. TomTom haastaa Microsoftin patenttikiistaan  ​​(eng.)  (linkki ei ole käytettävissä) . CNet (19. maaliskuuta 2009). Haettu 20. maaliskuuta 2009. Arkistoitu alkuperäisestä 22. elokuuta 2011.

Linkit