Работа с описателями

Обсуждение статей, опубликованных на сайте.
gaidar
System Debugger
System Debugger
 
Сообщения: 3152
Зарегистрирован: 23.12.2001 (Вс) 13:22

Сообщение gaidar » 10.06.2006 (Сб) 18:51

Подойдет. Если не сложно, то вышли, пожалуйста, на gaidar.magdanurov@gmail.com все, что у тебя к публикации готово. Иначе я просто забываю опубликовать на сайте когда время появляется.
The difficult I’ll do right now. The impossible will take a little while. (c) US engineers in WWII
I don't always know what I'm talking about, but I know I'm right. (c) Muhammad Ali

tyomitch
Пользователь #1352
Пользователь #1352
Аватара пользователя
 
Сообщения: 12822
Зарегистрирован: 20.10.2002 (Вс) 17:02
Откуда: חיפה

Сообщение tyomitch » 14.06.2006 (Ср) 16:41

Утроенный по объёму вариант -- в аттаче. Продублировать на мыло?
Вложения
Строки в VB6.zip
(16.43 Кб) Скачиваний: 659
Изображение

gaidar
System Debugger
System Debugger
 
Сообщения: 3152
Зарегистрирован: 23.12.2001 (Вс) 13:22

Сообщение gaidar » 14.06.2006 (Ср) 18:56

Продублируй, если не сложно.
The difficult I’ll do right now. The impossible will take a little while. (c) US engineers in WWII
I don't always know what I'm talking about, but I know I'm right. (c) Muhammad Ali

ANDLL
Великий гастроном
Великий гастроном
Аватара пользователя
 
Сообщения: 3450
Зарегистрирован: 29.06.2003 (Вс) 18:55

Сообщение ANDLL » 08.08.2006 (Вт) 14:47

Интересно узнать у автора статьи, почему он использует VirtualAlloc а не HeapAlloc? Ведь первая выделяет память по несколько килобайт срау.
Гастрономия - наука о пище, о ее приготовлении, употреблении, переварении и испражнении.
Блог

tyomitch
Пользователь #1352
Пользователь #1352
Аватара пользователя
 
Сообщения: 12822
Зарегистрирован: 20.10.2002 (Вс) 17:02
Откуда: חיפה

Сообщение tyomitch » 08.08.2006 (Вт) 15:48

А автор и выделяет как раз по несколько килобайт сразу...
Изображение

ANDLL
Великий гастроном
Великий гастроном
Аватара пользователя
 
Сообщения: 3450
Зарегистрирован: 29.06.2003 (Вс) 18:55

Сообщение ANDLL » 08.08.2006 (Вт) 17:58

Ааа. Ну тогда это... Что бы не вводить меня в заблуждение. 1 страница(4 Кб) это 4096 байт, а не 4000...[/code]
Гастрономия - наука о пище, о ее приготовлении, употреблении, переварении и испражнении.
Блог

tyomitch
Пользователь #1352
Пользователь #1352
Аватара пользователя
 
Сообщения: 12822
Зарегистрирован: 20.10.2002 (Вс) 17:02
Откуда: חיפה

Сообщение tyomitch » 08.08.2006 (Вт) 19:37

ANDLL, предлагаешь сэкономить 96 байт? ;-)
Изображение

ANDLL
Великий гастроном
Великий гастроном
Аватара пользователя
 
Сообщения: 3450
Зарегистрирован: 29.06.2003 (Вс) 18:55

Сообщение ANDLL » 08.08.2006 (Вт) 19:46

Нет, просто я плохо сосчитал нули, и мне сначала показалось, что там 400... Если бы там было написано все как у людей(то есть 4096) я бы не ошибся и не пришлось бы писать сообщение.
Гастрономия - наука о пище, о ее приготовлении, употреблении, переварении и испражнении.
Блог

GM
programador
programador
 
Сообщения: 1427
Зарегистрирован: 24.06.2003 (Вт) 15:56
Откуда: 194.67.52.100

Сообщение GM » 08.08.2006 (Вт) 23:37

Все же в статье есть некоторые ошибки в оглашении структур, а именно:
Код: Выделить всё
  Reserved1(4) As Long
...
Reserved2(4) As Long

Видимо когда автор переводил из Си, где в оглашении написано
Код: Выделить всё
ULONG Reserved1[4];
...
ULONG Reserved[4];

забыл что в VB по умолчанию(Option Base 0), Reserved1(4) означает Reserved(0 to 4), а не Reserved[0..3] как в Си.
Мелочь но все же :roll:
الفيجوال بيسك الرابح

Twister
Теоретик
Теоретик
Аватара пользователя
 
Сообщения: 2251
Зарегистрирован: 28.06.2005 (Вт) 12:32
Откуда: Алматы

Сообщение Twister » 09.08.2006 (Ср) 5:21

Интересно узнать у автора статьи, почему он использует VirtualAlloc а не HeapAlloc? Ведь первая выделяет память по несколько килобайт срау.
Привычка такая. Для больших объемов (больше 4кб) я ее обычно использую. Тем более, что для HeapAlloc необходимо еще и кучу найти, а это лишние телодвижения. :)
1 страница(4 Кб) это 4096 байт, а не 4000...
Но выделится-то все равно страница размером 4096 байт. Впрочем Темыч уже ответил...

GM
Тебе спасибо, я и правда не взял в расчет OptionBase... :oops:

Эй, народ! А что по поводу второй статьи? Ее что, ни кто не осилил? :wink:
А я все практикую лечение травами...

tyomitch
Пользователь #1352
Пользователь #1352
Аватара пользователя
 
Сообщения: 12822
Зарегистрирован: 20.10.2002 (Вс) 17:02
Откуда: חיפה

Сообщение tyomitch » 16.02.2007 (Пт) 17:08

Став писать аналогичную прогу, обнаружил более тонкие баги.

>"SYSTEM_HANDLE_INFORMATION = 2"
разве не 16? в моём справочнике 2=SystemPerformanceInformation.

>"но мы не будем использовать этот параметр"
а зря, при нехватке места туда положат требуемый размер -- и не нужен перебор

>"Открываем процесс-владелец описателя с доступом PROCESS_DUP_HANDLE и копируем описатель к себе"
мне для этого потребовалось включить SeDebugPrivilege, иначе не давало
Изображение

tyomitch
Пользователь #1352
Пользователь #1352
Аватара пользователя
 
Сообщения: 12822
Зарегистрирован: 20.10.2002 (Вс) 17:02
Откуда: חיפה

Сообщение tyomitch » 16.02.2007 (Пт) 23:26

И ещё один вопрос вдогонку: как по хэндлу дочернего объекта узнать родительский? (В моём случае, по хэндлу файла -- том.)
Изображение

tyomitch
Пользователь #1352
Пользователь #1352
Аватара пользователя
 
Сообщения: 12822
Зарегистрирован: 20.10.2002 (Вс) 17:02
Откуда: חיפה

Сообщение tyomitch » 17.02.2007 (Сб) 18:11

(Уже и не надеясь завладеть вниманием автора)

> "запрашивая информацию о хэндле ... (ZwQueryObject или ZwQueryInformationFile, не важно) ... вызывающий поток ... «умирает». Самое ужасное что такой «мертвый» поток уже невозможно никак закрыть, а процесс, имеющий такие потоки выгружается из памяти только по ресету"

Мои эксперименты с Win2000 показали, что поток, замерший в ZwQueryInformationFile, отлично убивается. Замерший в ZwQueryObject -- действительно, бессмертный.
Изображение

Twister
Теоретик
Теоретик
Аватара пользователя
 
Сообщения: 2251
Зарегистрирован: 28.06.2005 (Вт) 12:32
Откуда: Алматы

Сообщение Twister » 03.04.2007 (Вт) 7:24

tyomitch писал(а):(Уже и не надеясь завладеть вниманием автора)
Да, меня сейчас в сети практически не бывает. Много работы - времени посидеть и почитать форумы катастрофически не хватает. Ну а если находится время посидеть за компом "для себя", то посвещяю его написанию вируса, который уже почти готов... Так что извеняюсь за то, что вопросы ко мне оставались долгое время без ответа. Итак...

tyomitch писал(а):SYSTEM_HANDLE_INFORMATION = 2
Угу. Очепятка. Конечно 16.
tyomitch писал(а):при нехватке места туда положат требуемый размер -- и не нужен перебор
Это, конечно, было мне известно. Но я брал в расчет тот факт, что между двумя вызовами функции информация о хэндлах может поменяться (и не редко делает это!), а перебор гарантирует, что мы получим самую "свежую" инфу.
tyomitch писал(а):мне для этого потребовалось включить SeDebugPrivilege, иначе не давало
Да. А разве в исходниках я не включал эту привилегию?
tyomitch писал(а):как по хэндлу дочернего объекта узнать родительский? (В моём случае, по хэндлу файла -- том.)
Ну, вообще если бы не комментарий в скобках, то я б и не понял что ты имеешь ввиду. Хотя то, что без скобок и то, что в скобках - абсолютно разные вещи. Хэндл, как известно, просто индекс ячейки в трехуровневой таблице (два первых бита - уровень таблицы). Ячейка же указывает на сам объект ядра. Так вот, к чему я это - понятие "родительский объект" есть не у всех объектов. Вот у объекта "процесс" есть запись об ID родительского процесса (EPROCESS->InheritedFromUniqueProcessId), поэтому нет проблем узнать процесс-родитель. А у объекта "файл", как не сложно догадаться, нет "ссылки" на том. Зато есть ссылка на имя файла. Имя, если я не ошибаюсь, в Native'ном формате - "\Device\HardiskVolume3\WINNT". Отмечу, что из имени в нативном формате нельзя однозначно получить имя в Win32-формате (из "\Device\HardiskVolume3\WINNT" получить "K:\WINNT"), а вот наоборот можно. Как писалось в одной статье: "преобразование явно может не быть однозначным даже в случае компьютера без службы сервера, ибо существует программа subst." Т.е. единственный способ - это отсечь от имени начало - "\Device\HardiskVolume3", перебрать каталог объектов "\Global??" и найти симлинк, указывающий на то, что обозначено в "отсеченной части". Имя симлинка и будет буквой тома ("C:", "D:").

Надеюсь, что столь запоздалый ответ все же будет полезен...
А я все практикую лечение травами...

tyomitch
Пользователь #1352
Пользователь #1352
Аватара пользователя
 
Сообщения: 12822
Зарегистрирован: 20.10.2002 (Вс) 17:02
Откуда: חיפה

Сообщение tyomitch » 03.04.2007 (Вт) 11:17

Twister писал(а):
tyomitch писал(а):мне для этого потребовалось включить SeDebugPrivilege, иначе не давало
Да. А разве в исходниках я не включал эту привилегию?

Включал, но я-то читал статью, а не исходники :-)


(Про родительский объект я действительно спорол чушь, но когда это осознал, править свой пост не мог.)

Twister писал(а):Надеюсь, что столь запоздалый ответ все же будет полезен...

Увы, нет: уже самостоятельно наступил на все грабли, и дописал-таки ту прогу.
Изображение

Пред.

Вернуться в Статьи

Кто сейчас на конференции

Сейчас этот форум просматривают: нет зарегистрированных пользователей и гости: 2

    TopList  
cron