提交 131bac1e 编写于 作者: N Namjae Jeon

ksmbd: use f_bsize in FS_SECTOR_SIZE_INFORMATION

Use f_bsize in FS_SECTOR_SIZE_INFORMATION to avoid the access the block
layer.
Signed-off-by: NNamjae Jeon <namjae.jeon@samsung.com>
Signed-off-by: NSteve French <stfrench@microsoft.com>
上级 560ac051
...@@ -4791,19 +4791,15 @@ static int smb2_get_info_filesystem(struct ksmbd_work *work, ...@@ -4791,19 +4791,15 @@ static int smb2_get_info_filesystem(struct ksmbd_work *work,
case FS_SECTOR_SIZE_INFORMATION: case FS_SECTOR_SIZE_INFORMATION:
{ {
struct smb3_fs_ss_info *info; struct smb3_fs_ss_info *info;
struct ksmbd_fs_sector_size fs_ss;
info = (struct smb3_fs_ss_info *)(rsp->Buffer); info = (struct smb3_fs_ss_info *)(rsp->Buffer);
ksmbd_vfs_smb2_sector_size(d_inode(path.dentry), &fs_ss);
info->LogicalBytesPerSector = info->LogicalBytesPerSector = cpu_to_le32(stfs.f_bsize);
cpu_to_le32(fs_ss.logical_sector_size);
info->PhysicalBytesPerSectorForAtomicity = info->PhysicalBytesPerSectorForAtomicity =
cpu_to_le32(fs_ss.physical_sector_size); cpu_to_le32(stfs.f_bsize);
info->PhysicalBytesPerSectorForPerf = info->PhysicalBytesPerSectorForPerf = cpu_to_le32(stfs.f_bsize);
cpu_to_le32(fs_ss.optimal_io_size);
info->FSEffPhysicalBytesPerSectorForAtomicity = info->FSEffPhysicalBytesPerSectorForAtomicity =
cpu_to_le32(fs_ss.optimal_io_size); cpu_to_le32(stfs.f_bsize);
info->Flags = cpu_to_le32(SSINFO_FLAGS_ALIGNED_DEVICE | info->Flags = cpu_to_le32(SSINFO_FLAGS_ALIGNED_DEVICE |
SSINFO_FLAGS_PARTITION_ALIGNED_ON_DEVICE); SSINFO_FLAGS_PARTITION_ALIGNED_ON_DEVICE);
info->ByteOffsetForSectorAlignment = 0; info->ByteOffsetForSectorAlignment = 0;
......
...@@ -1118,37 +1118,6 @@ int ksmbd_vfs_unlink(struct dentry *dir, struct dentry *dentry) ...@@ -1118,37 +1118,6 @@ int ksmbd_vfs_unlink(struct dentry *dir, struct dentry *dentry)
return err; return err;
} }
/*
* ksmbd_vfs_get_smb2_sector_size() - get fs sector sizes
* @inode: inode
* @fs_ss: fs sector size struct
*/
void ksmbd_vfs_smb2_sector_size(struct inode *inode,
struct ksmbd_fs_sector_size *fs_ss)
{
struct request_queue *q;
fs_ss->logical_sector_size = 512;
fs_ss->physical_sector_size = 512;
fs_ss->optimal_io_size = 512;
if (!inode->i_sb->s_bdev)
return;
q = inode->i_sb->s_bdev->bd_disk->queue;
if (q) {
if (q->limits.logical_block_size)
fs_ss->logical_sector_size =
q->limits.logical_block_size;
if (q->limits.physical_block_size)
fs_ss->physical_sector_size =
q->limits.physical_block_size;
if (q->limits.io_opt)
fs_ss->optimal_io_size = q->limits.io_opt;
}
}
static int __dir_empty(struct dir_context *ctx, const char *name, int namlen, static int __dir_empty(struct dir_context *ctx, const char *name, int namlen,
loff_t offset, u64 ino, unsigned int d_type) loff_t offset, u64 ino, unsigned int d_type)
{ {
......
...@@ -192,12 +192,6 @@ struct ksmbd_kstat { ...@@ -192,12 +192,6 @@ struct ksmbd_kstat {
__le32 file_attributes; __le32 file_attributes;
}; };
struct ksmbd_fs_sector_size {
unsigned short logical_sector_size;
unsigned int physical_sector_size;
unsigned int optimal_io_size;
};
int ksmbd_vfs_inode_permission(struct dentry *dentry, int acc_mode, int ksmbd_vfs_inode_permission(struct dentry *dentry, int acc_mode,
bool delete); bool delete);
int ksmbd_vfs_query_maximal_access(struct dentry *dentry, __le32 *daccess); int ksmbd_vfs_query_maximal_access(struct dentry *dentry, __le32 *daccess);
...@@ -247,8 +241,6 @@ int ksmbd_vfs_fqar_lseek(struct ksmbd_file *fp, loff_t start, loff_t length, ...@@ -247,8 +241,6 @@ int ksmbd_vfs_fqar_lseek(struct ksmbd_file *fp, loff_t start, loff_t length,
struct file_allocated_range_buffer *ranges, struct file_allocated_range_buffer *ranges,
int in_count, int *out_count); int in_count, int *out_count);
int ksmbd_vfs_unlink(struct dentry *dir, struct dentry *dentry); int ksmbd_vfs_unlink(struct dentry *dir, struct dentry *dentry);
void ksmbd_vfs_smb2_sector_size(struct inode *inode,
struct ksmbd_fs_sector_size *fs_ss);
void *ksmbd_vfs_init_kstat(char **p, struct ksmbd_kstat *ksmbd_kstat); void *ksmbd_vfs_init_kstat(char **p, struct ksmbd_kstat *ksmbd_kstat);
int ksmbd_vfs_fill_dentry_attrs(struct ksmbd_work *work, struct dentry *dentry, int ksmbd_vfs_fill_dentry_attrs(struct ksmbd_work *work, struct dentry *dentry,
struct ksmbd_kstat *ksmbd_kstat); struct ksmbd_kstat *ksmbd_kstat);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册