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 ' <= 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 <= 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 > 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 > 1024 i co wicej przy wczonej opcji
BIOSu `> 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 > 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 >= 1024, i co wicej na sterwoniku zostaa
wczona translacja rozszerzona, co w takim pryzpadku powoduje
przyjceie parametrw H=128, S=32 jeli M < 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 < 2^21 (1 GB), lub H=128, S=63
jeli M < 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 <= 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 <<;= 1024. To znaczy, e H
bdzie miao warto 0, jeliM > 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>
|