blob: 1f1258276986d0400ddfb8f0263d2938eff1d061 [file] [log] [blame]
srs5694e7b4ff92009-08-18 13:16:10 -04001GPT fdisk (aka gdisk)
2by Roderick W. Smith, rodsmith@rodsbooks.com
3
4Introduction
5------------
6
7This software is intended as a (somewhat) fdisk-workalike program for
8GPT-partitioned disks. Although libparted and programs that use it (GNU
9Parted, gparted, etc.) provide the ability to handle GPT disks, they have
10certain limitations that gdisk overcomes. Specific advantages of gdisk
11include:
12
13* The ability to convert MBR-partitioned disks in-place to GPT format,
14 without losing data
15
16* The ability to specify sector-exact partition sizes
17
18* More flexible specification of filesystem type code GUIDs, which
19 GNU Parted tends to corrupt (particularly for FAT partitions)
20
21* Clear identification of the number of unallocated sectors on a
22 disk
23
24* A user interface that's familiar to long-time users of Linux
25 fdisk
26
27* The MBR boot loader code is left alone (GNU Parted tends to
28 wipe it out with every change)
29
30Of course, gdisk isn't without its limitations. Most notably, it lacks the
31filesystem awareness and filesystem-related features of GNU Parted. You
32can't resize a partition's filesystem or create a partition with a
33filesystem already in place with gdisk, for instance. There's no GUI
34version of gdisk.
35
36Installing
37----------
38
39To compile gdisk, you must have appropriate development tools installed,
40most notably the GNU Compiler Collection (GCC) and its g++ compiler for
41C++. uncompress the package and type "make" at the command prompt in the
42resulting directory. The result should be a program file called gdisk. You
43can use this in place or copy the file to a suitable directory, such as
44/usr/local/sbin. You can copy the man page (gdisk.8) to /usr/local/man/man8
45to make it available.
46
47Caveats
48-------
49
50THIS SOFTWARE IS EARLY BETA SOFTWARE! IF IT WIPES OUT YOUR HARD DISK OR
51EATS YOUR CAT, DON'T BLAME ME! To date, I've tested the software mainly on
52two USB flash drives, 2 GiB and 8 GiB in size. I've also made a few minor
53tweaks to a production system with a 500 GiB hard disk and made more
54extensive changes to a handful of 80-160 GiB hard disks. I believe all
55data-corruption bugs to be squashed, but I know full well that the odds of
56my missing something are high. This is particularly true for large drives;
57I have no way of testing the software with > 2TiB drives, which will test
58the 64-bit sector pointer support.
59
60The MBR-to-GPT feature seems to work well for data drives, but it's largely
61untested on boot drives. One attempt with Windows failed miserably, but I
62believe that was because of Windows' inherent limitations with respect to
63GPT. (The partitions themselves were intact.)
64
65My main development platform is a system running the 64-bit version of
66Ubuntu. I've also tested on 64-bit OpenSuSE and 32-bit Fedora 10. Problems
67relating to 64-bit integers on the 32-bit Linux have been common during
68development and may crop up in the future. The Mac OS X support is new,
69and has at least one bug/limitation: It seems to be impossible to write
70a new partition table if any partitions from the disk are currently
71mounted.
72
73Redistribution
74--------------
75
76This program is licensed under terms of the GNU GPL (see the file COPYING).
77
78Acknowledgements
79----------------
80
81This code is mostly my own; however, I've used three functions from two
82other GPLed programs:
83
84- The code used to generate CRCs is taken from the efone program by
85 Krzysztof Dabrowski and ElysiuM deeZine. (See the crc32.h and
86 crc32.cc source code files.)
87
88- A function to find the disk size is taken from Linux fdisk by
89 A. V. Le Blanc.
90
91Additional code contributors include:
92
93- Yves Blusseau (1otnwmz02@sneakemail.com)
94
95- One anonymous contributor