ALT Linux Team development discussions
 help / color / mirror / Atom feed
* [devel] Q: hwdatabase Vs. kernel pcimap
@ 2006-04-17  9:22 Anton D. Kachalov
  2006-04-17  9:25 ` Anton D. Kachalov
  0 siblings, 1 reply; 8+ messages in thread
From: Anton D. Kachalov @ 2006-04-17  9:22 UTC (permalink / raw)
  To: devel

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

После некоторого шаманства произвёл на свет скрипт, который аналогично
getpciids из libhw-devel, выдаёт список соответствия
vendorID/productID(subvendor/subproduct) <=> ядерный модуль.
getpciids использует нахаченную базу соответствий из hwdatabase.
Модули в 2.6 ядрах итак прекрасно умеют сообщать, какие железки они
поддерживают. Исключение составляют шаблонные девайсы, например, uhci-hcd,
где принадлежность модуля к железке определяется по его классу. В
hwdatabase это нахачено в виде нескольких известных VID/PID.

К письму приложен скрипт mod2pciids, который имеет совместимость с
getpciids, если вызывать его с параметром "-s".
А так же diff между modules.map для первой стадии livecd/installer/...,
полученные в результате работы getpciids и mod2pciids соответственно.

Я считаю более верным использование pcimap от ядра, нежели некой базы.
Но для этого потребуется добавить некоторые железки в модули.
А ещё подумать на тему того, как быть с модулями, подобными uhci-hcd.
Возможно, придётся внести нахаченные VID/PID в aliases к соответствующим
модулям помимо существующих там wildcards.

--
mouse


[-- Attachment #2: mod2pciids --]
[-- Type: text/plain, Size: 866 bytes --]

#!/bin/sh

readonly PROG="${0##*/}"

show_usage()
{
	cat <<EOF
$PROG -f module-list
EOF
	exit
}

TEMP=`getopt -n $PROG -o f:,k:,s,h -l kernel:,short-list,help -- "$@"` ||
	show_usage
eval set -- "$TEMP"

short=
modulelist=
kernel=$(uname -r)
while :; do
	case "$1" in
		-f) shift; modulelist="$1" ;;
		-k|--kernel) shift; kernel="$1" ;;
		-s|--short-list) short=1 ;;
		-h|--help) show_usage ;;
		--) shift; break ;;
		*) show_usage ;;
	esac
	shift
done

[ "$modulelist" != "-" ] || modulelist=

sed -n 's,\(\.ko\)\?\(\.gz\)\?$,,; s,^\([[:alnum:]._-]\+\)$,^\1[[:space:]]\.\*,p;' $modulelist |
	egrep -x -f - /lib/modules/$kernel/modules.pcimap |
	sed 's,ffffffff,ffff,g; s, 0x\(0000\)\?, ,g' |
while read m v d sv sd foo; do
	printf %s "$v $d"
	[ "$sv" = 'ffff' -o -n "$short" ] || echo -n " $sv"
	[ "$sd" = 'ffff' -o -n "$short" ] || echo -n " $sd"
	echo " $m"
done

[-- Attachment #3: modules.map.diff.bz2 --]
[-- Type: application/x-bzip2, Size: 3178 bytes --]

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [devel] Q: hwdatabase Vs. kernel pcimap
  2006-04-17  9:22 [devel] Q: hwdatabase Vs. kernel pcimap Anton D. Kachalov
@ 2006-04-17  9:25 ` Anton D. Kachalov
  2006-04-17  9:58   ` Anton Farygin
  0 siblings, 1 reply; 8+ messages in thread
From: Anton D. Kachalov @ 2006-04-17  9:25 UTC (permalink / raw)
  To: ALT Devel discussion list

On Mon, Apr 17, 2006 at 01:22:20PM +0400, Anton D. Kachalov wrote:
> Я считаю более верным использование pcimap от ядра, нежели некой базы.
> Но для этого потребуется добавить некоторые железки в модули.
> А ещё подумать на тему того, как быть с модулями, подобными uhci-hcd.
> Возможно, придётся внести нахаченные VID/PID в aliases к соответствующим
> модулям помимо существующих там wildcards.
Или, что идеологически верно, добавить поддержку wildcards в первую
стадию. Что позволит поднимать железо даже по классу.

--
mouse



^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [devel] Q: hwdatabase Vs. kernel pcimap
  2006-04-17  9:25 ` Anton D. Kachalov
@ 2006-04-17  9:58   ` Anton Farygin
  2006-04-17 10:05     ` Anton D. Kachalov
  0 siblings, 1 reply; 8+ messages in thread
From: Anton Farygin @ 2006-04-17  9:58 UTC (permalink / raw)
  To: ALT Devel discussion list

Anton D. Kachalov wrote:
> On Mon, Apr 17, 2006 at 01:22:20PM +0400, Anton D. Kachalov wrote:
>> Я считаю более верным использование pcimap от ядра, нежели некой базы.
>> Но для этого потребуется добавить некоторые железки в модули.
>> А ещё подумать на тему того, как быть с модулями, подобными uhci-hcd.
>> Возможно, придётся внести нахаченные VID/PID в aliases к соответствующим
>> модулям помимо существующих там wildcards.
> Или, что идеологически верно, добавить поддержку wildcards в первую
> стадию. Что позволит поднимать железо даже по классу.
> 

Скорее последнее, чем первое. Ибо сейчас часть железок теряется.

И hwdatabase всё равно придётся использовать, правда по другому 
алгоритму (для добавления в blacklist модулей, которые сломаны /или опасны)

Rgds,
Rider



^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [devel] Q: hwdatabase Vs. kernel pcimap
  2006-04-17  9:58   ` Anton Farygin
@ 2006-04-17 10:05     ` Anton D. Kachalov
  2006-04-17 11:20       ` Anton Farygin
  0 siblings, 1 reply; 8+ messages in thread
From: Anton D. Kachalov @ 2006-04-17 10:05 UTC (permalink / raw)
  To: ALT Devel discussion list

On Mon, Apr 17, 2006 at 01:58:26PM +0400, Anton Farygin wrote:
> Скорее последнее, чем первое. Ибо сейчас часть железок теряется.
> 
> И hwdatabase всё равно придётся использовать, правда по другому 
> алгоритму (для добавления в blacklist модулей, которые сломаны /или опасны)
Я думаю, что всё-таки основным свойством hwdatabase должно являтся
_дополнение_ основной базы, а не её замена, как сейчас.
Т.ч. я думаю, что имеет смысл добавить поддержку class, а также
subproduct/subvendor в первую стадию и использовать предложенный мною
скрипт, вынеся его в отдельный пакет, без зависимостей на libhw. Ему после
допиливания, по сути, нужно будет только залезать в blacklists из
hwdatabase.

--
mouse



^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [devel] Q: hwdatabase Vs. kernel pcimap
  2006-04-17 11:20       ` Anton Farygin
@ 2006-04-17 11:15         ` Anton D. Kachalov
  2006-04-17 12:54           ` Anton Farygin
  0 siblings, 1 reply; 8+ messages in thread
From: Anton D. Kachalov @ 2006-04-17 11:15 UTC (permalink / raw)
  To: ALT Devel discussion list

On Mon, Apr 17, 2006 at 03:20:51PM +0400, Anton Farygin wrote:
> Да, именно так и планируется. Просто для первой стадии пока не было 
> поддержки class и subproduct/subvendor.
Будет просто замечательно.

> Или сделать ещё проще и добавить этот алгоритм в getpciids, что 
> собственно уже давным давно планировалось сделать.
> 
> Что бы отказаться от скриптов.
От каких скриптов? Некоторые вещи намного лучше заскриптовать, нежели
писать на Це/ЦеПиПи.
Честно говоря, немного смущяет такое огромное число зависимостей у простой
программки: $ ldd /usr/bin/getpciids
        libhw.so.0 => /usr/lib/libhw.so.0 (0x00117000)
        libstdc++.so.6 => /usr/lib/libstdc++.so.6 (0x0016d000)
        libsysfs.so.1 => /usr/lib/libsysfs.so.1 (0x00377000)
        libfdisk.so.1 => /usr/lib/libfdisk.so.1 (0x00383000)
        libuuid.so.1 => /lib/libuuid.so.1 (0x0038d000)
Их неоправданно много. А тулзень эта бывает полезной и без такого
количества библиотек.

--
mouse



^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [devel] Q: hwdatabase Vs. kernel pcimap
  2006-04-17 10:05     ` Anton D. Kachalov
@ 2006-04-17 11:20       ` Anton Farygin
  2006-04-17 11:15         ` Anton D. Kachalov
  0 siblings, 1 reply; 8+ messages in thread
From: Anton Farygin @ 2006-04-17 11:20 UTC (permalink / raw)
  To: ALT Devel discussion list

Anton D. Kachalov wrote:
> On Mon, Apr 17, 2006 at 01:58:26PM +0400, Anton Farygin wrote:
>> Скорее последнее, чем первое. Ибо сейчас часть железок теряется.
>>
>> И hwdatabase всё равно придётся использовать, правда по другому 
>> алгоритму (для добавления в blacklist модулей, которые сломаны /или опасны)
> Я думаю, что всё-таки основным свойством hwdatabase должно являтся
> _дополнение_ основной базы, а не её замена, как сейчас.

Да, именно так и планируется. Просто для первой стадии пока не было 
поддержки class и subproduct/subvendor.


> Т.ч. я думаю, что имеет смысл добавить поддержку class, а также
> subproduct/subvendor в первую стадию и использовать предложенный мною
> скрипт, вынеся его в отдельный пакет, без зависимостей на libhw. Ему после
> допиливания, по сути, нужно будет только залезать в blacklists из
> hwdatabase.

Или сделать ещё проще и добавить этот алгоритм в getpciids, что 
собственно уже давным давно планировалось сделать.

Что бы отказаться от скриптов.

Rgds,
Rider


^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [devel] Q: hwdatabase Vs. kernel pcimap
  2006-04-17 11:15         ` Anton D. Kachalov
@ 2006-04-17 12:54           ` Anton Farygin
  2006-04-17 14:20             ` Anton D. Kachalov
  0 siblings, 1 reply; 8+ messages in thread
From: Anton Farygin @ 2006-04-17 12:54 UTC (permalink / raw)
  To: ALT Devel discussion list

Anton D. Kachalov wrote:
> On Mon, Apr 17, 2006 at 03:20:51PM +0400, Anton Farygin wrote:
>> Да, именно так и планируется. Просто для первой стадии пока не было 
>> поддержки class и subproduct/subvendor.
> Будет просто замечательно.

Здесь патчи приветствуются...

> 
>> Или сделать ещё проще и добавить этот алгоритм в getpciids, что 
>> собственно уже давным давно планировалось сделать.
>>
>> Что бы отказаться от скриптов.
> От каких скриптов? Некоторые вещи намного лучше заскриптовать, нежели
> писать на Це/ЦеПиПи.
> Честно говоря, немного смущяет такое огромное число зависимостей у простой
> программки: $ ldd /usr/bin/getpciids
>         libhw.so.0 => /usr/lib/libhw.so.0 (0x00117000)
>         libstdc++.so.6 => /usr/lib/libstdc++.so.6 (0x0016d000)
>         libsysfs.so.1 => /usr/lib/libsysfs.so.1 (0x00377000)
>         libfdisk.so.1 => /usr/lib/libfdisk.so.1 (0x00383000)
>         libuuid.so.1 => /lib/libuuid.so.1 (0x0038d000)
> Их неоправданно много. А тулзень эта бывает полезной и без такого
> количества библиотек.

Т.к. она используется только при сборке образа, то собственно говоря 
наличие большого количества библиотек никак не мешает. Правда часть из 
них я действительно оторву (libfdisk, libuuid) и добавлю зависимость на 
libvolume_id.

Rgds,
Rider



^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [devel] Q: hwdatabase Vs. kernel pcimap
  2006-04-17 12:54           ` Anton Farygin
@ 2006-04-17 14:20             ` Anton D. Kachalov
  0 siblings, 0 replies; 8+ messages in thread
From: Anton D. Kachalov @ 2006-04-17 14:20 UTC (permalink / raw)
  To: ALT Devel discussion list

On Mon, Apr 17, 2006 at 04:54:32PM +0400, Anton Farygin wrote:
> Здесь патчи приветствуются...
Возможно, будут :)

> Т.к. она используется только при сборке образа, то собственно говоря 
> наличие большого количества библиотек никак не мешает. Правда часть из 
> них я действительно оторву (libfdisk, libuuid) и добавлю зависимость на 
> libvolume_id.
Я всё равно не понимаю, зачем использовать плюсовую прогу, когда можно
обойтись простым шельным скриптом в пять строчек

--
mouse



^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2006-04-17 14:20 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2006-04-17  9:22 [devel] Q: hwdatabase Vs. kernel pcimap Anton D. Kachalov
2006-04-17  9:25 ` Anton D. Kachalov
2006-04-17  9:58   ` Anton Farygin
2006-04-17 10:05     ` Anton D. Kachalov
2006-04-17 11:20       ` Anton Farygin
2006-04-17 11:15         ` Anton D. Kachalov
2006-04-17 12:54           ` Anton Farygin
2006-04-17 14:20             ` Anton D. Kachalov

ALT Linux Team development discussions

This inbox may be cloned and mirrored by anyone:

	git clone --mirror http://lore.altlinux.org/devel/0 devel/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 devel devel/ http://lore.altlinux.org/devel \
		devel@altlinux.org devel@altlinux.ru devel@lists.altlinux.org devel@lists.altlinux.ru devel@linux.iplabs.ru mandrake-russian@linuxteam.iplabs.ru sisyphus@linuxteam.iplabs.ru
	public-inbox-index devel

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


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