Page 10 of 18
Re: SATA в режиме IDE - полная поддержка
Posted: Sun Sep 01, 2013 10:20 pm
by Mario_r4
Serge wrote:Mario_r4
А ты запускал нумератор устройств и сохранял devices.dat в образе ?
Нет. Ты же сам сказал, что не нужно - я немного раньше спрашивал.
Re: SATA в режиме IDE - полная поддержка
Posted: Mon Sep 02, 2013 9:39 am
by Serge
Mario_r4
Мы друг друга не поняли. Я имел ввиду что никаких особых телодвижений в коде не требуется, только прочитать номер линии обязательно после APIC_init. Сама же поддержка APIC включается по инструкции в соответствующей теме.
Re: SATA в режиме IDE - полная поддержка
Posted: Thu Oct 03, 2013 8:22 am
by Mario_r4
SVN r.3964
По результатам
олимпиады сделал быстрофикс. До написания полноценного решения
контроллер 018A будет функционировать в режиме PIO.
Re: SATA в режиме IDE - полная поддержка
Posted: Sat Nov 23, 2013 9:12 am
by Mario_r4
Итак промежуточные результаты:
1) Советы
viewtopic.php?f=27&t=17&start=504 по проверке флага прерывания помогли запустить еще один ноутбук - Acer Packard Bell.
2) На eBox в режиме IDE Native прерывания продолжают генерироваться, даже если сброшен бит прерывания Bus Master IDE Status Register. Я сделал "слепой" цикл на 5 повторений, после 5 повторения прерывания контроллера явно запрещаются через:
Spoiler:
Code: Select all
; Disable interrupts in IDE controller
mov al, 2
mov dx, [IDE_BAR1_val] ;0x3F4
add dx, 2 ;0x3F6
out dx, al
mov dx, [IDE_BAR3_val] ;0x374
add dx, 2 ;0x376
out dx, al
Все повторения после первого упорно показывают, что бит прерывания в Bus Master IDE Status Register сброшен, но прерывания упорно продолжают генерироваться контроллером вызывая мнимое зависание системы. Что за такая хуета происходит с этой железкой еще предстоит разбираться.
3) Мамка Asus "дохнет" даже с изменениями в п.2, просто замерзает и все.
Я в прошлом посте отчетном перепутал малость - это мамка Asrock (native) при первом обращении к жесткому по прежнему отваливается USB стек, потому что они делят между собой одно прерывание, а вот мамка Asus (native) как раз замерзает.
К сожалению советы
viewtopic.php?f=27&t=17&start=504 не помогли побороть проблему с отваливающимся контроллером USB, так что возможно я не там копаю.
В процессе гугления нашел страницу
http://forum.sources.ru/index.php?showtopic=349091&hl= однако информация там приведенная прогресса, к сожалению, не дала.
Re: SATA в режиме IDE - полная поддержка
Posted: Sat Nov 23, 2013 11:03 am
by Kopa
А может ли помочь делу борьбы с "заморочками" тест проверки работоспособности проблемного железа в Haiku OS
и её, например, исходный код для прояснения сущности проблемы?
P.S. У них, вроде, много железа работает в Os.
Re: SATA в режиме IDE - полная поддержка
Posted: Sat Nov 23, 2013 12:39 pm
by Mario_r4
Kopa wrote:А может ли помочь делу борьбы с "заморочками" тест проверки работоспособности проблемного железа в Haiku OS
и её, например, исходный код для прояснения сущности проблемы?
P.S. У них, вроде, много железа работает в Os.
В моем случае нет, поскольку я пытаюсь запустить без APIC.
Re: SATA в режиме IDE - полная поддержка
Posted: Sat Nov 23, 2013 1:47 pm
by Mario_r4
Пока рылся в гугле обнаружил полезную литературу
http://www.swd.ru/files/pdf/nop/bgtu/BG ... ivanii.pdf
О.Л. Никольский
ПРОГРАММИРОВАНИЕ ПРИЛОЖЕНИЙ РЕАЛЬНОГО
ВРЕМЕНИ ДЛЯ ИСПОЛНЕНИЯ В СРЕДЕ ОПЕРАЦИОННОЙ
СИСТЕМЫ РЕАЛЬНОГО ВРЕМЕНИQNX/NEUTRINO 2
ЧастьII
ОБРАБОТКА ПРЕРЫВАНИЙ В ОПЕРАЦИОННОЙ
СИСТЕМЕ РЕАЛЬНОГО ВРЕМЕНИQNX /NEUTRINO
По прерываниям есть любопытные объяснения.
Re: SATA в режиме IDE - полная поддержка
Posted: Sun Nov 24, 2013 3:21 pm
by Mario_r4
На случай важных переговоров:
Объяснение что такое: 80, 85, 8A, 8F контроллеры.
Spoiler:

-
offset09h.png (50.63 KiB)
Viewed 5153 times
Re: SATA в режиме IDE - полная поддержка
Posted: Sun Nov 24, 2013 10:37 pm
by Mario_r4
Сегодня я таки нашел причину проблем с eBox и Asus. В спецификациях этого нет и нашел информацию я все в той же книге Владимира Кулакова "Программирование дисковых подсистем". В ней упоминается, что альтернативный регистр состояния (AC) не снимает запроса прерывания, но не упоминается что основной регистр состояния (SR) снимает запрос прерывания. Сильно сомневаясь я все же решил проверить и это сработало! Просто добавил чтение регистра в обработчик прерывания и это решило проблему.
Re: SATA в режиме IDE - полная поддержка
Posted: Mon Nov 25, 2013 11:15 pm
by Mario_r4
SVN r. 4291 Исправлены баги приводящие к зависаниям при работе с IDE DMA в режиме SATA Native.
Также отмечаю тот факт, что поскольку драйвер ATAPI работает только в режиме PIO, то жесткий диск висящий с ним на одном канале также будет работать в режиме PIO. По крайней мере такое я наблюдаю на одном своем ноутбуке. Решение не идеальное, но пока нет кода для работы с ATAPI приводами дисков в режиме DMA это временное решение проблемы и оно работает. Несмотря на то что физически SATA контроллеры независимы, но в режиме эмуляции старого IDE они подвержены этому ограничению. Так что если есть возможность развесить на разные каналы, то лучше это сделать. В ноутбуке разумеется это сложно, а может и невозможно, если производитель пожадничал, но на стационарном компьютере вполне возможно - просто переткнуть кабель в другой разъем SATA на материнке.
По прежнему поддерживается только один контроллер и еще немало работы.
Еще нужно сделать проверку флагов, поскольку SATA контроллеры более подвержены ошибкам передачи данных по шлейфу и это нужно учесть в коде. Пока такой проверки нет.
Re: SATA в режиме IDE - полная поддержка
Posted: Tue Nov 26, 2013 11:00 pm
by 0CodErr
В режиме только SATA работает.
В режиме SATA+PATA зависла оба раза из двух.
В режиме PATA тоже зависла.
Зависает на этом месте:
Spoiler:

Re: SATA в режиме IDE - полная поддержка
Posted: Wed Nov 27, 2013 12:46 am
by yogev_ezra
Code: Select all
VMware® Workstation (Version 7.0.1 build-227600)
Host OS version: Windows 7 Professional, 64-bit 6.1.7601, Service Pack 1
CPU: Intel Core i5-3570 @ 3.40 GHz
RAM: 8GB
SVN r4297. На первом канале висит IDE Hard Disk, на втором - IDE CD-ROM. Почему-то устанавливается режим PIO, хотя, если я правильно тебя понял, должно быть уже DMA. Если удалить CD-ROM и оставить только Hard Disk, всё равно остаётся PIO. Логи прилагаю.
Spoiler:

-
ScreenShot644.png (30 KiB)
Viewed 5029 times
Re: SATA в режиме IDE - полная поддержка
Posted: Wed Nov 27, 2013 2:45 am
by punk_joker
Насколько я понял, DMA у меня на ноуте завелось. Логи прилагаю
Re: SATA в режиме IDE - полная поддержка
Posted: Wed Nov 27, 2013 7:26 am
by Mario_r4
0CodErr
Согласно прилагаемым логам у тебя завелось и работает. ATAPI привода либо нет, либо подключен в другие разъемы, которые в текущей схеме не поддерживаются.
Нужны логи от сборки SVN. r. 4290, в двух оставшихся схемах подключения.
Еще желательно включить опцию С в синем загрузочном экране и сфоткать правый столбик в SVN r. 4291 (Где зависает на обоих вариантах), поскольку фото левого столбика мало что объясняет.
Re: SATA в режиме IDE - полная поддержка
Posted: Wed Nov 27, 2013 7:29 am
by Mario_r4
yogev_ezra
Вечером посмотрю код. Может поставлю эмулятор и буду смотреть в чем проблема.