Сообщение о сбое BIOS в Debian 8 (но не при загрузке Ubuntu)

Сообщение о сбое BIOS в Debian 8 (но не при загрузке Ubuntu)

У меня ошибка, которая не позволяет мне запустить систему. На этом SSD у меня Windows 8 и Debian 8, а на моем HDD — Windows 7 и Ubuntu 14.04 (я переносил свои SO на SSD, когда появилась эта ошибка).

[    0.000000] Calgary: detecting Calgary via BIOS EBDA area
[    0.000000] Calgary: Unable to locate Rio Grande table in EBDA - bailing!

*надрез*

[    0.000000] WARNING: CPU: 0 PID: 0 at /build/linux-ELRFVQ/linux-3.16.7-ckt11/drivers/iommu/dmar.c:760 warn_invalid_dmar+0x7a/0x8a()
[    0.000000] Your BIOS is broken; DMAR reported at address fed90000 returns all ones!
BIOS vendor: American Megatrends Inc.; Ver: 1302   ; Product Version: System Version
[    0.000000] Modules linked in:
[    0.000000] CPU: 0 PID: 0 Comm: swapper Not tainted 3.16.0-4-amd64 #1 Debian 3.16.7-ckt11-1+deb8u3
[    0.000000] Hardware name: System manufacturer System Product Name/P7H55-M, BIOS 1302    04/25/2011
[    0.000000]  ffffffff81016785 ffffffff8150b3a5 ffffffff81803e80 ffffffff81067767
[    0.000000]  ffffffff81af301c ffffffff81803ed0 00000000fed90000 0000000000000000
[    0.000000]  ffffffff81803fb0 ffffffff81067814 ffffffff8176edb0 ffffffff00000030
[    0.000000] Call Trace:
[    0.000000]  [<ffffffff81016785>] ? show_stack+0x5/0x50
[    0.000000]  [<ffffffff8150b3a5>] ? dump_stack+0x41/0x51
[    0.000000]  [<ffffffff81067767>] ? warn_slowpath_common+0x77/0x90
[    0.000000]  [<ffffffff81067814>] ? warn_slowpath_fmt_taint+0x44/0x50
[    0.000000]  [<ffffffff8192f4fa>] ? __early_ioremap+0x167/0x1fa
[    0.000000]  [<ffffffff8192f736>] ? early_ioremap+0xf/0x10
[    0.000000]  [<ffffffff81340ee9>] ? acpi_tb_acquire_table+0x39/0x66
[    0.000000]  [<ffffffff8150c3b3>] ? warn_invalid_dmar+0x7a/0x8a
[    0.000000]  [<ffffffff819499d6>] ? detect_intel_iommu+0xe3/0x16a
[    0.000000]  [<ffffffff8190bdd3>] ? pci_iommu_alloc+0x46/0x67
[    0.000000]  [<ffffffff8191b0d5>] ? mem_init+0x11/0x92
[    0.000000]  [<ffffffff81902e1a>] ? start_kernel+0x23b/0x49d
[    0.000000]  [<ffffffff81902a04>] ? set_init_arg+0x4e/0x4e
[    0.000000]  [<ffffffff81902120>] ? early_idt_handlers+0x120/0x120
[    0.000000]  [<ffffffff8190271f>] ? x86_64_start_kernel+0x14d/0x15c

Здесь'a pastebin со всем syslog. Я могу запустить Windows 7, 8 и Ubuntu 14.04, но когда я пытаюсь запустить Debian, вот что я получаю.


Когда я пытаюсь запустить GUI, startxвот что пишет:

[   98.627889] nvidia 0000:01:00.0: irq 48 for MSI/MSI-X
[  100.211135] traps: x-session-manag[534] trap int3 ip:7f3258e78d30 sp:7ffef7745cf0 error:0

Pastebinс Xorg.0.logвыходом.

решение1

Каждая современная система использует MMU для отображения виртуальной памяти в физическую память. Более современное оборудование также имеет эту возможность на другом оборудовании (например, на видеокарте). Тогда это называется IO-MMU.

(Видетьhttp://www.cyberciti.biz/tips/wp-content/uploads/2007/09/mmu-vs-iommu-memory.pngдля графики, которая стоит тысячи слов)

В вашем случае у вас есть карта Nvidia со встроенным io-MMU, но она либо не инициализируется должным образом при загрузке, либо не работает с драйвером в вашей установке Debian.

Это приводит к четырем решениям:

  1. Исправьте прошивку. (На видеокарте или на материнской плате (также известной как BIOS/UEFI).
  2. Обойдите это в драйвере.
  3. Обойти эту проблему можно, загрузив ОС, которая правильно ее настроит и оставит ее в частично настроенном состоянии во время «теплых» перезагрузок.
  4. Не используйте эту неисправную функцию.

Последнее можно легко сделать программно. В зависимости от того, как он сломан, попробуйте отключить VT-d (в прошивке BIOS) или через параметры ядра.

Чтобы установить параметры ядра, перейдите по этой ссылкеhttps://www.kernel.org/doc/Documentation/kernel-parameters.txt.

Я думаю, что вам нужен вариант iommu=off или soft.

Если вы хотите собрать ядро ​​без поддержки IOMMU, проверьте эти значения в файле .config и «поиграйтесь с ними», чтобы найти подходящий для вас вариант.

CONFIG_GART_IOMMU=y
CONFIG_CALGARY_IOMMU=y
CONFIG_CALGARY_IOMMU_ENABLED_BY_DEFAULT=y
CONFIG_AMD_IOMMU=y
CONFIG_AMD_IOMMU_STATS=y
CONFIG_IOMMU_HELPER=y
CONFIG_IOMMU_API=y
CONFIG_IOMMU_DEBUG

решение2

BIOS уже был последней версии, но я его перепрошил и теперь все работает хорошо.

ОБНОВЛЯТЬ

Проблема возникла снова.

Связанный контент