|
Разбивка HDD, Как ОС определяет кол-во логических головок на винте? |
|
|
|
 |
Ответов
(1 - 56)
|
Jul 30 2011, 10:46
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
QUOTE (GetSmart @ Jul 30 2011, 12:26)  Как ОС (MS-DOS or Windows) определяет кол-во логических головок на винте? В данных BIOS смотрят. Win, если в BIOS данные отсутствуют, сам читает 512 байтовый блок данных из HDD и разбирается с кем имеет дело. QUOTE Не знаю как в новых, больших винтах, но в старых используется CHS адресация Это уже не в старых, а безумно старых, ну или сейчас разве только в мелких CF.
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Jul 30 2011, 11:29
|
.
     
Группа: Участник
Сообщений: 4 005
Регистрация: 3-05-06
Из: Россия
Пользователь №: 16 753

|
Цитата(zltigo @ Jul 30 2011, 15:46)  В данных BIOS смотрят. Win, если в BIOS данные отсутствуют, сам читает 512 байтовый блок данных из HDD и разбирается с кем имеет дело. У меня в стареньком ноуте в BIOS стоит автоопределение и оно показывает логические CHS уровня ATA, а не уровня BIOS Int 13h. Цитата(zltigo @ Jul 30 2011, 15:46)  Это уже не в старых, а безумно старых, ну или сейчас разве только в мелких CF. А в HDD средней "старости", которые от 8 ГБ до 2 ТБ, у них нет в конце диска неиспользуемого места из-за округления по кол-ву цилиндров/головок?
Сообщение отредактировал GetSmart - Jul 30 2011, 11:32
--------------------
Заблуждаться - Ваше законное право :-)
|
|
|
|
|
Jul 30 2011, 11:35
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
QUOTE (GetSmart @ Jul 30 2011, 13:18)  оно показывает логические CHS уровня ATA, а не уровня BIOS Int 13h. BIOS может пользоваться и пользуется (если умеет) только данными полученными с ATA. Другое дело, что он по Вашему приказу, может на них наплевать и/или воспользоваться, например, древней таблицей "стандарных" HDD. HDD это все равно, если в размер укладывается. Единственно, что может рухнуть файловая система из-за изменения размеров разделов. QUOTE (GetSmart @ Jul 30 2011, 13:29)  А в HDD средней "старости", которые от 8 ГБ до 2 ТБ, у них нет в конце диска неиспользуемого места из-за округления по кол-ву цилиндров/головок? Они вообще не могут адресоваться CHS - размеры далеко уходят за возможности CHS адресации.
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Jul 30 2011, 11:37
|
.
     
Группа: Участник
Сообщений: 4 005
Регистрация: 3-05-06
Из: Россия
Пользователь №: 16 753

|
Цитата(zltigo @ Jul 30 2011, 16:33)  BIOS может пользоваться и пользуется (если умеет) только данными полученными с ATA. Ну это явно не так. Int 13 как раз к BIOS относится. Если, конечно, его не перехватывает ОС, что ещё нужно подтвердить. Int 13 принимает в виде параметров CHS уровня BIOS, а не уровня АТА. Цитата(zltigo @ Jul 30 2011, 16:35)  Они вообще не могут адресоваться CHS - размеры далеко уходят за возможности CHS адресации. Вопрос не в этом. Читайте внимательно.
--------------------
Заблуждаться - Ваше законное право :-)
|
|
|
|
|
Jul 30 2011, 11:43
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
QUOTE (GetSmart @ Jul 30 2011, 13:37)  Ну это явно не так. Int 13 как раз к BIOS относится. Если, конечно, его не перехватывает ОС, что ещё нужно подтвердить. Int 13 принимает в виде параметров CHS уровня BIOS, а не уровня АТА. Когда сами себе сможете объяснить, что написали, то попробуйте задать вопрос еще раз.
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Jul 30 2011, 11:50
|
.
     
Группа: Участник
Сообщений: 4 005
Регистрация: 3-05-06
Из: Россия
Пользователь №: 16 753

|
Цитата(zltigo @ Jul 30 2011, 16:43)  Когда сами себе сможете объяснить, что написали, то попробуйте задать вопрос еще раз. Объясняю. В BIOS у меня написано, что кол-во головок 15. В MBR винта, как и в загр.секторе диска С, указано, что кол-во головок 255. Через Int 13 я могу считывать головки 0-254. То есть не 15, которые в настройках BIOS и передаются через АТА. На каком-то уровне ОС/BIOS происходит конвертация CHS OS (BIOS?) в CHS ATA. Я конечно же знаю про функции 4x прерывания int 13, использующие линейную одномерную адресацию по логическим секторам, но сейчас не об этом, а о функциях < 10h Int 13h.
Сообщение отредактировал GetSmart - Jul 30 2011, 12:21
--------------------
Заблуждаться - Ваше законное право :-)
|
|
|
|
|
Jul 30 2011, 12:08
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
QUOTE (GetSmart @ Jul 30 2011, 13:50)  Объясняю. В BIOS у меня написано, что кол-во головок 15. В MBR винта, как и в загр.секторе диска С, указано, что кол-во головок 255. Через Int 13 я могу считывать головки 0-254. Типа INT13h/AH=13h ? QUOTE То есть не 15, которые в настройках BIOS и передаются через АТА. На каком-то уровне ОС/BIOS происходит конвертация CHS OS (BIOS?) в CHS ATA. о функциях < 10h Int 13h. Ну и какая такая функция AH < 10h Вам возвращает параметры диска?
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Jul 30 2011, 12:30
|
.
     
Группа: Участник
Сообщений: 4 005
Регистрация: 3-05-06
Из: Россия
Пользователь №: 16 753

|
Цитата(zltigo @ Jul 30 2011, 17:24)  Прежде, чем обратиться, Вы должны спросить параметры. Это 13h функция. Начиная с MSDOS 5.0 это ДОСОВСКАЯ, а не BOIS функция. Соответственно она все ретранслирует. Для обращения так-же производится ретрансляция. ОК. А DOS откуда узнаёт, ведь это какой-то виртуальный уровень? DOS это выясняет из MBR или загрузочного сектора логического диска? Кроме того, ещё до запуска DOS, то бишь во время запуска загрузочного сектора используется Int 13h для загрузки IO.SYS и Int 13h передаются в виде параметров CHS уже этого виртуального уровня, якобы неизвестного BIOS.
Сообщение отредактировал GetSmart - Jul 30 2011, 12:32
--------------------
Заблуждаться - Ваше законное право :-)
|
|
|
|
|
Jul 30 2011, 12:49
|
.
     
Группа: Участник
Сообщений: 4 005
Регистрация: 3-05-06
Из: Россия
Пользователь №: 16 753

|
Цитата(zltigo @ Jul 30 2011, 17:42)  Сомневаюсь в необходимости разных вариантов, поскольку вся эта возня затевалась для достижения адресации максимального объема диска. Но даже если вдруг там есть зачем-то какая-то стратегия выбора, то она абсолютно произвольна. Всё не дано понять... Фишка в том, что досовские проги используют эту виртуальную CHS и умудряются правильно её определять. Хотя может я чего-то и упустил. Но заглянул бы сюда какой-нить спец по DOS/BIOS чтобы указать что именно. А винда, скорее всего, работает с одномерными логическими секторами через Int 13 func > 40h, или своими аналогичными. Поэтому там вопрос так остро не стоит. Хотя и под виндой я разбивал 4 гиговый винт, у которого в результате был обрезан конец винта при округлении до целого числа цилиндров (255 головок).
Сообщение отредактировал GetSmart - Jul 30 2011, 12:53
--------------------
Заблуждаться - Ваше законное право :-)
|
|
|
|
|
Jul 30 2011, 12:51
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
QUOTE (GetSmart @ Jul 30 2011, 14:49)  Всё не дано понять... Фишка в том, что досовские проги используют эту виртуальную CHS и умудряются правильно её определять. Они ее НЕ определяют, они ее СПРАШИВАЮТ у DOS используя INT13h/AH=13h. QUOTE Хотя может я чего-то и упустил. Упустили ответы на вопросы  . Пост №8
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Jul 30 2011, 13:08
|
.
     
Группа: Участник
Сообщений: 4 005
Регистрация: 3-05-06
Из: Россия
Пользователь №: 16 753

|
Цитата(zltigo @ Jul 30 2011, 17:59)  Естественно молча пользуется первоначальными. Это накладывает только одно ограничение IO.SYS и (не помню точно) DOS.SYS должны быть на первых 500 мегабайтах диска. Ваша некомпетентность бросается в глаза  Загрузочный сектор уже использует DOS? разметку. Представьте, 15 головок в BIOS. Как только код обратится к 16-ой, то кирдык. А 15 головок * 63 сектора - это 472.5 КБ (!). Теоретически это может быть правдой, т.к. смещение первого кластера на диске FAT16 нах-ся в районе 260КБ. При этом остаётся место для IO.SYS размером 200 КБ. ИМХО зря они этот уровень ввели. Лучше бы оставался один уровень ATA/BIOS, а следующий был бы в DOS уже одномерный в секторах. Тогда и загрузочной области была бы адресация уровня АТА и загрузчик работал бы через BIOS с параметрами АТА. Upd. Пока у меня есть несколько версий, как определяется кол-во головок. 1. По общему размеру диска, ограничивая кол-во цилиндров в диапазоне 1023-512. 2. Прочитав MBR и определив по значениям CHS максимальное значение головки. 2а. Прочитав загрузочный сектор и взяв оттуда кол-во головок
Сообщение отредактировал GetSmart - Jul 30 2011, 16:24
--------------------
Заблуждаться - Ваше законное право :-)
|
|
|
|
|
Jul 30 2011, 13:23
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
QUOTE (GetSmart @ Jul 30 2011, 15:08)  Ваша некомпетентность бросается в глаза  Угу, именно она позволяла мне уже 20 лет назад писать MainBIOS, патчить биосы контроллеров IDE интерфейсов и писать загрузчики для своей системы. QUOTE (GetSmart @ Jul 30 2011, 15:08)  Представьте, 15 головок в BIOS. Как только код обратится к 16-ой, то кирдык. А 15 головок * 63 сектора - это 472.5 КБ (!). Пустой набор слов ни о чем.
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Jul 30 2011, 13:29
|
.
     
Группа: Участник
Сообщений: 4 005
Регистрация: 3-05-06
Из: Россия
Пользователь №: 16 753

|
Цитата(zltigo @ Jul 30 2011, 18:23)  Угу, именно она позволяла мне уже 20 лет назад писать MainBIOS, патчить биосы контроллеров IDE интерфейсов и писать загрузчики для своей системы. Профессионалы ошибаются на плюс/минус 3 порядка  Цитата Пустой набор слов ни о чем. Второй раз объясню. Я недавно дизассемблил несколько загрузочных секторов MS-DOS/Windows. Так вот, в них указано кол-во головок уровня DOS?. И при вычислении местоположения IO.SYS логический одномерный сектор делится на кол-во головок. Если вдруг местоположение IO.SYS окажется на головке выше чем в BIOS, то BIOS пошлёт код подальше. Если цилиндр окажется не нулевой, то сектор прочитается совсем не оттуда. Вот так то.
--------------------
Заблуждаться - Ваше законное право :-)
|
|
|
|
|
Jul 30 2011, 13:51
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
QUOTE (GetSmart @ Jul 30 2011, 15:29)  Я недавно дизассемблил несколько загрузочных секторов MS-DOS/Windows. И увидели фигу, не поняли, откуда берется расположение IO.SYS и как грузится IO.SYS, что не удивительно  , ибо Вам удается ее видеть даже глядя на более простые вещи, нежели дизассемблированный загрузчик. Продолжайте изучать. Должно-же когда-то дойти?
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Jul 30 2011, 17:17
|
Частый гость
 
Группа: Участник
Сообщений: 182
Регистрация: 4-11-10
Пользователь №: 60 646

|
боже , из вас никто про LBA не слышал ? и про LBA48 точно никто и про LBA -> CHS виртуальное преобразование ? Человек вам правду говорил - из биоса получают данные , попробуйте простой тест , в старом биосе в котором можно ручками выставить CHS уберите часть головок или цилиндров или секторов и посмотрите как изменится определяемый DOS'ом размер прошу прощения если я кого обижу . но гляньте тут на CHS , на LBA и на INT 13Hразвязали тут две страницы полемики на пустом месте ....
|
|
|
|
|
Jul 30 2011, 17:49
|
.
     
Группа: Участник
Сообщений: 4 005
Регистрация: 3-05-06
Из: Россия
Пользователь №: 16 753

|
Цитата(follow_me @ Jul 30 2011, 22:17)  Человек вам правду говорил - из биоса получают данные , попробуйте простой тест , в старом биосе в котором можно ручками выставить CHS уберите часть головок или цилиндров или секторов и посмотрите как изменится определяемый DOS'ом размер Кое-что не сходится. Мой биос показывает на одном из винтов 16 головок. Это честные АТА головки. Физически на винте их может быть и меньше, не суть. Но разметка на этом винте стоит на 32 головки. Не 16 и не 255. Я не собираюсь задавать сам какие-то значения. Меня интересует автоопределение и по какому алгоритму оно работает. Цитата(follow_me @ Jul 30 2011, 22:17)  прошу прощения если я кого обижу . но гляньте тут на CHSЭто напрямую никак не проясняет ситуацию с кол-вом головок. BIOS (int 13 func < 10h) может работать с головками до 255. Однако если диск (логический) размечен на 32, то BIOS будет работать с 32-мя. А не с 255. Причём кол-во АТА головок совершенно "до лампочки". Так вот. Либо BIOS приходится после перезагрузки читать первые сектора диска и их анализировать, либо по общему объёму диска по какому-то алгоритму задаётся кол-во головок.
Сообщение отредактировал GetSmart - Jul 30 2011, 17:57
--------------------
Заблуждаться - Ваше законное право :-)
|
|
|
|
|
Jul 31 2011, 14:57
|
.
     
Группа: Участник
Сообщений: 4 005
Регистрация: 3-05-06
Из: Россия
Пользователь №: 16 753

|
Цитата(follow_me @ Jul 30 2011, 22:17)  прошу прощения если я кого обижу . но гляньте тут на CHS , на LBA и на INT 13Hразвязали тут две страницы полемики на пустом месте .... Прочитал эти три ссылки. Ржунимагу. Вы, товарищи-писатели, хоть бы вчитывались в вопросы. Все три ссылки никак не проясняют алгоритм определения головок. В приличных биосах есть режим AUTO. Он умеет сам определять кол-во головок без ручного ввода их в биос. zltigo просто мастер жанра. Когда ему указываешь что ответ не на тот вопрос, у него одна заготовка - вы, батенька, дурак  zltigo, впредь прошу мне не отвечать. Ваша недопомощь мне не нужна.
--------------------
Заблуждаться - Ваше законное право :-)
|
|
|
|
|
Jul 31 2011, 18:40
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
QUOTE (GetSmart @ Jul 31 2011, 16:57)  zltigo, впредь прошу мне не отвечать. Ваша недопомощь мне не нужна. Так ведь можно просто, в крайнем случае, непонятное просто молча пропустить. Ну а поскольку это форум, то отвечать или нет я буду решать сам. QUOTE (Xenia @ Jul 31 2011, 20:02)  то может быть окажется полезной ссылка " Работа с IDE HDD через порты контроллера"? Нет, у него другая проблема, он типа дизасемблировал какую-то MBR (кстати,они достаточно разные у разных версий DOS и тем более WIN) и не понял, как загружается Boot Record активного раздела.
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Jul 31 2011, 18:53
|
.
     
Группа: Участник
Сообщений: 4 005
Регистрация: 3-05-06
Из: Россия
Пользователь №: 16 753

|
Цитата(Xenia @ Jul 31 2011, 23:02)  то может быть окажется полезной ссылка " Работа с IDE HDD через порты контроллера"? Спасибо, конечно. Но это тоже не то. Здесь идёт работа напрямую с разметкой АТА. Там всё детерминировано. LBA пересчитать в CHS винта проблемы не вызывает. Проблему вызывает CHS Int 13h для дисков 540 MB..8GB. То есть неясно откуда берётся кол-во головок в этом CHS, по какому алгоритму, т.к. их кол-во не совпадает с головками ATA. Кроме того, меня интересует CHS Int 13 для работы с дисками более 8 ГБ, вплоть до 2 ТБ (или 0.5, не суть), хотя я прекрасно понимаю, что доступны будут только первые 8 гиг. Главное, алгоритм определения головок. И доп. вопрос - округляются ли разделы на дисках до 2 ТБ по целому числу цилиндров, с учётом опять же кол-ва логических головок, не АТА-шных. Цитата(zltigo @ Jul 31 2011, 23:40)  Нет, у него другая проблема, он типа дизасемблировал какую-то MBR (кстати,они достаточно разные у разных версий DOS и тем более WIN) и не понял, как загружается Boot Record активного раздела. Конкретно загрузочный сектор MS-DOS 6.22 и WIN95 и MBR не слишком старую, т.к. она умеет пользоваться Int 13 func > 40h. Чья MBR - пока не знаю. И понял я там абсолютно всё, кроме одного вопроса, на который никто ещё не ответил. Касательно загрузки с дискет, то там нет такой проблемы. Там нет второго уровня CHS.
Сообщение отредактировал GetSmart - Jul 31 2011, 19:09
--------------------
Заблуждаться - Ваше законное право :-)
|
|
|
|
|
Jul 31 2011, 19:25
|
Профессионал
    
Группа: Свой
Сообщений: 1 526
Регистрация: 8-04-05
Пользователь №: 3 960

|
Цитата(GetSmart @ Jul 31 2011, 22:48)  Спасибо, конечно. Но это тоже не то. Здесь идёт работа напрямую с разметкой АТА. Там всё детерминировано. LBA пересчитать в CHS винта проблемы не вызывает. Проблему вызывает CHS Int 13h для дисков 540 MB..8GB. То есть неясно откуда берётся кол-во головок в этом CHS, по какому алгоритму, т.к. их кол-во не совпадает с головками ATA. Есть спецификация ST506 - формат регистров контроллера жесткого дика. В этой спецификации максимальное число головок 16, но число дорожек 65535. Есть спецификация нерасширенного INT13 (не LBA48), где число головок 255, а число дорожек - 1024. То есть при удоволетворении и той и другой - максимальный размер 512 МБ. Для обхода этого ограничения появилась спецификация LBA - использующая полные возможности INT13 посредством стандартного преобразования CHS-ST506 в CHS-LBA. Диск на запрос геометрии может выдавать CHS-ST506 и BIOS SETUP (а не BIOS INT13!) показывает эти значения. Но для работы с таким диском надо все равно использовать CHS-LBA, которые и используются в INT13 Для работы с диками >8 ГБ используется расширение INT13, где используется только номер сектора без деления на CHS.
|
|
|
|
|
Jul 31 2011, 19:30
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
QUOTE (GetSmart @ Jul 31 2011, 21:16)  На винте 16 головок. Или не 16. Он всем говорит, что 16, но ему на физическом уровне глубоко все равно. QUOTE В MBR действительно разметка CHS уровня Int 13h. И там указано 32, 64 или любое другое число. MBR сформировал DOS проставив количество головок для обеспечения доступа ко всему диску а не ~500Mb. Из каких соображений не сразу 255 - спросите у MS. QUOTE Чаще всего вообще 255. Я собственно других не видел, о чем уже писал, и не вижу смысла не в 255. QUOTE откуда BIOS узнала, что головок на уровне Int 13 будет 32? Да то, что было DOS-ом сформировано в таблице разделов в качестве адреса раздела, то и берет. Ничего ему знать НЕ надо. QUOTE Повторяю для особо особо особо одарённых. Даже для особо тупых, разжевал более чем. Достаточно.
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Jul 31 2011, 19:42
|
.
     
Группа: Участник
Сообщений: 4 005
Регистрация: 3-05-06
Из: Россия
Пользователь №: 16 753

|
Цитата(vvs157 @ Aug 1 2011, 00:25)  Есть спецификация ST506 - формат регистров контроллера жесткого дика. ... Это уже было написано в недавних ссылках на вики. Но это всё не отвечает на мой вопрос. Цитата(vvs157 @ Aug 1 2011, 00:25)  Для работы с диками >8 ГБ используется расширение INT13, где используется только номер сектора без деления на CHS. Эти функции я знаю, func >= 40h. Там всё элементарно. За мелкими нюансами. Но доступ к диску всё равно будет через func < 40h, особенно если диск размечен на несколько разделов и первый раздел < 8GB. То есть всё равно кол-во головок имеет значение. Вероятно там всегда будет 255 головок, но не уверен. Цитата(zltigo @ Aug 1 2011, 00:30)  Из каких соображений не сразу 255 - спросите у MS. ... Я собственно других не видел, о чем уже писал, и не вижу смысла не в 255. Вот они, ключевые моменты. Так бы и сказали, что Вы некомпетентны в данном вопросе. И не вертели передо мной своей харизмой  Если бы там стояло всегда 255 для дисков более 500 МБ, то у меня и вопросов бы не возникло. Цитата(zltigo @ Aug 1 2011, 00:30)  Да то, что было DOS-ом сформировано в таблице разделов в качестве адреса раздела, то и берет. Ничего ему знать НЕ надо. Предположений я не спрашиваю. У меня их у самого вагон и маленькая тележка. Мне нужен точный алгоритм.
Сообщение отредактировал GetSmart - Jul 31 2011, 19:37
--------------------
Заблуждаться - Ваше законное право :-)
|
|
|
|
|
Jul 31 2011, 19:48
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
QUOTE (GetSmart @ Jul 31 2011, 21:34)  Вот они, ключевые моменты. Так бы и сказали, что Вы некомпетентны в данном вопросе. Вам с самого начала было указано: 1) почему пересчитывается 2) что этим занимается DOS 3) и то, что число не имеет никакого значения. Это и есть ключевые моменты. QUOTE И не вертели передо мной своей харизмой  Если бы там стояло всегда 255 для дисков более 500 МБ, то у меня и вопросов бы не возникло. Типа поумнели после разжевывания и решили что сможете постфактум прикинутся умным  . Не проканает после этого: QUOTE Ваша некомпетентность бросается в глаза Загрузочный сектор уже использует DOS? разметку. Представьте, 15 головок в BIOS. Как только код обратится к 16-ой, то кирдык. А 15 головок * 63 сектора - это 472.5 КБ (!). Теоретически это может быть правдой, т.к. смещение первого кластера на диске FAT16 нах-ся в районе 260КБ. При этом остаётся место для IO.SYS размером 200 КБ. То, что Вы чистопробный ламер (чайник, который думает, что круто заварен) не скроете.
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Jul 31 2011, 20:13
|
Профессионал
    
Группа: Свой
Сообщений: 1 526
Регистрация: 8-04-05
Пользователь №: 3 960

|
Цитата(GetSmart @ Jul 31 2011, 23:51)  В том-то и прикол, что когда в BIOS-ах стоит AUTO, то можно диск перетыкать на другие материнки и всё будет одинаково. При этом, можно хоть голый, неотформатированный винт вставлять в материнку и БИОС в авто режиме назначит ему какое-то кол-во головок. И возможно разные БИОСы умудряются сразу назначать одинаковое число головок. Они (BIOS'ы) просто пользуются одинаковой формулой :-)) Для современных ОС имеет значение только абсолютный номер сектора, CHS ими не используется. Поэтому ОС использует только ту часть записи Partition Table в MBR, где указан абсолютный номер сектора. Записи CHS в MBR нужны только для MSDOS и иже с ним. FreeDOS по-моему тоже перешел на абсолютный номер сектора. Из этого следует, что для таких ОС непринципиально, как проведен мэппинг BIOS'ом ST506 в LBA
|
|
|
|
|
Jul 31 2011, 20:22
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
QUOTE (vvs157 @ Jul 31 2011, 21:48)  как BIOS материнки (а это делает именно BIOS материнки) отмаппил ST506 в LBA Незачем этим биосу заниматься. Он должен только интерфейс предоставить для любой адресации, а том сам HDD выругается если что не так. Не верите? Обратите внимание, что, уже писал, функция INT13h/AH=13h документирована у самого коричневого ральфа  , как функция DOS начиная с версии 5.0. http://www.ctyme.com/intr/rb-0637.htmQUOTE (vvs157 @ Jul 31 2011, 22:13)  Они (BIOS'ы) просто пользуются одинаковой формулой :-)) Они просто отображают ровно то,что сообщает им о себе HDD.
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Jul 31 2011, 20:22
|
.
     
Группа: Участник
Сообщений: 4 005
Регистрация: 3-05-06
Из: Россия
Пользователь №: 16 753

|
Цитата(vvs157 @ Aug 1 2011, 01:13)  Они (BIOS'ы) просто пользуются одинаковой формулой :-)) А Вы её знаете?  Всего-то вопрос плёвый. На который zltigo тупит нипадецки. Цитата(vvs157 @ Aug 1 2011, 01:13)  Для современных ОС имеет значение только абсолютный номер сектора, CHS ими не используется. Но ведь система MBR/Boot sector грузится ещё до всякой ОС, используя адресацию Int13h. То есть ещё до запуска ОС, Int 13 уже знает сколько будет головок на диске. ОС в данном вопросе меня интересует только в том, ограничивает ли она общий размер винта, округляя его до целого числа цилиндров, опять же через головки. То есть в современных разметках дисков (< 2TB) разделы могут быть размером кратно 1 или 63 или 63*Heads, которые (Heads) якобы не используются?
Сообщение отредактировал GetSmart - Jul 31 2011, 20:25
--------------------
Заблуждаться - Ваше законное право :-)
|
|
|
|
|
Jul 31 2011, 20:35
|
Профессионал
    
Группа: Свой
Сообщений: 1 526
Регистрация: 8-04-05
Пользователь №: 3 960

|
Цитата(GetSmart @ Aug 1 2011, 00:22)  А Вы её знаете?  Да как-то никогда надобности в ней не было. Ее легко отреверсить. Берете LBA max , делите на 63*1024, округляете в большую сторону - получите фиктивное число головок. Цитата(GetSmart @ Aug 1 2011, 00:22)  Но ведь система MBR/Boot sector грузится ещё до всякой ОС, используя адресацию Int13h. То есть ещё до запуска ОС, Int 13 уже знает сколько будет головок на диске. А это неважно, так как MBR всегда первый сектор. Если BIOS поддерживает EXT, то загрузка раздела пойдет с абс. LBA, если нет - то с CHS.
|
|
|
|
|
Jul 31 2011, 20:39
|
Профессионал
    
Группа: Свой
Сообщений: 1 526
Регистрация: 8-04-05
Пользователь №: 3 960

|
Цитата(GetSmart @ Aug 1 2011, 00:22)  То есть в современных разметках дисков (< 2TB) разделы могут быть размером кратно 1 или 63 или 63*Heads, которые (Heads) якобы не используются? Вообще-то обычно принято раздел начинать с нового цилиндра. Цитата(zltigo @ Aug 1 2011, 00:36)  до любого числа вплоть до 255.  Естественно. Но BIOS'ы одного производителя деляют это одинаковым способом. Если нужна определенность.
|
|
|
|
|
Jul 31 2011, 21:31
|
.
     
Группа: Участник
Сообщений: 4 005
Регистрация: 3-05-06
Из: Россия
Пользователь №: 16 753

|
Цитата(vvs157 @ Aug 1 2011, 01:58)  Цилиндров там конечно нет. Но так как раньше они были, то выравнивание делается по старым традициям - для совместимости PT MBR в части записи HS. Значит ли это, что объём диска ограничивается усечением последнего неполного цилиндра? (с учётом, вероятно, 255 головок) И сразу же второй вопрос. Если я на голом диске создам первый раздел с Heads=16, то можно ли будет "отхватить" от винта больше места, т.к. остаток на неполном цилиндре будет в районе 1..15 головок. Цитата(vvs157 @ Aug 1 2011, 01:58)  ... то выравнивание делается по старым традициям - для совместимости PT MBR в части записи CHS. С этим ещё один прикол был связан. Я сделал копию 1 гигового винта на другой, большой. При изменении размеров разделов Acronis Partition-ом у меня начало разделов менялись кратно 255 головкам. Хотя в MBR и старого и нового винта стояло кол-во головок = 32. Точнее, в новом/большом стояло сразу после копирования один-в-один. После работы с Acronis оно поменялось на 255. Цитата(vvs157 @ Aug 1 2011, 01:35)  Да как-то никогда надобности в ней не было. Ее легко отреверсить. Берете LBAmax , делите на 63*1024, округляете в большую сторону - получите фиктивное число головок. Эта формула мне не внушает доверия. Т.к. мне почему-то попадались кол-во головок 32,64 и 255. Возможно ещё существуют 16 и 128. Про остальные значения я не уверен, что они разрешены. Но и не отрицаю. До сих пор ясной картины нету.
Сообщение отредактировал GetSmart - Jul 31 2011, 21:28
--------------------
Заблуждаться - Ваше законное право :-)
|
|
|
|
|
Aug 1 2011, 09:03
|
Профессионал
    
Группа: Свой
Сообщений: 1 526
Регистрация: 8-04-05
Пользователь №: 3 960

|
Цитата(GetSmart @ Aug 1 2011, 01:31)  Значит ли это, что объём диска ограничивается усечением последнего неполного цилиндра? (с учётом, вероятно, 255 головок) Нет, конечно. Руками Вы можете до разметки выставить, все, что угодно, главное кратно размеру кластера. Цитата(GetSmart @ Aug 1 2011, 01:31)  С этим ещё один прикол был связан. Я сделал копию 1 гигового винта на другой, большой. При изменении размеров разделов Acronis Partition-ом у меня начало разделов менялись кратно 255 головкам. Хотя в MBR и старого и нового винта стояло кол-во головок = 32. Точнее, в новом/большом стояло сразу после копирования один-в-один. После работы с Acronis оно поменялось на 255. Правильно, для систем с LBA CHS не имеет принципиального значения. Мне не совсем понятен практический аспект Вашего интереса к этому вопросу.
|
|
|
|
|
Aug 1 2011, 10:05
|
.
     
Группа: Участник
Сообщений: 4 005
Регистрация: 3-05-06
Из: Россия
Пользователь №: 16 753

|
Цитата(vvs157 @ Aug 1 2011, 14:03)  Правильно, для систем с LBA CHS не имеет принципиального значения. Мне не совсем понятен практический аспект Вашего интереса к этому вопросу. Один из главных вопросов - совместимость вверх-вниз. В частности, взятие старого винта от старой системы, переразбивка или другие работы с ним под виндой и установка этого же винта обратно в старую систему. Далее, почти то же самое, но с копированием малого винта на больший, опять же с обратной установкой. Т.к. доставать старые малые рабочие винты сейчас большая проблема, то проще и дешевле достать винт большего объёма. При этом возникают вопросы - а как поведёт себя старая система, на которой не используется LBA функции Int 13. Например MS-DOS 6.x или WIN95 в режиме DOS. Цитата(vvs157 @ Aug 1 2011, 14:03)  Нет, конечно. Руками Вы можете до разметки выставить, все, что угодно, главное кратно размеру кластера. Имелось ввиду не размер логического диска, а общий размер всех разделов на винте. Я, например, заметил усечение последнего цилиндра в последнем разделе. Поэтому подумал, что если в этот раздел включить последний неполный цилиндр, а в логическом диске сделать всё корректно, не вылезая за общий размер винта, то как поведёт себя система? Последний неполный цилиндр явно указывается на винтах <8Gb. Но и на винтах < 2TB он косвенно присутствует, если поделить общее число секторов всех разделов на 63 и на 255. Поэтому ошибается тот, кто утверждает, что их там нет. Даже Вики. Во всяком случае, без обязательных оговорок. Как и собственно упоминание CHS в вики без оговорок какого уровня эта CHS. Такое разгильдяйство в статьях меня откровенно достало.
Сообщение отредактировал GetSmart - Aug 1 2011, 10:54
--------------------
Заблуждаться - Ваше законное право :-)
|
|
|
|
|
Aug 1 2011, 13:39
|
Профессионал
    
Группа: Свой
Сообщений: 1 526
Регистрация: 8-04-05
Пользователь №: 3 960

|
Цитата(GetSmart @ Aug 1 2011, 14:05)  Один из главных вопросов - совместимость вверх-вниз. В частности, взятие старого винта от старой системы, переразбивка или другие работы с ним под виндой и установка этого же винта обратно в старую систему. Проблем быть не должно. Очень старые винчестеры не всегда опознаются USB-IDE шнурками. Цитата(GetSmart @ Aug 1 2011, 14:05)  Далее, почти то же самое, но с копированием малого винта на больший, опять же с обратной установкой. Т.к. доставать старые малые рабочие винты сейчас большая проблема, то проще и дешевле достать винт большего объёма. При этом возникают вопросы - а как поведёт себя старая система, на которой не используется LBA функции Int 13. Например MS-DOS 6.x или WIN95 в режиме DOS. На очень старых системах винты >8G скорее всего вообще не опознаются - БИОС без EXT - они либо вообще не видятся БИОС'ом, либо показываются несуразные значения. Если БИОС правильно определил размер - то все будет работать. Цитата(GetSmart @ Aug 1 2011, 14:05)  на которой не используется LBA функции Int 13. Например MS-DOS 6.x или WIN95 в режиме DOS. DOS (тот, что в WIN95 OSR2) c LBA работать умеет, так как там есть уже FAT32. Про Win95 без OSR2 - не знаю, так как не было на чем испытывать, но так там и FAT16, и никаких "толстых" дисков.
|
|
|
|
|
Aug 1 2011, 14:25
|
.
     
Группа: Участник
Сообщений: 4 005
Регистрация: 3-05-06
Из: Россия
Пользователь №: 16 753

|
Цитата(vvs157 @ Aug 1 2011, 18:39)  Проблем быть не должно. Очень старые винчестеры не всегда опознаются USB-IDE шнурками. У меня Win XP с IDE на материнке. Цитата(vvs157 @ Aug 1 2011, 18:39)  На очень старых системах винты >8G скорее всего вообще не опознаются - БИОС без EXT - они либо вообще не видятся БИОС'ом, либо показываются несуразные значения. Если БИОС правильно определил размер - то все будет работать. Недавно проверял комп с 80486 у которого биос только 8 гиг видит. Втыкаю винт на 40 гиг, прекрасно работаю с первыми 8-мью от него. Причём винт в биосе определяется как 8 гиговый  Цитата(vvs157 @ Aug 1 2011, 18:39)  DOS (тот, что в WIN95 OSR2) c LBA работать умеет, так как там есть уже FAT32. Про Win95 без OSR2 - не знаю, так как не было на чем испытывать, но так там и FAT16, и никаких "толстых" дисков. "Толстые" диски там без проблем. Другое дело, что логический диск FAT16 ограничен 2 гигами. А кол-во логических дисков там может быть уйма, друг за дружкой. Даже дос 6.22 может с десяток подряд их видеть в доп.разделе винта. А то и больше.
Сообщение отредактировал GetSmart - Aug 1 2011, 14:28
--------------------
Заблуждаться - Ваше законное право :-)
|
|
|
|
|
  |
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|