Cygwin: get/set security descriptors using FILE_OPEN_NO_RECALL
Add FILE_OPEN_NO_RECALL to NtOpenFile calls trying to fetch or write file security descriptors so as not to recall them from offline storage inadvertently. Signed-off-by: Corinna Vinschen <corinna@vinschen.de>
This commit is contained in:
parent
f6b56abec1
commit
2100c6ef0d
|
@ -65,7 +65,8 @@ get_file_sd (HANDLE fh, path_conv &pc, security_descriptor &sd,
|
||||||
fh ? pc.init_reopen_attr (attr, fh)
|
fh ? pc.init_reopen_attr (attr, fh)
|
||||||
: pc.get_object_attr (attr, sec_none_nih),
|
: pc.get_object_attr (attr, sec_none_nih),
|
||||||
&io, FILE_SHARE_VALID_FLAGS,
|
&io, FILE_SHARE_VALID_FLAGS,
|
||||||
FILE_OPEN_FOR_BACKUP_INTENT
|
FILE_OPEN_NO_RECALL
|
||||||
|
| FILE_OPEN_FOR_BACKUP_INTENT
|
||||||
| pc.is_known_reparse_point ()
|
| pc.is_known_reparse_point ()
|
||||||
? FILE_OPEN_REPARSE_POINT : 0);
|
? FILE_OPEN_REPARSE_POINT : 0);
|
||||||
if (!NT_SUCCESS (status))
|
if (!NT_SUCCESS (status))
|
||||||
|
@ -129,7 +130,8 @@ get_file_sd (HANDLE fh, path_conv &pc, security_descriptor &sd,
|
||||||
NULL, NULL);
|
NULL, NULL);
|
||||||
status = NtOpenFile (&fh, READ_CONTROL, &attr, &io,
|
status = NtOpenFile (&fh, READ_CONTROL, &attr, &io,
|
||||||
FILE_SHARE_VALID_FLAGS,
|
FILE_SHARE_VALID_FLAGS,
|
||||||
FILE_OPEN_FOR_BACKUP_INTENT
|
FILE_OPEN_NO_RECALL
|
||||||
|
| FILE_OPEN_FOR_BACKUP_INTENT
|
||||||
| FILE_OPEN_REPARSE_POINT);
|
| FILE_OPEN_REPARSE_POINT);
|
||||||
if (!NT_SUCCESS (status))
|
if (!NT_SUCCESS (status))
|
||||||
{
|
{
|
||||||
|
@ -234,7 +236,8 @@ set_file_sd (HANDLE fh, path_conv &pc, security_descriptor &sd, bool is_chown)
|
||||||
: pc.get_object_attr (attr, sec_none_nih),
|
: pc.get_object_attr (attr, sec_none_nih),
|
||||||
&io,
|
&io,
|
||||||
FILE_SHARE_VALID_FLAGS,
|
FILE_SHARE_VALID_FLAGS,
|
||||||
FILE_OPEN_FOR_BACKUP_INTENT
|
FILE_OPEN_NO_RECALL
|
||||||
|
| FILE_OPEN_FOR_BACKUP_INTENT
|
||||||
| pc.is_known_reparse_point ()
|
| pc.is_known_reparse_point ()
|
||||||
? FILE_OPEN_REPARSE_POINT : 0);
|
? FILE_OPEN_REPARSE_POINT : 0);
|
||||||
if (!NT_SUCCESS (status))
|
if (!NT_SUCCESS (status))
|
||||||
|
|
Loading…
Reference in New Issue