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
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
|
.\" fatlabel.8 - manpage for fatlabel
.\"
.\" Copyright (C) 2006-2014 Daniel Baumann <daniel@debian.org>
.\" Copyright (C) 2017 Andreas Bombe <aeb@debian.org>
.\" Copyright (C) 2017-2021 Pali Rohár <pali.rohar@gmail.com>
.\"
.\" This program is free software: you can redistribute it and/or modify
.\" it under the terms of the GNU General Public License as published by
.\" the Free Software Foundation, either version 3 of the License, or
.\" (at your option) any later version.
.\"
.\" This program is distributed in the hope that it will be useful,
.\" but WITHOUT ANY WARRANTY; without even the implied warranty of
.\" MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
.\" GNU General Public License for more details.
.\"
.\" You should have received a copy of the GNU General Public License
.\" along with this program. If not, see <http://www.gnu.org/licenses/>.
.\"
.\" The complete text of the GNU General Public License
.\" can be found in /usr/share/common-licenses/GPL-3 file.
.\"
.\"
.TH FATLABEL 8 @RELEASE_DATE@ "dosfstools @PACKAGE_VERSION@"
.SH NAME
fatlabel \- set or get MS-DOS filesystem label or volume ID
.\" ----------------------------------------------------------------------------
.SH SYNOPSIS
\fBfatlabel\fP [\fIOPTIONS\fP] \fIDEVICE\fP [\fINEW\fP]
.\" ----------------------------------------------------------------------------
.SH DESCRIPTION
\fBfatlabel\fP will display or change the volume label or volume ID on the
MS-DOS filesystem located on \fIDEVICE\fP.
By default it works in label mode.
It can be switched to volume ID mode with the option \fB\-i\fP or
\fB\-\-volume\-id\fP.
.PP
If \fINEW\fP is omitted, then the existing label or volume ID is written to the
standard output.
A label can't be longer than 11 bytes and should be in all upper case for best
compatibility.
An empty string or a label consisting only of white space is not allowed.
A volume ID must be given as a hexadecimal number (no leading "0x" or
similar) and must fit into 32 bits.
.\" ----------------------------------------------------------------------------
.SH OPTIONS
.IP "\fB\-i\fP, \fB\-\-volume\-id\fP" 4
Switch to volume ID mode.
.IP "\fB\-r\fP, \fB\-\-reset\fP" 4
Remove label in label mode or generate new ID in volume ID mode.
.IP "\fB-c\fP \fIPAGE\fP, \fB\-\-codepage\fP=\fIPAGE\fP" 4
Use DOS codepage \fIPAGE\fP to encode/decode label.
By default codepage 850 is used.
.IP "\fB\-h\fP, \fB\-\-help\fP" 4
Display a help message and terminate.
.IP "\fB\-V\fP, \fB\-\-version\fP" 4
Show version number and terminate.
.\" ----------------------------------------------------------------------------
.SH COMPATIBILITY and BUGS
For historic reasons FAT label is stored in two different locations: in the boot
sector and as a special volume label entry in the root directory.
MS-DOS 5.00, MS-DOS 6.22, MS-DOS 7.10, Windows 98, Windows XP and also
Windows 10 read FAT label only from the root directory.
Absence of the volume label in the root directory is interpreted as empty or
none label, even if boot sector contains some valid label.
When Windows XP or Windows 10 system changes a FAT label it stores it only in
the root directory \(em letting boot sector unchanged.
Which leads to problems when a label is removed on Windows.
Old label is still stored in the boot sector but is removed from the root
directory.
\fBdosfslabel\fP prior to the version 3.0.7 operated only with FAT labels stored
in the boot sector, completely ignoring a volume label in the root directory.
\fBdosfslabel\fP in versions 3.0.7\(en3.0.15 reads FAT labels from the root
directory and in case of absence, it fallbacks to a label stored in the boot
sector.
Change operation resulted in updating a label in the boot sector and
\fIsometimes\fP also in the root directory due to the bug.
That bug was fixed in \fBdosfslabel\fP version 3.0.16 and since this version
\fBdosfslabel\fP updates label in both location.
Since version 4.2, \fBfatlabel\fP reads a FAT label only from the root directory
(like MS-DOS and Windows systems), but changes a FAT label in both locations.
In version 4.2 was fixed handling of empty labels and labels which starts with a
byte 0xE5.
Also in this version was added support for non-ASCII labels according to the
specified DOS codepage and were added checks if a new label is valid.
It is strongly suggested to not use \fBdosfslabel\fP prior to version 3.0.16.
.\" ----------------------------------------------------------------------------
.SH DOS CODEPAGES
MS-DOS and Windows systems use DOS (OEM) codepage for encoding and decoding FAT
label.
In Windows systems DOS codepage is global for all running applications and
cannot be configured explicitly.
It is set implicitly by option \fILanguage for non-Unicode programs\fP available
in \fIRegional and Language Options\fP via \fIControl Panel\fP.
Default DOS codepage for fatlabel is 850.
See following mapping table between DOS codepage and Language for non-Unicode
programs:
.TS
tab(:);
c lx.
\fBCodepage\fP:\fBLanguage\fP
437:T{
English (India), English (Malaysia), English (Republic of the Philippines),
English (Singapore), English (South Africa), English (United States),
English (Zimbabwe), Filipino, Hausa, Igbo, Inuktitut, Kinyarwanda, Kiswahili,
Yoruba
T}
720:Arabic, Dari, Persian, Urdu, Uyghur
737:Greek
775:Estonian, Latvian, Lithuanian
850:T{
Afrikaans, Alsatian, Basque, Breton, Catalan, Corsican, Danish, Dutch,
English (Australia), English (Belize), English (Canada), English (Caribbean),
English (Ireland), English (Jamaica), English (New Zealand),
English (Trinidad and Tobago), English (United Kingdom), Faroese, Finnish,
French, Frisian, Galician, German, Greenlandic, Icelandic, Indonesian, Irish,
isiXhosa, isiZulu, Italian, K'iche, Lower Sorbian, Luxembourgish, Malay,
Mapudungun, Mohawk, Norwegian, Occitan, Portuguese, Quechua, Romansh, Sami,
Scottish Gaelic, Sesotho sa Leboa, Setswana, Spanish, Swedish, Tamazight,
Upper Sorbian, Welsh, Wolof
T}
852:T{
Albanian, Bosnian (Latin), Croatian, Czech, Hungarian, Polish, Romanian,
Serbian (Latin), Slovak, Slovenian, Turkmen
T}
855:Bosnian (Cyrillic), Serbian (Cyrillic)
857:Azeri (Latin), Turkish, Uzbek (Latin)
862:Hebrew
866:T{
Azeri (Cyrillic), Bashkir, Belarusian, Bulgarian, Kyrgyz, Macedonian, Mongolian,
Russian, Tajik, Tatar, Ukrainian, Uzbek (Cyrillic), Yakut
T}
874:Thai
932:Japanese
936:Chinese (Simplified)
949:Korean
950:Chinese (Traditional)
1258:Vietnamese
.TE
.\" ----------------------------------------------------------------------------
.SH SEE ALSO
.BR fsck.fat (8),
.BR mkfs.fat (8)
.\" ----------------------------------------------------------------------------
.SH HOMEPAGE
The home for the \fBdosfstools\fP project is its
.UR https://github.com/dosfstools/dosfstools
GitHub project page
.UE .
.\" ----------------------------------------------------------------------------
.SH AUTHORS
\fBdosfstools\fP were written by
.MT werner.almesberger@\:lrc.di.epfl.ch
Werner Almesberger
.ME ,
.MT Roman.Hodek@\:informatik.\:uni-erlangen.de
Roman Hodek
.ME ,
and others.
Current maintainers are
.MT aeb@\:debian.org
Andreas Bombe
.ME
and
.MT pali.rohar@\:gmail.com
Pali Rohár
.ME .
|