Форум программистов, компьютерный форум, киберфорум
Assembler: Windows/protected mode
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.67/21: Рейтинг темы: голосов - 21, средняя оценка - 4.67
Asm/C++/Delphi/Py/PHP/VBA
 Аватар для Jin X
6808 / 2048 / 238
Регистрация: 14.12.2014
Сообщений: 4,297
Записей в блоге: 12

NtOpenSection → OpenFileMapping

30.09.2018, 23:06. Показов 4846. Ответов 47
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет!

Подскажите, кто знает, как открыть \Device\PhysicalMemory через OpenFileMapping, а не через NtOpenSection ?
Проблема в том, что OpenFileMapping задаёт в качестве поля ObjectAttributes.RootDirectory (при вызове NtOpenSection) значение, возвращаемое BaseGetNamedObjectDirectory(), а не NULL. Т.е. если заменить это поле на NULL (изнутри функции OpenFileMappingW), всё работает. Иначе возвращается ошибка.

MSDN пишет про поле RootDirectory:
Optional handle to the root object directory for the path name specified by the ObjectName member. If RootDirectory is NULL, ObjectName must point to a fully qualified object name that includes the full path to the target object. If RootDirectory is non-NULL, ObjectName specifies an object name relative to the RootDirectory directory. The RootDirectory handle can refer to a file system directory or an object directory in the object manager namespace.
Т.е. надо полный путь \Device\PhysicalMemory преобразовать относительно пути, хендл которого выдаёт BaseGetNamedObjectDirectory(). Как это сделать?
Я так понял, это путь \BaseNamedObjects, только что это за путь и как относительно него адресовать \Device\PhysicalMemory – х/з.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
30.09.2018, 23:06
Ответы с готовыми решениями:

Выполнить преобразование: 140,536→[?]5→[?]4→[?]7
Выполнить преобразование: 140,536→5→4→7 Добавлено через 2 часа 40 минут Просто я гуманитарий, а нам задали в институте порешать вот...

Вывести закон контрапозиции (A→¬B)→(B→¬A)
Вывести закон контрапозиции (A→¬B)→(B→¬A): Откуда взялись эти леммы?: 1) A→B, B→C⊢A→C 2)A→(B→C)⊢B→(A→C)...

Word 2016/2019, уравнение → конструктор → Сумма
Независимо от того, какой значек я нажимаю, вставленный значек суммы всегда имеет вид, как на правом значке Это можно как-то...

47
328 / 81 / 2
Регистрация: 21.07.2018
Сообщений: 112
Записей в блоге: 1
01.10.2018, 05:55
Может быть, \\.\Device\PhysicalMemory
как у других устройств?

Это на XP?
0
 Аватар для Ethereal
6773 / 2741 / 385
Регистрация: 17.02.2013
Сообщений: 4,048
01.10.2018, 06:18
Ни хрена не понимаю в этой галиматье, но имею сказать, что если у тебя имеется хендл ObjectAttributes.RootDirectory , то применив его к
NTSTATUS
ObReferenceObjectByHandle(
IN HANDLE Handle,
IN ACCESS_MASK DesiredAccess,
IN POBJECT_TYPE ObjectType OPTIONAL,
IN KPROCESSOR_MODE AccessMode,
OUT PVOID *Object,
OUT POBJECT_HANDLE_INFORMATION HandleInformation OPTIONAL
)
ты получишь *Object - corresponding pointer to the object's body. А там в этой "боде" как выглядит
Цитата Сообщение от Jin X Посмотреть сообщение
что это за путь
посмотреть ?
Т.е. если в поле ObjectAttributes.RootDirectory лежит хендл объекта Рут_Директори, то получить по этому хендлу адрес самого объекта Рут_Директори и посмотреть что там лежит. Ну там строчки или ссылки на строчки. Должен же там этот путь Рут_Директори в виде строки лежать.
0
Модератор
2131 / 1000 / 170
Регистрация: 23.07.2018
Сообщений: 3,349
Записей в блоге: 3
01.10.2018, 09:49
Из Win32 объекты могут быть и не видны под своими именами.

Добавлено через 6 минут
https://docs.microsoft.com/en-... namespaces

Добавлено через 56 минут

>dir lpt9

Содержимое папки \\.

Файл не найден

Цитата Сообщение от ОС Посмотреть сообщение
\\.\Device\PhysicalMemory
как у других устройств?
Если как других, то должно быть что-то вроде \\.\PhysicalMemory
0
Asm/C++/Delphi/Py/PHP/VBA
 Аватар для Jin X
6808 / 2048 / 238
Регистрация: 14.12.2014
Сообщений: 4,297
Записей в блоге: 12
01.10.2018, 15:11  [ТС]
Цитата Сообщение от ОС Посмотреть сообщение
Это на XP?
Да. И ниже.

Цитата Сообщение от ОС Посмотреть сообщение
Может быть, \\.\Device\PhysicalMemory
как у других устройств?
Я тоже так думал, но это не работает
GetLastError выдаёт 000000A1 (ERROR_BAD_PATHNAME), (NtOpenSection выдаёт там C000003B (STATUS_OBJECT_PATH_SYNTAX_BAD)).

Цитата Сообщение от Ethereal Посмотреть сообщение
Должен же там этот путь Рут_Директори в виде строки лежать.
А что толку? Как это мне поможет правильно адресовать нужный мне путь? К тому же, я почти уверен, что это
Цитата Сообщение от Jin X Посмотреть сообщение
\BaseNamedObjects
(где-то нашёл эту инфу)

Цитата Сообщение от politoto Посмотреть сообщение
\\.\PhysicalMemory
К сожалению, это тоже не работает. Ошибка та же
0
Модератор
2131 / 1000 / 170
Регистрация: 23.07.2018
Сообщений: 3,349
Записей в блоге: 3
01.10.2018, 15:19
А в чём минусы NtOpenSection?

Может быть, попробовать добавить ДОС-устройство? Это же символическая ссылка на объект.
0
 Аватар для Ethereal
6773 / 2741 / 385
Регистрация: 17.02.2013
Сообщений: 4,048
01.10.2018, 20:34
Цитата Сообщение от Jin X Посмотреть сообщение
Как это мне поможет
Цитата Сообщение от Jin X Посмотреть сообщение
К тому же, я почти уверен
Вот это почти отпадет.
Цитата Сообщение от Jin X Посмотреть сообщение
Я так понял, это путь \BaseNamedObjects, только что это за путь и как относительно него адресовать \Device\PhysicalMemory – х/з.
Если думать тупорыло, то ..\..\..\Device\PhysicalMemory , т.е. три раза вверх по пути от \BaseNamedObjects и там будет корень в котором \Device
1
Asm/C++/Delphi/Py/PHP/VBA
 Аватар для Jin X
6808 / 2048 / 238
Регистрация: 14.12.2014
Сообщений: 4,297
Записей в блоге: 12
02.10.2018, 00:20  [ТС]
Цитата Сообщение от politoto Посмотреть сообщение
А в чём минусы NtOpenSection?
Мне интересно сделать без натива.
Ну и через OpenFileMapping не надо инициализировать ObjectAttributes и записывать строку в UNICODE-формате (да, я понимаю, что там куча обёрток и пр. ерунды).

Цитата Сообщение от Ethereal Посмотреть сообщение
т.е. три раза вверх
Почему три? И почему не с \ начинается?
В общем, перепробовал 6 вариантов:
..\PhysicalMemory
\..\PhysicalMemory
..\..\PhysicalMemory
\..\..\PhysicalMemory
..\..\..\PhysicalMemory
\..\..\..\PhysicalMemory
Всё бестолку. Иногда, правда, вместо STATUS_OBJECT_PATH_SYNTAX_BAD выдаётся STATUS_OBJECT_PATH_NOT_FOUND.
0
 Аватар для Ethereal
6773 / 2741 / 385
Регистрация: 17.02.2013
Сообщений: 4,048
02.10.2018, 06:09
Цитата Сообщение от Jin X Посмотреть сообщение
В общем, перепробовал 6 вариантов:
..\PhysicalMemory
\..\PhysicalMemory
..\..\PhysicalMemory
\..\..\PhysicalMemory
..\..\..\PhysicalMemory
\..\..\..\PhysicalMemory
Тут \Device куда-то подевалось.
Цитата Сообщение от Jin X Посмотреть сообщение
Почему три?
Просто предположил, что речь шла о \Sessions\1\BaseNameObjects и тогда до корня надо 3 раза вверх. Но я-же говорю, что ничего в этой галиматье не понимаю. Просто у меня большой опыт разбираться в черных ящиках. Когда знаний почерпнуть неоткуда кроме как из самого черного ящика. Так-что представляю, что у тебя там черный ящик и каким бы я тогда пошел логическим ходом
Нет, ну реально, берем черный ящик, документации по нему тебе не дадут, кто в нем понимает говорить с тобой не станет и начинаем с "тупорыло предположим, что".
Все равно того кто знает в топике нет, так-что чем в данном случае не метод ?

Вот есть такая дивная утилита : https://docs.microsoft.com/en-... ads/winobj
Если она показывает то с чем ты имеешь дело, то \BaseNameObjects там в двух местах, в корне и внутри \Sessions\1 , \Device есть, а вот \Device\PhysicalMemory что-то не видать.

Добавлено через 4 часа 35 минут
Цитата Сообщение от Jin X Посмотреть сообщение
Иногда, правда, вместо STATUS_OBJECT_PATH_SYNTAX_BAD
А это STATUS_OBJECT_PATH_SYNTAX_BAD было когда начало пути \.. или когда .. ?
1
Asm/C++/Delphi/Py/PHP/VBA
 Аватар для Jin X
6808 / 2048 / 238
Регистрация: 14.12.2014
Сообщений: 4,297
Записей в блоге: 12
02.10.2018, 19:45  [ТС]
Цитата Сообщение от Ethereal Посмотреть сообщение
Тут \Device куда-то подевалось.

Тем не менее, добавление \Device не помогло.

Цитата Сообщение от Ethereal Посмотреть сообщение
А это STATUS_OBJECT_PATH_SYNTAX_BAD было когда начало пути \.. или когда .. ?
Когда \..
0
 Аватар для Ethereal
6773 / 2741 / 385
Регистрация: 17.02.2013
Сообщений: 4,048
03.10.2018, 01:31
Боюсь, что
Название может иметь префикс "Global" или "Local", чтобы явно открывать объект в глобальном или сессионном пространстве имен. Остаточный член имени может содержать любые символы кроме символа обратного слэша (\).
то есть у функции OpenFileMapping принудительно закрыта возможность ползать по путям куда захочется.

Добавлено через 4 минуты
Global или Local - это символические ссылки. Global - ссылка на \BaseNamedObjects . И еще вижу ссылку Section . Вот если бы там лежала бы еще одна символическая ссылка на \Device . Если ее как-нибудь туда подкинуть.

Добавлено через 15 минут
По ссылкам вроде-бы можно бегать сколько угодно. Например до объекта \BaseNamedObjects\RasPbFile я вроде как добрался (сужу только по изменениям номеров ошибок) именем "RasPbFile" и именем "Session\0\RasPbFile" где ссылка Session указывает на \Sessions\BNOLINK , внутри которого еще одна ссылка 0 на \BaseNamedObjects . То есть по ссылкам я прошел как-бы по кругу.
0
328 / 81 / 2
Регистрация: 21.07.2018
Сообщений: 112
Записей в блоге: 1
03.10.2018, 06:02
У меня вроде получилось сделать какую-то ссылку.
Code
1
2
3
4
5
6
7
8
(gdb) p QueryDosDeviceA( "lpt4", buffer, 4000 )
$14 = 0
(gdb) p DefineDosDeviceA(1, "lpt4", "\\Device\\PhysicalMemory")
$15 = 1
(gdb) p QueryDosDeviceA( "lpt4", buffer, 4000 )
$16 = 24
(gdb) x /s buffer
0x22ef8c:        "\\Device\\PhysicalMemory"
Команды type lpt4, copy ругаются на Неверный дескриптор.
0
Asm/C++/Delphi/Py/PHP/VBA
 Аватар для Jin X
6808 / 2048 / 238
Регистрация: 14.12.2014
Сообщений: 4,297
Записей в блоге: 12
03.10.2018, 11:50  [ТС]
Цитата Сообщение от Ethereal Посмотреть сообщение
то есть у функции OpenFileMapping принудительно закрыта возможность ползать по путям куда захочется.
Есть такое подозрение, но мало ли?

Цитата Сообщение от ОС Посмотреть сообщение
У меня вроде получилось сделать какую-то ссылку.
Я так и не понял, какая ссылка в итоге получилась? lpt4 не стал же алиасом \Device\PhysicalMemory.
0
Модератор
2131 / 1000 / 170
Регистрация: 23.07.2018
Сообщений: 3,349
Записей в блоге: 3
03.10.2018, 12:32
Jin X, если не стал, то где-то в DosDevices или ещё где-нибудь есть соответствие lpt4 -> [inline]\Device\PhysicalMemory[/quote]

Если бы это было не так, почему тогда QueryDosDevice( "lpt4") вернул \Device\PhysicalMemory ?
Напрямую через досовое имя секция, скорее всего, не окроется, хотя бы потому, что искать начинает с другого корня, но можно попытаться найти эту ссылку через относительный путь.

Добавлено через 10 минут
Но лучше, наверно, не пытаться, а пользоваться тем, что работает.
Для подобных программ и предназначены нативные функции.
0
 Аватар для Ethereal
6773 / 2741 / 385
Регистрация: 17.02.2013
Сообщений: 4,048
03.10.2018, 20:39
Просто идея. Лень проверять. Если с помощью NtCreateSymbolicLinkObject в \BaseNamedObjects создать символическую ссылку Blabla на \Device , то именем Blabla\PhysicalMemory ты бы открыл то, что тебе нужно. Если в \BaseNamedObjects уже есть три символические ссылки, то они должны обрабатываться каким-то общим алгоритмом. Ну и раз по этим трем ссылкам мы ходить можем, то и по четвертой сможем.

Добавлено через 3 минуты
Просто пока у меня получется, что ос отказывается воспринимать .. как переход на каталог вверх в этом пространстве имен объектов. ..\BaseNamedObjects по идее должна не изменять путь, потому-что сначала вверх, а потом обратно вниз. Но ругается ERROR_PATH_NOT_FOUND. Ну и если по .. пройти наверх нельзя, то по ссылке-то можно и сразу куда нужно.

Добавлено через 1 минуту
Вот так бегать по ссылкам туда-сюда не вопрос "Local\Global\Local\Global\Local\Global\ Local\Global\RasPbFile"

Добавлено через 51 минуту
NtCreateSymbolicLinkObject , как понял, должна создать ссылку, которая не есть перманентный объект. Как только ты проделаешь CloseHandle с хендлом этой ссылки она удалится. Но это ведь то, что надо. Временной ссылкой проложить куда надо путь. Проторить так-сказать дорогу.
1
Модератор
2131 / 1000 / 170
Регистрация: 23.07.2018
Сообщений: 3,349
Записей в блоге: 3
04.10.2018, 07:22
Зачем торить, если NtOpenSection() сразу открывает \Device\PhysicalMemory ?
0
 Аватар для Ethereal
6773 / 2741 / 385
Регистрация: 17.02.2013
Сообщений: 4,048
04.10.2018, 09:37
Цитата Сообщение от politoto Посмотреть сообщение
Зачем торить, если NtOpenSection() сразу открывает \Device\PhysicalMemory ?
Читать что писал тс будем ?
Цитата Сообщение от Jin X Посмотреть сообщение
Подскажите, кто знает, как открыть \Device\PhysicalMemory через OpenFileMapping, а не через NtOpenSection ?
Да сам топик называется NtOpenSection → OpenFileMapping
0
Модератор
2131 / 1000 / 170
Регистрация: 23.07.2018
Сообщений: 3,349
Записей в блоге: 3
04.10.2018, 09:48
Цитата Сообщение от Jin X Посмотреть сообщение
Сообщение от politoto
А в чём минусы NtOpenSection?
Мне интересно сделать без натива.
Для создания ссылок где угодно может понадобиться больше захватить прав и запросить привилегий, чем для открытия существующего объекта
0
Эксперт Hardware
Эксперт Hardware
 Аватар для R71MT
6206 / 2441 / 402
Регистрация: 29.07.2014
Сообщений: 3,174
Записей в блоге: 4
04.10.2018, 10:36
Лучший ответ Сообщение было отмечено Jin X как решение

Решение

М.Руссинович, Д.Соломон
Внутреннее устройство Microsoft Windows. 6-е изд.


Место хранения имен объектов зависит от типа объекта.
В табл. 3.17 перечислены стандартные каталоги объектов, находящиеся во всех системах Windows, и те типы объектов, чьи имена в них хранятся. Из перечисленных каталогов стандартные Win-приложения видят только каталоги \BaseNamedObjects и \Global?? (см.раздел «Пространство имен сеанса»).
Для этой функции запрещена косая черта в любом виде: хоть в голове, хоть в тушке.
Разрешено читать только содержимое указанных выше каталогов по именам объектов, которое ищется сначала в "\BaseName", потом в "\Global??". Если такого имени нет, то встречаем ошибку "Файл не найден!".

Можно создавать объекты самому чз "CreateFileMapping", но они помещаются только в эти каталоги, а "\Device" находится выше, ..значит подобраться к нему будет проблематично. Хоть ты и получишь как-нибудь ссылку, то нужно будет указать её в пути, опять-же через косую черту, которая запрещена.

Например вот прожка для теста ошибки (чтоб не ловить эрроры в отладчике), и при косой черте в любом виде выплёвывает "Недопустимый путь!". Если оставить только "PhysicalMemory", то и создаётся и открывается без проблем, но только в дирах Base и Global, а значит драйверам IO (которые читаю память) из папки \Device, этот файл становится не доступным.
Assembler
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
format   PE gui
include  'win32ax.inc'
 
.data
szName   db  '\Device\PhysicalMemory',0
lpfmt    db  'Error code: %08X',0
buff     db  32 dup(0)
errMes   db  128 dup(0)
 
.code
start:
;        invoke  CreateFileMappingA,0,0,PAGE_READONLY,0,512,szName
;       stdcall  GetError
 
        invoke  OpenFileMapping,FILE_MAP_READ,0,szName
       stdcall  GetError
 
        invoke  ExitProcess,0
 
;-- Сообщение об ошибке ------------
GetError:
        invoke  GetLastError
        invoke  FormatMessage,FORMAT_MESSAGE_FROM_SYSTEM,0,eax,0,errMes,128,0
        invoke  MessageBox,0, errMes, <'Get_Last_Error',0>, 0
ret
;-- Код ошибки ---------------------
GetErrorCode:
        invoke  GetLastError
       cinvoke  wsprintf,buff,lpfmt,eax
        invoke  MessageBox,0, buff,<'GetLastError',0>, 0
ret
.end start
По сабжу, почитать ещё можно Рихтер. Windows для профессионалов
он разжёвывает тему объектов не по-детски и с примерами.
3
Asm/C++/Delphi/Py/PHP/VBA
 Аватар для Jin X
6808 / 2048 / 238
Регистрация: 14.12.2014
Сообщений: 4,297
Записей в блоге: 12
04.10.2018, 13:47  [ТС]
В общем, получается, что задача нерешаемая, открыть можно только через NtOpenSection...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.10.2018, 13:47
Помогаю со студенческими работами здесь

Упростить формулу A^(B→A)→Ā. Проверьте результат, используя таблицу истинности
Упростить формулу A^(B→A)→Ā. Проверьте результат, используя таблицу истинности.

(A → B) ∧ (B→¬ A ) ∧(C→A) упростите формулу
(A → B) ∧ (B→¬ A ) ∧(C→A) упростите формулу на основе законах логики, A → B =¬ A ⌵B

Эта функция имеет форму :f(0)→ [] Unitless, а должна иметь форму: f(0)→ any1
Добрый день, помогите пожалуйста кто умеет работать в MathCAD, необходимо построить в курсовой график зависимости. Появляется сообщение...

Создать таблицу → Считать в двумерный массив → Вывести в таблицу
Добрый день. Необходимо создать динамическую таблицу M x N, считать из нее данные и вывести результат в такую же таблицу. Буду рад...

Что нужно сделать, чтобы получить доступ к OpenFileMapping
Подскажите пожалуйста, кто использовал метод OpenFileMapping? У меня программа ругается, говорит что такого метода не существует. ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru