From: Eric Biggers Date: Sat, 6 Sep 2014 04:56:20 +0000 (-0500) Subject: win32_capture.c: Use volume ID as device number X-Git-Tag: v1.7.2~33 X-Git-Url: https://wimlib.net/git/?p=wimlib;a=commitdiff_plain;h=054f366c7dfde356ca8d3c9f1262f68505976c02;hp=97235bb7c109f4a0d310007c5a38870f502df254 win32_capture.c: Use volume ID as device number --- diff --git a/src/win32_capture.c b/src/win32_capture.c index 8cf32efd..2df80f34 100644 --- a/src/win32_capture.c +++ b/src/win32_capture.c @@ -1237,13 +1237,17 @@ winnt_build_dentry_tree_recursive(struct wim_dentry **root_ret, * However, we need to explicitly check for directories and files with * only 1 link and refuse to hard link them. This is because Windows * has a bug where it can return duplicate File IDs for files and - * directories on the FAT filesystem. */ + * directories on the FAT filesystem. + * + * Since we don't follow mount points on Windows, we don't need to query + * the volume ID per-file. Just once, for the root, is enough. But we + * can't simply pass 0, because then there could be inode collisions + * among multiple calls to win32_build_dentry_tree() that are scanning + * files on different volumes. */ ret = inode_table_new_dentry(params->inode_table, filename, file_info.InternalInformation.IndexNumber.QuadPart, - 0, /* We don't follow mount points, so we - currently don't need to get the - volume ID / device number. */ + params->capture_root_dev, (file_info.StandardInformation.NumberOfLinks <= 1 || (file_info.BasicInformation.FileAttributes & FILE_ATTRIBUTE_DIRECTORY)),