Сейчас на форуме: bartolomeo, tyns777 (+5 невидимых) |
eXeL@B —› Программирование —› энумерация USB-устройств в драйвере |
. 1 . 2 . >> |
Посл.ответ | Сообщение |
|
Создано: 03 марта 2011 00:50 · Личное сообщение · #1 Собственно возникла задача из кода драйвера определять наличие подключенных юсб-устройств и получить от них для начала хоть дескрипторы. Познания в написании драйверов ближе к начальному уровню, поэтому прошу сильно не пинать. Как вариант решения вижу (слыхал) нужно опросить хабы на наличие подключенных к портам устройств, но вот как это реализовать в коде ring0 не знаю. Подскажите, с чего начинать, а может есть готовые примеры? Или юсб-устройства можно тоже получить по перебору типа phisicalDevice? |
|
Создано: 03 марта 2011 01:10 · Личное сообщение · #2 |
|
Создано: 03 марта 2011 01:34 · Личное сообщение · #3 |
|
Создано: 03 марта 2011 01:55 · Личное сообщение · #4 не, не думаю что это зависит от уровня перебора, ибо все PhysicalDrive мы видим в проводнике хотя-бы, а хасп ключи там никогда не появляются, это видимо определяется свойствами подключаемого девайса(дескрипторами например или еще как-то). Поэтому думаю перебор по PhysicalDrive не подходит, ибо инетересуют в основном то ключи. |
|
Создано: 03 марта 2011 05:24 · Поправил: PE_Kill · Личное сообщение · #5 NikolayD пишет: скорее всего не обнаруживается потому, что в ринг3 перебираете Потому что интерфейсы устройств разные, соответственно и CLASS GUID другой. Это то же самое что искать клавиатуру в мониторах. ЗЫ Из ring3 нужно работать с PnP Code:
----- Yann Tiersen best and do not fuck | Сообщение посчитали полезным: ARCHANGEL, NikolayD |
|
Создано: 03 марта 2011 09:49 · Личное сообщение · #6 Tolkin Даже когда вот так обходите, то не видите хасп? ----- Stuck to the plan, always think that we would stand up, never ran. |
|
Создано: 03 марта 2011 11:35 · Поправил: DenCoder · Личное сообщение · #7 |
|
Создано: 03 марта 2011 11:56 · Личное сообщение · #8 |
|
Создано: 03 марта 2011 12:17 · Личное сообщение · #9 И раз уж нужно реализовывать в р0, то без виртуальных машин не обойтись. А раз так, то ставьте WMware нпример, создавайте вм, ставьте ось, ставьте WinDbg подключайтесь к вм через виртуальный com-порт или usb и дебажьте, должно во мнгом помочь. Для работы с реестром обычно используют сервисы nt!ZwQueryKey, nt!ZwCreateKey, nt!ZwOpenKey... Для получения хендла хаспа можно использовать nt!ZwCreateFile. ----- IZ.RU |
|
Создано: 03 марта 2011 12:41 · Личное сообщение · #10 |
|
Создано: 03 марта 2011 12:44 · Личное сообщение · #11 |
|
Создано: 03 марта 2011 12:57 · Личное сообщение · #12 Ринг3 варианты как-бы не нужны, ибо там все намного проще(через те же CLASS GUID) и есть реализовано. - По поводу парсинга реестра из драйвера - вполне приемлимый вариант, т.е. ищем символьные имена типа \??\USB#VID_0529&PID_0001#5&22a20d61&0&1#{a5dcbf10-6530-11d2-901f-00c04fb951ed}, а дальше через ZwCreateFile пробуем открыть устройство, и если все нормально то можно слать IOCTL. Недостаток такого способа - мы будем также нумеровать и все виртуальные юсб мули, а они в даной задаче не нужны. - r_e пишет: Нужно проенумить хабы, а затем послать им запрос на подключенные устройства. можно этот способ поподробней? т.е. опять же какие имена перебирать для открытия хабов и какие потом запросы слать. Но если я правильно знаю через информацию с порта хаба можно получить только дескрипторы устройства? можно ли через опрос хаба получить символьное имя присоединенного устройства(или какое другое), чтоб открыть его потом через ZwCreateFile, или надо идти какими другими обходными путями? |
|
Создано: 03 марта 2011 12:59 · Поправил: Tolkin · Личное сообщение · #13 ARCHANGEL пишет: Какова конечная цель всего этого? Конечная цель - работать из драйвера с реальным донглом (т.е. вызывать его функи) т.е. 1. найти необходимое имя реального девайса для его открытия. 2. пробовать работать с донглом минуя его родные дрова (только куда надо слать запросы в таком случае и то ли устройство мы открываем, чтоб (пример хаспа) слать уже сам пакет URB_FUNCTION_VENDOR_DEVICE) ЗЫ. хотя после открытия устройства и посыла ему IOCTL хз как он пойдет, через родные дрова хаспа или нет. Кстати тот же хасп имеет типа 3 разных символьных имени, соответственно вероятно и пути следования пакетов будут разные. |
|
Создано: 03 марта 2011 13:38 · Личное сообщение · #14 Tolkin Можете попробовать usb_lib для реализации своих фантазий. Для каждого найденного через реестр устройства отсылаете GET_DESCRIPTOR с нужным типом и получаете символьное имя. Работать с усб устройствами мимо их родных дров - не самый надежный способ. И если вы таким образом собираетесь обойти эмуляторы могу вас огорчить - ничего не выйдет. ----- старый пень |
|
Создано: 03 марта 2011 15:19 · Личное сообщение · #15 |
|
Создано: 03 марта 2011 18:59 · Личное сообщение · #16 |
|
Создано: 03 марта 2011 20:40 · Поправил: DenCoder · Личное сообщение · #17 Tolkin пишет: т.е. ищем символьные имена типа \??\USB#VID_0529&PID_0001#5&22a20d61&0&1#{a5dcbf10-6530-11d2-901f-00c04fb951ed} DenCoder пишет: в подразделе Services можно найти службу хаспа, где в подразделе Enum можно найти ключ Count, а за ним нужный подключ в root!!! служба хаспа - одно, служба эмуля - другое, другими словами они в разных ветках! Tolkin пишет: Подскажите, с чего начинать Прочитать все про kernel services, порядок загрузки драйверов... Ключом к поиску может служить EnumServicesStatusEx, например. Tolkin пишет: а может есть готовые примеры? Должны быть. Но не рекомендую изучать kernel-простанство по исходникам, лучше сначала подготовиться теоретически. Только в "экстренных" случаях можно по кодам дров учиться, но и то параллельно долбить теоретическую часть! Хотя бы, связанную с используемыми сервисами. ----- IZ.RU |
|
Создано: 04 марта 2011 01:53 · Личное сообщение · #18 |
|
Создано: 04 марта 2011 14:23 · Поправил: Hexxx · Личное сообщение · #19 Если хочется общаться на самом низком уровне то через UsbBuildGetDescriptorRequest UsbBuildInterruptOrBulkTransferRequest и дальше фигачить в пайп хаба. Как найти пайп хаба не знаю, не пробовал. Обычно хватало энумерации девайсов более высокоуровневыми методами. ----- Реверсивная инженерия - написание кода идентичного натуральному |
|
Создано: 04 марта 2011 15:29 · Личное сообщение · #20 Нарыл еще полезный материал по этой теме. Оказывается, полезный и рабочий код режима ядра можно найти только в сорсах например руткитов ) Вот один такой мне попался, там реализована работа (кроме всего прочего) с файлами через Irp пакеты, на примере которых все становится намного понятней. А код энумерации хабов с получением обьектов донглов нашел в одной проге с драйвером - код используется для детектирования эмуляторов. Вообщем вот такой винегрет ) |
|
Создано: 05 марта 2011 21:29 · Личное сообщение · #21 Пример, нписанный под х32 бсодит при х64. Подозрение что структуры IRP пакетов для х32 и 64 разные? (например та же URB_CONTROL_DESCRIPTOR_REQUEST в иде имеют разные длины) ну структуры я поменяю, вопрос вот в чем. 1. Формируем новый IRP через IoBuildDeviceIoControlRequest 2. Отдельно формируем нужный нам URB_CONTROL_DESCRIPTOR_REQUEST 3. Подставляем указатель на наш URB в сам IRP. Вот здесь я немного запутался, куда именно его подставить в х64. в моем варианте в х32 ставится сюда Code:
меняется ли эта точка входа в х64? и может есть имя этого параметра без смещения как тут (-8) ? |
|
Создано: 06 марта 2011 00:12 · Личное сообщение · #22 |
|
Создано: 06 марта 2011 01:08 · Личное сообщение · #23 |
|
Создано: 06 марта 2011 01:17 · Личное сообщение · #24 |
|
Создано: 06 марта 2011 09:15 · Личное сообщение · #25 |
|
Создано: 06 марта 2011 11:23 · Поправил: Tolkin · Личное сообщение · #26 ARCHANGEL да этот есть Code:
но по сути вроде не то, а похоже на Code:
только непонятно зачем нужно это ЗЫ. И если это точно вызов IoSetNextIrpStackLocation, то (-8) значит что вызываем дважды ? |
|
Создано: 06 марта 2011 11:58 · Личное сообщение · #27 |
|
Создано: 06 марта 2011 12:16 · Личное сообщение · #28 |
|
Создано: 06 марта 2011 15:17 · Личное сообщение · #29 |
|
Создано: 06 марта 2011 17:41 · Личное сообщение · #30 |
. 1 . 2 . >> |
eXeL@B —› Программирование —› энумерация USB-устройств в драйвере |