1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143
|
Ntfs2btrfs
==========
Ntfs2btrfs is a tool which does in-place conversion of Microsoft's NTFS
filesystem to the open-source filesystem Btrfs, much as `btrfs-convert`
does for ext2. The original image is saved as a reflink copy at
`image/ntfs.img`, and if you want to keep the conversion you can delete
this to free up space.
Although I believe this tool to be stable, please note that I take no
responsibility if something goes awry!
You're probably also interested in [WinBtrfs](https://github.com/maharmstone/btrfs),
which is a Btrfs filesystem driver for Windows.
Thanks to [Eric Biggers](https://github.com/ebiggers), who [successfully reverse-engineered](https://github.com/ebiggers/ntfs-3g-system-compression/) Windows 10's
"WOF compressed data", and whose code I've used here.
Usage
-----
On Windows, from an Administrator command prompt:
`ntfs2btrfs.exe D:\`
Bear in mind that it won't work with your boot drive or a drive containing a
pagefile that's currently in use.
On Linux, as root:
`ntfs2btrfs /dev/sda1`
Installation
------------
On Windows, go to the [Releases page](https://github.com/maharmstone/ntfs2btrfs/releases) and
download the latest Zip file, or use [Scoop](https://github.com/ScoopInstaller/Main/blob/master/bucket/ntfs2btrfs.json).
For Linux:
* [Arch](https://aur.archlinux.org/packages/ntfs2btrfs)
* [Fedora](https://src.fedoraproject.org/rpms/ntfs2btrfs) (thanks to [Conan-Kudo](https://github.com/Conan-Kudo))
* Gentoo - available as sys-fs/ntfs2btrfs in the guru repository
* [Debian](https://packages.debian.org/ntfs2btrfs) (thanks to [alexmyczko](https://github.com/alexmyczko))
* [Ubuntu](https://packages.ubuntu.com/ntfs2btrfs) (thanks to [alexmyczko](https://github.com/alexmyczko))
* [openSUSE](https://build.opensuse.org/package/show/filesystems/ntfs2btrfs) (thanks to David Sterba)
For other distributions or operating systems, you will need to compile it yourself - see
below.
Changelog
---------
* 20240115
* Fixed compilation on GCC 14 (`-Werror=incompatible-pointer-types` now enabled by default)
* 20230501
* Fixed inline extent items being written out of order (not diagnosed by `btrfs check`)
* Fixed metadata items being written with wrong level value (not diagnosed by `btrfs check`)
* ADSes with overly-long names now get skipped
* 20220812
* Added --no-datasum option, to skip calculating checksums
* LXSS / WSL metadata is now preserved
* Fixed lowercase drive letters not being recognized
* Fixed crash due to iterator invalidation (thanks to nyanpasu64)
* Fixed corruption when NTFS places file in last megabyte of disk
* 20210923
* Added (Btrfs) compression support (zlib, lzo, and zstd)
* Added support for other hash algorithms: xxhash, sha256, and blake2
* Added support for rolling back to NTFS
* Added support for NT4-style security descriptors
* Increased conversion speed for volume with many inodes
* Fixed bug when fragmented file was in superblock location
* Fixed buffer overflow when reading security descriptors
* Fixed bug where filesystems would be corrupted in a way that `btrfs check` doesn't pick up
* 20210523
* Improved handling of large compressed files
* 20210402 (source code only release)
* Fixes for compilation on non-amd64 architectures
* 20210105
* Added support for NTFS compression
* Added support for "WOF compressed data"
* Fixed problems caused by sparse files
* Miscellaneous bug fixes
* 20201108
* Improved error handling
* Added better message if NTFS is corrupted or unclean
* Better handling of relocations
* 20200330
* Initial release
Compilation
-----------
On Windows, open the source directory in a recent version of MSVC, right-click
on CMakeLists.txt, and click Compile.
On Linux:
mkdir build
cd build
cmake ..
make
You'll also need [libfmt](https://github.com/fmtlib/fmt) installed - it should be
in your package manager.
Compression support requires zlib, lzo, and/or zstd - again, they will be in your
package manager. See also the cmake options WITH_ZLIB, WITH_LZO, and WITH_ZSTD,
if you want to disable this.
What works
----------
* Files
* Directories
* Symlinks
* Other reparse points
* Security descriptors
* Alternate data streams
* DOS attributes (hidden, system, etc.)
* Rollback to original NTFS image
* Preservation of LXSS metadata
What doesn't work
-----------------
* Windows' old extended attributes (you're not using these)
* Large (i.e >16KB) ADSes (you're not using these either)
* Preservation of the case-sensitivity flag
* Unusual cluster sizes (i.e. not 4 KB)
* Encrypted files
Can I boot Windows from Btrfs with this?
----------------------------------------
Yes, if the stars are right. See [Quibble](https://github.com/maharmstone/quibble).
|