精华内容
下载资源
问答
  • 中断服务函数函数调用的区别

    千次阅读 2019-12-23 17:02:06
    在《微机原理》《计算机组成》等课程[1-4]教学中(本文以MCS-51单片机为例),中断过程既是教学难点又是教学重点,它与主程序调用程序过程有一定相似性,但又有很大区别,调用程序过程相对比较容易掌握,通过...

    在《微机原理》和《计算机组成》等课程[1-4]教学中(本文以MCS-51单片机为例),中断过程既是教学难点又是教学重点,它与主程序调用子程序过程有一定相似性,但又有很大区别,调用子程序过程相对比较容易掌握,通过把两过程结合起来,采用比较教学方法,能收到了很好的教学效果。

    1、两过程定义与作用

    子程序是微机基本程序结构中的1种,基本程序结构包括顺序(简单)、分支(判断)、循环、子程序和查表等5种。
    
    子程序是一组可以公用的指令序列,只要给出子程序的入口地址就能从主程序转入子程序。子程序在功能上具有相对的独立性,在执行主程序的过程中往往被多次调用,甚至被不同的程序所调用。一般微机首先执行主程序,碰到调用指令就转去执行子程序,子程序执行完后,返回指令就返回主程序断点(即调用指令的下一条指令),继续执行没有处理完的主程序,这一过程叫做(主程序)调用子程序过程。
    

    子程序结构可简化程序,防止重复书写错误,并可节省内存空间。计算机中经常把常用的各种通用的程序段编成子程序,提供给用户使用。用户在自己编写的程序中,只要会调用这些子程序,就可大大简化用户编程的困难。

    中断是计算机中央处理单元CPU与外设I/O交换数据的一种方式,除此方式外,还有无条件、条件(查询)、存贮器直接存取DMA和I/O通道等四种方式。由于无条件不可靠,条件效率低,DMA和I/O通道两方式硬件复杂,而中断方式CPU效率高,因此一般大多采用中断方式。
    

    中断概念是当计算机正在执行某一(主)程序时,收到一中断请求,如果中断响应条件成立,计算机就把正在执行的程序暂停一下,去响应处理这一请求,执行中断服务程序,处理完服务程序后,中断返回指令使计算机返回原来还没有执行完的程序断点处继续执行,这一过程称为中断过程。有了中断,计算机才能具有并行处理,实时处理和故障处理等重要功能。

    2、两过程的联系与区别

    2.1联系

    中断与调用子程序两过程属于完全不同的概念,但它们也有不少相似之处。两者都需要保护断点(即下一条指令地址)、跳至子程序或中断服务程序、保护现场、子程序或中断处理、恢复现场、恢复断点(即返回主程序)。两者都可实现嵌套,即正在执行的子程序再调另一子程序或正在处理的中断程序又被另一新中断请求所中断,嵌套可为多级。
    

    正是由于这些表面上的相似处,很容易使学生把两者混淆起来,特别是把中断也看为子程序,这就大错特错了。

    2.2区别

    中断过程与调用子程序过程相似点是表面的,从本质上讲两者是完全不一样的。
    

    两者的根本区别主要表现在服务时间与服务对象不一样上。首先,调用子程序过程发生的时间是已知和固定的,即在主程序中的调用指令(CALL)执行时发生主程序调用子程序,调用指令所在位置是已知和固定的。而中断过程发生的时间一般的随机的,CPU在执行某一主程序时收到中断源提出的中断申请时,就发生中断过程,而中断申请一般由硬件电路产生,申请提出时间是随机的(软中断发生时间是固定的),也可以说,调用子程序是程序设计者事先安排的,而执行中断服务程序是由系统工作环境随机决定的;其次,子程序完全为主程序服务的,两者属于主从关系,主程序需要子程序时就去调用子程序,并把调用结果带回主程序继续执行。而中断服务程序与主程序两者一般是无关的,不存在谁为谁服务的问题,两者是平行关系;第三,主程序调用子程序过程完全属于软件处理过程,不需要专门的硬件电路,而中断处理系统是一个软、硬件结合系统,需要专门的硬件电路才能完成中断处理的过程;第四,子程序嵌套可实现若干级,嵌套的最多级数由计算机内存开辟的堆栈大小限制,而中断嵌套级数主要由中断优先级数来决定,一般优先级数不会很大。


    中断是嵌入式系统中重要的组成部分,但是在标准C中不包含中断。许多编译开发商在标准C上增加了对中断的支持,提供新的关键字用于标示中断服务程序 (ISR),类似于__interrupt、#program interrupt等。当一个函数被定义为ISR的时候,编译器会自动为该函数增加中断服务程序所需要的中断现场入栈和出栈代码。

    中断服务程序需要满足如下要求:

    (1)不能返回值;

    (2)不能向ISR传递参数;

    (3) ISR应该尽可能的短小精悍;

    (4) printf(char * lpFormatString,…)函数会带来重入和性能问题,不能在ISR中采用。

    参阅网上资料和个人的一些理解

    a.为什么不能有返回值?

    中断服务函数的调用是硬件级别的,当中断产生,pc指针强制跳转到对应的中断服务函数入口,进入中断具有随机性,并不是某段代码对其进行调用,那么如果有返回值它的返回值返回给谁?显然这个返回值毫无意义,如果有返回值,它必定需要进行压栈操作,这样一来何时出栈怎么出栈将变得无法解决。

    b.不能向ISR传递参数?

    同理,也是由于这样会破坏栈的原因,因为函数传递参数必定会要求压栈出栈操作,由于进入中断服务函数的随机行,谁给它传递参数都成问题

    c.ISR应尽可能的短小精悍?

    如果某个中断频繁产生,而它对应的ISR相当的耗时,那么对中断的响应就会无限的延迟,会丢掉很多的中断请求

    d.printf(char * lpFormatString,…)函数会带来重入和性能问题,不能在ISR中采用。

    这就涉及到一个中断嵌套问题,由于printf之类的glibc函数采用的是缓冲机制,这个缓冲区是共享的,相当于一个全局变量,第一层中断来时,它向缓冲里面写入一些部分内容,恰好这时来了个优先级更高的中断,它同样调用了printf,也向缓冲里面写入一些内容,这样缓冲区的内容就错乱了。
    http://www.cnblogs.com/thammer/p/5017329.html

    展开全文
  • 在《微机原理》《计算机组成》等课程[1-4]教学中(本文以MCS-51单片机为例),中断过程既是教学难点又是教学重点,它与主程序调用程序过程有一定相似性,但又有很大区别,调用程序过程相对比较容易掌握,通过...

    http://www.cnblogs.com/linuxbird/archive/2013/06/06/3121738.html

    在《微机原理》和《计算机组成》等课程[1-4]教学中(本文以MCS-51单片机为例),中断过程既是教学难点又是教学重点,它与主程序调用子程序过程有一定相似性,但又有很大区别,调用子程序过程相对比较容易掌握,通过把两过程结合起来,采用比较教学方法,能收到了很好的教学效果。 
    1、两过程定义与作用
        子程序是微机基本程序结构中的1种,基本程序结构包括顺序(简单)、分支(判断)、循环、子程序和查表等5种。
        子程序是一组可以公用的指令序列,只要给出子程序的入口地址就能从主程序转入子程序。子程序在功能上具有相对的独立性,在执行主程序的过程中往往被多次调用,甚至被不同的程序所调用。一般微机首先执行主程序,碰到调用指令就转去执行子程序,子程序执行完后,返回指令就返回主程序断点(即调用指令的下一条指令),继续执行没有处理完的主程序,这一过程叫做(主程序)调用子程序过程。
    子程序结构可简化程序,防止重复书写错误,并可节省内存空间。计算机中经常把常用的各种通用的程序段编成子程序,提供给用户使用。用户在自己编写的程序中,只要会调用这些子程序,就可大大简化用户编程的困难。 
        中断是计算机中央处理单元CPU与外设I/O交换数据的一种方式,除此方式外,还有无条件、条件(查询)、存贮器直接存取DMA和I/O通道等四种方式。由于无条件不可靠,条件效率低,DMA和I/O通道两方式硬件复杂,而中断方式CPU效率高,因此一般大多采用中断方式。
    中断概念是当计算机正在执行某一(主)程序时,收到一中断请求,如果中断响应条件成立,计算机就把正在执行的程序暂停一下,去响应处理这一请求,执行中断服务程序,处理完服务程序后,中断返回指令使计算机返回原来还没有执行完的程序断点处继续执行,这一过程称为中断过程。有了中断,计算机才能具有并行处理,实时处理和故障处理等重要功能。 
    2、两过程的联系与区别
    2.1联系
        中断与调用子程序两过程属于完全不同的概念,但它们也有不少相似之处。两者都需要保护断点(即下一条指令地址)、跳至子程序或中断服务程序、保护现场、子程序或中断处理、恢复现场、恢复断点(即返回主程序)。两者都可实现嵌套,即正在执行的子程序再调另一子程序或正在处理的中断程序又被另一新中断请求所中断,嵌套可为多级。
    正是由于这些表面上的相似处,很容易使学生把两者混淆起来,特别是把中断也看为子程序,这就大错特错了。
    2.2区别
        中断过程与调用子程序过程相似点是表面的,从本质上讲两者是完全不一样的。
    两者的根本区别主要表现在服务时间与服务对象不一样上。首先,调用子程序过程发生的时间是已知和固定的,即在主程序中的调用指令(CALL)执行时发生主程序调用子程序,调用指令所在位置是已知和固定的。而中断过程发生的时间一般的随机的,CPU在执行某一主程序时收到中断源提出的中断申请时,就发生中断过程,而中断申请一般由硬件电路产生,申请提出时间是随机的(软中断发生时间是固定的),也可以说,调用子程序是程序设计者事先安排的,而执行中断服务程序是由系统工作环境随机决定的;其次,子程序完全为主程序服务的,两者属于主从关系,主程序需要子程序时就去调用子程序,并把调用结果带回主程序继续执行。而中断服务程序与主程序两者一般是无关的,不存在谁为谁服务的问题,两者是平行关系;第三,主程序调用子程序过程完全属于软件处理过程,不需要专门的硬件电路,而中断处理系统是一个软、硬件结合系统,需要专门的硬件电路才能完成中断处理的过程;第四,子程序嵌套可实现若干级,嵌套的最多级数由计算机内存开辟的堆栈大小限制,而中断嵌套级数主要由中断优先级数来决定,一般优先级数不会很大。

    转载于:https://www.cnblogs.com/feng9exe/p/7282782.html

    展开全文
  • 在《微机原理》《计算机组成》等课程[1-4]教学中(本文以MCS-51单片机为例),中断过程既是教学难点又是教学重点,它与主程序调用程序过程有一定相似性,但又有很大区别,调用程序过程相对比较容易掌握,通过...
    
    

    在《微机原理》和《计算机组成》等课程[1-4]教学中(本文以MCS-51单片机为例),中断过程既是教学难点又是教学重点,它与主程序调用子程序过程有一定相似性,但又有很大区别,调用子程序过程相对比较容易掌握,通过把两过程结合起来,采用比较教学方法,能收到了很好的教学效果。 
    1、两过程定义与作用
        子程序是微机基本程序结构中的1种,基本程序结构包括顺序(简单)、分支(判断)、循环、子程序和查表等5种。
        子程序是一组可以公用的指令序列,只要给出子程序的入口地址就能从主程序转入子程序。子程序在功能上具有相对的独立性,在执行主程序的过程中往往被多次调用,甚至被不同的程序所调用。一般微机首先执行主程序,碰到调用指令就转去执行子程序,子程序执行完后,返回指令就返回主程序断点(即调用指令的下一条指令),继续执行没有处理完的主程序,这一过程叫做(主程序)调用子程序过程。
    子程序结构可简化程序,防止重复书写错误,并可节省内存空间。计算机中经常把常用的各种通用的程序段编成子程序,提供给用户使用。用户在自己编写的程序中,只要会调用这些子程序,就可大大简化用户编程的困难。 
        中断是计算机中央处理单元CPU与外设I/O交换数据的一种方式,除此方式外,还有无条件、条件(查询)、存贮器直接存取DMA和I/O通道等四种方式。由于无条件不可靠,条件效率低,DMA和I/O通道两方式硬件复杂,而中断方式CPU效率高,因此一般大多采用中断方式。
    中断概念是当计算机正在执行某一(主)程序时,收到一中断请求,如果中断响应条件成立,计算机就把正在执行的程序暂停一下,去响应处理这一请求,执行中断服务程序,处理完服务程序后,中断返回指令使计算机返回原来还没有执行完的程序断点处继续执行,这一过程称为中断过程。有了中断,计算机才能具有并行处理,实时处理和故障处理等重要功能。 
    2、两过程的联系与区别
    2.1联系
        中断与调用子程序两过程属于完全不同的概念,但它们也有不少相似之处。两者都需要保护断点(即下一条指令地址)、跳至子程序或中断服务程序、保护现场、子程序或中断处理、恢复现场、恢复断点(即返回主程序)。两者都可实现嵌套,即正在执行的子程序再调另一子程序或正在处理的中断程序又被另一新中断请求所中断,嵌套可为多级。
    正是由于这些表面上的相似处,很容易使学生把两者混淆起来,特别是把中断也看为子程序,这就大错特错了。
    2.2区别
        中断过程与调用子程序过程相似点是表面的,从本质上讲两者是完全不一样的。
    两者的根本区别主要表现在服务时间与服务对象不一样上。首先,调用子程序过程发生的时间是已知和固定的,即在主程序中的调用指令(CALL)执行时发生主程序调用子程序,调用指令所在位置是已知和固定的。而中断过程发生的时间一般的随机的,CPU在执行某一主程序时收到中断源提出的中断申请时,就发生中断过程,而中断申请一般由硬件电路产生,申请提出时间是随机的(软中断发生时间是固定的),也可以说,调用子程序是程序设计者事先安排的,而执行中断服务程序是由系统工作环境随机决定的;其次,子程序完全为主程序服务的,两者属于主从关系,主程序需要子程序时就去调用子程序,并把调用结果带回主程序继续执行。而中断服务程序与主程序两者一般是无关的,不存在谁为谁服务的问题,两者是平行关系;第三,主程序调用子程序过程完全属于软件处理过程,不需要专门的硬件电路,而中断处理系统是一个软、硬件结合系统,需要专门的硬件电路才能完成中断处理的过程;第四,子程序嵌套可实现若干级,嵌套的最多级数由计算机内存开辟的堆栈大小限制,而中断嵌套级数主要由中断优先级数来决定,一般优先级数不会很大。
    http://blog.csdn.net/douyuhua0918/article/details/7473254

    中断是嵌入式系统中重要的组成部分,但是在标准C中不包含中断。许多编译开发商在标准C上增加了对中断的支持,提供新的关键字用于标示中断服务程序 (ISR),类似于__interrupt、#program interrupt等。当一个函数被定义为ISR的时候,编译器会自动为该函数增加中断服务程序所需要的中断现场入栈和出栈代码。
      中断服务程序需要满足如下要求:
      (1)不能返回值;
      (2)不能向ISR传递参数;
      (3) ISR应该尽可能的短小精悍;
      (4) printf(char * lpFormatString,…)函数会带来重入和性能问题,不能在ISR中采用。

     

      参阅网上资料和个人的一些理解

      a.为什么不能有返回值?

        中断服务函数的调用是硬件级别的,当中断产生,pc指针强制跳转到对应的中断服务函数入口,进入中断具有随机性,并不是某段代码对其进行调用,那么如果有返回值它的返回值返回给谁?显然这个返回值毫无意义,如果有返回值,它必定需要进行压栈操作,这样一来何时出栈怎么出栈将变得无法解决。

      b.不能向ISR传递参数?

        同理,也是由于这样会破坏栈的原因,因为函数传递参数必定会要求压栈出栈操作,由于进入中断服务函数的随机行,谁给它传递参数都成问题

      c.ISR应尽可能的短小精悍?

        如果某个中断频繁产生,而它对应的ISR相当的耗时,那么对中断的响应就会无限的延迟,会丢掉很多的中断请求

      d.printf(char * lpFormatString,…)函数会带来重入和性能问题,不能在ISR中采用。

        这就涉及到一个中断嵌套问题,由于printf之类的glibc函数采用的是缓冲机制,这个缓冲区是共享的,相当于一个全局变量,第一层中断来时,它向缓冲里面写入一些部分内容,恰好这时来了个优先级更高的中断,它同样调用了printf,也向缓冲里面写入一些内容,这样缓冲区的内容就错乱了。

    http://www.cnblogs.com/thammer/p/5017329.html





    展开全文
  • 声明:本博内容由...区别系统中断函数和用户中断函数和前面一篇文章区别开来,之所以要区别系统中断函数和用户中断函数,这是我自己理解。 来看一个结构体:struct irq_desc { unsigned int irq; str

    声明:本博内容由http://blog.csdn.net/luckywang1103/article/details/48949545原创,转载请注明出处,谢谢!

    区别系统中断函数和用户中断函数

    和前面一篇文章区别开来,之所以要区别系统中断函数和用户中断函数,这是我自己的理解。
    来看一个结构体:

    struct irq_desc {
        unsigned int        irq;
        struct irq_chip     *chip;
        irq_flow_handler_t  handle_irq;
        struct irqaction    *action;/* IRQ action list */
        ...
    } ____cacheline_internodealigned_in_smp;

    前面通过set_irq_chip和set_irq_handler是设置了struct irq_desc结构体中的chip和handler_irq,中断产生后,handler_irq对应的系统中断处理函数会首先被调用,这个系统中断处理函数又会去调用irq_desc->action即用户中断处理函数,并且会遍历irq_desc下所有的action,所以要把系统中断处理函数handler_irq与用户中断处理函数action区别开来。以handler_irq为handle_level_irq的例子,如下:

    void handle_level_irq(unsigned int irq, struct irq_desc *desc)
    {
        ...
        action = desc->action;
        action_ret = handle_IRQ_event(irq, action);
        ...
    }
    
    irqreturn_t handle_IRQ_event(unsigned int irq, struct irqaction *action)
    {
        ...
        do {
            ret = action->handler(irq, action->dev_id);
            switch (ret) {
            case IRQ_WAKE_THREAD:
                ...
            case IRQ_HANDLED:
                ...
            default:
                break;
            }
    
            retval |= ret;
            action = action->next;
        } while (action);
    
        return retval;
    }

    注册用户中断处理函数

    一般都使用
    static inline int __must_check request_irq(unsigned int irq, irq_handler_t handler, unsigned long flags, const char *name, void *dev)

    void free_irq(unsigned int irq, void *dev_id)

    展开全文
  • 中断子程序中定义变量,KEIL C51 中也不报错,编译能通过 /* 名称:定时器控制单只LED 说明:LED在定时器的中断例程控制下不断闪烁。 */ #include<reg51.h> #define uint unsigned int #define uchar ...
  • 中断和调用子程序那点破事2.1联系2.2区别3.常见题型   今天来学习记录下中断服务函数(ISR)。关于中断,其实大家或多或少都会了解过,那么,在笔试&面试中,关于中断服务子函数,我们又需要知道那些知识点...
  • 这里主要讲是为何引入进程、进程在Linux空间是如何实现,并且描述了所有与进程执行相关数据结构,最后还会讲到异常和中断等异步执行流程,它们是如何Linux内核进行交互,下面我就来具体介绍一下进程奥妙...
  • 总结:二重点区分了抢占式内核非抢占式内核的区别:抢占式内核可以在内核空间进行抢占,通过对中断处理进行线程化可以提高Linux内核实时性。 三介绍了Linux中断注册函数request_threaded_irq,其实request_irq也...
  • 1. 项目背景 项目是基于Nxp Mcu+FreeRtos,成品是车机(车载导航系统),也是刚入职接手的项目,机器总是无缘无故的重启,没有规律 2. 问题结果 ... 关于Mcu中断的设置,FreeRtosUcos有着明显的区别 ...
  • 关于函数的可重入递归

    千次阅读 2012-03-09 17:34:54
    看到这么一段话:“所谓的重入,就是指某段子程序还没有执行完,就因为中断或者是多任务操作系统的调度原因,导致该程序在一个新的寄存器上下文中被执行(请不要把重入与递归混淆,它们有本质的区别)。...
  • 线程协程之间的区别很大,甚至大过进程线程之间的区别。线程建立在进程之上,协程建立在线程之上。那么协程是什么呢? 协程是一段计算机程序,它一般是一个协作类型的程序,执行时允许暂停恢复。协程非常...
  • forkvfork都是调用函数显示进程id,但是fork是父子进程同时顺序进行,不会中断影响,而vfork是先执行进程,当进程结束之后才会执行父进程 vfork函数执行 这个vfork函数中,利用for循环将进程执行三次,然后...
  • 线程协程之间的区别很大,甚至大过进程线程之间的区别。线程建立在进程之上,协程建立在线程之上。那么协程是什么呢?协程是一段计算机程序,它一般是一个协作类型的程序,执行时允许暂停恢复。协程非常适合...
  • 1.进程定义: ...在一个线程中会有很多函数,我们把这些函数称为程序,在程序执行过程中可以中断去执行别的子程序,而别的子程序也可以中断回来继续执行之前的子程序,这个过程就称为协程。...
  • 用户堆栈系统堆栈的区别

    千次阅读 2017-02-22 16:03:50
    系统栈(也叫核心栈、内核栈)是内存中属于... (2)保存操作系统程序间相互调用参数、返回值、返回点以及程序(函数)局部变量。  用户栈是用户进程空间中一块区域,用于保存用户进程的子程序间相互调用
  • stm32学习笔记——中断的原理

    千次阅读 2018-08-16 00:31:40
    在《微机原理》《计算机组成》等课程[1-4]教学中(本文以MCS-51单片机为例),中断过程既是教学难点又是教学重点,它与主程序调用程序过程有一定相似性,但又有很大区别,调用程序过程相对比较容易掌握,通过...
  • 下面就在C语言中使用子函数实现延时几个问题做些讨论,当然讨论高级语言延时就需要考虑编译器处理器,这里为了讨论方便,而且不失一般性,可以用标准51单片机作处理器uVision2作为编译环境,晶振为12MHz,...
  • 进程线程的区别 无论是进程还是线程,都是由操作系统所管理切换的。 进程线程的切换完全是用户无感,从用户态到内核态再到用户态。 协程的切换完全是程序代码控制的,在用户态的切换,就像函数回调的消
  • 可恢复:等到合适的时候,可以恢复到中断的地方继续执行特殊之处:在执行过程中,在程序(或者说函数)内部可中断,然后转而执行别的程序,在适当的时候再返回来接着执行。进程线程的区别无论是进程还是线程,都...
  • *比如鼠标点击按钮的过程,首先鼠标按下,就会产生一个鼠标左键按下事件(这个可以看成是一个外部鼠标中断事件,由电脑硬件外部中断产生的或者以勾子函数的形式形成的,即事件也可以自己创造了),而这个事件是一个...
  • 可恢复:等到合适的时候,可以恢复到中断的地方继续执行特殊之处:在执行过程中,在程序(或者说函数)内部可中断,然后转而执行别的程序,在适当的时候再返回来接着执行。进程线程的区别无论是进程还是线程,...
  • 可恢复:等到合适的时候,可以恢复到中断的地方继续执行特殊之处:在执行过程中,在程序(或者说函数)内部可中断,然后转而执行别的程序,在适当的时候再返回来接着执行。进程线程的区别无论是进程还是线程,都...
  • windows中断请求级(IRQL)

    千次阅读 2010-02-09 22:03:00
    这也许就是宏内核微内核的区别吧?windows是一个基本的c/s模式的系统,内核里面也不乏这样的例 ,到处都是c/s的影子,不信你看,到处都是xx管理器。所以如果一个模块需要一个服务,那么它就得请求一个服务
  • 在嵌入式系统中,延时是经常需要使用一种手段,延时方法可以通过使用类似于"NOP"指令来实现...下面就在C语言中使用子函数实现延时几个问题做些讨论,当然讨论高级语言延时就需要考虑编译器处理器,这里为了
  • 疯狂内核之——进程管理系统

    热门讨论 2011-05-30 23:31:24
    1.5 fork与vfock系统调用的区别 42 1.6 内核线程 46 1.7 挂起状态进程的组织 49 1.7.1 等待队列头 49 1.7.2 等待队列的操作 50 1.7.3 进程资源限制 55 1.8 系统调用execve() 56 1.8.1 拷贝用户态参数 57 1.8.2 重要...

空空如也

空空如也

1 2 3 4 5 ... 7
收藏数 133
精华内容 53
关键字:

中断函数和子函数的区别