• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆-23  評論-73  文章-3  trackbacks-0

            代碼很簡單,也沒什么好說的

            #include <ntifs.h>

            #define SECTION_SIZE 0x1000

            VOID
            DrvUnload(
                IN PDRIVER_OBJECT  DriverObject
                );

            NTSTATUS
            DriverEntry( IN PDRIVER_OBJECT DriverObject,IN PUNICODE_STRING RegistryPath )
            {
             HANDLE ShareHandle;
             OBJECT_ATTRIBUTES Objatt;
             UNICODE_STRING uString;
             NTSTATUS status;
             LARGE_INTEGER SecSize;
             LARGE_INTEGER offsetsize = {0,0};
             SIZE_T liViewSize;
             PVOID Viraddr = NULL;
             PCHAR TestString = "SharedMemory Test !";
             
             SecSize.HighPart = 0;
             SecSize.LowPart = SECTION_SIZE;
             liViewSize = 0;
             
             RtlInitUnicodeString( &uString,L"\\BaseNamedObjects\\ShareMemory");
             InitializeObjectAttributes( &Objatt,&uString,OBJ_CASE_INSENSITIVE,NULL,NULL );
             
             DriverObject->DriverUnload = DrvUnload;
             
             status = ZwCreateSection( &ShareHandle,
                     SECTION_MAP_READ | SECTION_MAP_WRITE,
                     &Objatt,
                     &SecSize,
                     PAGE_READWRITE,
                     SEC_COMMIT,
                     NULL );
             if( status != STATUS_SUCCESS )
             {
              DbgPrint("CreateSection Object fail \n");
              ZwClose( ShareHandle );
              return STATUS_SUCCESS;
             }
             DbgPrint("CreateSection SUCCESS \n ");
             
             status = ZwMapViewOfSection( ShareHandle,
                     NtCurrentProcess(),
                     &Viraddr,
                     0,
                     SECTION_SIZE,
                     &offsetsize,
                     &liViewSize,
                     ViewShare,
                     0,
                     PAGE_READWRITE );
             if( status != STATUS_SUCCESS )
             {
              DbgPrint("MapViewof Virual addr fail \n ");
              ZwClose( ShareHandle );
              return STATUS_SUCCESS;
             }
             DbgPrint("MapView of Virual Addr SUCCUESS \n ");
             
             memcpy( Viraddr,TestString,19 );
             
             //ZwUnmapViewOfSection( ShareHandle,Viraddr );
             //ZwClose( ShareHandle );
             
             return STATUS_SUCCESS;
             
            }

            VOID
            DrvUnload(
                IN PDRIVER_OBJECT  DriverObject
                )
            {
             
            }







            #include <ntifs.h>

            #define SECTION_SIZE 0x1000

            VOID
            DrvUnload(
                IN PDRIVER_OBJECT  DriverObject
                );

            NTSTATUS
            DriverEntry( IN PDRIVER_OBJECT DriverObject,IN PUNICODE_STRING RegisterPath )
            {
             OBJECT_ATTRIBUTES Objatt;
             UNICODE_STRING uString;
             PVOID Viraddr = NULL;
             LARGE_INTEGER offsetsize = {0,0};
             SIZE_T liViewSize = 0;
             CHAR TestString[100];
             NTSTATUS status;
             HANDLE ShareHandle;
             
             RtlInitUnicodeString( &uString,L"\\BaseNamedObjects\\ShareMemory");
             InitializeObjectAttributes( &Objatt,&uString,OBJ_CASE_INSENSITIVE,NULL,NULL );
             
             DriverObject->DriverUnload = DrvUnload;
             
             status = ZwOpenSection( &ShareHandle,
                   SECTION_ALL_ACCESS,
                   &Objatt );
             if( status != STATUS_SUCCESS )
             {
              DbgPrint("Open SectionObject fail \n");
              return STATUS_UNSUCCESSFUL;
             }
             
             status = ZwMapViewOfSection( ShareHandle,
                     NtCurrentProcess(),
                     &Viraddr,
                     0,
                     SECTION_SIZE,
                     &offsetsize,
                     &liViewSize,
                     ViewShare,
                     0,
                     PAGE_READWRITE );
             if( status != STATUS_SUCCESS )
             {
              DbgPrint("Get SectionObject Virtual Address Error \n");
              return STATUS_UNSUCCESSFUL;
             }
             
             memcpy( TestString,Viraddr,19 );
             DbgPrint("TestString is %s \n",(PCHAR)Viraddr);
             
             ZwUnmapViewOfSection( ShareHandle,Viraddr );
             ZwClose( ShareHandle );
             
             return STATUS_SUCCESS;
             
            }

            VOID
            DrvUnload(
                IN PDRIVER_OBJECT  DriverObject
                )
            {
             
            }

            posted on 2008-07-14 17:14 ViskerWong 閱讀(917) 評論(0)  編輯 收藏 引用
            777久久精品一区二区三区无码| 久久精品中文无码资源站| 99精品久久精品| 国产精品久久久久久久午夜片 | 色综合久久天天综线观看| 久久精品成人欧美大片| 久久精品aⅴ无码中文字字幕重口 久久精品a亚洲国产v高清不卡 | 久久免费视频1| 久久青草国产手机看片福利盒子 | 精品久久久久久中文字幕| 久久久无码精品亚洲日韩蜜臀浪潮 | 伊人久久大香线蕉AV一区二区| 久久久国产精品网站| 亚洲国产成人久久综合区| 久久久青草久久久青草| 要久久爱在线免费观看| 久久综合久久久| 久久婷婷成人综合色综合| 亚洲精品午夜国产va久久| 久久综合九色综合精品| 一本色道久久综合狠狠躁| 久久精品无码免费不卡| 久久精品成人免费网站| 无码人妻精品一区二区三区久久| 色婷婷久久综合中文久久一本| 国内精品久久久久影院免费| 久久精品国产久精国产果冻传媒| 久久精品国产欧美日韩| 久久综合综合久久97色| 99久久99久久久精品齐齐| 国产精品久久久久国产A级| 久久超碰97人人做人人爱| 久久成人小视频| 久久综合给合久久狠狠狠97色69 | 色偷偷88888欧美精品久久久| 色偷偷88欧美精品久久久 | 久久久久波多野结衣高潮| 久久精品国产亚洲AV蜜臀色欲 | 国产一级做a爰片久久毛片| 国产精品一区二区久久国产| 亚洲va久久久噜噜噜久久天堂|