49{
   55    UINT32                             ActionBreakToDebuggerLength = 0;
 
   56    UINT32                             ActionCustomCodeLength      = 0;
 
   57    UINT32                             ActionScriptLength          = 0;
 
   60    vector<string>                     SplitCommandCaseSensitive {
Split(Command, 
' ')};
 
   61    UINT32                             IndexInCommandCaseSensitive = 0;
 
   63 
   64    if (SplitCommand.size() < 2)
   65    {
   68        return;
   69    }
   70 
   71    
   72    
   73    
   75            &SplitCommand,
   76            &SplitCommandCaseSensitive,
   78            &Event,
   79            &EventLength,
   80            &ActionBreakToDebugger,
   81            &ActionBreakToDebuggerLength,
   82            &ActionCustomCode,
   83            &ActionCustomCodeLength,
   84            &ActionScript,
   85            &ActionScriptLength,
   86            &EventParsingErrorCause))
   87    {
   88        return;
   89    }
   90 
   91    
   92    
   93    
   95    {
   96        ShowMessages(
"the utilization of 'post' or 'all' event calling stages is not meaningful " 
   97                     "for the hidden hook; therefore, this command does not support them\n");
   98 
  100        return;
  101    }
  102 
  103    
  104    
  105    
  106    for (auto Section : SplitCommand)
  107    {
  108        IndexInCommandCaseSensitive++;
  109 
  110        if (!Section.compare("!epthook2"))
  111        {
  112            continue;
  113        }
  114        else if (!GetAddress)
  115        {
  116            
  117            
  118            
  120                    SplitCommandCaseSensitive.at(IndexInCommandCaseSensitive - 1),
  121                    &OptionalParam1))
  122            {
  123                
  124                
  125                
  127                             SplitCommandCaseSensitive.at(IndexInCommandCaseSensitive - 1).c_str());
  129 
  131                return;
  132            }
  133            else
  134            {
  136            }
  137        }
  138        else
  139        {
  140            
  141            
  142            
  143            ShowMessages(
"unknown parameter '%s'\n\n", Section.c_str());
 
  145 
  147            return;
  148        }
  149    }
  150    if (OptionalParam1 == 0)
  151    {
  152        ShowMessages(
"please choose an address to put the hook on it\n");
 
  153 
  155        return;
  156    }
  157 
  158    
  159    
  160    
  162 
  163    
  164    
  165    
  167    {
  168        
  169        
  170        
  171        
  172        
  173 
  175        return;
  176    }
  177 
  178    
  179    
  180    
  182                               ActionBreakToDebugger,
  183                               ActionBreakToDebuggerLength,
  184                               ActionCustomCode,
  185                               ActionCustomCodeLength,
  186                               ActionScript,
  187                               ActionScriptLength))
  188    {
  189        
  190        
  191        
  192 
  194        return;
  195    }
  196}
UCHAR BOOLEAN
Definition BasicTypes.h:39
#define TRUE
Definition BasicTypes.h:55
#define FALSE
Definition BasicTypes.h:54
unsigned __int64 UINT64
Definition BasicTypes.h:21
unsigned int UINT32
Definition BasicTypes.h:48
@ VMM_CALLBACK_CALLING_STAGE_PRE_EVENT_EMULATION
Definition DataTypes.h:93
const vector< string > Split(const string &s, const char &c)
general split command
Definition common.cpp:117
VOID FreeEventsAndActionsMemory(PDEBUGGER_GENERAL_EVENT_DETAIL Event, PDEBUGGER_GENERAL_ACTION ActionBreakToDebugger, PDEBUGGER_GENERAL_ACTION ActionCustomCode, PDEBUGGER_GENERAL_ACTION ActionScript)
Deallocate buffers relating to events and actions.
Definition debugger.cpp:2292
BOOLEAN InterpretGeneralEventAndActionsFields(vector< string > *SplitCommand, vector< string > *SplitCommandCaseSensitive, VMM_EVENT_TYPE_ENUM EventType, PDEBUGGER_GENERAL_EVENT_DETAIL *EventDetailsToFill, PUINT32 EventBufferLength, PDEBUGGER_GENERAL_ACTION *ActionDetailsToFillBreakToDebugger, PUINT32 ActionBufferLengthBreakToDebugger, PDEBUGGER_GENERAL_ACTION *ActionDetailsToFillCustomCode, PUINT32 ActionBufferLengthCustomCode, PDEBUGGER_GENERAL_ACTION *ActionDetailsToFillScript, PUINT32 ActionBufferLengthScript, PDEBUGGER_EVENT_PARSING_ERROR_CAUSE ReasonForErrorInParsing)
Interpret general event fields.
Definition debugger.cpp:2342
BOOLEAN SendEventToKernel(PDEBUGGER_GENERAL_EVENT_DETAIL Event, UINT32 EventBufferLength)
Register the event to the kernel.
Definition debugger.cpp:1969
BOOLEAN RegisterActionToEvent(PDEBUGGER_GENERAL_EVENT_DETAIL Event, PDEBUGGER_GENERAL_ACTION ActionBreakToDebugger, UINT32 ActionBreakToDebuggerLength, PDEBUGGER_GENERAL_ACTION ActionCustomCode, UINT32 ActionCustomCodeLength, PDEBUGGER_GENERAL_ACTION ActionScript, UINT32 ActionScriptLength)
Register the action to the event.
Definition debugger.cpp:2086
VOID CommandEptHook2Help()
help of the !epthook2 command
Definition epthook2.cpp:20
VOID ShowMessages(const char *Fmt,...)
Show messages.
Definition libhyperdbg.cpp:96
NULL()
Definition test-case-generator.py:530
UINT64 OptionalParam1
Definition Events.h:272
Each event can have multiple actions.
Definition Events.h:406
Each command is like the following struct, it also used for tracing works in user mode and sending it...
Definition Events.h:350
DEBUGGER_EVENT_OPTIONS Options
Definition Events.h:391
VMM_CALLBACK_EVENT_CALLING_STAGE_TYPE EventStage
Definition Events.h:369
BOOLEAN SymbolConvertNameOrExprToAddress(const string &TextToConvert, PUINT64 Result)
check and convert string to a 64 bit unsigned integer and also check for symbol object names and eval...
Definition symbol.cpp:360