#include <linux/module.h>
#include <linux/init.h>
#include <linux/fs.h>
#include <linux/fs_context.h>
#include <linux/sched/mm.h>
#include <linux/statfs.h>
#include <linux/kthread.h>
#include <linux/parser.h>
#include <linux/mount.h>
#include <linux/seq_file.h>
#include <linux/proc_fs.h>
#include <linux/random.h>
#include <linux/exportfs.h>
#include <linux/blkdev.h>
#include <linux/quotaops.h>
#include <linux/f2fs_fs.h>
#include <linux/sysfs.h>
#include <linux/quota.h>
#include <linux/unicode.h>
#include <linux/part_stat.h>
#include <linux/zstd.h>
#include <linux/lz4.h>
#include "f2fs.h"
#include "node.h"
#include "segment.h"
#include "xattr.h"
#include "gc.h"
#include "iostat.h"
#define CREATE_TRACE_POINTS
#include <trace/events/f2fs.h>
static struct kmem_cache *f2fs_inode_cachep;
#ifdef CONFIG_F2FS_FAULT_INJECTION
const char *f2fs_fault_name[FAULT_MAX] = …;
int f2fs_build_fault_attr(struct f2fs_sb_info *sbi, unsigned long rate,
unsigned long type)
{ … }
#endif
static struct shrinker *f2fs_shrinker_info;
static int __init f2fs_init_shrinker(void)
{ … }
static void f2fs_exit_shrinker(void)
{ … }
enum { … };
static match_table_t f2fs_tokens = …;
void f2fs_printk(struct f2fs_sb_info *sbi, bool limit_rate,
const char *fmt, ...)
{ … }
#if IS_ENABLED(CONFIG_UNICODE)
static const struct f2fs_sb_encodings { … } f2fs_sb_encoding_map[] = …;
static const struct f2fs_sb_encodings *
f2fs_sb_read_encoding(const struct f2fs_super_block *sb)
{ … }
struct kmem_cache *f2fs_cf_name_slab;
static int __init f2fs_create_casefold_cache(void)
{ … }
static void f2fs_destroy_casefold_cache(void)
{ … }
#else
static int __init f2fs_create_casefold_cache(void) { return 0; }
static void f2fs_destroy_casefold_cache(void) { }
#endif
static inline void limit_reserve_root(struct f2fs_sb_info *sbi)
{ … }
static inline void adjust_unusable_cap_perc(struct f2fs_sb_info *sbi)
{ … }
static void init_once(void *foo)
{ … }
#ifdef CONFIG_QUOTA
static const char * const quotatypes[] = INITQFNAMES;
#define QTYPE2NAME(t) …
static int f2fs_set_qf_name(struct super_block *sb, int qtype,
substring_t *args)
{ … }
static int f2fs_clear_qf_name(struct super_block *sb, int qtype)
{ … }
static int f2fs_check_quota_options(struct f2fs_sb_info *sbi)
{ … }
#endif
static int f2fs_set_test_dummy_encryption(struct super_block *sb,
const char *opt,
const substring_t *arg,
bool is_remount)
{ … }
#ifdef CONFIG_F2FS_FS_COMPRESSION
static bool is_compress_extension_exist(struct f2fs_sb_info *sbi,
const char *new_ext, bool is_ext)
{ … }
static int f2fs_test_compress_extension(struct f2fs_sb_info *sbi)
{ … }
#ifdef CONFIG_F2FS_FS_LZ4
static int f2fs_set_lz4hc_level(struct f2fs_sb_info *sbi, const char *str)
{ … }
#endif
#ifdef CONFIG_F2FS_FS_ZSTD
static int f2fs_set_zstd_level(struct f2fs_sb_info *sbi, const char *str)
{ … }
#endif
#endif
static int parse_options(struct super_block *sb, char *options, bool is_remount)
{ … }
static struct inode *f2fs_alloc_inode(struct super_block *sb)
{ … }
static int f2fs_drop_inode(struct inode *inode)
{ … }
int f2fs_inode_dirtied(struct inode *inode, bool sync)
{ … }
void f2fs_inode_synced(struct inode *inode)
{ … }
static void f2fs_dirty_inode(struct inode *inode, int flags)
{ … }
static void f2fs_free_inode(struct inode *inode)
{ … }
static void destroy_percpu_info(struct f2fs_sb_info *sbi)
{ … }
static void destroy_device_list(struct f2fs_sb_info *sbi)
{ … }
static void f2fs_put_super(struct super_block *sb)
{ … }
int f2fs_sync_fs(struct super_block *sb, int sync)
{ … }
static int f2fs_freeze(struct super_block *sb)
{ … }
static int f2fs_unfreeze(struct super_block *sb)
{ … }
#ifdef CONFIG_QUOTA
static int f2fs_statfs_project(struct super_block *sb,
kprojid_t projid, struct kstatfs *buf)
{ … }
#endif
static int f2fs_statfs(struct dentry *dentry, struct kstatfs *buf)
{ … }
static inline void f2fs_show_quota_options(struct seq_file *seq,
struct super_block *sb)
{ … }
#ifdef CONFIG_F2FS_FS_COMPRESSION
static inline void f2fs_show_compress_options(struct seq_file *seq,
struct super_block *sb)
{ … }
#endif
static int f2fs_show_options(struct seq_file *seq, struct dentry *root)
{ … }
static void default_options(struct f2fs_sb_info *sbi, bool remount)
{ … }
#ifdef CONFIG_QUOTA
static int f2fs_enable_quotas(struct super_block *sb);
#endif
static int f2fs_disable_checkpoint(struct f2fs_sb_info *sbi)
{ … }
static void f2fs_enable_checkpoint(struct f2fs_sb_info *sbi)
{ … }
static int f2fs_remount(struct super_block *sb, int *flags, char *data)
{ … }
static void f2fs_shutdown(struct super_block *sb)
{ … }
#ifdef CONFIG_QUOTA
static bool f2fs_need_recovery(struct f2fs_sb_info *sbi)
{ … }
static bool f2fs_recover_quota_begin(struct f2fs_sb_info *sbi)
{ … }
static void f2fs_recover_quota_end(struct f2fs_sb_info *sbi,
bool quota_enabled)
{ … }
static ssize_t f2fs_quota_read(struct super_block *sb, int type, char *data,
size_t len, loff_t off)
{ … }
static ssize_t f2fs_quota_write(struct super_block *sb, int type,
const char *data, size_t len, loff_t off)
{ … }
int f2fs_dquot_initialize(struct inode *inode)
{ … }
static struct dquot __rcu **f2fs_get_dquots(struct inode *inode)
{ … }
static qsize_t *f2fs_get_reserved_space(struct inode *inode)
{ … }
static int f2fs_quota_on_mount(struct f2fs_sb_info *sbi, int type)
{ … }
int f2fs_enable_quota_files(struct f2fs_sb_info *sbi, bool rdonly)
{ … }
static int f2fs_quota_enable(struct super_block *sb, int type, int format_id,
unsigned int flags)
{ … }
static int f2fs_enable_quotas(struct super_block *sb)
{ … }
static int f2fs_quota_sync_file(struct f2fs_sb_info *sbi, int type)
{ … }
int f2fs_quota_sync(struct super_block *sb, int type)
{ … }
static int f2fs_quota_on(struct super_block *sb, int type, int format_id,
const struct path *path)
{ … }
static int __f2fs_quota_off(struct super_block *sb, int type)
{ … }
static int f2fs_quota_off(struct super_block *sb, int type)
{ … }
void f2fs_quota_off_umount(struct super_block *sb)
{ … }
static void f2fs_truncate_quota_inode_pages(struct super_block *sb)
{ … }
static int f2fs_dquot_commit(struct dquot *dquot)
{ … }
static int f2fs_dquot_acquire(struct dquot *dquot)
{ … }
static int f2fs_dquot_release(struct dquot *dquot)
{ … }
static int f2fs_dquot_mark_dquot_dirty(struct dquot *dquot)
{ … }
static int f2fs_dquot_commit_info(struct super_block *sb, int type)
{ … }
static int f2fs_get_projid(struct inode *inode, kprojid_t *projid)
{ … }
static const struct dquot_operations f2fs_quota_operations = …;
static const struct quotactl_ops f2fs_quotactl_ops = …;
#else
int f2fs_dquot_initialize(struct inode *inode)
{
return 0;
}
int f2fs_quota_sync(struct super_block *sb, int type)
{
return 0;
}
void f2fs_quota_off_umount(struct super_block *sb)
{
}
#endif
static const struct super_operations f2fs_sops = …;
#ifdef CONFIG_FS_ENCRYPTION
static int f2fs_get_context(struct inode *inode, void *ctx, size_t len)
{ … }
static int f2fs_set_context(struct inode *inode, const void *ctx, size_t len,
void *fs_data)
{ … }
static const union fscrypt_policy *f2fs_get_dummy_policy(struct super_block *sb)
{ … }
static bool f2fs_has_stable_inodes(struct super_block *sb)
{ … }
static struct block_device **f2fs_get_devices(struct super_block *sb,
unsigned int *num_devs)
{ … }
static const struct fscrypt_operations f2fs_cryptops = …;
#endif
static struct inode *f2fs_nfs_get_inode(struct super_block *sb,
u64 ino, u32 generation)
{ … }
static struct dentry *f2fs_fh_to_dentry(struct super_block *sb, struct fid *fid,
int fh_len, int fh_type)
{ … }
static struct dentry *f2fs_fh_to_parent(struct super_block *sb, struct fid *fid,
int fh_len, int fh_type)
{ … }
static const struct export_operations f2fs_export_ops = …;
loff_t max_file_blocks(struct inode *inode)
{ … }
static int __f2fs_commit_super(struct f2fs_sb_info *sbi, struct folio *folio,
pgoff_t index, bool update)
{ … }
static inline bool sanity_check_area_boundary(struct f2fs_sb_info *sbi,
struct folio *folio, pgoff_t index)
{ … }
static int sanity_check_raw_super(struct f2fs_sb_info *sbi,
struct folio *folio, pgoff_t index)
{ … }
int f2fs_sanity_check_ckpt(struct f2fs_sb_info *sbi)
{ … }
static void init_sb_info(struct f2fs_sb_info *sbi)
{ … }
static int init_percpu_info(struct f2fs_sb_info *sbi)
{ … }
#ifdef CONFIG_BLK_DEV_ZONED
struct f2fs_report_zones_args { … };
static int f2fs_report_zone_cb(struct blk_zone *zone, unsigned int idx,
void *data)
{ … }
static int init_blkz_info(struct f2fs_sb_info *sbi, int devi)
{ … }
#endif
static int read_raw_super_block(struct f2fs_sb_info *sbi,
struct f2fs_super_block **raw_super,
int *valid_super_block, int *recovery)
{ … }
int f2fs_commit_super(struct f2fs_sb_info *sbi, bool recover)
{ … }
static void save_stop_reason(struct f2fs_sb_info *sbi, unsigned char reason)
{ … }
static void f2fs_record_stop_reason(struct f2fs_sb_info *sbi)
{ … }
void f2fs_save_errors(struct f2fs_sb_info *sbi, unsigned char flag)
{ … }
static bool f2fs_update_errors(struct f2fs_sb_info *sbi)
{ … }
static void f2fs_record_errors(struct f2fs_sb_info *sbi, unsigned char error)
{ … }
void f2fs_handle_error(struct f2fs_sb_info *sbi, unsigned char error)
{ … }
void f2fs_handle_error_async(struct f2fs_sb_info *sbi, unsigned char error)
{ … }
static bool system_going_down(void)
{ … }
void f2fs_handle_critical_error(struct f2fs_sb_info *sbi, unsigned char reason,
bool irq_context)
{ … }
static void f2fs_record_error_work(struct work_struct *work)
{ … }
static int f2fs_scan_devices(struct f2fs_sb_info *sbi)
{ … }
static int f2fs_setup_casefold(struct f2fs_sb_info *sbi)
{ … }
static void f2fs_tuning_parameters(struct f2fs_sb_info *sbi)
{ … }
static int f2fs_fill_super(struct super_block *sb, void *data, int silent)
{ … }
static struct dentry *f2fs_mount(struct file_system_type *fs_type, int flags,
const char *dev_name, void *data)
{ … }
static void kill_f2fs_super(struct super_block *sb)
{ … }
static struct file_system_type f2fs_fs_type = …;
MODULE_ALIAS_FS(…) …;
static int __init init_inodecache(void)
{ … }
static void destroy_inodecache(void)
{ … }
static int __init init_f2fs_fs(void)
{ … }
static void __exit exit_f2fs_fs(void)
{ … }
module_init(…) …
module_exit(…)
MODULE_AUTHOR(…) …;
MODULE_DESCRIPTION(…) …;
MODULE_LICENSE(…) …;
MODULE_SOFTDEP(…) …;