hello how it's possible to code one protection for anti BPM (breakpoint hardware) ? :confused:
how erase the value of registry debug without passing by Ring 0 ? :confused:
Please give me one exemple with code source.
Thks for u help :)

@+++:alright:
Posted on 2004-06-23 00:37:09 by dicky96
You can desactivate those BP using API SetThreadContext (a way to reach
Ring0), that will clean the DRx registers, rendering inefective any hardware
BP set by the debugger. I don't know if this could be achevied without
using Ring0....

Sorry, no source under hand, you should go and have a look either at Daemon's
cave or http://www.yates2k.net/sysinfo.html

Regards
etherlord
Posted on 2004-06-23 01:18:10 by etherlord
You really shouldn't be messing with hardware breakpoints...
Posted on 2004-06-23 06:34:06 by f0dder
Hello,

Here's way, one may say that's ugly...

-Implement a SEH
-Try to do a gpf:

xor eax,eax
mov eax, ;cause a gpf

-then it will call your SEH
-In your SEH, access the CONTEXT structure
-In the CONTEXT struct you'll find all debug registers (aka DRx)
-Erase DR7


This is one way to access Debug registers without CPL0.



Neitsa
Posted on 2004-06-23 18:20:37 by Neitsa
ths u verry mutch +Neitsa ;):alright: :alright: :alright:
Posted on 2004-06-23 18:38:16 by dicky96