git: fd5d316a9a - main - Handbook WG - Filesystems: Rework filesystems chapter

From: Sergio Carlavilla Delgado <carlavilla_at_FreeBSD.org>
Date: Thu, 16 Jan 2025 18:58:14 UTC
The branch main has been updated by carlavilla:

URL: https://cgit.FreeBSD.org/doc/commit/?id=fd5d316a9ae7912ceff6f27db22b26b4c58e887f

commit fd5d316a9ae7912ceff6f27db22b26b4c58e887f
Author:     Sergio Carlavilla Delgado <carlavilla@FreeBSD.org>
AuthorDate: 2025-01-16 18:56:18 +0000
Commit:     Sergio Carlavilla Delgado <carlavilla@FreeBSD.org>
CommitDate: 2025-01-16 18:56:18 +0000

    Handbook WG - Filesystems: Rework filesystems chapter
    
    PR:                     254191
    Reviewed by:            arrowd@, bcr@, fernape@, jrm@, ziaee@
    Differential Revision:  https://reviews.freebsd.org/D48400
    Sponsored by:           Siracusa
---
 .../content/en/books/handbook/disks/_index.adoc    |  84 +---------
 .../en/books/handbook/filesystems/_index.adoc      | 180 ++++++++++++++++++---
 2 files changed, 157 insertions(+), 107 deletions(-)

diff --git a/documentation/content/en/books/handbook/disks/_index.adoc b/documentation/content/en/books/handbook/disks/_index.adoc
index bc03eedbfb..c66a4ad31f 100644
--- a/documentation/content/en/books/handbook/disks/_index.adoc
+++ b/documentation/content/en/books/handbook/disks/_index.adoc
@@ -4,7 +4,7 @@ part: Part III. System Administration
 prev: books/handbook/audit
 next: books/handbook/geom
 description: This chapter covers the use of disks and storage media in FreeBSD. This includes SCSI and IDE disks, CD and DVD media, memory-backed disks, and USB storage devices.
-tags: ["storage", "disks", "gpart", "mount", "quotas", "encrypt", "GPT", "cdrecord", "NTFS", "quotas", "swap", "HAST", "CD", "DVD", "resizing", "growing"]
+tags: ["storage", "disks", "gpart", "mount", "quotas", "encrypt", "GPT", "cdrecord", "quotas", "swap", "HAST", "CD", "DVD", "resizing", "growing"]
 showBookMenu: true
 weight: 24
 path: "/books/handbook/disks/"
@@ -1140,88 +1140,6 @@ The disk is now ready for use.
 To use the floppy, mount it with man:mount_msdosfs[8].
 One can also install and use package:emulators/mtools[] from the Ports Collection.
 
-[[using-ntfs]]
-== Using NTFS Disks
-
-This section explains how to mount NTFS disks in FreeBSD.
-
-NTFS (New Technology File System) is a proprietary journaling file system developed by Microsoft(R).
-It has been the default file system in Microsoft Windows(R) for many years.
-FreeBSD can mount NTFS volumes using a FUSE file system.
-These file systems are implemented as user space programs which interact with the man:fusefs[5] kernel module via a well defined interface.
-
-[.procedure]
-====
-*Procedure: Steps to Mount a NTFS Disk*
-
-. Before using a FUSE file system we need to load the man:fusefs[5] kernel
-module:
-+
-[source,shell]
-....
-# kldload fusefs
-....
-+
-Use man:sysrc[8] to load the module at startup:
-+
-[source,shell]
-....
-# sysrc kld_list+=fusefs
-....
-
-. Install the actual NTFS file system from packages as in the example (see crossref:ports[pkgng-intro,Using pkg for Binary Package Management]) or from ports (see crossref:ports[ports-using,Using the Ports Collection]):
-+
-[source,shell]
-....
-# pkg install fusefs-ntfs
-....
-
-. Last we need to create a directory where the file system will be mounted:
-+
-[source,shell]
-....
-# mkdir /mnt/usb
-....
-
-. Suppose a USB disk is plugged in.  The disk partition information can be viewed with man:gpart[8]:
-+
-[source,shell]
-....
-# gpart show da0
-=>	  63  1953525105  da0 MBR   (932G)
-	  63  1953525105    1 ntfs  (932G)
-....
-
-. We can mount the disk using the following command:
-+
-[source,shell]
-....
-# ntfs-3g /dev/da0s1 /mnt/usb/
-....
-The disk is now ready to use.
-+
-. Additionally, an entry can be added to /etc/fstab:
-+
-[.programlisting]
-....
-/dev/da0s1  /mnt/usb	ntfs mountprog=/usr/local/bin/ntfs-3g,noauto,rw  0 0
-....
-+
-Now the disk can be now mounted with:
-+
-[source,shell]
-....
-# mount /mnt/usb
-....
-
-. The disk can be unmounted with:
-+
-[source,shell]
-....
-# umount /mnt/usb/
-....
-====
-
 [[backup-basics]]
 == Backup Basics
 
diff --git a/documentation/content/en/books/handbook/filesystems/_index.adoc b/documentation/content/en/books/handbook/filesystems/_index.adoc
index a735a241d8..c0748ddc83 100644
--- a/documentation/content/en/books/handbook/filesystems/_index.adoc
+++ b/documentation/content/en/books/handbook/filesystems/_index.adoc
@@ -4,7 +4,7 @@ part: Part III. System Administration
 prev: books/handbook/zfs
 next: books/handbook/virtualization
 description: This chapter shows the other filesystems supported by FreeBSD
-tags: ["filesystem", "ext2", "ext3", "ext4", "ext2fs"]
+tags: ["filesystem", "ext2", "ext3", "ext4", "ext2fs", "FAT", "exFAT", "NTFS", "HFS", "HFS+", "Apple", "Microsoft", "Linux"]
 showBookMenu: true
 weight: 27
 path: "/books/handbook/filesystems/"
@@ -51,32 +51,28 @@ endif::[]
 [[filesystems-synopsis]]
 == Synopsis
 
-File systems are an integral part of any operating system.
-They allow users to upload and store files, provide access to data, and make hard drives useful.
-Different operating systems differ in their native file system.
-Traditionally, the native FreeBSD file system has been the Unix File System UFS which has been modernized as UFS2.
-Since FreeBSD 7.0, the Z File System (ZFS) is also available as a native file system.
-See crossref:zfs[zfs,The Z File System (ZFS)] for more information.
+File systems are a fundamental component of any operating system.
+They enable users to store, manage, and access data, making storage devices like hard drives, flash drives, and USB storage devices practical for everyday use.
+Different operating systems use different file systems natively.
 
-In addition to its native file systems, FreeBSD supports a multitude of other file systems so that data from other operating systems can be accessed locally, such as data stored on locally attached USB storage devices, flash drives, and hard disks.
-This includes support for the Linux(R) Extended File System (EXT).
+FreeBSD has traditionally used the Unix File System (UFS), with the modernized UFS2 as its primary native file system.
+FreeBSD also uses the Z File System (ZFS), known for its advanced features, robustness, and reliability.
+See crossref:zfs[zfs,The Z File System (ZFS)] for more details.
 
-There are different levels of FreeBSD support for the various file systems.
-Some require a kernel module to be loaded and others may require a toolset to be installed.
-Some non-native file system support is full read-write while others are read-only.
-
-After reading this chapter, you will know:
-
-* The difference between native and supported file systems.
-* Which file systems are supported by FreeBSD.
-* How to enable, configure, access, and make use of non-native file systems.
+In addition to its native file systems, FreeBSD supports a broad range of file systems from other operating systems.
+Support for these file systems varies, some require loading kernel modules, while others need additional userland tools.
 
 Before reading this chapter, you should:
 
-* Understand UNIX(R) and crossref:basics[basics,FreeBSD basics].
-* Be familiar with the basics of crossref:kernelconfig[kernelconfig,kernel configuration and compilation].
+* Be familiar with UNIX(R) concepts and crossref:basics[basics,FreeBSD basics].
 * Feel comfortable crossref:ports[ports,installing software] in FreeBSD.
-* Have some familiarity with crossref:disks[disks,disks], storage, and device names in FreeBSD.
+* Have some understanding of crossref:disks[disks,disks], storage devices, and FreeBSD's naming conventions for devices.
+
+After reading this chapter, you will:
+
+* Understand the differences between native and supported file systems.
+* Know which file systems are supported by FreeBSD and the level of support available.
+* Learn how to enable, configure, access, and work with non-native file systems.
 
 [[filesystems-linux]]
 == Linux(R) File Systems
@@ -84,12 +80,13 @@ Before reading this chapter, you should:
 FreeBSD provides built-in support for several Linux(R) file systems.
 This section demonstrates how to load support for and how to mount the supported Linux(R) file systems.
 
-=== ext2 / ext3 / ext4
+[[ext]]
+=== Extended File System (EXT)
 
-Kernel support for ext2 file systems has been available since FreeBSD 2.2.
+Kernel support for Extended File System (EXT) file systems has been available since FreeBSD 2.2.
 The man:ext2fs[5] driver allows the FreeBSD kernel to both read and write to ext2, ext3, and ext4 file systems.
 
-[NOTE]
+[WARNING]
 ====
 Journalling and encryption are not supported yet.
 ====
@@ -101,3 +98,138 @@ This example mounts [.filename]#/dev/ada1s1# on [.filename]#/mnt#:
 ....
 # mount -t ext2fs /dev/ada1s1 /mnt
 ....
+
+[[filesystems-windows]]
+== Windows(R) File Systems
+
+FreeBSD supports FAT, exFAT, and NTFS file systems, enabling access to Windows-formatted storage.
+
+[[fat]]
+=== FAT File System
+
+The FAT file system is a simple and robust file system.
+Although it lacks the performance, reliability, and scalability of modern alternatives, its availability on many different operating systems makes it a common choice for data exchange between devices.
+
+To access a FAT file system, mount the FAT volume by specifying its FreeBSD partition name and an existing mount point.
+This example mounts [.filename]#/dev/ada0s1# on [.filename]#/mnt#:
+
+[source,shell]
+....
+# mount -t msdosfs /dev/ada0s1 /mnt
+....
+
+[[ex-fat]]
+=== exFAT File System
+
+exFAT (Extended File Allocation Table) is a lightweight file system optimized for flash storage devices, such as USB drives and SD cards.
+It supports large file sizes and is widely used across various platforms, making it ideal for external storage.
+
+To use exFAT on FreeBSD, install the package:filesystems/exfat[] package, load the FUSE kernel module, and mount the file system as shown below:
+
+Install the exFAT package:
+
+[source,shell]
+....
+# pkg install exfat
+....
+
+Before using a FUSE file system, load the man:fusefs[5] kernel module:
+
+[source,shell]
+....
+# kldload fusefs
+....
+
+Use man:sysrc[8] to load the module at startup:
+
+[source,shell]
+....
+# sysrc kld_list+=fusefs
+....
+
+Mount the exFAT volumne by specifying its FreeBSD partition name and an existing mount point.
+This example mounts [.filename]#/dev/ada0s1# on [.filename]#/mnt#:
+
+[source,shell]
+....
+# mount.exfat /dev/ada0s1 /mnt
+....
+
+[[using-ntfs]]
+=== NTFS File System
+
+NTFS is a robust file system developed by Microsoft(R) and commonly used in Windows operating systems.
+FreeBSD provides full read and write support for NTFS through the package:filesystems/ntfs[] package, making it easy to access and modify NTFS-formatted storage devices.
+
+To use NTFS on FreeBSD, install the package:filesystems/ntfs[] package, load the FUSE kernel module, and mount the file system as shown below:
+
+Install the NTFS package:
+
+[source,shell]
+....
+# pkg install ntfs
+....
+
+Before using a FUSE file system, load the man:fusefs[5] kernel module:
+
+[source,shell]
+....
+# kldload fusefs
+....
+
+Use man:sysrc[8] to load the module at startup:
+
+[source,shell]
+....
+# sysrc kld_list+=fusefs
+....
+
+Mount the NTFS volumne by specifying its FreeBSD partition name and an existing mount point.
+This example mounts [.filename]#/dev/ada0s1# on [.filename]#/mnt#:
+
+[source,shell]
+....
+# ntfs-3g /dev/ada0s1 /mnt
+....
+
+[[filesystems-macos]]
+== MacOS(R) File Systems
+
+FreeBSD provides support for MacOS(R) file systems, including HFS/HFS+, allowing access to storage devices formatted for Apple(R) systems.
+
+[[hfs]]
+=== HFS/HFS+ File System
+
+HFS/HFS+ was the primary file system for MacOS prior to APFS, commonly used on older Mac devices and external drives.
+FreeBSD provides read-only support for HFS/HFS+ through the package:filesystems/hfsfuse[] package.
+
+To use HFS/HFS+ on FreeBSD, install the package:filesystems/hfsfuse[] package, load the FUSE kernel module, and mount the file system as shown below:
+
+Install the HFS/HFS+ package:
+
+[source,shell]
+....
+# pkg install fusefs-hfsfuse
+....
+
+Before using a FUSE file system, load the man:fusefs[5] kernel module:
+
+[source,shell]
+....
+# kldload fusefs
+....
+
+Use man:sysrc[8] to load the module at startup:
+
+[source,shell]
+....
+# sysrc kld_list+=fusefs
+....
+
+Mount the HFS/HFS+ volumne by specifying its FreeBSD partition name and an existing mount point.
+This example mounts [.filename]#/dev/ada0s1# on [.filename]#/mnt#:
+
+[source,shell]
+....
+# hfsfuse /dev/ada0s1 /mnt
+....