Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
91a7dab9
Commit
91a7dab9
authored
Apr 24, 2002
by
Anton Altaparmakov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
NTFS: Various fixes and cleanups. Make it work with kernel 2.5.9.
parent
9a5d1f49
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
34 additions
and
20 deletions
+34
-20
fs/ntfs/aops.c
fs/ntfs/aops.c
+7
-3
fs/ntfs/attrib.c
fs/ntfs/attrib.c
+5
-5
fs/ntfs/layout.h
fs/ntfs/layout.h
+15
-5
fs/ntfs/unistr.c
fs/ntfs/unistr.c
+7
-7
No files found.
fs/ntfs/aops.c
View file @
91a7dab9
...
@@ -31,6 +31,10 @@
...
@@ -31,6 +31,10 @@
#define MAX_BUF_PER_PAGE (PAGE_CACHE_SIZE / 512)
#define MAX_BUF_PER_PAGE (PAGE_CACHE_SIZE / 512)
#if LINUX_VERSION_CODE < KERNEL_VERSION(2,5,8)
#define page_buffers(page) (page)->buffers
#endif
/*
/*
* Async io completion handler for accessing files. Adapted from
* Async io completion handler for accessing files. Adapted from
* end_buffer_read_mst_async().
* end_buffer_read_mst_async().
...
@@ -110,7 +114,7 @@ static int ntfs_file_read_block(struct page *page)
...
@@ -110,7 +114,7 @@ static int ntfs_file_read_block(struct page *page)
blocksize
=
1
<<
blocksize_bits
;
blocksize
=
1
<<
blocksize_bits
;
create_empty_buffers
(
page
,
blocksize
);
create_empty_buffers
(
page
,
blocksize
);
bh
=
head
=
page
->
buffers
;
bh
=
head
=
page
_buffers
(
page
)
;
if
(
!
bh
)
if
(
!
bh
)
return
-
ENOMEM
;
return
-
ENOMEM
;
...
@@ -387,7 +391,7 @@ static int ntfs_mftbmp_readpage(ntfs_volume *vol, struct page *page)
...
@@ -387,7 +391,7 @@ static int ntfs_mftbmp_readpage(ntfs_volume *vol, struct page *page)
blocksize_bits
=
vol
->
sb
->
s_blocksize_bits
;
blocksize_bits
=
vol
->
sb
->
s_blocksize_bits
;
create_empty_buffers
(
page
,
blocksize
);
create_empty_buffers
(
page
,
blocksize
);
bh
=
head
=
page
->
buffers
;
bh
=
head
=
page
_buffers
(
page
)
;
if
(
!
bh
)
if
(
!
bh
)
return
-
ENOMEM
;
return
-
ENOMEM
;
...
@@ -621,7 +625,7 @@ int ntfs_mst_readpage(struct file *dir, struct page *page)
...
@@ -621,7 +625,7 @@ int ntfs_mst_readpage(struct file *dir, struct page *page)
blocksize
=
1
<<
blocksize_bits
;
blocksize
=
1
<<
blocksize_bits
;
create_empty_buffers
(
page
,
blocksize
);
create_empty_buffers
(
page
,
blocksize
);
bh
=
head
=
page
->
buffers
;
bh
=
head
=
page
_buffers
(
page
)
;
if
(
!
bh
)
if
(
!
bh
)
return
-
ENOMEM
;
return
-
ENOMEM
;
...
...
fs/ntfs/attrib.c
View file @
91a7dab9
...
@@ -485,7 +485,6 @@ run_list_element *merge_run_lists(run_list_element *drl, run_list_element *srl)
...
@@ -485,7 +485,6 @@ run_list_element *merge_run_lists(run_list_element *drl, run_list_element *srl)
finish
=
((
drl
[
dins
].
lcn
>=
LCN_RL_NOT_MAPPED
)
&&
/* End of file */
finish
=
((
drl
[
dins
].
lcn
>=
LCN_RL_NOT_MAPPED
)
&&
/* End of file */
((
drl
[
dins
].
vcn
+
drl
[
dins
].
length
)
<=
/* End of hole */
((
drl
[
dins
].
vcn
+
drl
[
dins
].
length
)
<=
/* End of hole */
(
srl
[
send
-
1
].
vcn
+
srl
[
send
-
1
].
length
)));
(
srl
[
send
-
1
].
vcn
+
srl
[
send
-
1
].
length
)));
//srl[send-1].vcn));
/* Or we'll lose an end marker */
/* Or we'll lose an end marker */
if
(
start
&&
finish
&&
(
drl
[
dins
].
length
==
0
))
if
(
start
&&
finish
&&
(
drl
[
dins
].
length
==
0
))
...
@@ -510,9 +509,10 @@ run_list_element *merge_run_lists(run_list_element *drl, run_list_element *srl)
...
@@ -510,9 +509,10 @@ run_list_element *merge_run_lists(run_list_element *drl, run_list_element *srl)
else
else
nrl
=
ntfs_rl_split
(
drl
,
ds
,
srl
+
sstart
,
ss
,
dins
);
nrl
=
ntfs_rl_split
(
drl
,
ds
,
srl
+
sstart
,
ss
,
dins
);
if
(
marker
)
{
if
(
marker
&&
!
IS_ERR
(
nrl
))
{
for
(
ds
=
0
;
nrl
[
ds
].
lcn
;
ds
++
)
;
for
(
ds
=
0
;
nrl
[
ds
].
length
;
ds
++
)
nrl
=
ntfs_rl_insert
(
nrl
,
ds
+
1
,
srl
+
marker
,
1
,
ds
-
1
);
;
nrl
=
ntfs_rl_insert
(
nrl
,
ds
+
1
,
srl
+
marker
,
1
,
ds
);
}
}
}
}
...
@@ -1576,7 +1576,7 @@ attr_search_context *get_attr_search_ctx(ntfs_inode *ni, MFT_RECORD *mrec)
...
@@ -1576,7 +1576,7 @@ attr_search_context *get_attr_search_ctx(ntfs_inode *ni, MFT_RECORD *mrec)
ctx
=
kmem_cache_alloc
(
ntfs_attr_ctx_cache
,
SLAB_NOFS
);
ctx
=
kmem_cache_alloc
(
ntfs_attr_ctx_cache
,
SLAB_NOFS
);
if
(
ctx
)
if
(
ctx
)
init_attr_search_ctx
(
ctx
,
ni
,
mrec
);
init_attr_search_ctx
(
ctx
,
ni
,
mrec
);
return
NULL
;
return
ctx
;
}
}
/**
/**
...
...
fs/ntfs/layout.h
View file @
91a7dab9
...
@@ -81,8 +81,15 @@ typedef struct {
...
@@ -81,8 +81,15 @@ typedef struct {
u8
jump
[
3
];
/* Irrelevant (jump to boot up code).*/
u8
jump
[
3
];
/* Irrelevant (jump to boot up code).*/
u64
oem_id
;
/* Magic "NTFS ". */
u64
oem_id
;
/* Magic "NTFS ". */
BIOS_PARAMETER_BLOCK
bpb
;
/* See BIOS_PARAMETER_BLOCK. */
BIOS_PARAMETER_BLOCK
bpb
;
/* See BIOS_PARAMETER_BLOCK. */
u8
unused
[
4
];
/* zero */
u8
unused
[
4
];
/* zero, NTFS diskedit.exe states that
s64
number_of_sectors
;
/* Number of sectors in volume. Gives
this is actually:
__u8 physical_drive; // 0x80
__u8 current_head; // zero
__u8 extended_boot_signature;
// 0x80
__u8 unused; // zero
*/
/*0x28*/
s64
number_of_sectors
;
/* Number of sectors in volume. Gives
maximum volume size of 2^63 sectors.
maximum volume size of 2^63 sectors.
Assuming standard sector size of 512
Assuming standard sector size of 512
bytes, the maximum byte size is
bytes, the maximum byte size is
...
@@ -95,9 +102,10 @@ typedef struct {
...
@@ -95,9 +102,10 @@ typedef struct {
u8
reserved1
[
3
];
/* zero */
u8
reserved1
[
3
];
/* zero */
u64
volume_serial_number
;
/* Irrelevant (serial number). */
u64
volume_serial_number
;
/* Irrelevant (serial number). */
u32
checksum
;
/* Boot sector checksum. */
u32
checksum
;
/* Boot sector checksum. */
u8
bootstrap
[
426
];
/* Irrelevant (boot up code). */
/*0x54*/
u8
bootstrap
[
426
];
/* Irrelevant (boot up code). */
u16
end_of_sector_marker
;
/* End of bootsector magic. Always is
u16
end_of_sector_marker
;
/* End of bootsector magic. Always is
0xaa55 in little endian. */
0xaa55 in little endian. */
/* sizeof() = 512 (0x200) bytes */
}
__attribute__
((
__packed__
))
NTFS_BOOT_SECTOR
;
}
__attribute__
((
__packed__
))
NTFS_BOOT_SECTOR
;
/*
/*
...
@@ -174,8 +182,10 @@ typedef enum {
...
@@ -174,8 +182,10 @@ typedef enum {
FILE_MFT
=
0
,
/* Master file table (mft). Data attribute
FILE_MFT
=
0
,
/* Master file table (mft). Data attribute
contains the entries and bitmap attribute
contains the entries and bitmap attribute
records which ones are in use (bit==1). */
records which ones are in use (bit==1). */
FILE_MFTMirr
=
1
,
/* Mft mirror (copy of first four mft records)
FILE_MFTMirr
=
1
,
/* Mft mirror: copy of first four mft records
in data attribute. */
in data attribute. If cluster size > 4kiB,
copy of first N mft records, with
N = cluster_size / mft_record_size. */
FILE_LogFile
=
2
,
/* Journalling log in data attribute. */
FILE_LogFile
=
2
,
/* Journalling log in data attribute. */
FILE_Volume
=
3
,
/* Volume name attribute and volume information
FILE_Volume
=
3
,
/* Volume name attribute and volume information
attribute (flags and ntfs version). Windows
attribute (flags and ntfs version). Windows
...
...
fs/ntfs/unistr.c
View file @
91a7dab9
...
@@ -327,12 +327,12 @@ int ntfs_ucstonls(const ntfs_volume *vol, const uchar_t *ins,
...
@@ -327,12 +327,12 @@ int ntfs_ucstonls(const ntfs_volume *vol, const uchar_t *ins,
if
(
ins
)
{
if
(
ins
)
{
ns
=
*
outs
;
ns
=
*
outs
;
ns_len
=
outs_len
;
ns_len
=
outs_len
;
if
(
!
ns_len
)
{
if
(
ns
&&
!
ns_len
)
{
wc
=
-
ENAMETOOLONG
;
wc
=
-
ENAMETOOLONG
;
goto
conversion_err
;
goto
conversion_err
;
}
}
if
(
!
ns
)
{
if
(
!
ns
)
{
ns_len
=
ins_len
*
3
;
ns_len
=
ins_len
*
NLS_MAX_CHARSET_SIZE
;
ns
=
(
unsigned
char
*
)
kmalloc
(
ns_len
,
GFP_NOFS
);
ns
=
(
unsigned
char
*
)
kmalloc
(
ns_len
,
GFP_NOFS
);
if
(
!
ns
)
if
(
!
ns
)
goto
mem_err_out
;
goto
mem_err_out
;
...
@@ -347,12 +347,12 @@ retry: wc = nls->uni2char(le16_to_cpu(ins[i]), ns + o,
...
@@ -347,12 +347,12 @@ retry: wc = nls->uni2char(le16_to_cpu(ins[i]), ns + o,
break
;
break
;
else
if
(
wc
==
-
ENAMETOOLONG
&&
ns
!=
*
outs
)
{
else
if
(
wc
==
-
ENAMETOOLONG
&&
ns
!=
*
outs
)
{
unsigned
char
*
tc
;
unsigned
char
*
tc
;
/* Grow
by 64 bytes. (Chosen at random.)
*/
/* Grow
in multiples of 64 bytes.
*/
tc
=
(
unsigned
char
*
)
kmalloc
(
ns_len
+
64
,
tc
=
(
unsigned
char
*
)
kmalloc
(
(
ns_len
+
64
)
&
GFP_NOFS
);
~
63
,
GFP_NOFS
);
if
(
tc
)
{
if
(
tc
)
{
memcpy
(
tc
,
ns
,
ns_len
);
memcpy
(
tc
,
ns
,
ns_len
);
ns_len
+=
64
;
ns_len
=
(
ns_len
+
64
)
&
~
63
;
kfree
(
ns
);
kfree
(
ns
);
ns
=
tc
;
ns
=
tc
;
goto
retry
;
goto
retry
;
...
@@ -364,7 +364,7 @@ retry: wc = nls->uni2char(le16_to_cpu(ins[i]), ns + o,
...
@@ -364,7 +364,7 @@ retry: wc = nls->uni2char(le16_to_cpu(ins[i]), ns + o,
*
outs
=
ns
;
*
outs
=
ns
;
return
o
;
return
o
;
}
/* else (!ins) */
}
/* else (!ins) */
ntfs_error
(
NULL
,
"Received NULL pointer."
);
ntfs_error
(
vol
->
sb
,
"Received NULL pointer."
);
return
-
EINVAL
;
return
-
EINVAL
;
conversion_err:
conversion_err:
ntfs_error
(
vol
->
sb
,
"Unicode name contains characters that cannot be "
ntfs_error
(
vol
->
sb
,
"Unicode name contains characters that cannot be "
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment