ntdll: Fixed file system name comparison on *BSD.

This commit is contained in:
Alexandre Julliard 2007-08-29 12:02:13 +02:00
parent 0c9c00cf2b
commit 8765a0da83
2 changed files with 9 additions and 16 deletions

View File

@ -1736,24 +1736,21 @@ NTSTATUS WINAPI NtQueryAttributesFile( const OBJECT_ATTRIBUTES *attr, FILE_BASIC
#if defined(__FreeBSD__) || defined(__FreeBSD_kernel__) || defined(__NetBSD__) || defined(__APPLE__) #if defined(__FreeBSD__) || defined(__FreeBSD_kernel__) || defined(__NetBSD__) || defined(__APPLE__)
/* helper for FILE_GetDeviceInfo to hide some platform differences in fstatfs */ /* helper for FILE_GetDeviceInfo to hide some platform differences in fstatfs */
static inline void get_device_info_fstatfs( FILE_FS_DEVICE_INFORMATION *info, const char *fstypename, static inline void get_device_info_fstatfs( FILE_FS_DEVICE_INFORMATION *info, const char *fstypename,
size_t fstypesize, unsigned int flags ) unsigned int flags )
{ {
if (!strncmp("cd9660", fstypename, fstypesize) || if (!strcmp("cd9660", fstypename) || !strcmp("udf", fstypename))
!strncmp("udf", fstypename, fstypesize))
{ {
info->DeviceType = FILE_DEVICE_CD_ROM_FILE_SYSTEM; info->DeviceType = FILE_DEVICE_CD_ROM_FILE_SYSTEM;
/* Don't assume read-only, let the mount options set it below */ /* Don't assume read-only, let the mount options set it below */
info->Characteristics |= FILE_REMOVABLE_MEDIA; info->Characteristics |= FILE_REMOVABLE_MEDIA;
} }
else if (!strncmp("nfs", fstypename, fstypesize) || else if (!strcmp("nfs", fstypename) || !strcmp("nwfs", fstypename) ||
!strncmp("nwfs", fstypename, fstypesize) || !strcmp("smbfs", fstypename) || !strcmp("afpfs", fstypename))
!strncmp("smbfs", fstypename, fstypesize) ||
!strncmp("afpfs", fstypename, fstypesize))
{ {
info->DeviceType = FILE_DEVICE_NETWORK_FILE_SYSTEM; info->DeviceType = FILE_DEVICE_NETWORK_FILE_SYSTEM;
info->Characteristics |= FILE_REMOTE_DEVICE; info->Characteristics |= FILE_REMOTE_DEVICE;
} }
else if (!strncmp("procfs", fstypename, fstypesize)) else if (!strcmp("procfs", fstypename))
info->DeviceType = FILE_DEVICE_VIRTUAL_DISK; info->DeviceType = FILE_DEVICE_VIRTUAL_DISK;
else else
info->DeviceType = FILE_DEVICE_DISK_FILE_SYSTEM; info->DeviceType = FILE_DEVICE_DISK_FILE_SYSTEM;
@ -1849,16 +1846,14 @@ static NTSTATUS get_device_info( int fd, FILE_FS_DEVICE_INFORMATION *info )
if (fstatfs( fd, &stfs ) < 0) if (fstatfs( fd, &stfs ) < 0)
info->DeviceType = FILE_DEVICE_DISK_FILE_SYSTEM; info->DeviceType = FILE_DEVICE_DISK_FILE_SYSTEM;
else else
get_device_info_fstatfs( info, stfs.f_fstypename, get_device_info_fstatfs( info, stfs.f_fstypename, stfs.f_flags );
sizeof(stfs.f_fstypename), stfs.f_flags );
#elif defined(__NetBSD__) #elif defined(__NetBSD__)
struct statvfs stfs; struct statvfs stfs;
if (fstatvfs( fd, &stfs) < 0) if (fstatvfs( fd, &stfs) < 0)
info->DeviceType = FILE_DEVICE_DISK_FILE_SYSTEM; info->DeviceType = FILE_DEVICE_DISK_FILE_SYSTEM;
else else
get_device_info_fstatfs( info, stfs.f_fstypename, get_device_info_fstatfs( info, stfs.f_fstypename, stfs.f_flag );
sizeof(stfs.f_fstypename), stfs.f_flag );
#elif defined(sun) #elif defined(sun)
/* Use dkio to work out device types */ /* Use dkio to work out device types */
{ {

View File

@ -802,14 +802,12 @@ static int is_device_removable( dev_t dev, int unix_fd )
struct statfs stfs; struct statfs stfs;
if (fstatfs( unix_fd, &stfs ) == -1) return 0; if (fstatfs( unix_fd, &stfs ) == -1) return 0;
return (!strncmp("cd9660", stfs.f_fstypename, sizeof(stfs.f_fstypename)) || return (!strcmp("cd9660", stfs.f_fstypename) || !strcmp("udf", stfs.f_fstypename));
!strncmp("udf", stfs.f_fstypename, sizeof(stfs.f_fstypename)));
#elif defined(__NetBSD__) #elif defined(__NetBSD__)
struct statvfs stfs; struct statvfs stfs;
if (fstatvfs( unix_fd, &stfs ) == -1) return 0; if (fstatvfs( unix_fd, &stfs ) == -1) return 0;
return (!strncmp("cd9660", stfs.f_fstypename, sizeof(stfs.f_fstypename)) || return (!strcmp("cd9660", stfs.f_fstypename) || !strcmp("udf", stfs.f_fstypename));
!strncmp("udf", stfs.f_fstypename, sizeof(stfs.f_fstypename)));
#elif defined(sun) #elif defined(sun)
# include <sys/dkio.h> # include <sys/dkio.h>
# include <sys/vtoc.h> # include <sys/vtoc.h>