ALT Linux Sisyphus discussions
 help / color / mirror / Atom feed
From: Sergey Vlasov <vsu@altlinux.ru>
To: sisyphus@lists.altlinux.org
Subject: Re: [sisyphus] После обновления ядра с 2.6.25 до 2.6.30 не монтируется раздел
Date: Thu, 22 Oct 2009 17:41:31 +0400
Message-ID: <20091022134131.GB9428@newmaster.mivlgu.local> (raw)
In-Reply-To: <d77783290910212329m6c6b1459jcb79fb068aa6186@mail.gmail.com>

[-- Attachment #1: Type: text/plain, Size: 3524 bytes --]

On Thu, Oct 22, 2009 at 11:29:46AM +0500, Денис Черносов wrote:
> Есть интернет-шлюз с Office Server 4.0 (kernel-image-std-smp-2.6.18).
> Понадобилось мне включить на нем модули для трассировки rtsp. А в ядре
> их не оказалось... Стал я обновляться.
> dist-upgrade до 4.1 + ядро  2.6.25-std-def-alt8.M41.5 - модулей нет,
> но полет нормальный.
> 
> Поставил ядро kernel-image-std-def-2.6.30-alt14 - система перестала
> загружаться. Во время загрузки аварийный режим и сообщение:
> 
> /dev/sda5 filesystem size (according to the superblock is 6018460 blocks
> physical size of the device is 6018299
> Either the superblock or the partition table is likely to be corrupt!
> 
> Если снова загрузиться с ядром  2.6.25-std-def-alt8.M41.5, то
> нормально загружается и показывает размер /dev/hda5 (не sda5!) 6018460
> блоков.
[...]
> Помогите пожалуйста разобраться - кто из них неправ и что делать
> (желательно без переформатирования раздела :) ).

Видимо, на диске есть Host Protected Area - область, которая должна
быть скрыта от ОС (такая область, например, создаётся многими версиями
BIOS от Gigabyte для хранения резервной копии кода BIOS).  Старые
драйверы IDE при загрузке всегда отключали HPA (во время написания
этого кода была причина для подобных действий - отключение ограничения
размера диска, поставленного для обхода ошибок BIOS при работе с
большими дисками); в новых драйверах libata отключение HPA по
умолчанию не производится.  В результате при переходе с ide на libata
без дополнительных настроек возможно уменьшение доступного размера
дисков; причём, начиная с 2.6.28, если какой-либо раздел выходит за
пределы диска, ядро автоматически уменьшает доступный размер этого
раздела с выдачей сообщения вида:

  sdXY: pN size M limited to end of disk

(а если и начало раздела за пределами диска, такой раздел полностью
игнорируется).  Ядра до 2.6.28 в аналогичной ситуации показывали
размер разделов полностью, но выдавали ошибки ввода-вывода при попытке
обращения к недоступной части разделов.

Решать такую проблему можно несколькими способами:

 - Наиболее правильный - переразбить диск с учётом HPA (чтобы
   исключить возможность конфликтов с тем кодом в BIOS, который
   использует эту область).  Для ext2/3/4 есть возможность уменьшить
   размер ФС без переформатирования с помощью resize2fs.

 - Можно попробовать снять HPA - например, с помощью hdparm (опция -N), но
   это может не пройти, если BIOS устанавливает HPA при каждой загрузке
   (тогда команда установки постоянного значения HPA пройдёт только после
   передёргивания питания диска); кроме того, подобная функция может быть
   в утилитах от производителя диска.  Однако даже после успешного снятия
   HPA при следующей перезагрузке BIOS может вновь установить своё
   значение (если там нет в этом месте правильной проверки содержимого
   таблицы разделов).

 - Наконец, можно заставить драйверы libata отключать HPA, как это
   делали старые драйверы ide:

     options libata ignore_hpa=1

   В этом варианте наибольший риск конфликтов с BIOS (поскольку BIOS
   считает, что HPA на диске есть и может использоваться BIOS для своих
   целей, однако ОС на самом деле использует эту область диска для
   хранения данных).  В случае материнок от Gigabyte в качестве меры
   защиты вроде бы годится переключение контроллера из режима IDE в AHCI
   (если эта опция доступна) - похоже, эти BIOS в режиме AHCI не умеют
   использовать HPA для сохранения резервной копии BIOS.

[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 189 bytes --]

  parent reply	other threads:[~2009-10-22 13:41 UTC|newest]

Thread overview: 10+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-10-22  6:29 Денис Черносов
2009-10-22 12:12 ` Alexey Shabalin
2009-10-22 12:15 ` Sergei Epiphanov
2009-10-22 12:35   ` Денис Черносов
2009-10-22 13:02     ` Sergei Epiphanov
2009-10-22 13:48     ` Sergey Vlasov
2009-10-23  5:05       ` Денис Черносов
2009-10-22 13:41 ` Sergey Vlasov [this message]
2009-10-26 13:19   ` [sisyphus] [wiki] " Michael Shigorin
2009-10-27  6:17     ` Денис Черносов

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20091022134131.GB9428@newmaster.mivlgu.local \
    --to=vsu@altlinux.ru \
    --cc=sisyphus@lists.altlinux.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link

ALT Linux Sisyphus discussions

This inbox may be cloned and mirrored by anyone:

	git clone --mirror http://lore.altlinux.org/sisyphus/0 sisyphus/git/0.git

	# If you have public-inbox 1.1+ installed, you may
	# initialize and index your mirror using the following commands:
	public-inbox-init -V2 sisyphus sisyphus/ http://lore.altlinux.org/sisyphus \
		sisyphus@altlinux.ru sisyphus@altlinux.org sisyphus@lists.altlinux.org sisyphus@lists.altlinux.ru sisyphus@lists.altlinux.com sisyphus@linuxteam.iplabs.ru sisyphus@list.linux-os.ru
	public-inbox-index sisyphus

Example config snippet for mirrors.
Newsgroup available over NNTP:
	nntp://lore.altlinux.org/org.altlinux.lists.sisyphus


AGPL code for this site: git clone https://public-inbox.org/public-inbox.git