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

书上说进程堆栈段可执行,请问这个可执行是什么意思?

    来源: 互联网  发布时间:2016-04-29

    本文导语:  代码段里面是可执行代码,段属性可读可执行不可写 数据段里是堆/全局变量和静态变量.....,段属性是可读可写不可执行 堆栈段里面是返回地址/局部变量......段属性是可读可写可执行 这个代码段可执行我能够理解,...

代码段里面是可执行代码,段属性可读可执行不可写
数据段里是堆/全局变量和静态变量.....,段属性是可读可写不可执行
堆栈段里面是返回地址/局部变量......段属性是可读可写可执行


这个代码段可执行我能够理解,因为里面装的就是像一条一条的汇编命令,好像是有个什么指针,指针指到那条命令就执行该命令。
请问这个堆栈段说的“可执行”是什么意思?它不是专门放数据的吗,它里面怎么放命令,我程序编译后的代码可执行命令不是都应该放到代码段吗,怎么能跑到堆栈段里。 请大家指点一下,小弟先在此谢过了。

|
不要常规地想这件事,至于代码段,数据段,堆栈段的概念我就不说了,考虑缓冲区溢出攻击,其中很有效的一种方式就是栈溢出(还有堆溢出...),当你调用一个函数的时候栈如下:

主调函数的栈帧     -->
esp-->数据(地址为XXXX) 
    ......
       -->局部变量(local)
ebp-->老的栈指针
       -->被调函数的返回地址
                   -->函数参数
主调函数的栈帧     -->
                ......
如果局部变量local向下溢出,那么就会覆盖被调函数的返回地址,如果攻击者将其攻击代码(当然是要用来执行的)放到XXXX处,XXXX也在堆栈中,而且恰好把被调函数的返回地址覆盖成地址XXXX(需要一定技术),那么当函数返回的时候,执行流就会自觉地进入XXXX开始执行,再强调一遍XXXX在堆栈,但是如果堆栈可执行,那么攻击者的目的就达到了,若堆栈不可执行,那么程序立马报错退出,攻击者就要考虑别的手段了。至于怎么设置可执行,那就要看硬件和操作系统的实现了,可在段表设置,也可以在页表设置,对于linux和windows这种平坦模式的段而言,设置堆栈对应的页表项的可执行位为1或为0代表堆栈可执行或者不可执行

|
堆栈段也是可以执行的,你说的只是一般情况而已,其实是可以设置页属性在堆栈段执行代码的。
LINUX内核中关于信号部分就有在堆栈中执行的实现。

    
 
 

您可能感兴趣的文章:

  • 父进程等待子进程n秒,如果子进程正常退出,父进程立即继续向下执行,如果子出现进程故障一直不退出,父进程等待n秒后继续向下执行,请问
  • 如何在程序中执行另外一个程序,并且当前进程依然执行?
  • 先 fork 子进程然后 execl 另一个可执行程序, 如何得到这个可执行程序结束的返回值?
  • 在shell命令行中敲一个可执行文件,起一个进程pc,这个进程属于shell进程
  • linux下system函数调用shell命令后,怎样让主进程不等子进程返回,接着执行(在线)?
  • 父进程sleep(10) 秒,但不需要子进程执行这句代码,怎么办,求大虾指导
  • 在unix下面,执行tbinit进程可以启动OnLine,怎么才能执行tbinit啊?
  • 关于子进程的执行
  • 如何获得子进程的执行时间
  • fork() 父子进程执行顺序问题
  • 各位前辈,当代码执行一个系统调用fork()后,为什么如果共享页设置了写时拷贝位,在父进程之前调度子进程将具有优越性?内核如何能使子进
  • 如何取得进程执行时间?
  • 进程定时执行问题
  • POPEN后如何知道哪个是父进程执行的结果
  • linux c 获得当前进程的进程名和执行路径(示例)
  • 执行一个main函数程序时,unix操作系统调用什么创建进程?fork?newproc?
  • 进程执行问题
  • 请问谁知道子进程用wait结束是不是相当于顺序执行啊!
  • linux 中用fork创建子进程后,用exec执行自己的程序的问题
  • 大虾们帮个忙吧。linux下可否有类似WaitForSingleObject的等待进程执行完毕的函数呢?
  • 每个线程有自己私有的堆栈,其实这些堆栈的资源是操作系统分配给进程的,这种说法对吗?
  • redhat下改变某个进程中使用的堆栈大小
  • linux下,进程的堆栈大小到底是OS决定的还是编译器决定的?
  • (100分急)怎么样才能让LINUX进程起多于255个线程还不影响堆栈
  • 如何在linux系统上看一个进程的所有线呈的堆栈情况?
  • SuSE9上,多线程程序正在运行,用pstack打印堆栈信息,结果导致进程挂起(ps x 命令显示为T状态),为什么
  • 输出java进程的jstack信息示例分享 通过线程堆栈信息分析java线程
  • gdb 调试运行进程 堆栈中的函数名为问号
  • DEFINE_WAIT(__wait)这宏把__wait变量定义在了进程的内核堆栈中,则另一进程使用wake_up时,是如何访问到__wait变量的呢?
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 后台进程和与控制终端断开的进程是一个意思吗?
  • Linux编程的"进程挂靠"是什么意思?
  • 进程退出码大于129代表什么意思?
  • unix进程间的通信:一个有意思的简单程序
  • kill(0,15) 是给当前进程发送信号,后面的15代表什么意思。?
  • top 显示的%MEM 是什么意思呢?我把这些值加起来超过了100%,这怎么回事呢?(我运行oracle,它的多个进程加起来就超过了。。。)
  • linux僵尸(zombie)进程介绍及清除
  • 进程Afork进程B,进程Bfor进程C,如果进程C退出发出SIGCHLD,A进程是否可以收到
  • Ubuntu查看内存,进程相关命令介绍
  • 如果一个server进程要fork许多子进程,但不等待子进程终止,也不希望子进程结束后处于僵进程状态直到父进程终止。请问可采用什么方法实现
  • linux下进程占用内存空间详解
  • 在多进程中父进程frok子进程,怎样让子进程自举,脱离父进程,而且父进程不退出
  • Linux进程的内核栈和用户栈概念,相互关系及切换过程
  • fock()开出的子进程的进程ID是否进程ID都大于父进程的?
  • android 4.0 托管进程介绍及优先级和回收机制
  • 多进程问题 子进程读取内容 读完挂起,父进程写 写入后唤醒子进程
  • linux下进程间通信:共享内存原理及具体用法举例(基于c/c++语言)
  • 一个进程首先监听一个端口,等到有连接了就新开一个进程,让新进程来处理后面的通讯。请问母进程中已经打开了端口,子进程怎么来使用同一
  • 我在一个父进程中,生成了4个子进程,子进程的优先级是一样的。我现在想结束子进程。该如何做?
  • 子进程wait/waitpid//子进程不结束,父进程会等待子进程吗?
  • 在一个进程中我定义了几个全局变量,然后我又fork了几个子进程,子进程中是否可以各自对全局变量进行修改,如果各子进程都对其进行修改,
  • 怎样一次杀掉父进程创建的所有子进程?我在父进程中用kill(0,SIGKILL),结果父进程也给干掉了,参数0难道不是表示除自己外的所有同uid的进
  • 进程创建进程组后,然后创建该组中的进程,然后终止。这里的终止....?
  • 如何实现子进程根据父进程的信号来确定是否终止子进程???
  • 高手请教!linux怎样通过pid获取进程信息,如:进程名、进程状态等?
  • 如何通过进程号获得进程的一些信息,例如:进程运行的目录
  • 【如何彻底杀死子进程】Kill -9子进程后进程呈僵死状态


  • 站内导航:


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

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

    浙ICP备11055608号-3