November 2019

S M T W T F S
      12
34 5 678 9
10111213141516
17181920212223
24252627282930

Style Credit

Expand Cut Tags

No cut tags
Sunday, January 17th, 2010 03:06 am

По мотивам раздумий о судьбах звука в HDMI.

Заставить звук выводиться из компьютера через HDMI мне так и не удалось. Девайс есть, драйвер его видит, mplayer в него играет, а в телевизоре тишина. А поскольку  телевизор сильно вумный, то как только он обнаруживает, что в HDMI у него звук может быть, он аналоговый вход отключает. И неважно, что на самом деле в HDMI звука нет. Он же может..

Полдня гугления показали, что проблема известная (даже в Windows), а как ее решать, никто толком не знает. Остаётся ждать, пока nVidia напишет правильный аудиодрайвер. Они уже пообещали.

Но если переключиться в текстовый режим, то телевизор таки берёт звук из аналогового входа, хотя изображение получает по тому же HDMI. Это наводит на мысль, что телевизору можно как-то объяснить, что вот конкретно сейчас в HDMI звука нет. Производитель телевизора на вопрос, как это сделать, вот уже неделю молчит.

Оказалось, что это можно сделать со стороны компьютера. Для этого надо nVidia’вскому драйверу объяснить, что телевизор по ту сторону HDMI звук не поддерживает, тогда драйвер не скажет телевизору, что может подавать в него звук, и телевизор будет его брать из аналога. Что и требуется. В Windows это делается путём записи магических значений в registry.

А в линуксе так:

запускаем nvidia-settings, находим там телевизор, нажимаем на кнопочку Acquire EDID, сохраняем в файл. Внимательно разглядываем файл и обнаруживаем, что он длиной больше 128 байт. А значит, в нём присутствует extended section, в которой и описываются аудио-возможности телевизора. Берём первые 128 байт, затем меняем предпоследний байт на 00 (раньше там было 01, что свидетельствовало о наличии отрезанной extended section), и корректируем последний байт (это контрольная сумма). Полученный файл подсовываем драйверу в виде Option “CustomEDID”, перезапускаем X-Window, и с радостью обнаруживаем, что аналоговый звук больше не исчезает.

Корректировка контрольной суммы оставляется интересующимся читателям в качестве самостоятельного задания. Это очень просто.

Оригинал этой записи. Комментировать можно тут или там.

Любые материалы из этого блога запрещается использовать на сайте livejournal.ru в любой форме и любом объёме

Sunday, January 17th, 2010 09:46 am (UTC)
Жеееееесть. Ви ищо хочите пользовать проприетарных дрофф??
Sunday, January 17th, 2010 10:26 am (UTC)
думаешь, с открытыми дровами всё сильно лучше будет?

Какая качественно разница, кто криво прочитал стандарт (если там вообще это четко оговаривается) и не совсем правильно сообщеал телевизору реальное положение дел, писатель в нвидии, исходники которого не раздаются, или писатель где-то там в интернете, который исходники раздает?

Для простого человека - никакой. Он вкулючает и оно не работает. Тот факт, что в случае opensource простой члеовек может найти кого-то еще, кто пропатчит драйвер, радости не доставит. Самостоятельно эти патчи накладывать у простого члеовека врядли получится, в обновления его дистрибутива они врядли попадут быстрее, чем закрытые драйвера от производителя.

Единсвенный плюс от открытых драйверов - гикам, котоыре могут повторить весь цикл разработки и производства софта.
Sunday, January 17th, 2010 11:56 am (UTC)
Для конкретного пользователя - хозяина журнала - польза может быть, ибо он не очень "простой человек"
Sunday, January 17th, 2010 12:15 pm (UTC)
Хозяин журнала гик - конечно :)
Но вот я бы такими вещами уже не стал заморачиваться (хотя, с такой инструкцией работы на 5 минут). Я бы пробовал или менять железо на то, которое работает из коробки, или софт, который заработает.
Sunday, January 17th, 2010 12:17 pm (UTC)
У другого железа могут быть другие ишьюзы, не правда ли? А благодаря таким как хозяин журнала и гугл - иногда лучше потратить 5 минут, если все остальное устраивает.
Sunday, January 17th, 2010 12:21 pm (UTC)
Конечно у другого железа могутбыть другие приколы. И у другого софта - тоже. Но я прагаматик. Не уменьшая благодарности автору (и другим людям, которые раскапывают такие вот странности), я собственно хочу сказать, что в глобальном масштабе, OpenSource не решает проблем простых людей.

Например, кончина линукса у меня на домашнем десктопе была благодаря WiFi карточке. Которая в линуксе заводилась какими-то плясками с ndiswrapper и поиском правильной версии firmware, а под виндой работала из коробки. И несмотря на то, что давно уже я тут отказался от wifi протянул проводок, и в линуксе наверняка подточили драйвера, но "всё остальное" меня устраивает в WinXP. Вот ведь.
Sunday, January 17th, 2010 12:25 pm (UTC)
> OpenSource не решает проблем простых людей.
Соббсно его задача - помогать таким как автор решать проблемы простых людей (хотя бы через гугл), максимально просто. Но сам по себе опенсорц не решает проблемы простых людей, это да.

> но "всё остальное" меня устраивает в WinXP
Каждый выбирает по себе. Я выбираю линух не по техническим, а по идеологическим причинам;)
Sunday, January 17th, 2010 12:29 pm (UTC)
простые люди такие проблемы через гугл будут решать с очень малой вероятностью. Мне кажется, вера в это одна из ошибок тех, кто "живет" внутри OpenSource. Через гугл проблемы решают гики.

Мои наблюдения показывают, что идеология - не очень хорошая основа :)
Sunday, January 17th, 2010 12:45 pm (UTC)
Да, это правда. Но это им по силам - надо им только разок показать. Иногда так и делаю.

"Не очень _хорошая_ основа". Зависит от того, что считать хорошим и плохим. Соббсно опенсорц (точнее даже фрисофт в его Столмановской трактовке) меня привлекает именно этикой.
Sunday, January 17th, 2010 12:55 pm (UTC)
Я тоже, но уже поднадоело ;(

Хорошим я считаю то, что минимальными затратами (overall, так сказать) даёт успешный результат. А меня когда-то не один раз оттолкнул, тем, что кроме этики (которая далеко не всегда есть у автора), на этого автора нет никаких других способов воздействия, чтоб получить результат.

Люблю пересказывать историю, когда люди за решение задачи предлагали цену Win2k/server (больше $1000 на тот момент). На чём будет решение, плательщику по барабану. Linux, FreeBSD - да что угодно. Microsoft Support решил за неделю. Прислали те самые "магические заклинания в реестре", с которыми их софт начинал работать так, как нужно было в конкретном случае. Тем, кто пытался решать такое же на opensource платформах, времени было кажется не меньше пары недель выдано.
Sunday, January 17th, 2010 12:59 pm (UTC)
> на этого автора нет никаких других способов воздействия, чтоб получить результат.
Опенсорц дает возможность получить результат, не спрашивая автора.

А насчет цены, времени и пр. - да, бывает. Тот же редхат - совсем не дешевая конторка...
Sunday, January 17th, 2010 01:01 pm (UTC)
угу, но не гарантирует, что полученный результат поможет еще кому-нибудь.
Впрочем, как и вообще не гарантирует, что эту возможность удастся реализовать ;(
Sunday, January 17th, 2010 01:04 pm (UTC)
Да, гарантий никаких. А в мире софта реальную "железную" гарантию вообще получить непросто... Проприетарщики при первом же случае задницу еулой прикрывают.
Sunday, January 17th, 2010 01:06 pm (UTC)
в мире просто софта - да. Но вон, как минимум один раз с MS удалось получить :)

Но вот на стыке софт-железо, шансы есть хоть немного ощутимые. И эти шансы оцениваются вполне конкретными деньгами (цена железяки) и немного подкрепляются законами защиты прав потребителя (хотя, тоже не без фокусов ;((
Sunday, January 17th, 2010 01:09 pm (UTC)
> Но вон, как минимум один раз с MS удалось получить :)
Это ж не гарантия, это решение конкретной проблемы. Гарантия - это жесткая ответственность за решение любой проблемы (или финансовая компенсация).

В остальном - согласен. Но мы все-таки говорим про шансы. Вероятность...
Sunday, January 17th, 2010 01:16 pm (UTC)
Насколько я понимаю, если MS бы не решил вопрос, то покупатель был бы вправе вернуть лицензию обратно и получить возврат денег.
Sunday, January 17th, 2010 01:25 pm (UTC)
Так ли это легко в реальности?
Sunday, January 17th, 2010 01:29 pm (UTC)
думаю, что нелегко.
Но тут интересный вопрос (ответа на который у меня нет) - в каком случае легче получить результат, в случае проприетарщина+деньги или opensource+этика(+деньги)
Sunday, January 17th, 2010 01:36 pm (UTC)
ответ в каждом конкретном случае получается разный. есил бы он был однозначный, то вымер бы либо closed-source, либо open :)
Sunday, January 17th, 2010 01:39 pm (UTC)
угу :)
Sunday, January 17th, 2010 02:46 pm (UTC)
У меня тоже. Уверен, что это зависит от конкретного случая. Именно поэтому я скидываю со счетов этот фактор и выбираю этику.
Sunday, January 17th, 2010 01:35 pm (UTC)
Это правильно, хорошее решение - то, что даёт требуемый результат с минимальными затратами.
Причём затраты бывают как фминансовые, так и временнЫе, и иногда важнее одни, иногда другие.

Я - не коммерческая организация, у меня нет лишней тысячи долларов, чтобы попросить Microsoft, nVidia, Philips или авторов линуксовых драйверов решить мою конкретную проблему. А если бы и была, не факт, что они бы согласились.

Opensource даёт мне [хотя бы теоретическую] возможность решить проблему самому, пусть за счёт моего времени, а closed-source не даёт такой возможности в принципе.
Sunday, January 17th, 2010 12:33 pm (UTC)
а я вот как раз по техническим. потому что если что не так, можно подправить.
ну и по экономическим - линукс дешевле :)
Sunday, January 17th, 2010 12:47 pm (UTC)
Попробуй подправить что-нибудь в оракле или вмвари. Под линухом;) Насчет дешевизны - на десктопе пофиг. В общем случае у опенсорца нет однозначного технического преимущества.
Sunday, January 17th, 2010 01:22 pm (UTC)
ну closed-source софт он в любой ОС closed-source, тут уж ничего не сделаешь.
но в целом в линуксе открытых исходников куда больше, чем в windows.
Sunday, January 17th, 2010 12:35 pm (UTC)
видишь ли, у меня нет возможности покупать много железок по очереди и проверять, будут ли они работать. и софт покупать, в надежде, что он заработает с этой железкой - тоже..
Sunday, January 17th, 2010 12:41 pm (UTC)
угу, такая возможность, на самом деле, мало у кого есть. Поэтому берут всё то, на чем есть логотип "Win** Compatible", а если и это не помогает - мучают магазины с возвратом товара или службы поддержки - чтоб заставили это работать. Довольно регулярно помогает.
Sunday, January 17th, 2010 01:20 pm (UTC)
в данном случае это бы не помогло.
да, оно win-compatible, но вы купили _видео_карту? видео работает? ну и какие претензии?
Sunday, January 17th, 2010 01:26 pm (UTC)
про данный случай я понимаю, и мы с как-бы ушли в философию :))

К видеокарте, можно попробовать сформулировать претензию: есть выход HDMI, звук туда не попадает, хотя должен. Если не должен, должно быть в спецификации, что HDMI без звука, либо чините (расскажите с какими драйверами и магией в реестре/конфигах запускать), либо давайте я её верну обратно, и куплю другую, у которой звук туда попадает.
Sunday, January 17th, 2010 12:31 pm (UTC)
для простого пользователя разницы, конечно, никакой, он туда не полезет.
а я бы как-нибудь отключил в них звук, если бы были исходинки. вот с ИК получилось же.
Sunday, January 17th, 2010 12:29 pm (UTC)
а есть альтернатива?