我来我网
https://5come5.cn
 
您尚未 登录  注册 | 菠菜 | 软件站 | 音乐站 | 邮箱1 | 邮箱2 | 风格选择 | 更多 » 
 

«1 2 » Pages: ( 2/2 total )
本页主题: 刚刚找了个用户态执行内核态程序的源码 显示签名 | 打印 | 加为IE收藏 | 收藏主题 | 上一主题 | 下一主题

yinx



性别: 帅哥 状态: 该用户目前不在线
等级: 人见人爱
家族: 丢丢
发贴: 2333
威望: 0
浮云: 1260
在线等级:
注册时间: 2006-09-15
最后登陆: 2009-05-11

5come5帮你背单词 [ gene // n. 基因,遗传因了 ]


Quote:
引用第9楼yinx于2007-12-22 12:04发表的  :


本来是不可以的,
但它调用了SetPhyscialMemorySectionCanBeWrited这个函数之后就可以了


我错了~~

Copy code
        status = ntdll.CallFunc( "ZwOpenSection",
            &m_hSection,
            SECTION_MAP_READ|SECTION_MAP_WRITE,
            &objectAttributes );

        if(status == STATUS_ACCESS_DENIED)
        {
            status = ntdll.CallFunc( "ZwOpenSection",
                &m_hSection,
                READ_CONTROL|WRITE_DAC,
                &objectAttributes );

            if( status == STATUS_SUCCESS )
            {
                SetPhyscialMemorySectionCanBeWrited(m_hSection);
                ntdll.CallFunc( "ZwClose", m_hSection );
                status = ntdll.CallFunc( "ZwOpenSection",
                    &m_hSection,
                    SECTION_MAP_WRITE|SECTION_MAP_WRITE,
                    &objectAttributes );
            }
        }


他是先调用ZwOpenSection,如果返回STATUS_ACCESS_DENIED再调用SetPhyscialMemorySectionCanBeWrited的。

我调试的时候调用ZwOpenSection就已经成功的了,程序没有再去调用SetPhyscialMemorySectionCanBeWrited
顶端 Posted: 2007-12-22 12:49 | [15 楼]
blulove



性别: 帅哥 状态: 该用户目前不在线
等级: 栋梁之材
发贴: 712
威望: 0
浮云: 1117
在线等级:
注册时间: 2006-02-27
最后登陆: 2008-06-30

5come5帮你背单词 [ conductivity /kondΛk'tiviti/ n. 传导性,传导率 ]


主要的流程大概是这样: 
  1:高地址虚拟空间转换为物理空间,RING3不可见
2:重新映射获得的物理空间到低地址虚拟空间,这下RING3可见了赛
3:添加GDT描述符,完事
顶端 Posted: 2007-12-22 12:50 | [16 楼]
blulove



性别: 帅哥 状态: 该用户目前不在线
等级: 栋梁之材
发贴: 712
威望: 0
浮云: 1117
在线等级:
注册时间: 2006-02-27
最后登陆: 2008-06-30

5come5帮你背单词 [ overtime /'əuvətaim/ a. 超时的,加班的;ad. 加班地 ]


GDT,IDT这些当然不能被换出,不然那还不蓝屏蓝爽
顶端 Posted: 2007-12-22 12:52 | [17 楼]
blulove



性别: 帅哥 状态: 该用户目前不在线
等级: 栋梁之材
发贴: 712
威望: 0
浮云: 1117
在线等级:
注册时间: 2006-02-27
最后登陆: 2008-06-30

5come5帮你背单词 [ sickness /'siknis/ n. 疾病,患病,恶心 ]


这个似乎通过打开物理内存对象来操作的吧
顶端 Posted: 2007-12-22 12:53 | [18 楼]
yinx



性别: 帅哥 状态: 该用户目前不在线
等级: 人见人爱
家族: 丢丢
发贴: 2333
威望: 0
浮云: 1260
在线等级:
注册时间: 2006-09-15
最后登陆: 2009-05-11

5come5帮你背单词 [ rigid /'rid3id/ a. 僵硬的,刻板的,严格的 ]


Quote:
引用第16楼blulove于2007-12-22 12:50发表的  :
主要的流程大概是这样: 
  1:高地址虚拟空间转换为物理空间,RING3不可见
2:重新映射获得的物理空间到低地址虚拟空间,这下RING3可见了赛
3:添加GDT描述符,完事


第2项不懂,蝈蝈教我一下~
它是用哪些语句完成第2项的?
顶端 Posted: 2007-12-22 12:54 | [19 楼]
blulove



性别: 帅哥 状态: 该用户目前不在线
等级: 栋梁之材
发贴: 712
威望: 0
浮云: 1117
在线等级:
注册时间: 2006-02-27
最后登陆: 2008-06-30

5come5帮你背单词 [ faithful /'feiθful/ a. 忠实的,如实的 ]


里面应该有VirtualAddrToPhysicAddr这样的函数的,不然没有办法操作嘛
顶端 Posted: 2007-12-22 13:03 | [20 楼]
blulove



性别: 帅哥 状态: 该用户目前不在线
等级: 栋梁之材
发贴: 712
威望: 0
浮云: 1117
在线等级:
注册时间: 2006-02-27
最后登陆: 2008-06-30

5come5帮你背单词 [ unable /'Λn'eibl/ a. 不能够的,没有办法的 ]


求强人转下C代码  
顶端 Posted: 2007-12-22 13:04 | [21 楼]
yinx



性别: 帅哥 状态: 该用户目前不在线
等级: 人见人爱
家族: 丢丢
发贴: 2333
威望: 0
浮云: 1260
在线等级:
注册时间: 2006-09-15
最后登陆: 2009-05-11

5come5帮你背单词 [ watt /wot/ n. 瓦(特) ]


Quote:
引用第20楼blulove于2007-12-22 13:03发表的  :
里面应该有VirtualAddrToPhysicAddr这样的函数的,不然没有办法操作嘛


确实是有这样的函数,
不过你说的第二步是把物理空间映射到低虚拟空间,
我不知道要用什么语句完成映射这个操作
顶端 Posted: 2007-12-22 13:07 | [22 楼]
blulove



性别: 帅哥 状态: 该用户目前不在线
等级: 栋梁之材
发贴: 712
威望: 0
浮云: 1117
在线等级:
注册时间: 2006-02-27
最后登陆: 2008-06-30

5come5帮你背单词 [ snowstorm /'snəusto:m/ n. 暴风雪 ]


原来API帮我们完成了,MapViewOfFile
顶端 Posted: 2007-12-22 13:34 | [23 楼]
blulove



性别: 帅哥 状态: 该用户目前不在线
等级: 栋梁之材
发贴: 712
威望: 0
浮云: 1117
在线等级:
注册时间: 2006-02-27
最后登陆: 2008-06-30

5come5帮你背单词 [ honest /'onist/ a. 诚实的,可靠的,坦率的,正直的 ]


貌似想复杂了,有物理内存对象这个接口,不需要这么复杂
顶端 Posted: 2007-12-22 14:03 | [24 楼]
blulove



性别: 帅哥 状态: 该用户目前不在线
等级: 栋梁之材
发贴: 712
威望: 0
浮云: 1117
在线等级:
注册时间: 2006-02-27
最后登陆: 2008-06-30

5come5帮你背单词 [ thankful /'θæŋkful/ a. 感谢的,感激的 ]


1:获取内存中GDT基地址VirGdtAddr(_asm sgdt fword ptr gdt;)
2:调用VirtualToPhysicalAddress把VirGdtAddr转换成PhyGdtAddr
3:打开物理内存对象,设置写权限
4:映射物理内存对象
5:定位到PhyGdtAddr,搜索GDT空项,填加gate


[ 此帖被blulove在2007-12-22 17:59重新编辑 ]
顶端 Posted: 2007-12-22 14:12 | [25 楼]
blulove



性别: 帅哥 状态: 该用户目前不在线
等级: 栋梁之材
发贴: 712
威望: 0
浮云: 1117
在线等级:
注册时间: 2006-02-27
最后登陆: 2008-06-30

5come5帮你背单词 [ procedure /prə'si:d3ə/ n. 手续,步骤,程序 ]


Quote:
引用第16楼blulove于2007-12-22 12:50发表的  :
主要的流程大概是这样: 
  1:高地址虚拟空间转换为物理空间,RING3不可见
2:重新映射获得的物理空间到低地址虚拟空间,这下RING3可见了赛
3:添加GDT描述符,完事


至于这个嘛,可以做个不利用物理内存对象操作任意进程任意空间的东东出来耍,不过似乎要对OS分页分段很熟悉才行
顶端 Posted: 2007-12-22 14:15 | [26 楼]
«1 2 » Pages: ( 2/2 total )
我来我网·5come5 Forum » 程序员之家

Total 0.015796(s) query 5, Time now is:05-04 21:13, Gzip enabled
Powered by PHPWind v5.3, Localized by 5come5 Tech Team, 黔ICP备16009856号