* [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 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: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 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