1*4882a593Smuzhiyun // SPDX-License-Identifier: GPL-2.0-or-later
2*4882a593Smuzhiyun /*
3*4882a593Smuzhiyun * Copyright (C) 2012-2013 Samsung Electronics Co., Ltd.
4*4882a593Smuzhiyun */
5*4882a593Smuzhiyun
6*4882a593Smuzhiyun #include <linux/init.h>
7*4882a593Smuzhiyun #include <linux/buffer_head.h>
8*4882a593Smuzhiyun #include <linux/mpage.h>
9*4882a593Smuzhiyun #include <linux/bio.h>
10*4882a593Smuzhiyun #include <linux/blkdev.h>
11*4882a593Smuzhiyun #include <linux/time.h>
12*4882a593Smuzhiyun #include <linux/writeback.h>
13*4882a593Smuzhiyun #include <linux/uio.h>
14*4882a593Smuzhiyun #include <linux/random.h>
15*4882a593Smuzhiyun #include <linux/iversion.h>
16*4882a593Smuzhiyun
17*4882a593Smuzhiyun #include "exfat_raw.h"
18*4882a593Smuzhiyun #include "exfat_fs.h"
19*4882a593Smuzhiyun
__exfat_write_inode(struct inode * inode,int sync)20*4882a593Smuzhiyun static int __exfat_write_inode(struct inode *inode, int sync)
21*4882a593Smuzhiyun {
22*4882a593Smuzhiyun unsigned long long on_disk_size;
23*4882a593Smuzhiyun struct exfat_dentry *ep, *ep2;
24*4882a593Smuzhiyun struct exfat_entry_set_cache *es = NULL;
25*4882a593Smuzhiyun struct super_block *sb = inode->i_sb;
26*4882a593Smuzhiyun struct exfat_sb_info *sbi = EXFAT_SB(sb);
27*4882a593Smuzhiyun struct exfat_inode_info *ei = EXFAT_I(inode);
28*4882a593Smuzhiyun bool is_dir = (ei->type == TYPE_DIR) ? true : false;
29*4882a593Smuzhiyun
30*4882a593Smuzhiyun if (inode->i_ino == EXFAT_ROOT_INO)
31*4882a593Smuzhiyun return 0;
32*4882a593Smuzhiyun
33*4882a593Smuzhiyun /*
34*4882a593Smuzhiyun * If the indode is already unlinked, there is no need for updating it.
35*4882a593Smuzhiyun */
36*4882a593Smuzhiyun if (ei->dir.dir == DIR_DELETED)
37*4882a593Smuzhiyun return 0;
38*4882a593Smuzhiyun
39*4882a593Smuzhiyun if (is_dir && ei->dir.dir == sbi->root_dir && ei->entry == -1)
40*4882a593Smuzhiyun return 0;
41*4882a593Smuzhiyun
42*4882a593Smuzhiyun exfat_set_volume_dirty(sb);
43*4882a593Smuzhiyun
44*4882a593Smuzhiyun /* get the directory entry of given file or directory */
45*4882a593Smuzhiyun es = exfat_get_dentry_set(sb, &(ei->dir), ei->entry, ES_ALL_ENTRIES);
46*4882a593Smuzhiyun if (!es)
47*4882a593Smuzhiyun return -EIO;
48*4882a593Smuzhiyun ep = exfat_get_dentry_cached(es, 0);
49*4882a593Smuzhiyun ep2 = exfat_get_dentry_cached(es, 1);
50*4882a593Smuzhiyun
51*4882a593Smuzhiyun ep->dentry.file.attr = cpu_to_le16(exfat_make_attr(inode));
52*4882a593Smuzhiyun
53*4882a593Smuzhiyun /* set FILE_INFO structure using the acquired struct exfat_dentry */
54*4882a593Smuzhiyun exfat_set_entry_time(sbi, &ei->i_crtime,
55*4882a593Smuzhiyun &ep->dentry.file.create_tz,
56*4882a593Smuzhiyun &ep->dentry.file.create_time,
57*4882a593Smuzhiyun &ep->dentry.file.create_date,
58*4882a593Smuzhiyun &ep->dentry.file.create_time_cs);
59*4882a593Smuzhiyun exfat_set_entry_time(sbi, &inode->i_mtime,
60*4882a593Smuzhiyun &ep->dentry.file.modify_tz,
61*4882a593Smuzhiyun &ep->dentry.file.modify_time,
62*4882a593Smuzhiyun &ep->dentry.file.modify_date,
63*4882a593Smuzhiyun &ep->dentry.file.modify_time_cs);
64*4882a593Smuzhiyun exfat_set_entry_time(sbi, &inode->i_atime,
65*4882a593Smuzhiyun &ep->dentry.file.access_tz,
66*4882a593Smuzhiyun &ep->dentry.file.access_time,
67*4882a593Smuzhiyun &ep->dentry.file.access_date,
68*4882a593Smuzhiyun NULL);
69*4882a593Smuzhiyun
70*4882a593Smuzhiyun /* File size should be zero if there is no cluster allocated */
71*4882a593Smuzhiyun on_disk_size = i_size_read(inode);
72*4882a593Smuzhiyun
73*4882a593Smuzhiyun if (ei->start_clu == EXFAT_EOF_CLUSTER)
74*4882a593Smuzhiyun on_disk_size = 0;
75*4882a593Smuzhiyun
76*4882a593Smuzhiyun ep2->dentry.stream.valid_size = cpu_to_le64(on_disk_size);
77*4882a593Smuzhiyun ep2->dentry.stream.size = ep2->dentry.stream.valid_size;
78*4882a593Smuzhiyun
79*4882a593Smuzhiyun exfat_update_dir_chksum_with_entry_set(es);
80*4882a593Smuzhiyun return exfat_free_dentry_set(es, sync);
81*4882a593Smuzhiyun }
82*4882a593Smuzhiyun
exfat_write_inode(struct inode * inode,struct writeback_control * wbc)83*4882a593Smuzhiyun int exfat_write_inode(struct inode *inode, struct writeback_control *wbc)
84*4882a593Smuzhiyun {
85*4882a593Smuzhiyun int ret;
86*4882a593Smuzhiyun
87*4882a593Smuzhiyun mutex_lock(&EXFAT_SB(inode->i_sb)->s_lock);
88*4882a593Smuzhiyun ret = __exfat_write_inode(inode, wbc->sync_mode == WB_SYNC_ALL);
89*4882a593Smuzhiyun mutex_unlock(&EXFAT_SB(inode->i_sb)->s_lock);
90*4882a593Smuzhiyun
91*4882a593Smuzhiyun return ret;
92*4882a593Smuzhiyun }
93*4882a593Smuzhiyun
exfat_sync_inode(struct inode * inode)94*4882a593Smuzhiyun void exfat_sync_inode(struct inode *inode)
95*4882a593Smuzhiyun {
96*4882a593Smuzhiyun lockdep_assert_held(&EXFAT_SB(inode->i_sb)->s_lock);
97*4882a593Smuzhiyun __exfat_write_inode(inode, 1);
98*4882a593Smuzhiyun }
99*4882a593Smuzhiyun
100*4882a593Smuzhiyun /*
101*4882a593Smuzhiyun * Input: inode, (logical) clu_offset, target allocation area
102*4882a593Smuzhiyun * Output: errcode, cluster number
103*4882a593Smuzhiyun * *clu = (~0), if it's unable to allocate a new cluster
104*4882a593Smuzhiyun */
exfat_map_cluster(struct inode * inode,unsigned int clu_offset,unsigned int * clu,int create)105*4882a593Smuzhiyun static int exfat_map_cluster(struct inode *inode, unsigned int clu_offset,
106*4882a593Smuzhiyun unsigned int *clu, int create)
107*4882a593Smuzhiyun {
108*4882a593Smuzhiyun int ret, modified = false;
109*4882a593Smuzhiyun unsigned int last_clu;
110*4882a593Smuzhiyun struct exfat_chain new_clu;
111*4882a593Smuzhiyun struct super_block *sb = inode->i_sb;
112*4882a593Smuzhiyun struct exfat_sb_info *sbi = EXFAT_SB(sb);
113*4882a593Smuzhiyun struct exfat_inode_info *ei = EXFAT_I(inode);
114*4882a593Smuzhiyun unsigned int local_clu_offset = clu_offset;
115*4882a593Smuzhiyun unsigned int num_to_be_allocated = 0, num_clusters = 0;
116*4882a593Smuzhiyun
117*4882a593Smuzhiyun if (ei->i_size_ondisk > 0)
118*4882a593Smuzhiyun num_clusters =
119*4882a593Smuzhiyun EXFAT_B_TO_CLU_ROUND_UP(ei->i_size_ondisk, sbi);
120*4882a593Smuzhiyun
121*4882a593Smuzhiyun if (clu_offset >= num_clusters)
122*4882a593Smuzhiyun num_to_be_allocated = clu_offset - num_clusters + 1;
123*4882a593Smuzhiyun
124*4882a593Smuzhiyun if (!create && (num_to_be_allocated > 0)) {
125*4882a593Smuzhiyun *clu = EXFAT_EOF_CLUSTER;
126*4882a593Smuzhiyun return 0;
127*4882a593Smuzhiyun }
128*4882a593Smuzhiyun
129*4882a593Smuzhiyun *clu = last_clu = ei->start_clu;
130*4882a593Smuzhiyun
131*4882a593Smuzhiyun if (ei->flags == ALLOC_NO_FAT_CHAIN) {
132*4882a593Smuzhiyun if (clu_offset > 0 && *clu != EXFAT_EOF_CLUSTER) {
133*4882a593Smuzhiyun last_clu += clu_offset - 1;
134*4882a593Smuzhiyun
135*4882a593Smuzhiyun if (clu_offset == num_clusters)
136*4882a593Smuzhiyun *clu = EXFAT_EOF_CLUSTER;
137*4882a593Smuzhiyun else
138*4882a593Smuzhiyun *clu += clu_offset;
139*4882a593Smuzhiyun }
140*4882a593Smuzhiyun } else if (ei->type == TYPE_FILE) {
141*4882a593Smuzhiyun unsigned int fclus = 0;
142*4882a593Smuzhiyun int err = exfat_get_cluster(inode, clu_offset,
143*4882a593Smuzhiyun &fclus, clu, &last_clu, 1);
144*4882a593Smuzhiyun if (err)
145*4882a593Smuzhiyun return -EIO;
146*4882a593Smuzhiyun
147*4882a593Smuzhiyun clu_offset -= fclus;
148*4882a593Smuzhiyun } else {
149*4882a593Smuzhiyun /* hint information */
150*4882a593Smuzhiyun if (clu_offset > 0 && ei->hint_bmap.off != EXFAT_EOF_CLUSTER &&
151*4882a593Smuzhiyun ei->hint_bmap.off > 0 && clu_offset >= ei->hint_bmap.off) {
152*4882a593Smuzhiyun clu_offset -= ei->hint_bmap.off;
153*4882a593Smuzhiyun /* hint_bmap.clu should be valid */
154*4882a593Smuzhiyun WARN_ON(ei->hint_bmap.clu < 2);
155*4882a593Smuzhiyun *clu = ei->hint_bmap.clu;
156*4882a593Smuzhiyun }
157*4882a593Smuzhiyun
158*4882a593Smuzhiyun while (clu_offset > 0 && *clu != EXFAT_EOF_CLUSTER) {
159*4882a593Smuzhiyun last_clu = *clu;
160*4882a593Smuzhiyun if (exfat_get_next_cluster(sb, clu))
161*4882a593Smuzhiyun return -EIO;
162*4882a593Smuzhiyun clu_offset--;
163*4882a593Smuzhiyun }
164*4882a593Smuzhiyun }
165*4882a593Smuzhiyun
166*4882a593Smuzhiyun if (*clu == EXFAT_EOF_CLUSTER) {
167*4882a593Smuzhiyun exfat_set_volume_dirty(sb);
168*4882a593Smuzhiyun
169*4882a593Smuzhiyun new_clu.dir = (last_clu == EXFAT_EOF_CLUSTER) ?
170*4882a593Smuzhiyun EXFAT_EOF_CLUSTER : last_clu + 1;
171*4882a593Smuzhiyun new_clu.size = 0;
172*4882a593Smuzhiyun new_clu.flags = ei->flags;
173*4882a593Smuzhiyun
174*4882a593Smuzhiyun /* allocate a cluster */
175*4882a593Smuzhiyun if (num_to_be_allocated < 1) {
176*4882a593Smuzhiyun /* Broken FAT (i_sze > allocated FAT) */
177*4882a593Smuzhiyun exfat_fs_error(sb, "broken FAT chain.");
178*4882a593Smuzhiyun return -EIO;
179*4882a593Smuzhiyun }
180*4882a593Smuzhiyun
181*4882a593Smuzhiyun ret = exfat_alloc_cluster(inode, num_to_be_allocated, &new_clu,
182*4882a593Smuzhiyun inode_needs_sync(inode));
183*4882a593Smuzhiyun if (ret)
184*4882a593Smuzhiyun return ret;
185*4882a593Smuzhiyun
186*4882a593Smuzhiyun if (new_clu.dir == EXFAT_EOF_CLUSTER ||
187*4882a593Smuzhiyun new_clu.dir == EXFAT_FREE_CLUSTER) {
188*4882a593Smuzhiyun exfat_fs_error(sb,
189*4882a593Smuzhiyun "bogus cluster new allocated (last_clu : %u, new_clu : %u)",
190*4882a593Smuzhiyun last_clu, new_clu.dir);
191*4882a593Smuzhiyun return -EIO;
192*4882a593Smuzhiyun }
193*4882a593Smuzhiyun
194*4882a593Smuzhiyun /* append to the FAT chain */
195*4882a593Smuzhiyun if (last_clu == EXFAT_EOF_CLUSTER) {
196*4882a593Smuzhiyun if (new_clu.flags == ALLOC_FAT_CHAIN)
197*4882a593Smuzhiyun ei->flags = ALLOC_FAT_CHAIN;
198*4882a593Smuzhiyun ei->start_clu = new_clu.dir;
199*4882a593Smuzhiyun modified = true;
200*4882a593Smuzhiyun } else {
201*4882a593Smuzhiyun if (new_clu.flags != ei->flags) {
202*4882a593Smuzhiyun /* no-fat-chain bit is disabled,
203*4882a593Smuzhiyun * so fat-chain should be synced with
204*4882a593Smuzhiyun * alloc-bitmap
205*4882a593Smuzhiyun */
206*4882a593Smuzhiyun exfat_chain_cont_cluster(sb, ei->start_clu,
207*4882a593Smuzhiyun num_clusters);
208*4882a593Smuzhiyun ei->flags = ALLOC_FAT_CHAIN;
209*4882a593Smuzhiyun modified = true;
210*4882a593Smuzhiyun }
211*4882a593Smuzhiyun if (new_clu.flags == ALLOC_FAT_CHAIN)
212*4882a593Smuzhiyun if (exfat_ent_set(sb, last_clu, new_clu.dir))
213*4882a593Smuzhiyun return -EIO;
214*4882a593Smuzhiyun }
215*4882a593Smuzhiyun
216*4882a593Smuzhiyun num_clusters += num_to_be_allocated;
217*4882a593Smuzhiyun *clu = new_clu.dir;
218*4882a593Smuzhiyun
219*4882a593Smuzhiyun if (ei->dir.dir != DIR_DELETED && modified) {
220*4882a593Smuzhiyun struct exfat_dentry *ep;
221*4882a593Smuzhiyun struct exfat_entry_set_cache *es;
222*4882a593Smuzhiyun int err;
223*4882a593Smuzhiyun
224*4882a593Smuzhiyun es = exfat_get_dentry_set(sb, &(ei->dir), ei->entry,
225*4882a593Smuzhiyun ES_ALL_ENTRIES);
226*4882a593Smuzhiyun if (!es)
227*4882a593Smuzhiyun return -EIO;
228*4882a593Smuzhiyun /* get stream entry */
229*4882a593Smuzhiyun ep = exfat_get_dentry_cached(es, 1);
230*4882a593Smuzhiyun
231*4882a593Smuzhiyun /* update directory entry */
232*4882a593Smuzhiyun ep->dentry.stream.flags = ei->flags;
233*4882a593Smuzhiyun ep->dentry.stream.start_clu =
234*4882a593Smuzhiyun cpu_to_le32(ei->start_clu);
235*4882a593Smuzhiyun ep->dentry.stream.valid_size =
236*4882a593Smuzhiyun cpu_to_le64(i_size_read(inode));
237*4882a593Smuzhiyun ep->dentry.stream.size =
238*4882a593Smuzhiyun ep->dentry.stream.valid_size;
239*4882a593Smuzhiyun
240*4882a593Smuzhiyun exfat_update_dir_chksum_with_entry_set(es);
241*4882a593Smuzhiyun err = exfat_free_dentry_set(es, inode_needs_sync(inode));
242*4882a593Smuzhiyun if (err)
243*4882a593Smuzhiyun return err;
244*4882a593Smuzhiyun } /* end of if != DIR_DELETED */
245*4882a593Smuzhiyun
246*4882a593Smuzhiyun inode->i_blocks +=
247*4882a593Smuzhiyun num_to_be_allocated << sbi->sect_per_clus_bits;
248*4882a593Smuzhiyun
249*4882a593Smuzhiyun /*
250*4882a593Smuzhiyun * Move *clu pointer along FAT chains (hole care) because the
251*4882a593Smuzhiyun * caller of this function expect *clu to be the last cluster.
252*4882a593Smuzhiyun * This only works when num_to_be_allocated >= 2,
253*4882a593Smuzhiyun * *clu = (the first cluster of the allocated chain) =>
254*4882a593Smuzhiyun * (the last cluster of ...)
255*4882a593Smuzhiyun */
256*4882a593Smuzhiyun if (ei->flags == ALLOC_NO_FAT_CHAIN) {
257*4882a593Smuzhiyun *clu += num_to_be_allocated - 1;
258*4882a593Smuzhiyun } else {
259*4882a593Smuzhiyun while (num_to_be_allocated > 1) {
260*4882a593Smuzhiyun if (exfat_get_next_cluster(sb, clu))
261*4882a593Smuzhiyun return -EIO;
262*4882a593Smuzhiyun num_to_be_allocated--;
263*4882a593Smuzhiyun }
264*4882a593Smuzhiyun }
265*4882a593Smuzhiyun
266*4882a593Smuzhiyun }
267*4882a593Smuzhiyun
268*4882a593Smuzhiyun /* hint information */
269*4882a593Smuzhiyun ei->hint_bmap.off = local_clu_offset;
270*4882a593Smuzhiyun ei->hint_bmap.clu = *clu;
271*4882a593Smuzhiyun
272*4882a593Smuzhiyun return 0;
273*4882a593Smuzhiyun }
274*4882a593Smuzhiyun
exfat_map_new_buffer(struct exfat_inode_info * ei,struct buffer_head * bh,loff_t pos)275*4882a593Smuzhiyun static int exfat_map_new_buffer(struct exfat_inode_info *ei,
276*4882a593Smuzhiyun struct buffer_head *bh, loff_t pos)
277*4882a593Smuzhiyun {
278*4882a593Smuzhiyun if (buffer_delay(bh) && pos > ei->i_size_aligned)
279*4882a593Smuzhiyun return -EIO;
280*4882a593Smuzhiyun set_buffer_new(bh);
281*4882a593Smuzhiyun
282*4882a593Smuzhiyun /*
283*4882a593Smuzhiyun * Adjust i_size_aligned if i_size_ondisk is bigger than it.
284*4882a593Smuzhiyun */
285*4882a593Smuzhiyun if (ei->i_size_ondisk > ei->i_size_aligned)
286*4882a593Smuzhiyun ei->i_size_aligned = ei->i_size_ondisk;
287*4882a593Smuzhiyun return 0;
288*4882a593Smuzhiyun }
289*4882a593Smuzhiyun
exfat_get_block(struct inode * inode,sector_t iblock,struct buffer_head * bh_result,int create)290*4882a593Smuzhiyun static int exfat_get_block(struct inode *inode, sector_t iblock,
291*4882a593Smuzhiyun struct buffer_head *bh_result, int create)
292*4882a593Smuzhiyun {
293*4882a593Smuzhiyun struct exfat_inode_info *ei = EXFAT_I(inode);
294*4882a593Smuzhiyun struct super_block *sb = inode->i_sb;
295*4882a593Smuzhiyun struct exfat_sb_info *sbi = EXFAT_SB(sb);
296*4882a593Smuzhiyun unsigned long max_blocks = bh_result->b_size >> inode->i_blkbits;
297*4882a593Smuzhiyun int err = 0;
298*4882a593Smuzhiyun unsigned long mapped_blocks = 0;
299*4882a593Smuzhiyun unsigned int cluster, sec_offset;
300*4882a593Smuzhiyun sector_t last_block;
301*4882a593Smuzhiyun sector_t phys = 0;
302*4882a593Smuzhiyun loff_t pos;
303*4882a593Smuzhiyun
304*4882a593Smuzhiyun mutex_lock(&sbi->s_lock);
305*4882a593Smuzhiyun last_block = EXFAT_B_TO_BLK_ROUND_UP(i_size_read(inode), sb);
306*4882a593Smuzhiyun if (iblock >= last_block && !create)
307*4882a593Smuzhiyun goto done;
308*4882a593Smuzhiyun
309*4882a593Smuzhiyun /* Is this block already allocated? */
310*4882a593Smuzhiyun err = exfat_map_cluster(inode, iblock >> sbi->sect_per_clus_bits,
311*4882a593Smuzhiyun &cluster, create);
312*4882a593Smuzhiyun if (err) {
313*4882a593Smuzhiyun if (err != -ENOSPC)
314*4882a593Smuzhiyun exfat_fs_error_ratelimit(sb,
315*4882a593Smuzhiyun "failed to bmap (inode : %p iblock : %llu, err : %d)",
316*4882a593Smuzhiyun inode, (unsigned long long)iblock, err);
317*4882a593Smuzhiyun goto unlock_ret;
318*4882a593Smuzhiyun }
319*4882a593Smuzhiyun
320*4882a593Smuzhiyun if (cluster == EXFAT_EOF_CLUSTER)
321*4882a593Smuzhiyun goto done;
322*4882a593Smuzhiyun
323*4882a593Smuzhiyun /* sector offset in cluster */
324*4882a593Smuzhiyun sec_offset = iblock & (sbi->sect_per_clus - 1);
325*4882a593Smuzhiyun
326*4882a593Smuzhiyun phys = exfat_cluster_to_sector(sbi, cluster) + sec_offset;
327*4882a593Smuzhiyun mapped_blocks = sbi->sect_per_clus - sec_offset;
328*4882a593Smuzhiyun max_blocks = min(mapped_blocks, max_blocks);
329*4882a593Smuzhiyun
330*4882a593Smuzhiyun /* Treat newly added block / cluster */
331*4882a593Smuzhiyun if (iblock < last_block)
332*4882a593Smuzhiyun create = 0;
333*4882a593Smuzhiyun
334*4882a593Smuzhiyun if (create || buffer_delay(bh_result)) {
335*4882a593Smuzhiyun pos = EXFAT_BLK_TO_B((iblock + 1), sb);
336*4882a593Smuzhiyun if (ei->i_size_ondisk < pos)
337*4882a593Smuzhiyun ei->i_size_ondisk = pos;
338*4882a593Smuzhiyun }
339*4882a593Smuzhiyun
340*4882a593Smuzhiyun if (create) {
341*4882a593Smuzhiyun err = exfat_map_new_buffer(ei, bh_result, pos);
342*4882a593Smuzhiyun if (err) {
343*4882a593Smuzhiyun exfat_fs_error(sb,
344*4882a593Smuzhiyun "requested for bmap out of range(pos : (%llu) > i_size_aligned(%llu)\n",
345*4882a593Smuzhiyun pos, ei->i_size_aligned);
346*4882a593Smuzhiyun goto unlock_ret;
347*4882a593Smuzhiyun }
348*4882a593Smuzhiyun }
349*4882a593Smuzhiyun
350*4882a593Smuzhiyun if (buffer_delay(bh_result))
351*4882a593Smuzhiyun clear_buffer_delay(bh_result);
352*4882a593Smuzhiyun map_bh(bh_result, sb, phys);
353*4882a593Smuzhiyun done:
354*4882a593Smuzhiyun bh_result->b_size = EXFAT_BLK_TO_B(max_blocks, sb);
355*4882a593Smuzhiyun unlock_ret:
356*4882a593Smuzhiyun mutex_unlock(&sbi->s_lock);
357*4882a593Smuzhiyun return err;
358*4882a593Smuzhiyun }
359*4882a593Smuzhiyun
exfat_readpage(struct file * file,struct page * page)360*4882a593Smuzhiyun static int exfat_readpage(struct file *file, struct page *page)
361*4882a593Smuzhiyun {
362*4882a593Smuzhiyun return mpage_readpage(page, exfat_get_block);
363*4882a593Smuzhiyun }
364*4882a593Smuzhiyun
exfat_readahead(struct readahead_control * rac)365*4882a593Smuzhiyun static void exfat_readahead(struct readahead_control *rac)
366*4882a593Smuzhiyun {
367*4882a593Smuzhiyun mpage_readahead(rac, exfat_get_block);
368*4882a593Smuzhiyun }
369*4882a593Smuzhiyun
exfat_writepage(struct page * page,struct writeback_control * wbc)370*4882a593Smuzhiyun static int exfat_writepage(struct page *page, struct writeback_control *wbc)
371*4882a593Smuzhiyun {
372*4882a593Smuzhiyun return block_write_full_page(page, exfat_get_block, wbc);
373*4882a593Smuzhiyun }
374*4882a593Smuzhiyun
exfat_writepages(struct address_space * mapping,struct writeback_control * wbc)375*4882a593Smuzhiyun static int exfat_writepages(struct address_space *mapping,
376*4882a593Smuzhiyun struct writeback_control *wbc)
377*4882a593Smuzhiyun {
378*4882a593Smuzhiyun return mpage_writepages(mapping, wbc, exfat_get_block);
379*4882a593Smuzhiyun }
380*4882a593Smuzhiyun
exfat_write_failed(struct address_space * mapping,loff_t to)381*4882a593Smuzhiyun static void exfat_write_failed(struct address_space *mapping, loff_t to)
382*4882a593Smuzhiyun {
383*4882a593Smuzhiyun struct inode *inode = mapping->host;
384*4882a593Smuzhiyun
385*4882a593Smuzhiyun if (to > i_size_read(inode)) {
386*4882a593Smuzhiyun truncate_pagecache(inode, i_size_read(inode));
387*4882a593Smuzhiyun exfat_truncate(inode, EXFAT_I(inode)->i_size_aligned);
388*4882a593Smuzhiyun }
389*4882a593Smuzhiyun }
390*4882a593Smuzhiyun
exfat_write_begin(struct file * file,struct address_space * mapping,loff_t pos,unsigned int len,unsigned int flags,struct page ** pagep,void ** fsdata)391*4882a593Smuzhiyun static int exfat_write_begin(struct file *file, struct address_space *mapping,
392*4882a593Smuzhiyun loff_t pos, unsigned int len, unsigned int flags,
393*4882a593Smuzhiyun struct page **pagep, void **fsdata)
394*4882a593Smuzhiyun {
395*4882a593Smuzhiyun int ret;
396*4882a593Smuzhiyun
397*4882a593Smuzhiyun *pagep = NULL;
398*4882a593Smuzhiyun ret = cont_write_begin(file, mapping, pos, len, flags, pagep, fsdata,
399*4882a593Smuzhiyun exfat_get_block,
400*4882a593Smuzhiyun &EXFAT_I(mapping->host)->i_size_ondisk);
401*4882a593Smuzhiyun
402*4882a593Smuzhiyun if (ret < 0)
403*4882a593Smuzhiyun exfat_write_failed(mapping, pos+len);
404*4882a593Smuzhiyun
405*4882a593Smuzhiyun return ret;
406*4882a593Smuzhiyun }
407*4882a593Smuzhiyun
exfat_write_end(struct file * file,struct address_space * mapping,loff_t pos,unsigned int len,unsigned int copied,struct page * pagep,void * fsdata)408*4882a593Smuzhiyun static int exfat_write_end(struct file *file, struct address_space *mapping,
409*4882a593Smuzhiyun loff_t pos, unsigned int len, unsigned int copied,
410*4882a593Smuzhiyun struct page *pagep, void *fsdata)
411*4882a593Smuzhiyun {
412*4882a593Smuzhiyun struct inode *inode = mapping->host;
413*4882a593Smuzhiyun struct exfat_inode_info *ei = EXFAT_I(inode);
414*4882a593Smuzhiyun int err;
415*4882a593Smuzhiyun
416*4882a593Smuzhiyun err = generic_write_end(file, mapping, pos, len, copied, pagep, fsdata);
417*4882a593Smuzhiyun
418*4882a593Smuzhiyun if (ei->i_size_aligned < i_size_read(inode)) {
419*4882a593Smuzhiyun exfat_fs_error(inode->i_sb,
420*4882a593Smuzhiyun "invalid size(size(%llu) > aligned(%llu)\n",
421*4882a593Smuzhiyun i_size_read(inode), ei->i_size_aligned);
422*4882a593Smuzhiyun return -EIO;
423*4882a593Smuzhiyun }
424*4882a593Smuzhiyun
425*4882a593Smuzhiyun if (err < len)
426*4882a593Smuzhiyun exfat_write_failed(mapping, pos+len);
427*4882a593Smuzhiyun
428*4882a593Smuzhiyun if (!(err < 0) && !(ei->attr & ATTR_ARCHIVE)) {
429*4882a593Smuzhiyun inode->i_mtime = inode->i_ctime = current_time(inode);
430*4882a593Smuzhiyun ei->attr |= ATTR_ARCHIVE;
431*4882a593Smuzhiyun mark_inode_dirty(inode);
432*4882a593Smuzhiyun }
433*4882a593Smuzhiyun
434*4882a593Smuzhiyun return err;
435*4882a593Smuzhiyun }
436*4882a593Smuzhiyun
exfat_direct_IO(struct kiocb * iocb,struct iov_iter * iter)437*4882a593Smuzhiyun static ssize_t exfat_direct_IO(struct kiocb *iocb, struct iov_iter *iter)
438*4882a593Smuzhiyun {
439*4882a593Smuzhiyun struct address_space *mapping = iocb->ki_filp->f_mapping;
440*4882a593Smuzhiyun struct inode *inode = mapping->host;
441*4882a593Smuzhiyun loff_t size = iocb->ki_pos + iov_iter_count(iter);
442*4882a593Smuzhiyun int rw = iov_iter_rw(iter);
443*4882a593Smuzhiyun ssize_t ret;
444*4882a593Smuzhiyun
445*4882a593Smuzhiyun if (rw == WRITE) {
446*4882a593Smuzhiyun /*
447*4882a593Smuzhiyun * FIXME: blockdev_direct_IO() doesn't use ->write_begin(),
448*4882a593Smuzhiyun * so we need to update the ->i_size_aligned to block boundary.
449*4882a593Smuzhiyun *
450*4882a593Smuzhiyun * But we must fill the remaining area or hole by nul for
451*4882a593Smuzhiyun * updating ->i_size_aligned
452*4882a593Smuzhiyun *
453*4882a593Smuzhiyun * Return 0, and fallback to normal buffered write.
454*4882a593Smuzhiyun */
455*4882a593Smuzhiyun if (EXFAT_I(inode)->i_size_aligned < size)
456*4882a593Smuzhiyun return 0;
457*4882a593Smuzhiyun }
458*4882a593Smuzhiyun
459*4882a593Smuzhiyun /*
460*4882a593Smuzhiyun * Need to use the DIO_LOCKING for avoiding the race
461*4882a593Smuzhiyun * condition of exfat_get_block() and ->truncate().
462*4882a593Smuzhiyun */
463*4882a593Smuzhiyun ret = blockdev_direct_IO(iocb, inode, iter, exfat_get_block);
464*4882a593Smuzhiyun if (ret < 0 && (rw & WRITE))
465*4882a593Smuzhiyun exfat_write_failed(mapping, size);
466*4882a593Smuzhiyun return ret;
467*4882a593Smuzhiyun }
468*4882a593Smuzhiyun
exfat_aop_bmap(struct address_space * mapping,sector_t block)469*4882a593Smuzhiyun static sector_t exfat_aop_bmap(struct address_space *mapping, sector_t block)
470*4882a593Smuzhiyun {
471*4882a593Smuzhiyun sector_t blocknr;
472*4882a593Smuzhiyun
473*4882a593Smuzhiyun /* exfat_get_cluster() assumes the requested blocknr isn't truncated. */
474*4882a593Smuzhiyun down_read(&EXFAT_I(mapping->host)->truncate_lock);
475*4882a593Smuzhiyun blocknr = generic_block_bmap(mapping, block, exfat_get_block);
476*4882a593Smuzhiyun up_read(&EXFAT_I(mapping->host)->truncate_lock);
477*4882a593Smuzhiyun return blocknr;
478*4882a593Smuzhiyun }
479*4882a593Smuzhiyun
480*4882a593Smuzhiyun /*
481*4882a593Smuzhiyun * exfat_block_truncate_page() zeroes out a mapping from file offset `from'
482*4882a593Smuzhiyun * up to the end of the block which corresponds to `from'.
483*4882a593Smuzhiyun * This is required during truncate to physically zeroout the tail end
484*4882a593Smuzhiyun * of that block so it doesn't yield old data if the file is later grown.
485*4882a593Smuzhiyun * Also, avoid causing failure from fsx for cases of "data past EOF"
486*4882a593Smuzhiyun */
exfat_block_truncate_page(struct inode * inode,loff_t from)487*4882a593Smuzhiyun int exfat_block_truncate_page(struct inode *inode, loff_t from)
488*4882a593Smuzhiyun {
489*4882a593Smuzhiyun return block_truncate_page(inode->i_mapping, from, exfat_get_block);
490*4882a593Smuzhiyun }
491*4882a593Smuzhiyun
492*4882a593Smuzhiyun static const struct address_space_operations exfat_aops = {
493*4882a593Smuzhiyun .readpage = exfat_readpage,
494*4882a593Smuzhiyun .readahead = exfat_readahead,
495*4882a593Smuzhiyun .writepage = exfat_writepage,
496*4882a593Smuzhiyun .writepages = exfat_writepages,
497*4882a593Smuzhiyun .write_begin = exfat_write_begin,
498*4882a593Smuzhiyun .write_end = exfat_write_end,
499*4882a593Smuzhiyun .direct_IO = exfat_direct_IO,
500*4882a593Smuzhiyun .bmap = exfat_aop_bmap
501*4882a593Smuzhiyun };
502*4882a593Smuzhiyun
exfat_hash(loff_t i_pos)503*4882a593Smuzhiyun static inline unsigned long exfat_hash(loff_t i_pos)
504*4882a593Smuzhiyun {
505*4882a593Smuzhiyun return hash_32(i_pos, EXFAT_HASH_BITS);
506*4882a593Smuzhiyun }
507*4882a593Smuzhiyun
exfat_hash_inode(struct inode * inode,loff_t i_pos)508*4882a593Smuzhiyun void exfat_hash_inode(struct inode *inode, loff_t i_pos)
509*4882a593Smuzhiyun {
510*4882a593Smuzhiyun struct exfat_sb_info *sbi = EXFAT_SB(inode->i_sb);
511*4882a593Smuzhiyun struct hlist_head *head = sbi->inode_hashtable + exfat_hash(i_pos);
512*4882a593Smuzhiyun
513*4882a593Smuzhiyun spin_lock(&sbi->inode_hash_lock);
514*4882a593Smuzhiyun EXFAT_I(inode)->i_pos = i_pos;
515*4882a593Smuzhiyun hlist_add_head(&EXFAT_I(inode)->i_hash_fat, head);
516*4882a593Smuzhiyun spin_unlock(&sbi->inode_hash_lock);
517*4882a593Smuzhiyun }
518*4882a593Smuzhiyun
exfat_unhash_inode(struct inode * inode)519*4882a593Smuzhiyun void exfat_unhash_inode(struct inode *inode)
520*4882a593Smuzhiyun {
521*4882a593Smuzhiyun struct exfat_sb_info *sbi = EXFAT_SB(inode->i_sb);
522*4882a593Smuzhiyun
523*4882a593Smuzhiyun spin_lock(&sbi->inode_hash_lock);
524*4882a593Smuzhiyun hlist_del_init(&EXFAT_I(inode)->i_hash_fat);
525*4882a593Smuzhiyun EXFAT_I(inode)->i_pos = 0;
526*4882a593Smuzhiyun spin_unlock(&sbi->inode_hash_lock);
527*4882a593Smuzhiyun }
528*4882a593Smuzhiyun
exfat_iget(struct super_block * sb,loff_t i_pos)529*4882a593Smuzhiyun struct inode *exfat_iget(struct super_block *sb, loff_t i_pos)
530*4882a593Smuzhiyun {
531*4882a593Smuzhiyun struct exfat_sb_info *sbi = EXFAT_SB(sb);
532*4882a593Smuzhiyun struct exfat_inode_info *info;
533*4882a593Smuzhiyun struct hlist_head *head = sbi->inode_hashtable + exfat_hash(i_pos);
534*4882a593Smuzhiyun struct inode *inode = NULL;
535*4882a593Smuzhiyun
536*4882a593Smuzhiyun spin_lock(&sbi->inode_hash_lock);
537*4882a593Smuzhiyun hlist_for_each_entry(info, head, i_hash_fat) {
538*4882a593Smuzhiyun WARN_ON(info->vfs_inode.i_sb != sb);
539*4882a593Smuzhiyun
540*4882a593Smuzhiyun if (i_pos != info->i_pos)
541*4882a593Smuzhiyun continue;
542*4882a593Smuzhiyun inode = igrab(&info->vfs_inode);
543*4882a593Smuzhiyun if (inode)
544*4882a593Smuzhiyun break;
545*4882a593Smuzhiyun }
546*4882a593Smuzhiyun spin_unlock(&sbi->inode_hash_lock);
547*4882a593Smuzhiyun return inode;
548*4882a593Smuzhiyun }
549*4882a593Smuzhiyun
550*4882a593Smuzhiyun /* doesn't deal with root inode */
exfat_fill_inode(struct inode * inode,struct exfat_dir_entry * info)551*4882a593Smuzhiyun static int exfat_fill_inode(struct inode *inode, struct exfat_dir_entry *info)
552*4882a593Smuzhiyun {
553*4882a593Smuzhiyun struct exfat_sb_info *sbi = EXFAT_SB(inode->i_sb);
554*4882a593Smuzhiyun struct exfat_inode_info *ei = EXFAT_I(inode);
555*4882a593Smuzhiyun loff_t size = info->size;
556*4882a593Smuzhiyun
557*4882a593Smuzhiyun ei->dir = info->dir;
558*4882a593Smuzhiyun ei->entry = info->entry;
559*4882a593Smuzhiyun ei->attr = info->attr;
560*4882a593Smuzhiyun ei->start_clu = info->start_clu;
561*4882a593Smuzhiyun ei->flags = info->flags;
562*4882a593Smuzhiyun ei->type = info->type;
563*4882a593Smuzhiyun
564*4882a593Smuzhiyun ei->version = 0;
565*4882a593Smuzhiyun ei->hint_stat.eidx = 0;
566*4882a593Smuzhiyun ei->hint_stat.clu = info->start_clu;
567*4882a593Smuzhiyun ei->hint_femp.eidx = EXFAT_HINT_NONE;
568*4882a593Smuzhiyun ei->hint_bmap.off = EXFAT_EOF_CLUSTER;
569*4882a593Smuzhiyun ei->i_pos = 0;
570*4882a593Smuzhiyun
571*4882a593Smuzhiyun inode->i_uid = sbi->options.fs_uid;
572*4882a593Smuzhiyun inode->i_gid = sbi->options.fs_gid;
573*4882a593Smuzhiyun inode_inc_iversion(inode);
574*4882a593Smuzhiyun inode->i_generation = prandom_u32();
575*4882a593Smuzhiyun
576*4882a593Smuzhiyun if (info->attr & ATTR_SUBDIR) { /* directory */
577*4882a593Smuzhiyun inode->i_generation &= ~1;
578*4882a593Smuzhiyun inode->i_mode = exfat_make_mode(sbi, info->attr, 0777);
579*4882a593Smuzhiyun inode->i_op = &exfat_dir_inode_operations;
580*4882a593Smuzhiyun inode->i_fop = &exfat_dir_operations;
581*4882a593Smuzhiyun set_nlink(inode, info->num_subdirs);
582*4882a593Smuzhiyun } else { /* regular file */
583*4882a593Smuzhiyun inode->i_generation |= 1;
584*4882a593Smuzhiyun inode->i_mode = exfat_make_mode(sbi, info->attr, 0777);
585*4882a593Smuzhiyun inode->i_op = &exfat_file_inode_operations;
586*4882a593Smuzhiyun inode->i_fop = &exfat_file_operations;
587*4882a593Smuzhiyun inode->i_mapping->a_ops = &exfat_aops;
588*4882a593Smuzhiyun inode->i_mapping->nrpages = 0;
589*4882a593Smuzhiyun }
590*4882a593Smuzhiyun
591*4882a593Smuzhiyun i_size_write(inode, size);
592*4882a593Smuzhiyun
593*4882a593Smuzhiyun /* ondisk and aligned size should be aligned with block size */
594*4882a593Smuzhiyun if (size & (inode->i_sb->s_blocksize - 1)) {
595*4882a593Smuzhiyun size |= (inode->i_sb->s_blocksize - 1);
596*4882a593Smuzhiyun size++;
597*4882a593Smuzhiyun }
598*4882a593Smuzhiyun
599*4882a593Smuzhiyun ei->i_size_aligned = size;
600*4882a593Smuzhiyun ei->i_size_ondisk = size;
601*4882a593Smuzhiyun
602*4882a593Smuzhiyun exfat_save_attr(inode, info->attr);
603*4882a593Smuzhiyun
604*4882a593Smuzhiyun inode->i_blocks = round_up(i_size_read(inode), sbi->cluster_size) >>
605*4882a593Smuzhiyun inode->i_blkbits;
606*4882a593Smuzhiyun inode->i_mtime = info->mtime;
607*4882a593Smuzhiyun inode->i_ctime = info->mtime;
608*4882a593Smuzhiyun ei->i_crtime = info->crtime;
609*4882a593Smuzhiyun inode->i_atime = info->atime;
610*4882a593Smuzhiyun
611*4882a593Smuzhiyun return 0;
612*4882a593Smuzhiyun }
613*4882a593Smuzhiyun
exfat_build_inode(struct super_block * sb,struct exfat_dir_entry * info,loff_t i_pos)614*4882a593Smuzhiyun struct inode *exfat_build_inode(struct super_block *sb,
615*4882a593Smuzhiyun struct exfat_dir_entry *info, loff_t i_pos)
616*4882a593Smuzhiyun {
617*4882a593Smuzhiyun struct inode *inode;
618*4882a593Smuzhiyun int err;
619*4882a593Smuzhiyun
620*4882a593Smuzhiyun inode = exfat_iget(sb, i_pos);
621*4882a593Smuzhiyun if (inode)
622*4882a593Smuzhiyun goto out;
623*4882a593Smuzhiyun inode = new_inode(sb);
624*4882a593Smuzhiyun if (!inode) {
625*4882a593Smuzhiyun inode = ERR_PTR(-ENOMEM);
626*4882a593Smuzhiyun goto out;
627*4882a593Smuzhiyun }
628*4882a593Smuzhiyun inode->i_ino = iunique(sb, EXFAT_ROOT_INO);
629*4882a593Smuzhiyun inode_set_iversion(inode, 1);
630*4882a593Smuzhiyun err = exfat_fill_inode(inode, info);
631*4882a593Smuzhiyun if (err) {
632*4882a593Smuzhiyun iput(inode);
633*4882a593Smuzhiyun inode = ERR_PTR(err);
634*4882a593Smuzhiyun goto out;
635*4882a593Smuzhiyun }
636*4882a593Smuzhiyun exfat_hash_inode(inode, i_pos);
637*4882a593Smuzhiyun insert_inode_hash(inode);
638*4882a593Smuzhiyun out:
639*4882a593Smuzhiyun return inode;
640*4882a593Smuzhiyun }
641*4882a593Smuzhiyun
exfat_evict_inode(struct inode * inode)642*4882a593Smuzhiyun void exfat_evict_inode(struct inode *inode)
643*4882a593Smuzhiyun {
644*4882a593Smuzhiyun truncate_inode_pages(&inode->i_data, 0);
645*4882a593Smuzhiyun
646*4882a593Smuzhiyun if (!inode->i_nlink) {
647*4882a593Smuzhiyun i_size_write(inode, 0);
648*4882a593Smuzhiyun mutex_lock(&EXFAT_SB(inode->i_sb)->s_lock);
649*4882a593Smuzhiyun __exfat_truncate(inode, 0);
650*4882a593Smuzhiyun mutex_unlock(&EXFAT_SB(inode->i_sb)->s_lock);
651*4882a593Smuzhiyun }
652*4882a593Smuzhiyun
653*4882a593Smuzhiyun invalidate_inode_buffers(inode);
654*4882a593Smuzhiyun clear_inode(inode);
655*4882a593Smuzhiyun exfat_cache_inval_inode(inode);
656*4882a593Smuzhiyun exfat_unhash_inode(inode);
657*4882a593Smuzhiyun }
658