Rev 6876 | Details | Compare with Previous | Last modification | View Log | RSS feed
Rev | Author | Line No. | Line |
---|---|---|---|
2288 | clevermous | 1 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
2 | ;; ;; |
||
6080 | pathoswith | 3 | ;; Copyright (C) KolibriOS team 2004-2016. All rights reserved. ;; |
6462 | pathoswith | 4 | ;; Distributed under terms of the GNU General Public License. ;; |
2288 | clevermous | 5 | ;; ;; |
6 | ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; |
||
7 | |||
8 | $Revision: 9953 $ |
||
9 | |||
6462 | pathoswith | 10 | ; NTFS external functions |
11 | ; in: |
||
12 | ; ebx -> parameter structure of sysfunc 70 |
||
13 | ; ebp -> NTFS structure |
||
6471 | pathoswith | 14 | ; esi -> path string in UTF-8 |
6462 | pathoswith | 15 | ; out: |
16 | ; eax, ebx = return values for sysfunc 70 |
||
17 | iglobal |
||
18 | align 4 |
||
19 | ntfs_user_functions: |
||
20 | dd ntfs_free |
||
21 | dd (ntfs_user_functions_end - ntfs_user_functions - 4) / 4 |
||
22 | dd ntfs_ReadFile |
||
23 | dd ntfs_ReadFolder |
||
24 | dd ntfs_CreateFile |
||
25 | dd ntfs_WriteFile |
||
26 | dd ntfs_SetFileEnd |
||
27 | dd ntfs_GetFileInfo |
||
28 | dd ntfs_SetFileInfo |
||
29 | dd 0 |
||
30 | dd ntfs_Delete |
||
31 | dd ntfs_CreateFolder |
||
32 | ntfs_user_functions_end: |
||
33 | endg |
||
5954 | pathoswith | 34 | |
35 | ; Basic concepts: |
||
36 | ; File is a FileRecord in the $MFT. |
||
37 | ; $MFT is a file, that consists of FileRecords and starts with FileRecord of itself. |
||
38 | ; FileRecord (FILE) consists of a header and attributes. |
||
39 | ; Attribute consists of a header and a body. |
||
40 | ; Attribute's body can be inside (resident) or outside of FileRecord. |
||
41 | ; File's data is a body of $Data (80h) attribute. |
||
42 | ; FileRecords is a data of the $MFT file. |
||
43 | ; Directory is a file, that consists of index nodes. |
||
44 | ; Resident index node is always located in a body of $IndexRoot (90h) attribute. |
||
45 | ; Body of $IndexAllocation (A0h) attribute is always non resident |
||
46 | ; and consists of IndexRecords. |
||
47 | ; IndexRecord (INDX) consists of a header and an index node. |
||
48 | ; Index node consists of a header and indexes. |
||
49 | ; Index consists of a header and a copy of indexed attribute's body. |
||
50 | ; Directories index $Filename (30h) attribute of all existing files. |
||
51 | ; $IndexRoot and $IndexAllocation attributes of a directory has a name — $I30. |
||
52 | |||
53 | ; Offsets: |
||
54 | ; record header |
||
6273 | pathoswith | 55 | magic = 0 |
5954 | pathoswith | 56 | updateSequenceOffset = 4 |
57 | updateSequenceSize = 6 |
||
6273 | pathoswith | 58 | ; FileRecord header |
5954 | pathoswith | 59 | reuseCounter = 16 |
60 | hardLinkCounter = 12h |
||
61 | attributeOffset = 14h |
||
62 | recordFlags = 16h |
||
63 | recordRealSize = 18h |
||
64 | recordAllocatedSize = 1ch |
||
5994 | pathoswith | 65 | baseRecordReference = 20h ; for auxiliary records |
66 | baseRecordReuse = 26h |
||
5954 | pathoswith | 67 | newAttributeID = 28h |
68 | ; attribute header |
||
69 | attributeType = 0 |
||
70 | sizeWithHeader = 4 |
||
71 | nonResidentFlag = 8 |
||
72 | nameLength = 9 |
||
73 | nameOffset = 10 |
||
6019 | pathoswith | 74 | attributeFlags = 12 |
5954 | pathoswith | 75 | attributeID = 14 |
6080 | pathoswith | 76 | ; resident attribute header |
77 | sizeWithoutHeader = 10h |
||
6273 | pathoswith | 78 | attributeOffset = 14h |
6019 | pathoswith | 79 | indexedFlag = 16h |
5954 | pathoswith | 80 | ; non resident attribute header |
6080 | pathoswith | 81 | firstVCN = 10h |
5954 | pathoswith | 82 | lastVCN = 18h |
83 | dataRunsOffset = 20h |
||
84 | attributeAllocatedSize = 28h |
||
85 | attributeRealSize = 30h |
||
86 | initialDataSize = 38h |
||
87 | ; $IndexRoot |
||
6273 | pathoswith | 88 | indexedAttributesType = 0 |
5954 | pathoswith | 89 | collationRule = 4 |
90 | indexRecordSize = 8 |
||
6340 | pathoswith | 91 | indexRecordSizeClus = 12 ; in sectors if less than one cluster |
6273 | pathoswith | 92 | rootNode = 16 |
93 | ; IndexRecord header |
||
94 | recordVCN = 16 |
||
95 | recordNode = 18h |
||
5954 | pathoswith | 96 | ; node header |
97 | indexOffset = 0 |
||
98 | nodeRealSize = 4 |
||
99 | nodeAllocatedSize = 8 |
||
6273 | pathoswith | 100 | nonLeafFlag = 12 |
5954 | pathoswith | 101 | ; $Filename index |
102 | fileRecordReference = 0 |
||
103 | fileReferenceReuse = 6 |
||
104 | indexAllocatedSize = 8 |
||
105 | indexRawSize = 10 |
||
106 | indexFlags = 12 |
||
107 | directoryRecordReference = 16 |
||
108 | directoryReferenceReuse = 16h |
||
6297 | pathoswith | 109 | fileCreated = 18h |
110 | fileModified = 20h |
||
111 | recordModified = 28h |
||
112 | fileAccessed = 30h |
||
5954 | pathoswith | 113 | fileAllocatedSize = 38h |
114 | fileRealSize = 40h |
||
115 | fileFlags = 48h |
||
116 | fileNameLength = 50h |
||
6297 | pathoswith | 117 | namespace = 51h |
118 | fileName = 52h |
||
5954 | pathoswith | 119 | |
3742 | clevermous | 120 | struct NTFS PARTITION |
6462 | pathoswith | 121 | Lock MUTEX ; Currently operations with one partition |
5954 | pathoswith | 122 | ; can not be executed in parallel since the legacy code is not ready. |
6273 | pathoswith | 123 | sectors_per_cluster dd ? |
124 | mft_cluster dd ? ; location |
||
125 | mftmirr_cluster dd ? ; location |
||
126 | frs_size dd ? ; in bytes |
||
127 | frs_buffer dd ? ; MFT fileRecord buffer |
||
128 | mft_retrieval_end dd ? |
||
6405 | pathoswith | 129 | mftSize dd ? ; in sectors |
6273 | pathoswith | 130 | cur_index_size dd ? ; in sectors |
131 | cur_index_buf dd ? ; index node buffer |
||
6340 | pathoswith | 132 | secondIndexBuffer dd ? |
6273 | pathoswith | 133 | BitmapBuffer dd ? |
134 | BitmapTotalSize dd ? ; bytes reserved |
||
135 | BitmapSize dd ? ; bytes readen |
||
136 | BitmapLocation dd ? ; starting sector |
||
137 | BitmapStart dd ? ; first byte after area, reserved for MFT |
||
138 | mftBitmapBuffer dd ? ; one cluster |
||
139 | mftBitmapSize dd ? ; bytes readen |
||
140 | mftBitmapLocation dd ? ; starting sector |
||
2288 | clevermous | 141 | |
6405 | pathoswith | 142 | attr_size dq ? |
143 | attr_offs dd ? |
||
144 | attr_list dd ? |
||
145 | attr_iBaseRecord dd ? |
||
6273 | pathoswith | 146 | cur_attr dd ? ; attribute type |
147 | cur_iRecord dd ? ; number of fileRecord in MFT |
||
148 | cur_offs dd ? ; attribute VCN in sectors |
||
149 | cur_size dd ? ; max sectors to read |
||
150 | cur_buf dd ? |
||
151 | cur_read dd ? ; bytes readen |
||
6405 | pathoswith | 152 | cur_tail dd ? |
153 | cur_subnode_size dd ? |
||
6273 | pathoswith | 154 | LastRead dd ? ; last readen block of sectors |
6408 | pathoswith | 155 | mftLastRead dd ? |
6340 | pathoswith | 156 | rootLastRead dd ? |
157 | nodeLastRead dd ? |
||
158 | indexRoot dd ? |
||
6405 | pathoswith | 159 | indexPointer dd ? |
6340 | pathoswith | 160 | newRecord dd ? |
6273 | pathoswith | 161 | fileDataStart dd ? ; starting cluster |
162 | fileDataSize dd ? ; in clusters |
||
6292 | pathoswith | 163 | fileDataBuffer dd ? |
6273 | pathoswith | 164 | fileRealSize dd ? ; in bytes |
165 | fragmentCount db ? |
||
166 | bCanContinue db ? |
||
167 | bFolder db ? |
||
168 | bWriteAttr db ? ; Warning: Don't forget to turn off!!! |
||
3742 | clevermous | 169 | |
6558 | pathoswith | 170 | mft_retrieval rb 512 |
171 | align0 rb 1024-NTFS.align0 |
||
6405 | pathoswith | 172 | attrlist_buf rb 1024 |
173 | attrlist_mft_buf rb 1024 |
||
174 | bitmap_buf rb 1024 |
||
3742 | clevermous | 175 | ends |
176 | |||
2288 | clevermous | 177 | ntfs_test_bootsec: |
5954 | pathoswith | 178 | ; in: ebx -> buffer, edx = size of partition |
179 | ; out: CF=1 -> invalid |
||
2288 | clevermous | 180 | ; 1. Name=='NTFS ' |
181 | cmp dword [ebx+3], 'NTFS' |
||
182 | jnz .no |
||
183 | cmp dword [ebx+7], ' ' |
||
184 | jnz .no |
||
185 | ; 2. Number of bytes per sector is the same as for physical device |
||
186 | ; (that is, 0x200 for hard disk) |
||
187 | cmp word [ebx+11], 0x200 |
||
188 | jnz .no |
||
189 | ; 3. Number of sectors per cluster must be power of 2 |
||
190 | movzx eax, byte [ebx+13] |
||
191 | dec eax |
||
192 | js .no |
||
193 | test al, [ebx+13] |
||
194 | jnz .no |
||
195 | ; 4. FAT parameters must be zero |
||
196 | cmp word [ebx+14], 0 |
||
197 | jnz .no |
||
198 | cmp dword [ebx+16], 0 |
||
199 | jnz .no |
||
200 | cmp byte [ebx+20], 0 |
||
201 | jnz .no |
||
202 | cmp word [ebx+22], 0 |
||
203 | jnz .no |
||
204 | cmp dword [ebx+32], 0 |
||
205 | jnz .no |
||
206 | ; 5. Number of sectors <= partition size |
||
207 | cmp dword [ebx+0x2C], 0 |
||
208 | ja .no |
||
209 | cmp [ebx+0x28], edx |
||
210 | ja .no |
||
211 | ; 6. $MFT and $MFTMirr clusters must be within partition |
||
212 | cmp dword [ebx+0x34], 0 |
||
213 | ja .no |
||
214 | push edx |
||
215 | movzx eax, byte [ebx+13] |
||
216 | mul dword [ebx+0x30] |
||
217 | test edx, edx |
||
218 | pop edx |
||
219 | jnz .no |
||
220 | cmp eax, edx |
||
221 | ja .no |
||
222 | cmp dword [ebx+0x3C], 0 |
||
223 |