Re: [RFC PATCH 08/20] famfs: Add famfs_internal.h

From: Christian Brauner
Date: Tue Feb 27 2024 - 08:43:56 EST


On Fri, Feb 23, 2024 at 11:41:52AM -0600, John Groves wrote:
> Add the famfs_internal.h include file. This contains internal data
> structures such as the per-file metadata structure (famfs_file_meta)
> and extent formats.
>
> Signed-off-by: John Groves <john@xxxxxxxxxx>
> ---
> fs/famfs/famfs_internal.h | 53 +++++++++++++++++++++++++++++++++++++++

Already mentioned in another reply here but adding a bunch of types such
as famfs_file_operations that aren't even defines is pretty odd. So you
should reorder this.

> 1 file changed, 53 insertions(+)
> create mode 100644 fs/famfs/famfs_internal.h
>
> diff --git a/fs/famfs/famfs_internal.h b/fs/famfs/famfs_internal.h
> new file mode 100644
> index 000000000000..af3990d43305
> --- /dev/null
> +++ b/fs/famfs/famfs_internal.h
> @@ -0,0 +1,53 @@
> +/* SPDX-License-Identifier: GPL-2.0 */
> +/*
> + * famfs - dax file system for shared fabric-attached memory
> + *
> + * Copyright 2023-2024 Micron Technology, Inc.
> + *
> + * This file system, originally based on ramfs the dax support from xfs,
> + * is intended to allow multiple host systems to mount a common file system
> + * view of dax files that map to shared memory.
> + */
> +#ifndef FAMFS_INTERNAL_H
> +#define FAMFS_INTERNAL_H
> +
> +#include <linux/atomic.h>
> +#include <linux/famfs_ioctl.h>
> +
> +#define FAMFS_MAGIC 0x87b282ff

That needs to go into include/uapi/linux/magic.h.

> +
> +#define FAMFS_BLKDEV_MODE (FMODE_READ|FMODE_WRITE)
> +
> +extern const struct file_operations famfs_file_operations;
> +
> +/*
> + * Each famfs dax file has this hanging from its inode->i_private.
> + */
> +struct famfs_file_meta {
> + int error;
> + enum famfs_file_type file_type;
> + size_t file_size;
> + enum extent_type tfs_extent_type;
> + size_t tfs_extent_ct;
> + struct famfs_extent tfs_extents[]; /* flexible array */
> +};
> +
> +struct famfs_mount_opts {
> + umode_t mode;
> +};
> +
> +extern const struct iomap_ops famfs_iomap_ops;
> +extern const struct vm_operations_struct famfs_file_vm_ops;
> +
> +#define ROOTDEV_STRLEN 80
> +
> +struct famfs_fs_info {
> + struct famfs_mount_opts mount_opts;
> + struct file *dax_filp;
> + struct dax_device *dax_devp;
> + struct bdev_handle *bdev_handle;
> + struct list_head fsi_list;
> + char *rootdev;
> +};
> +
> +#endif /* FAMFS_INTERNAL_H */
> --
> 2.43.0
>