File: Large-Disk-HOWTO.pl.html

package info (click to toggle)
doc-linux-pl 2002.06.14-2
  • links: PTS
  • area: main
  • in suites: etch, etch-m68k, jessie, jessie-kfreebsd, lenny, squeeze, wheezy
  • size: 6,900 kB
  • ctags: 968
  • sloc: makefile: 66
file content (429 lines) | stat: -rw-r--r-- 22,769 bytes parent folder | download | duplicates (3)
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
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
<HTML>
<HEAD>
 <META NAME="GENERATOR" CONTENT="SGML-Tools 1.0.9">
<META HTTP-EQUIV="content-type" content="text/html; charset=iso-8859-2">
<TITLE>Due dyski </TITLE>


</HEAD>
<BODY>
<H1>Due dyski </H1>

<H2>Andries Brouwer, 
<A HREF="mailto:aeb@cwi.nl">aeb@cwi.nl</A><BR>
 v1.0, 960626<BR>
<B>wersja polska 
<A HREF="mailto:piotr.pogorzelski@ippt.gov.pl">piotr.pogorzelski@ippt.gov.pl</A><BR>
 wersja 1.0, 5 marca 1997 </B></H2>
<P><HR>
<EM>Wszystko na temat geometrii dyskw i granicy 1024 cylindrw.</EM>
<HR>
<H2><A NAME="s1">1. Postawienie problemu</A></H2>

<P>Zamy, e posiadasz dysk z wicej ni 1024 cylindrami. Co wicej
zamy, e posiadasz system ktry korzysta z BIOSu. Wtedy masz
problem. Masz problem poniewa zwyky interfejs We/Wy twojego dysku realizowany
przez przerwanie BIOSu INT13, ktre do przekazywania numeru cylindra, na
ktrym ma zosta wykonana operacja We/Wy korzysta z 10-cio bitowego
pola, przez co cylindry o numerze 1024 i wiekszym s niedostpne.
<P>Na szczcie Linux nie korzysta z BIOSu, wic nie ma tego problemu.
<P>No prawie, poza dwoma przypadkami:
<P>(1) Kiedy uruchamiasz swj system, Linux jeszcze nie dziaa i nie
potrafi uchroni ci przed kopotami z BIOSem. Ma to wpyw na prac LILO i
innych adowaczy systemw (boot loaders).
<P>(2) Wszystkie systemy operacyjne korzystajce z tego samego dysku
musz zgadza si co do pooenia poszczeglnych partycji. Innymi
sowy, jeli korzystasz na jednym dysku z Linuxa i powiedzmy DOSu,
wtedy oba musz interpretowa tabel partycji w ten sam sposb. Ma to
wpyw na sposb zachownia jdra i programu fdisk.
<P>Poniej znajdziesz sczegowy opis wszelkich istotnych szczegw.
Zauwa, e wszelkie informacje odnosz si do jdra w wersji
2.0.8. Inne wersje jdra mog zachowywa si troszk inaczej.
<P>
<P>
<H2><A NAME="s2">2. adowanie systemu (Booting)</A></H2>

<P>Podczas adowania systemu, BIOS odczytuje z pierwszego dysku twardego
(lub z dyskietki) sektor 0 (znany jako gwny sektor startowy (Master
Boto Record, MBR)) i wykonuje skok do znalezionego tam kodu - zwykle
do programu adowania pocztkowego. Te mae programy adujce
(adowacze) jakie si tam znajduj, nie posiadaj wlasnych drajwerw
dyskowych i korzystaj z funkcji BIOSu. To znaczy, e jdro Linuxa
moe zosta zaadowane, tylko wtedy gdy w caoci znajduje si poniej
1024 cylindra.
<P>Ten problem mona bardzo atwo rozwiza. Upewnij si, e jdro (i by
moe inne pliki wykorzystywane do startu systemu, np. pliki odzworowa
programu LILO) znajduj si na partycji, ktra w caoci zawiera si w
obszrze ponizej 1024 cylindra dysku, do ktrego BIOS ma dostp - zwykle
pierwszy lub drugi dysk twojego komputera.
<P>Poza tym adowacz i BIOS musz si zgadza w sprawie geometrii
dysku. Tutaj moe okaza si pomocne skorzystanie w konfiguracji LILO
z opcji <EM>linear</EM>. Wicej szczegw pniej.
<P>
<P>
<H2><A NAME="s3">3. Geometria dysku i partycje</A></H2>

<P>Jeli posiadasz na jednym dysku kilka systemw operacyjnych, wtedy
kady z nich uywa jednej lub wicej partycji. Niezgodno w ocenie,
gdzie te partycje si dokadnie znajduj moe mie katastrofalne
konsekwencje. 
<P>Rekord MBR zawiera <I>tabel partycji</I> okrelajc, gdzie znajduj si
partycje (podstawowe). Tabela zawiera 4 pozycje (dla 4 partycji) i
wyglda mniej wicej tak:
<BLOCKQUOTE><CODE>
<PRE>
struct partition {
        char active;    /* 0x80: startowa, 0: nie strtowa */
        char begin[3];  /* CHS pierwszego sektora partycji */
        char type;
        char end[3];    /* CHS ostatniego sektora partycji */
        int start;      /* 32 bitowy numer sektora (liczc od 0) */
        int length;     /* 32 bitowa liczba sektorw */
};
</PRE>
</CODE></BLOCKQUOTE>

(gdzie CHS oznacza numer cylindra/gowicy/sektora).
<P>Jak wida informacja jest nadmiarowa: lokalizacja partycji jest podana
zarwno w 24-ro bitowych polach <CODE>begin</CODE> i <CODE>end</CODE>, oraz w 32-dwu
bitowych polach <CODE>start</CODE> i <CODE>length</CODE>. 
<P>Linux korzysta jedynie z pl <CODE>start</CODE> i <CODE>length</CODE>, dlatego potrafi
obsuy partycje o liczbie sektorw nie przekraczajcej 2^32 
tzn. partycje o rozmiarze nie wikszym ni 2 TB. Czyli dwiecie razy
wiksz od dyskw obecnie dostpnych na rynku. Moemy mie nadzieje,
e bdzie to wystarczajce na najblisze 10 lat, a moe wicej.
<P>Niestety, funkcja BIOSu INT13 korzysta z inforamacij CHS zakodowanych
w polach 3bajtowych, przy czym na numer cylindra przeznaczonych jest
10 bitw, 8 bitw na numer gowicy i 6 bitw na numer sektora na
ciece. Dozwolone numery cylindrw to 0-1023, gowic 0-255 i
dozwolona liczba sektorw na ciece wynosi 1-63 (tak, sektory na
ciece s liczone od 1, a nie od 0). Na tych 24 bitach mona
zaadresowa nie wicej ni 8455716864 bajtw (7.875 GB), dwiecie razy
wicej ni rozmiar dyskw dostpnych w roku 1983.
<P>Kolejne, waniejsze (groniejsze) ograniczenie polega na tym, e  standard
interfejsu IDE pozwala jedynie na: 256 sektorw na ciece, 65536 cylindrw i 16
gowic. Sam w sobie pozwala na dostp do 2^37 = 137438953472 bajtw
(128 GB), lecz w poczeniu z ograniczeniami naoonymi przez BIOS,
faktycznie umoliwia na dostp tylko do  528482304 bajtw (504 MB).
<P>Nie jest to wystarczajce dla dostpnych obecnie dyskw i ludzie s
zmuszeni do stosowania rnego rodzaju sztuczek, zarwno sprztowych,
jak i programowych.
<P>
<P>
<H2><A NAME="s4">4. Translacja i Disk Managery</A></H2>

<P>Nikogo nie interesuje jaka jest `rzeczywista' geometria dysku.
Tak na prawd, liczba sektorw na ciece czsto jest zmienna - wicej
na ciekach zewntrznych i mniej na ciekach wewntrznych - 
nie ma tak na prawd `rzeczywstej' liczby sektorw na ciece. Dla
uytkownika najwygodniej jest traktowa dysk jako liniow tablic
sektorw, ponumerowanych 0,1 ... i pozostawi sterownikowi zadanie
odnalezienia pooenia danego sektora na dysku.
<P>To numerownie liniwe znane jest pod skrtem LBA. Adres liniowy
naleacy do sektora (c,h,s) dla dysku o geometrii (C,H,S) jest rwny
c*H*S+h*S+(s-1). Wszystkie sterowniki SCSI porozumiewaj si wedug
standardu LBA, niektre sterowniki IDE rwnie.
<P>BIOS zamienia 24-bitowe pole (c,h,s) na adres LBA i przekazuje to
sterownikowi, ktry rozumie co to jest LBA. Dziki temu ponownie mamy
dostp do 7.785 GB. Nie jest to wystarczajce dla wszystkich dyskw,
lecz jest to lepsze ni to co byo. Zauwa, e CHS wykorzystywane
przez BIOS nie ma adnego zwizku z rzeczywistoci.
<P>Co poddobnego dzieje si w sytuacji, gdy sterownik nie rozumie
adresw LBA, lecz BIOS wie o translacji (w Setupie BIOSu jest to
zwykle oznaczane jako `Large'). Teraz BIOS prezentuje systemowi
operacyjnemu geometri (C',H',S') i uywa geometrii (C,H,S) do
komunikacji ze sterownikiem. Zwykle S=S' C'=C/N i H'=H*N, gdzie N jest
najmniejsz potg 2, zapewniajc spenienie warunku ' &lt;= 1024
(w celu zminimalizowania marnujcej si przestrzeni przez zaokrglenie w
d C'=C/N). Ta metoda rwnie pozwala uzyska dostp do 7.875 GB.
<P>Jeli BIOS nic nie wie na tema `Large' lub LBA, wtedy pozostaj
rozwizania oparte na odpowiednich drajwerach. Takie programy, jak
OnTrack lub Ez-Drive zamieniaj programy obsugi dysku nalece do
BIOSu na wasne. Czsto jest to realizowane, przez umieszenie kodu
naleacego do Disk Managera w rekordzie MBR i kolejnych sektorach
dysku (OnTrack nazywa to DDO: Dynamic Drive Overlay) aby by on
uruchamiany przed zaadowniem jakiegokolwiek systemu
operacyjnego. To wyjania kopoty zwizane ze startowniem systemu z
dyskietki, dla dyskw z zainstalowanym programem Disk Manager.
<P>Efekt caego tego zamieszania jest mniej wicej taki sam, jak w
przypadku translacji przez BIOS - lecz w sytuacjach, gdy
na jednym dysku znajduje si wiele systemw operacyjnych programy typu
Disk Manager mog sprawia wiele kopotw.
<P>Linux od wersji 1.3.14 rozpoznaje istnienie programu Boot Manager
firmy OnTrack i od wersji 1.3.29 firmy EZ-Drive. Wicej szczegw
znajdziesz dalej.
<P>
<P>
<H2><A NAME="s5">5. Translacja wykonywana przez jdro dla dyskw IDE</A></H2>

<P>Jeli jdro Linuxa rozpozna istnienie na dysku IDE programu typu disk
manager, sprbuje przeprowadzi identyczn translacj jak robi ten
wanie program, tak aby widzie te same partycje co np. MS-DOS z
programe OnTrack lub EZ-Drive. Jeli jednak w parametrach startowych
zostanie przekazana geometria dysku, nie jest wykonywana adna
translacja. Tak wic opcja startowa
`<CODE>hd=</CODE><I>cyls</I><CODE>,</CODE><I>heads</I><CODE>,</CODE><I>secs</I>' moe zniszczy
zgodno z programem typu disk manager.
<P>Translacja wykonywana przez jdro polega na wyprbowaniu kolejno
liczby gowic rwnej 4, 8 ,16, 32, 128, 255 (utrzymujc sta warto
H*C) a do spenienia warunku C &lt;= 1024 lub H = 255.
<P>Troch uwag na temat tekstu poniej - nagwki podrozdziaw s identyczne z
pojawiajcymu si w komunikatach startowych. Tutaj i w caym tekscie
typy partycji podane s szesnastkowo.
<P>
<H2>5.1 EZD</H2>

<P> 
Rozpoznano drajwer EZ-Drive poniwa pierwsza partycja
podstawowa jest typu 55. Geometria dysku podlega opisanej powyej
translacji i tabela partycji z sektora 0 zostaje pominita - zmiast
tego korzystamy z tabeli partycji znajdujcej si w sektorze 1. Numery
blokw dyskowych pozostaj niezmienione, lecz zapis sektora 0 zostaje
przekierowany do sektora 1. To zachownie moe zosta zmienione przez
ponowne skompilowanie jdra przy zdefiniowaniu w pliku <I>ide.c</I> <CODE>#define FAKE_FDISK_FOR_EZDRIVE 0 </CODE>.
<P>
<H2>5.2 DM6:DDO</H2>

<P>Rozpoznano drajwer OnTrack Manager (na pierwszym dysku) poniewa
pierwsza partycja podstawowa jest typu 54. Geometria dysku podlega
opisanej powyej translacji i cay dysk zostaje przesunity o 63
sektory (tak wic stary sektor 63 staje si sektorem 0). Nastpnie nowy
rekord MBR (z tabel partycji) zostaje odczytany z nowego sektora
0. To przesunicie oczywicie ma na celu zrobienie miejsca dla DDO -
dlatego nie jest wykonywane dla innych dyskw.
<P>
<H2>5.3 DM6:AUX</H2>

<P>Rozpoznano drajwer OnTrack Manager (na innych dyskach)  poniewa
pierwsza partycja podstawowa jest typu 51 lub 53. Geometria dysku
podlega opisanej powyej translacji.
<P>
<H2>5.4 DM6:MBR</H2>

<P> 
Rozpoznano starsz wersj drajwera OnTrack Manager
poniwa znaleziono podpis drajwera (sprawdzono, e przesunicie
znalezione w 2-gim i 3-cim bajcie rekordu MBR nie jest wiksze od 430,
i zmienna typu short znaleziona pod tym adresem jest rwna 0x55AA, po
ktrej wystpuje bajt nieparzysty). Geometria dysku podlega opisanej
powuej translacji.
<P>
<H2>5.5 PTBL</H2>

<P>Na kocu wykonywany jest test prbujcy wydedukowa istnienie
translacji na podstawie wartoci pl <CODE>start</CODE> i <CODE>end</CODE>  partycji
podstawowej:  
Jeli cylinder pocztkowy i kocowy jednej z partycji jest mniejszy od
256, a sektory pocztkowy i kocowy maj numery odpowiednio 1, i 63, a
kocowe numery gowic s rwne 31, 63 lub 127, wtedy wnioskujemy, e
translacja dysku jest aktywna, i wykorzystujemy liczb gowic
rwn odpowiednio 32, 64 i 127 (poniewa zwykle partycja koczy si na
granicy cylindra i interfejs IDE nie pozawala na wicej ni
16 gowic). By moe jest tu bd i <I>genhd.c</I> nie powinien
sprawdza dwch najwyszych bitw zmiennej przechowujcej numer
cylindra? Jednake nie wykonuje si adej translacji, jesli aktualny
pogld na istniejc geometri ju zakada 63 sektory na ciece i co
najmniej tyle samo gowic (poniewa to prawdopodownie oznacza, ze
translacja ju zostaa dokonana).
<P>
<H2><A NAME="s6">6. Konsekwencje</A></H2>

<P>Jakie to wszystko ma znaczenie? Dla uytkownikw Linuxa tylko jedno:
musz si upewni, e LILO i fdisk uywaj `poprawnej' geometrii,
gdzie `poprawna' w przypadku fdiska jest rozumiana jako geometria
uywana przez inne systemy operacyjne znajdujce sie na tym samym
dysku, a w przypadku LILO, e jest to geometria pozwalajca na poprawn
wspprac z BIOSem podczas adowania systemu.
<P>Jak fdisk dowiaduje si o geometrii?
Pyta si jdra przy pomocy funkcji ioctl <CODE>HDIO_GETGEO</CODE>.
Lecz uytkownik moe poda dowoln geometri dysku przez parametry w
wierszu polece lub pniej w samym programie.
<P>Jak LILO dowiaduje si o geometrii dysku?  Pyta si jdra przy pomocy
funkcji ioctl <CODE>HDIO_GETGEO</CODE>.  Lecz uytkownik moe poda asne
inforamacje z pomoc opcji `<CODE>disk=</CODE>'.  Mona rwnie skorzystac z
opcji <CODE>linear</CODE>, co spowoduje, e LILO zachowa w pliku odwzorwania (map
file) adres LBA, zamiast CHS i podczas adowania sytemu odczyta
geometri dysku (wykorzystujc funkcj nr 8 przerwania INT 13).
<P>Skd jdro wie co odpowiedzie?
Ha!, po pierwsze uytkownik moe przekaz mu odpowiednie informacje
jako parametr wiersza zachty startowej:
`<CODE>hd=</CODE><I>cyls</I><CODE>,</CODE><I>heads</I><CODE>,</CODE><I>secs</I>'.
W innym przypadku jdro przepyta na ten temat sprzt.
<P>
<H2>6.1 Szczegly IDE</H2>

<P>Troch szczegw.
Drajwer IDE posiada cztery rda informacji o geometrii
dysku. Pierwsze (G_user) to dane podane przez uytkwonika w wierszu
zachety. Drugie (G_bios) to inforamcje BIOSu (tylko dla pierwszego i
drugiego dysku), ktre s odczytywana podczas uruchamiania systemu,
przed przeczeniem si w tryb 32-bitowy.  Trzecie (G_phys) i czwarte
(G_log) s przekazywane przez sterownik IDE jako odpowied na
polecenie IDENTIFY - s to `fizyczna' i aktualna `logiczna' geometria
dysku. 
<P>Z drugiej strony, sterownik potrzebuje dwch informacji o geometrii
dysku: lecz posiada z jednej strony G_fdisk, przekazywane przez funkcj ioctl
<CODE>HDIO_GETGEO</CODE>, a z drugiej strony  G_used, ktre jest naprawd
wykorzystywane do wykonywania operacji We/Wy. Zarwno G_fdisk, jak i
G_used s inicjowane: wartociami G_user jeli s podane, G_bios jeli
ta inforamcja jest dostepna wg. CMOS, lub G_phys w przeciwnym wypadku.
Jesli G_log wyglda rozsdnie to G_used przybiera t wasnie
warto. W przeciwnym wypadku, jeli G_used nie ma wikszego sensu i
G_phys wyglda OK, wtedy G_used przyjmuje warto G_phys. W tym
przypadku `rozsdnie' oznacza, e liczba gowic jest w zakresie 1-16.
<P>Innymi sowy parametry wiersza zachty s waniejsze od informacji
pobranych z BIOSu i okrelaj jak geometri widzi fdisk, lecz jeli
podane informacje odpowiadaj geometri poddanej translacji (wiecej ni
16 gowic), wtedy operacje We/wy jdra zostan zastpione odpowiedzi
sterownika na polecenie IDENTIFY.
<P>
<H2>6.2 Szczegy SCSI</H2>

<P>Sytuacja w przypadku SCSI jest troch inna, poniewa polecenia SCSI
uywaj logicznych numerw blokw, tak wic geometria dysku nie ma
absolutnie adnego znaczenia dla operacjami We/Wy.
Jednake format tabeli partycji jest cigle ten sam, wic fdisk musi
wymyle jak geometri i rwnie w tym przypadku korzysta z funkcji
<CODE>HDIO_GETGEO</CODE> - w rzeczywistoci fdisk nie rozrnia dyskw IDE i
SCSI. Jak kady moe si sam przekona (na podstawie szczegowego
omwienia poniej) poszceglne drajwery wymylaj rne
geometri. Rzeczywicie jeden wielki balagan.
<P>Jeli nie korzystasz DOSu, to unikaj wszelkich ustawie rozszerzonych
translacji i jeli to moliwe, uywaj ustawie 64 gowice, 32
sektory na ciece (wtedy jeden cylinder ma adny rozmiar 1MB).
Unikniesz problemw, gdy przeniesiesz dysk z jednego
sterownika do innego. Niektre dyski SCSI (aha152x, pas16, ppa,
qlogicfas, qlogicisp) s tak nerwowe w sprawach zgodnoci z MS-DOSem,
e nie pozwol systemowi z zainstalowanym wycznie systemem Linux na
wykorzystanie wicej ni 8GB. To jest bd.
<P>Jaka jest rzeczywista geometria?
Najprostsza odpowied mwi, e nie ma czego takiego.
I gdyby bya, to nie chciaby wiedzie, i na pewno NIGDY, ale to
PRZENIGDY nie mw o tym fdiskowi, LILO lub jdru.
To jest po prostu sprawa pomidzy dyskiem i sterownikiem
SCSI. Pozwolisz, e powtrz: tylko gupcy mwi fdiskowi/LILO/jdru o
rzeczywistej geometrii dyskw SCSI.
<P>Lecz jeli jeste ciekaw i nalegasz, moesz spyta o to sam dysk.
Istnieje bardzo wane polecenie READ CAPACITY, ktre przekazuje
cakowi objto dysku, a drugie polecenie MODE SENSE (patrz Rigid
Disk Drive Geometry Page (strona 04)) pozwala odczyta liczb
cylindrw i gowic (ta informacje nie moe by zmieniona), natomiast
w Format Page (strona 03) podaje liczb bajw w sektorze i liczb
sektorw w ciece. Ta ostania liczba jest zwykle zalena od wycicia
(notch) i liczba sektorw na ciece jest zmienna - cieki zewntrzne
posiadaj wicej sektorw, wewntrzne mniej. Program pracujcy pod
Linuxem o nazwie scsiinfo poda ci te wszystkie informacje.  
<P>Jest wiele szcegw i komplikacji, i jest jasne, e nikt
(prawdopodobnie nawet sam system operacyjny) nie chce wykorzystywa
tej informacji. Co wicej, tak dugo jak martwimy si tylko o
fdisk i LILO, zwykle otrzymuje si odpowiedz typu C/H.S=4476/27/171 -
wartoci, ktre nie mog by wykorzystane przez fdisk, poniewa tabela
partycji rezerwuje jedynie dla C/H/S odpowiednio 10/8/6 bitw.
<P>To skd na ten temat bierze informacj funkcja <CODE>HDIO_GETGEO</CODE> ?
Cz, albo ze sterownika SCSI lub zgaduje. Wyglda, e niektre dyski
mysl, e interesuje nas `rzeczywisto', lecz nas oczywicie
interesuje jedynie jakie parametry bd uywane przez FDISK pod DOSem
czy OS/2 (lub AFDISK Adapteca).
<P>Pamitaj, e fdisk Linuxa potrzebuje zna liczb gowic H i sektorw
na ciece S, aby mc zamieni numer sektora w foramcjie LBA na adres
c/h/s, lecz liczba cylindrw C nie ma znaczenia w tej konwersji.
Niektre dyski uywaj (C,H,S)=(1032,255,63) w celu zasygnalizowania,
e dysk ma co najmniej 1023*255*63 sektorw. Niestety to nie ujawnia
aktualnego rozmiaru dysku i bdzie ograniczao uytkownikw wikszoci
wersji programu fdisk do wykorzstania tylko okoo 8GB ich dyskw - w
dzisiejszych czasach jest to powane ograniczenie.
<P>W opisie przedstawionym poniej, M oznacza cakowit pojemno dysku,
a C,H i S liczb cylindrw, gowic i sektorw na ciece.
Jeli traktujemy C jako wynik dziaania C = M / (H*S), wtedy wystarczy
poda H i S.
<P>Domylnie H=63,S=32.
<P>
<DL>
<DT><B>aha1740, dtc, g_NCR5380, t128, wd7000:</B><DD><P>H=64, S=32.
<P>
<DT><B>aha152x, pas16, ppa, qlogicfas, qlogicisp:</B><DD><P>H=64, S=32 unless C &gt; 1024, W takim przypadku
H=255, S=63, C = min(1023, M/(H*S)).
(Tak wic C jest obcite i h*s*C  nie jest aproksymacj rozmiaru dysku
M. Taka sytuacja potrafi ogupi wikszo wersji programu fdsik.) Kod
w pliku <I>ppa.c</I> wykorzystuje M+1 zamiast M i twierdzi, e to z poowdu
bdu w  <I>sd.c</I> M jest przesunite o 1.
<P>
<DT><B>advansys:</B><DD><P>H=64, S=32 chyba, e C &gt; 1024 i co wicej przy wczonej opcji
BIOSu `&gt; 1 GB', 
co w takim przypadku daje H=255, S=63.
<P>
<DT><B>aha1542:</B><DD><P>Spytaj sterownika, ktry z moliwych dwch schematw translacji jest w
uyciu, i uyj albo H=255, S=63 lub H=64, S=32. W ostanim przypadku
wywietlany jest komunikat startowy "aha1542.c: Using extended bios translation".
<P>
<DT><B>aic7xxx:</B><DD><P> 
H=64, S=32 chyba, e C &gt; 1024, i co wicej jeli
przekazano parametr startowy (boot) "extended", lub jeli w pamici
SEEPROM, lub BIOSie by ustawiony bit `extended', to w takim przypadku
przyjmuje si H=255, S=63.
<P>
<DT><B>buslogic:</B><DD><P>H=64, S=32 chyba, e C &gt;= 1024, i co wicej na sterwoniku zostaa
wczona translacja rozszerzona, co w takim pryzpadku powoduje
przyjceie  parametrw H=128, S=32 jeli  M &lt; 2^22  lub  H=255,
S=63 w przeciwnym wypadku. Jednake po dokonaniu wyboru (C,H,S)
odczytywana jest tabela partycji i jeli dla jednej z trzech moliwoci
(H,S) = (64,32), (128,32), (255,63) gdziekolwiek zgadza si rwno
endH=H-1, wtedy stosowana jest dana para (H,S) i wywietlany jest
komunikat "Adopting Geometry from Partition Table".
<P>
<DT><B>fdomain:</B><DD><P> 
Znajduje parametry w tabeli parametrw dysku BIOSu,
lub odczytuje tabel partycji i uywa translacji H=endH+1, S=endS w
przypadku pierwszej partycji (pod warunkiem, e nie jest pusta), lub
uywa H=64, S=32 w przypadku gdy M &lt; 2^21 (1 GB), lub H=128, S=63
jeli M &lt; 63*2^17 (3.9 GB) w przeciwnym wypadku.  H=255, S=63.
<P>
<DT><B>in2000:</B><DD><P>Uyj pierwszej pary (H,S) = (64,32), (64,63), (128,63), (255,63), dla
ktrej zajdzie nierwno C &lt;= 1024. W przeciwnym wypadku skr C
do 1023.
<P>
<DT><B>seagate:</B><DD><P>Odczytuje C,H,S z dysku.  (Horror!)  Jeli C lub S jest zbyt due
wtedy przyjmuje S=17,H=2 i podwaja H a V &lt;&lt;;= 1024. To znaczy, e H
bdzie miao warto 0, jeliM &gt; 128*1024*17 (1.1 GB). To jest bd.
<P>
<DT><B>ultrastor and u14_34f:</B><DD><P>W zalenoci o trybu sterownika wykorzystywane jest jedno z
nastpujcych odwzoroa:((H,S) = (16,63), (64,32), (64,63))
<P>
</DL>

Jeli drajwer nie poda geometrii dysku, powracamy do metody polegajcej
na zgadywaniu na podstawie zawartoci  tabeli partycji, lub cakowitej
pojemnoci dysku.
<P>Zobacz tabel partycji. Poniewa powszechnie partycja koczy si na
granicy cylindra, znajc dla kadej partycji <CODE>end =
(endC,endH,endS)</CODE> moemy po prostu przyj H = <CODE>endH+1</CODE> and S =
<CODE>endS</CODE>. (Przypomnij sobie, e sektory liczy si od 1.) A dokadniej
wykonywana jest nastpujca operacja.
Jeli istnieje niepusta partycja, odczytaj t o najwikszej wartoci
<CODE>beginC</CODE>. Dla tej partycji sprawd <CODE>end+1</CODE>, obliczone przez
dodanie <CODE>start</CODE> i <CODE>length</CODE> przy zaoeniu, e ta partycja koczy
si na granicy sektorw. Jeli obie wartoci si zgadzaj lub jeli
<CODE>endC</CODE> = 1023  i <CODE>start+length</CODE> jest cakowit wielokrotnoci
<CODE>(endH+1)*endS</CODE>, wtedy moemy zaoy, e ta partycj rzeczywicie
bya wyrwnana do granicy cylindra i przyj H = <CODE>endH+1</CODE> i S =
<CODE>endS</CODE>. 
Jeli jednak tak nie jest, a to dlatego, e nie ma adnej partycji,
lub dlatego, e partycje maj dziwne rozmiary wtedy sprbuj
wykorzysta pojemno dysku M. Algorytm: przyjmij H=M/(62*1024)
(zaokrglone w gr), S = M/(1024*H) (zaokrglone w gor), C = M/(H*S)
(zaokrglone w d).  W ten sposb otrzymamy geometri (C,H,S), prz
czym C nie przekroczy 1024, a S 62.
<P>
<H2><A NAME="s7">7. Od tumacza</A></H2>

<P>Wszelkie uwagi na temat tumaczenia mile widziane. Uwagi merytoryczne
prosze kierowa do autora tekstu angielskiego, chyba e podejewasz,
e s one wynikiem bdnego tumaczenia.
<P>Inne dokumenty HOWTO przetumaczone na jzyk polski znajdziesz tutaj:
<A HREF="http://www.ippt.gov.pl/~ppogorze/Linux/JTZ/">http://www.ippt.gov.pl/~ppogorze/Linux/JTZ/</A>.
<P>Wersje txt i html lepiej nadajace sie do druku sa tutaj:
<A HREF="ftp://www.ippt.gov.pl/pub/Linux/JTZ/">ftp://www.ippt.gov.pl/pub/Linux/JTZ/</A>.
<P>
</BODY>
</HTML>