PDA

Просмотр полной версии : Hook d3d9::reset


Dark_Knight
19.08.2021, 01:59
Доброго времени суток граждане алкоголики, туниядцы и хулиганы. Есть ли у кого-то решение хукнуть ЧИСТОотдельный метод d3d9::reset? Акцент в плане вопроса сделан именно на том, чтобы хукнуть именно один метод.

kin4stat
19.08.2021, 02:45
Доброго времени суток граждане алкоголики, туниядцы и хулиганы. Есть ли у кого-то решение хукнуть ЧИСТОотдельный метод d3d9::reset? Акцент в плане вопроса сделан именно на том, чтобы хукнуть именно один метод.


Так не ставь хук на пресент и все

BulletTracer/fast/D3D/d3dhook.h at e20189b1d42ba0426807a16fd0dfbf31ee01f492 · kin4stat/BulletTracer (https://github.com/KiN4StAt/BulletTracer/blob/e20189b1d42ba0426807a16fd0dfbf31ee01f492/fast/D3D/d3dhook.h#L26)

Contribute to kin4stat/BulletTracer development by creating an account on GitHub.

github.com

loganhackerdff
19.08.2021, 03:27
Так не ставь хук на пресент и все

BulletTracer/fast/D3D/d3dhook.h at e20189b1d42ba0426807a16fd0dfbf31ee01f492 · kin4stat/BulletTracer (https://github.com/KiN4StAt/BulletTracer/blob/e20189b1d42ba0426807a16fd0dfbf31ee01f492/fast/D3D/d3dhook.h#L26)

Contribute to kin4stat/BulletTracer development by creating an account on GitHub.

github.com



Я когда юзал FindDevice жаловались что на семёрке крашит, с вмт хукером такого нет

kin4stat
19.08.2021, 03:35
Я когда юзал FindDevice жаловались что на семёрке крашит, с вмт хукером такого нет


vmt hook govno

(в gta:sa можно хукать по адресу девайса)

loganhackerdff
19.08.2021, 03:36
vmt hook govno
(в gta:sa можно хукать по адресу девайса)


Но он не крашит на семёрке, а finddevice этот крашит

Cake_
19.08.2021, 05:13
хукер urshadow

C++:






#define __RwD3DDevice 0x00C97C28
#define DIRECTX_VT_FUNC(offset) (reinterpret_cast(*reinterpret_cast(*reinterpret_c ast(__RwD3DDevice)))[offset])
HRESULT __stdcall
hkReset
(
IDirect3DDevice9
*
pDevice
,
D3DPRESENT_PARAMETERS
*
pPresentationParameters
)
{
HRESULT hres
=
hook_d3dReset
.
call

(
pDevice
,
pPresentationParameters
)
;
return
hres
;
}
hook_d3dReset
.
install
(
urmem
::
get_func_addr
(
DIRECTX_VT_FUNC
(
16
)
)
,
urmem
::
get_func_addr
(
&
hkReset
)
)
;

kin4stat
19.08.2021, 05:19
Код:






#define __RwD3DDevice 0x00C97C28
#define DIRECTX_VT_FUNC(offset) (reinterpret_cast(*reinterpret_cast(*reinterpret_c ast(__RwD3DDevice)))[offset])






C++:






constexpr
auto
__RwD3DDevice
=
0x00C97C28
;
void
*
DIRECTX_VT_FUNC
(
unsigned
int
offset
)
{
unsigned
long
Device
=
*
reinterpret_cast

(
__RwD3DDevice
)
;
return
*
reinterpret_cast

(
Device
)
[
offset
]
;
}




UPD:

C++20:

C++:






constinit
auto
__RwD3DDevice
=
0x00C97C28
;
void
*
DIRECTX_VT_FUNC
(
unsigned
int
offset
)
{
unsigned
long
Device
=
*
reinterpret_cast

(
__RwD3DDevice
)
;
return
*
reinterpret_cast

(
Device
)
[
offset
]
;
}

SR_team
19.08.2021, 05:26
C++:






constexpr
auto
__RwD3DDevice
=
0x00C97C28
;
constexpr
void
*
DIRECTX_VT_FUNC
(
unsigned
int
offset
)
{
unsigned
long
Device
=
*
reinterpret_cast

(
__RwD3DDevice
)
;
return
*
reinterpret_cast

(
Device
)
[
offset
]
;
}




UPD:
C++20:

C++:






constinit
auto
__RwD3DDevice
=
0x00C97C28
;
consteval
void
*
DIRECTX_VT_FUNC
(
unsigned
int
offset
)
{
unsigned
long
Device
=
*
reinterpret_cast

(
__RwD3DDevice
)
;
return
*
reinterpret_cast

(
Device
)
[
offset
]
;
}





consteval - выполнение строго во время компиляции. Что оно у тебя во время компиляции из 0x00C97C28; прочитает?

Dark_Knight
19.08.2021, 12:48
хукер urshadow

C++:






#define __RwD3DDevice 0x00C97C28
#define DIRECTX_VT_FUNC(offset) (reinterpret_cast(*reinterpret_cast(*reinterpret_c ast(__RwD3DDevice)))[offset])
HRESULT __stdcall
hkReset
(
IDirect3DDevice9
*
pDevice
,
D3DPRESENT_PARAMETERS
*
pPresentationParameters
)
{
HRESULT hres
=
hook_d3dReset
.
call

(
pDevice
,
pPresentationParameters
)
;
return
hres
;
}
hook_d3dReset
.
install
(
urmem
::
get_func_addr
(
DIRECTX_VT_FUNC
(
16
)
)
,
urmem
::
get_func_addr
(
&
hkReset
)
)
;





Вот это прям то что я искал. Спасибо. Я просто пробовал хукнуть по адрессу 0x6FFE0 для р1 и ловил краши. Тему можно закрыть.