Lines Matching +full:3 +full:- +full:4
1 // SPDX-License-Identifier: GPL-2.0-or-later
3 * Copyright (C) 2012-2013 Samsung Electronics Co., Ltd.
14 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0, 4, 0, 1, 0, 2,/* 0 ~ 19*/
15 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0, 5, 0, 1, 0, 2, 0, 1, 0, 3,/* 20 ~ 39*/
16 0, 1, 0, 2, 0, 1, 0, 4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2,/* 40 ~ 59*/
17 0, 1, 0, 6, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0, 4,/* 60 ~ 79*/
18 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0, 5, 0, 1, 0, 2,/* 80 ~ 99*/
19 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0, 4, 0, 1, 0, 2, 0, 1, 0, 3,/*100 ~ 119*/
20 0, 1, 0, 2, 0, 1, 0, 7, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2,/*120 ~ 139*/
21 0, 1, 0, 4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0, 5,/*140 ~ 159*/
22 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0, 4, 0, 1, 0, 2,/*160 ~ 179*/
23 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0, 6, 0, 1, 0, 2, 0, 1, 0, 3,/*180 ~ 199*/
24 0, 1, 0, 2, 0, 1, 0, 4, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2,/*200 ~ 219*/
25 0, 1, 0, 5, 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0, 4,/*220 ~ 239*/
26 0, 1, 0, 2, 0, 1, 0, 3, 0, 1, 0, 2, 0, 1, 0 /*240 ~ 254*/
30 0, 1, 1, 2, 1, 2, 2, 3, 1, 2, 2, 3, 2, 3, 3, 4, 1, 2, 2, 3,/* 0 ~ 19*/
31 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5, 1, 2, 2, 3, 2, 3, 3, 4,/* 20 ~ 39*/
32 2, 3, 3, 4, 3, 4, 4, 5, 2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5,/* 40 ~ 59*/
33 4, 5, 5, 6, 1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4, 3, 4, 4, 5,/* 60 ~ 79*/
34 2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6, 2, 3, 3, 4,/* 80 ~ 99*/
35 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6, 3, 4, 4, 5, 4, 5, 5, 6,/*100 ~ 119*/
36 4, 5, 5, 6, 5, 6, 6, 7, 1, 2, 2, 3, 2, 3, 3, 4, 2, 3, 3, 4,/*120 ~ 139*/
37 3, 4, 4, 5, 2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6,/*140 ~ 159*/
38 2, 3, 3, 4, 3, 4, 4, 5, 3, 4, 4, 5, 4, 5, 5, 6, 3, 4, 4, 5,/*160 ~ 179*/
39 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7, 2, 3, 3, 4, 3, 4, 4, 5,/*180 ~ 199*/
40 3, 4, 4, 5, 4, 5, 5, 6, 3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6,/*200 ~ 219*/
41 5, 6, 6, 7, 3, 4, 4, 5, 4, 5, 5, 6, 4, 5, 5, 6, 5, 6, 6, 7,/*220 ~ 239*/
42 4, 5, 5, 6, 5, 6, 6, 7, 5, 6, 6, 7, 6, 7, 7, 8 /*240 ~ 255*/
56 sbi->map_clu = le32_to_cpu(ep->dentry.bitmap.start_clu); in exfat_allocate_bitmap()
57 map_size = le64_to_cpu(ep->dentry.bitmap.size); in exfat_allocate_bitmap()
58 need_map_size = ((EXFAT_DATA_CLUSTER_COUNT(sbi) - 1) / BITS_PER_BYTE) in exfat_allocate_bitmap()
68 return -EIO; in exfat_allocate_bitmap()
70 sbi->map_sectors = ((need_map_size - 1) >> in exfat_allocate_bitmap()
71 (sb->s_blocksize_bits)) + 1; in exfat_allocate_bitmap()
72 sbi->vol_amap = kmalloc_array(sbi->map_sectors, in exfat_allocate_bitmap()
74 if (!sbi->vol_amap) in exfat_allocate_bitmap()
75 return -ENOMEM; in exfat_allocate_bitmap()
77 sector = exfat_cluster_to_sector(sbi, sbi->map_clu); in exfat_allocate_bitmap()
78 for (i = 0; i < sbi->map_sectors; i++) { in exfat_allocate_bitmap()
79 sbi->vol_amap[i] = sb_bread(sb, sector + i); in exfat_allocate_bitmap()
80 if (!sbi->vol_amap[i]) { in exfat_allocate_bitmap()
85 brelse(sbi->vol_amap[j++]); in exfat_allocate_bitmap()
87 kfree(sbi->vol_amap); in exfat_allocate_bitmap()
88 sbi->vol_amap = NULL; in exfat_allocate_bitmap()
89 return -EIO; in exfat_allocate_bitmap()
102 exfat_chain_set(&clu, sbi->root_dir, 0, ALLOC_FAT_CHAIN); in exfat_load_bitmap()
104 for (i = 0; i < sbi->dentries_per_clu; i++) { in exfat_load_bitmap()
110 return -EIO; in exfat_load_bitmap()
117 if (ep->dentry.bitmap.flags == 0x0) { in exfat_load_bitmap()
128 return -EIO; in exfat_load_bitmap()
131 return -EINVAL; in exfat_load_bitmap()
138 for (i = 0; i < sbi->map_sectors; i++) in exfat_free_bitmap()
139 __brelse(sbi->vol_amap[i]); in exfat_free_bitmap()
141 kfree(sbi->vol_amap); in exfat_free_bitmap()
148 struct super_block *sb = inode->i_sb; in exfat_set_bitmap()
152 return -EINVAL; in exfat_set_bitmap()
158 set_bit_le(b, sbi->vol_amap[i]->b_data); in exfat_set_bitmap()
159 exfat_update_bh(sbi->vol_amap[i], sync); in exfat_set_bitmap()
167 struct super_block *sb = inode->i_sb; in exfat_clear_bitmap()
169 struct exfat_mount_options *opts = &sbi->options; in exfat_clear_bitmap()
178 clear_bit_le(b, sbi->vol_amap[i]->b_data); in exfat_clear_bitmap()
179 exfat_update_bh(sbi->vol_amap[i], sync); in exfat_clear_bitmap()
181 if (opts->discard) { in exfat_clear_bitmap()
186 (1 << sbi->sect_per_clus_bits), GFP_NOFS, 0); in exfat_clear_bitmap()
188 if (ret_discard == -EOPNOTSUPP) { in exfat_clear_bitmap()
190 opts->discard = 0; in exfat_clear_bitmap()
214 for (i = EXFAT_FIRST_CLUSTER; i < sbi->num_clusters; in exfat_find_free_bitmap()
216 k = *(sbi->vol_amap[map_i]->b_data + map_b); in exfat_find_free_bitmap()
223 if (clu_free < sbi->num_clusters) in exfat_find_free_bitmap()
228 if (++map_b >= sb->s_blocksize || in exfat_find_free_bitmap()
229 clu_base >= sbi->num_clusters) { in exfat_find_free_bitmap()
230 if (++map_i >= sbi->map_sectors) { in exfat_find_free_bitmap()
254 clu_bits = *(sbi->vol_amap[map_i]->b_data + map_b); in exfat_count_used_clusters()
256 if (++map_b >= (unsigned int)sb->s_blocksize) { in exfat_count_used_clusters()
263 clu_bits = *(sbi->vol_amap[map_i]->b_data + map_b); in exfat_count_used_clusters()
276 struct super_block *sb = inode->i_sb; in exfat_trim_fs()
280 clu_start = max_t(u64, range->start >> sbi->cluster_size_bits, in exfat_trim_fs()
282 clu_end = clu_start + (range->len >> sbi->cluster_size_bits) - 1; in exfat_trim_fs()
283 trim_minlen = range->minlen >> sbi->cluster_size_bits; in exfat_trim_fs()
285 if (clu_start >= sbi->num_clusters || range->len < sbi->cluster_size) in exfat_trim_fs()
286 return -EINVAL; in exfat_trim_fs()
288 if (clu_end >= sbi->num_clusters) in exfat_trim_fs()
289 clu_end = sbi->num_clusters - 1; in exfat_trim_fs()
291 mutex_lock(&sbi->bitmap_lock); in exfat_trim_fs()
307 count = trim_end - trim_begin + 1; in exfat_trim_fs()
311 count * sbi->sect_per_clus, GFP_NOFS, 0); in exfat_trim_fs()
326 err = -ERESTARTSYS; in exfat_trim_fs()
335 count = trim_end - trim_begin + 1; in exfat_trim_fs()
338 count * sbi->sect_per_clus, GFP_NOFS, 0); in exfat_trim_fs()
346 mutex_unlock(&sbi->bitmap_lock); in exfat_trim_fs()
347 range->len = trimmed_total << sbi->cluster_size_bits; in exfat_trim_fs()