当前位置:  技术问答>linux和unix

64位linux 对cr0位进行清零操作,出错

    来源: 互联网  发布时间:2016-11-25

    本文导语:  本帖最后由 whoisthisman 于 2011-04-28 15:30:02 编辑 想获取sys_call_table,首先要先将cr0清零,从网上看了用如下方式unsigned int clear_and_return_cr0(void)  #include     #include     #include     #include     #include     #include   ...

本帖最后由 whoisthisman 于 2011-04-28 15:30:02 编辑
想获取sys_call_table,首先要先将cr0清零,从网上看了用如下方式unsigned int clear_and_return_cr0(void) 

#include    
#include    
#include    
#include    
#include    
#include    
#include    
#include 

#include 
   
unsigned long *sys_table = NULL;   

MODULE_DESCRIPTION("G kernel module");
MODULE_AUTHOR("root (iii@iiiiom)");
MODULE_LICENSE("$LICENSE$");


static void *memmem(const void *haystack, size_t haystack_len,   
const void *needle, size_t needle_len);   
static unsigned long get_syscall_table_long(void)    
{    
#define OFFSET_SYSCALL 200    
unsigned long syscall_long, retval;    
char sc_asm[OFFSET_SYSCALL];    
rdmsrl(MSR_LSTAR, syscall_long);    
memcpy(sc_asm, (char *)syscall_long, OFFSET_SYSCALL);    
retval = (unsigned long) memmem(sc_asm, OFFSET_SYSCALL, "xffx14xc5", 3);    
if ( retval != 0 ) {   
retval = (unsigned long) ( * (unsigned long *)(retval+3) );    
} else {    
printk("long mode : memmem found nothing, returning NULL:(");    
retval = 0;    
}   
#undef OFFSET_SYSCALL    
return retval;    
}   
static void *memmem(const void *haystack, size_t haystack_len,    
const void *needle, size_t needle_len)    
{   
const char *begin;    
const char *const last_possible = (const char *) haystack + haystack_len - needle_len;   
if (needle_len == 0){    
/* The first occurrence of the empty string is deemed to occur at   
the beginning of the string. */    
return (void *) haystack;   
}   
if (__builtin_expect(haystack_len 

    
 
 

您可能感兴趣的文章:

  • linux shell脚本 linux crond 的一个鲜为人知的错误,单独执行没问题,放到crond 中就执行出错 试问高手们哪个环节出错
  • linux 64位编译出错。linux 32位可以编译过。
  • 编译linux0.01内核时出错,没有权限?
  • 安装arm-linux-gcc出错
  • 还是老问题啊!!!高手吗?帮忙啊!LINUX 9.0安装时出错!
  • RH linux9启动出错?
  • 求教Redhat Linux 9.0安装出错问题?
  • socket在linux下能用,在unix下出错
  • u盘启动linux出错
  • 在移植linux 2.6.32.27与 33时出错
  • linux 网络编程中 send()函数出错
  • 急!!安装linux出错!希望指教!非常谢谢!
  • 安装Linux 出错(急)
  • linux内核升级后启动出错
  • 64位linux下编译C++出错问题,求解决
  • 安装Linux出错
  • arm-linux-gcc交叉编译出错,但gcc编译没错,什么原因呢???
  • Linux Shell提示符出错,并发出警报声
  • linux7.1 安装 oracle8.1.7 出错
  • Redhat Linux安装RealPlayer11出错
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux哪个版本好?linux操作系统版本详细介绍及选择方案推荐
  • linux 怎么也能用鼠标操作?? 我的系统是Ubuntu ,不是说linux都用代码操作么??
  • mount命令(linux操作系统)挂载卸载文件系统(cifs,光驱,nfs等)方法介绍
  • 请问各位,我想学习linux,是装linux操作系统还是在虚拟机下装操作系统呢?那种好点啊
  • linux下不使用sudo命令执行docker的操作步骤
  • 请问LINUX操作系统是怎样对外围设备进行操作的
  • Linux下GCC内置原子操作函数(多线程资源访问)介绍
  • 请问命令行操作下怎么改Linux操作系统的日期和时间?
  • Linux下u盘文件系统相关操作
  • 在linux操作系统上向ftp服务器(linux系统)上上传文件,我要纪录操作日志,得到上传到ftp服务器上的文件的路径问题?
  • Mysql服务器登陆,启动,停止等基本操作命令介绍(Linux/Centos环境)
  • 基于linux操作系统之上操作LCD问题,急???
  • linux 操作系统下ps命令介绍
  • Linux操作系统和Hurd操作系统
  • Linux和windows下用mysql c++ library操作Mysql数据库
  • 哪位大侠知道Linux里的有名管道传送数据快不快?有名管道操作的过程是否有读写硬盘的操作?
  • 我想格式掉linux操作系统,但这样会把引导区也格式掉,在format linux操作系统之前,该怎么设置引导区??
  • 已安装了Windows操作系统,还想安装Linux。却还想在开机选择操作系统时由Windows引导,请问如何操作。在线等待
  • 1哪位大侠知道Linux里的有名管道传送数据快不快?有名管道操作的过程是否有读写硬盘的操作?
  • ARM系列开发板是不是一定要用LINUX操作系统。windows操作系统可以吗?
  • linux 的命令操作和 windows的命令提示行有什么不同呢?? 为什么windows一般都不用命令提示行操作呢??
  • linux c/c++ IP字符串转换成可比较大小的数字
  • 在win分区上安装linux和独立分区安装linux有什么区别?可以同时安装吗?(两个linux系统)
  • secureCRT下Linux终端汉字乱码解决方法
  • 在虚拟机上安装的linux上,能像真的linux系统一样开发linux程序么?
  • Linux c字符串中不可打印字符转换成16进制
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在有linux的盘)
  • 移动开发 iis7站长之家
  • 安装vmware软件,不用再安装linux系统,就可以模拟linux系统了,然后可以在其上学习一下LINUX下的基本操作 了?
  • linux命令大全详细分类介绍及常用linux命令文档手册下载
  • 红旗Linux主机可以通过127.0.0.1访问,但如何是连网的Win2000机器通过Linux的IP去访问Linux


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3