sopc课件第八章.ppt
《sopc课件第八章.ppt》由会员分享,可在线阅读,更多相关《sopc课件第八章.ppt(231页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、本章讨论本章讨论Nios II处理器系统的深入处理器系统的深入设计设计内容包括内容包括:(1)异常处理程序的开发异常处理程序的开发(2)缓存和紧耦合存储器的编程缓存和紧耦合存储器的编程(3)C/os II实时操作系统实时操作系统(4)以太网与轻量以太网与轻量IP(5)Nios II多处理器系统多处理器系统(6)定制定制Nios II用户指令和定制基于用户指令和定制基于Avalon的用户外设等。的用户外设等。第八章第八章 目录目录n8.1 异常处理程序的开发异常处理程序的开发 8.1.1 Nios II异常分类异常分类 8.1.2 硬件抽象层的实现硬件抽象层的实现 8.1.3 中断服务程序(中断
2、服务程序(ISRs)n8.2 缓存和紧耦合存储器的编程缓存和紧耦合存储器的编程 8.2.1 复位后缓存的初始化复位后缓存的初始化 8.2.2 设备驱动程序中缓存的编程设备驱动程序中缓存的编程 8.2.3 装载程序或自更新程序的编写装载程序或自更新程序的编写 8.2.4 多主多主/多多CPU系统中缓存的管理系统中缓存的管理 8.2.5 紧耦合存储器概述紧耦合存储器概述 8.2.6 紧耦合存储器接口紧耦合存储器接口 8.2.7 使用紧耦合存储器创建使用紧耦合存储器创建Nios II系统系统n8.3 C/OS-II实时操作系统实时操作系统 8.3.1 C/OS-II实时操作系统简介实时操作系统简介
3、8.3.2 C/OS-II 在在Nios II上的移植上的移植 8.3.3 Nios II IDE中中C/os-II工程的实现工程的实现 8.3.4 软硬件要求软硬件要求 8.3.5 在在Nios II中建立中建立C/os- II工程工程 n8.4 以太网与轻量以太网与轻量IP 8.4.1 轻量轻量IP概述概述 8.4.2 轻量轻量IP协议栈的使用协议栈的使用 8.4.3 Nios II IDE中轻量中轻量IP的配置的配置 8.4.4 设计实例的软硬件环境设计实例的软硬件环境 8.4.5 实例的设计文件实例的设计文件 8.4.6 软件开发流程软件开发流程 8.4.7 Simple Socket
4、 Server设计概述设计概述n8.5 Nios II多处理器系统多处理器系统 8.5.1 多处理器系统设计概述多处理器系统设计概述 8.5.2 多处理器系统的优势多处理器系统的优势 8.5.3 Nios II多处理器系统硬件设计多处理器系统硬件设计 8.5.4 Nios II多处理器系统的资源共享多处理器系统的资源共享 8.5.5 Nios II多处理器系统软件设计多处理器系统软件设计 8.5.6 Nios II多处理器系统设计实例多处理器系统设计实例 n8.6 定制定制Nios II用户指令用户指令 8.6.1 Nios II定制指令综定制指令综述述 8.6.2 定制指令实现方式定制指令实
5、现方式 8.6.3 定制指令设计示例定制指令设计示例n8.7 定制基于定制基于Avalon的用户外的用户外设设 8.7.1 设计概述设计概述 8.7.2 组件开发流程组件开发流程 8.7.3 设计实例设计实例 PWM从端从端口口 8.1 异常处理程序的开发异常处理程序的开发 8.1.1 Nios II异常分类异常分类 8.1.2 硬件抽象层的实现硬件抽象层的实现 8.1.3 中断服务程序(中断服务程序(ISRs) 8.1 异常处理程序的开发异常处理程序的开发 8.1.1 Nios II异常分类异常分类 8.1.2 硬件抽象层的实现硬件抽象层的实现 8.1.3 中断服务程序(中断服务程序(ISR
6、s) NiosII处理器的异常分为两大类:处理器的异常分为两大类:n 硬件中断异常n 软件异常 8.1.1 Nios II异常分类异常分类 软件异常软件异常又分为:又分为:l 未实现指令l 软件陷阱l 其他异常 8.1 异常处理程序的开发异常处理程序的开发 8.1.1 Nios II异常分类异常分类 8.1.2 硬件抽象层的实现硬件抽象层的实现 8.1.3 中断服务程序(中断服务程序(ISRs) (2)确定)确定ipending是否不为零。若是否不为零。若ipending有非有非零位,则异常是一个硬件中断;若所有位均为零位,则异常是一个硬件中断;若所有位均为0,则异常是一软件异常。则异常是一软
7、件异常。HAL系统库提供的异常处理程序位于异常地址,它系统库提供的异常处理程序位于异常地址,它采用以下方法区分采用以下方法区分硬件中断硬件中断和和软件异常软件异常: (1)确定)确定estatus寄存器的寄存器的EPIE位是否被允许。位是否被允许。若不允许,则是一个软件异常;若若不允许,则是一个软件异常;若EPIE允许,则继允许,则继续下一步。续下一步。8.1.2 硬件抽象层的实现硬件抽象层的实现 alt_irq_entry 若若Nios II系统包含硬件中断,顶层汇编子程序系统包含硬件中断,顶层汇编子程序alt_irq_entry位于异常地址。这个汇编子程序检查位于异常地址。这个汇编子程序检
8、查产生了何种类型中断,调用相应子程序。软件中断产生了何种类型中断,调用相应子程序。软件中断调用一个调用一个Software_exception;硬件中断调用;硬件中断调用Alt_irq_handler子程序子程序 该方法使用如下该方法使用如下3个子程序:个子程序:lalt_irq_entry( )lalt_irq_handler( )lsoftware_exception( )software_exception software_exception子程序确定软件中断源。它子程序确定软件中断源。它主要确定引起软中断的未实现指令,并调用相应的主要确定引起软中断的未实现指令,并调用相应的指令仿真子
9、程序。指令仿真子程序。若若Nios II系统不包含产生硬件中断的外设,系统不包含产生硬件中断的外设,software_exception子程序直接被放在异常地址,子程序直接被放在异常地址,另外,另外,alt_irq_entry和和alt_irq_handler不被链接到不被链接到工程。工程。alt_irq_handler 函数函数alt_irq_handler()确定中断源(例如,引起()确定中断源(例如,引起中断的设备中断号)和执行已注册的相应的处理函中断的设备中断号)和执行已注册的相应的处理函数。数。IRQ0优先级最高,优先级最高,IRQ31最低。最低。 1 1未实现指令未实现指令 sof
10、tware_exception为每一条未实现指令定义为每一条未实现指令定义了一个仿真子程序,采用这种方式,可支持了一个仿真子程序,采用这种方式,可支持Nios II的所有指令,而并不是所有的所有指令,而并不是所有Nios II的指令都可的指令都可由硬件实现。另一方面,若一条指令由硬件实现,由硬件实现。另一方面,若一条指令由硬件实现,决不会发生相应指令的软件中断。仿真子程序很决不会发生相应指令的软件中断。仿真子程序很小,从一个目标小,从一个目标Nios II核中去掉它们不会有什么核中去掉它们不会有什么影响。未实现指令和无效指令含义不同,影响。未实现指令和无效指令含义不同,software_exc
11、eption子程序不能检测或响应一个子程序不能检测或响应一个无效指令。若指令字中的无效指令。若指令字中的OP和和OPX域的编码未域的编码未定义,其指令执行结果也未定义。定义,其指令执行结果也未定义。2 2软件陷阱异常处理软件陷阱异常处理 当前,当前,software_exception对软件陷阱异常执行对软件陷阱异常执行一个空操作。虽然没有陷阱处理程序,在一个空操作。虽然没有陷阱处理程序,在alt_exception.s中代码仍检测中代码仍检测OP和和OPX编码。当编码。当陷阱的陷阱的OP/OPX条件满足时,软件中断被发起,可条件满足时,软件中断被发起,可以转到用户自己的陷阱处理程序。祥见以转
12、到用户自己的陷阱处理程序。祥见alt_exception.s中的注释。中的注释。 3 3其他的异常类型其他的异常类型 未来未来Nios II处理器核可能定义新的异常类型。处理器核可能定义新的异常类型。HAL实现未考虑当前未定义的异常类型。实现未考虑当前未定义的异常类型。 8.1 异常处理程序的开发异常处理程序的开发 8.1.1 Nios II异常分类异常分类 8.1.2 硬件抽象层的实现硬件抽象层的实现 8.1.3 中断服务程序(中断服务程序(ISRs) Nios II处理器与外设的通讯通常由中断来实现。当处理器与外设的通讯通常由中断来实现。当某外设提出某外设提出IRQ时,相对处理器的正常执行
13、流产生时,相对处理器的正常执行流产生了一个异常。当中断发生时,相应的了一个异常。当中断发生时,相应的ISR必须处理必须处理该中断且中断处理完后使处理器返回到处理前的状该中断且中断处理完后使处理器返回到处理前的状态态。8.1.3 硬件抽象层的实现硬件抽象层的实现下面讨论HAL系统库中中断处理的框架1 1ISRsISRs的的HAL APIHAL API2. 2. 利用利用alt_irq_register()alt_irq_register()函数注册函数注册ISRISR 3 3ISRISR的编写的编写 4. ISRs4. ISRs的允许和禁止的允许和禁止5 5ISRISR的快速处理的快速处理6 6
14、描述描述ISRISR性能的参数性能的参数7 7ISRsISRs的调试的调试8 8编写编写ISRsISRs方法小结方法小结1ISRs的HAL APIn利用HAL API实现ISRs分为2步。首先,为某一特定外设中断写一中断服务程序。其次,必须使用alt_irq_register()函数注册该ISRs。在ISR执行期间,程序中可用alt_irq_enable_all()和alt_irq_disable_all()函数允许和禁止中断。n注意:禁止中断影响中断延迟,故影响系统性能。2. 利用alt_irq_register()函数注册ISR nHAL把alt_irq_register()函数指针注册到
15、一查找表中,当某一个ISR出现时,HAL在查找表中查找该IRQ且调度(dispatch)已注册的ISR。n若ISR成功注册,从alt_irq_register()返回后,相应中断(由id定义)被允许。3ISR的编写 n用户编写的ISR必须与alt_irq_register()要求的原型匹配,ISR函数的原型应该与void isr(void*context, alt_u32 id)原型匹配。nContext和id参数的定义与alt_irq_register()函数中的定义相同。ISR函数负责清除或屏蔽相应的中断条件,之后返回到中断处理程序。nISRs运行环境受到一定限制,在ISRs中许多HAL
16、API调用不可用。例如,在ISRs中不允许访问HAL文件系统。一般来讲,ISR中决不应包括那些可能影响等待中断的函数调用。注意:当最慢的ISR中指令少于70条指令时,允许中断嵌套增加了较高优先级中断的中断延迟。此时中断处理程序中不应该开中断。4. ISRs的允许和禁止nHAL提供alt_irq_disable()、alt_irq_enable()、 alt_irq_disable_all()、alt_irq_enable_all()和 alt_irq_enabled()等函数,允许在某段程序之前关中断,之后再开中断。alt_irq_disable()和alt_irq_enable()可禁止和允
17、许某个中断,alt_irq_disable_all()禁止所有中断,返回一个上下文相关值。调用alt_irq_enable_all()开放所有中断,且传递上下文参数,采用这种方式,中断返回到调用alt_irq_disable_all()之前的状态。若中断被允许,alt_irq_enabled()返回一非零值,允许程序检查中断的状态。n注意:关中断的时间应尽可能短,原因是当关中断时间增加时,最大中断延迟也增加。5ISR的快速处理要提高ISRs的性能,应遵守以下原则:n把异常地址映射到快速存储器可提高异常处理程序的执行速度。例如,与速度较慢的SDRAM相比,应优先选择具有零等待状态的片上RAM。这
18、不是通过软件选择的,异常地址在系统创建时就已被确定,是很容易修改的Nios II CPU硬件的一个属性。nISR函数也应该映射到快速存储器。n一般地,在ISR中应避免进行长时间的计算。6描述ISR性能的参数表8-1注:(1)表中数字表示CPU时钟周期。表8-1中断的性能参数表8-1列出了每种Nios II核的中断延迟、响应时间和恢复时间。7ISRs的调试 在Nios II IDE环境下通过在ISR内设断点可对ISR进行调试。调试器完当执行到断点处,全停止处理器的运行,同时,系统中硬件继续工作。因此当处理器停止时,其他的IRQs可能被忽略。利用Debugger可单步调试ISR,但其他采用中断驱动
19、的设备驱动程序的状态只有当处理器回到正常的状态时才有效。必须使处理器复位才能使系统回到已知状态。在单步期间,Ipending寄存器(ct14)被屏蔽为全0,这使得单步期间CPU不响应IRQs。结果,若单步调试需读取ipending寄存器的异常处理程序(例_irq_entry()或alt_irq_handler())时,代码无法检测任何已登记的IRQs。断点不影响软件异常的调试。可以在ISR中设断点(且单步运行),因为异常处理程序已使用Ipengding来确定哪个IRQ引起了异常。8编写ISRs方法小结n使用HAL API提供的alt_irq_register()函数注册ISR。n编写的ISR函
20、数应与原型void isr(void*context,alt_u32 id) 匹配。n尽可能减少ISR中的任务量。n从中断返回后,再对耗时较长的任务进行处理。ISR可使用消息传递机制通知ISR以外的耗时长的任务。n在ISR内部不要使用C标准库中的I/O函数,比如printf()。n在ISR中使用alt_irq_interruptible(),alt_irq_non_interruptible()允许和禁止高优先级的ISRs,若ISR很短,没有必要在其内部允许较高优先级的中断。n要得到最快的执行性能,异常处理程序和ISR代码应存放在快速存储器中。 8.2 缓存和紧耦合存储器的编程缓存和紧耦合存储
21、器的编程l 8.2.1 复位后缓存的初始化复位后缓存的初始化l 8.2.2 设备驱动程序中缓存的编程设备驱动程序中缓存的编程 l 8.2.3 装载程序或自更新程序的编写装载程序或自更新程序的编写 l 8.2.4 多主多主/多多CPU系统中缓存的管理系统中缓存的管理l 8.2.5 紧耦合存储器概述紧耦合存储器概述l 8.2.6 紧耦合存储器接口紧耦合存储器接口l 8.2.7 使用紧耦合存储器创建使用紧耦合存储器创建Nios II系统系统8.2 缓存和紧耦合存储器的编程 Nios II处理器核可以包含指令和数据缓存。幸运的是:大部分建立在HAL系统库上的软件,不需要对缓存进行特别的考虑,均可在Ni
22、os II处理器上正常运行。但某些程序必须直接管理缓存。Nios II提供一些方法来进行以下操作: 初始化指令和数据缓存行。 刷新指令和数据缓存行。 装载和存储指令时,旁路数据缓存。 8.2 缓存和紧耦合存储器的编程缓存和紧耦合存储器的编程l 8.2.1 复位后缓存的初始化复位后缓存的初始化l 8.2.2 设备驱动程序中缓存的编程设备驱动程序中缓存的编程 l 8.2.3 装载程序或自更新程序的编写装载程序或自更新程序的编写 l 8.2.4 多主多主/多多CPU系统中缓存的管理系统中缓存的管理l 8.2.5 紧耦合存储器概述紧耦合存储器概述l 8.2.6 紧耦合存储器接口紧耦合存储器接口l 8.
23、2.7 使用紧耦合存储器创建使用紧耦合存储器创建Nios II系统系统8.2.1 复位后缓存的初始化n复位后,指令和数据缓存的内容是随机的,程序必须首先对其初始化。n软件不能禁止Nios II的缓存。为了能正常进行操作,处理器复位时会使与复位处理程序地址相关的指令缓存行无效,这迫使指令缓存从存储器中取出与该缓存行相应的指令。复位处理程序的地址必须与指令缓存行的大小对齐。n复位处理程序的前8条指令必须初始化指令缓存的其余部分。Nios II initiiniti指令用于初始化指令缓存行。不要使用flushiflushi指令初始化指令缓存行,原因是它可能引起不可预知的结果。 8.2 缓存和紧耦合存
24、储器的编程缓存和紧耦合存储器的编程l 8.2.1 复位后缓存的初始化复位后缓存的初始化l 8.2.2 设备驱动程序中缓存的编程设备驱动程序中缓存的编程 l 8.2.3 装载程序或自更新程序的编写装载程序或自更新程序的编写 l 8.2.4 多主多主/多多CPU系统中缓存的管理系统中缓存的管理l 8.2.5 紧耦合存储器概述紧耦合存储器概述l 8.2.6 紧耦合存储器接口紧耦合存储器接口l 8.2.7 使用紧耦合存储器创建使用紧耦合存储器创建Nios II系统系统8.2.2 设备驱动程序中缓存的编程 HAL提供C语言的宏IORDIORD和IOWRIOWR,用来扩展旁路数据缓存的汇编指令。IORDI
25、ORD宏对ldwioldwio指令进行扩展,IOWRIOWR宏对stwiostwio指令进行扩展,HAL设备驱动程序访问设备寄存器时应使用这些宏。表8-2 旁路数据缓存的HAL I/O宏 宏 功能IORD(BASE,REGNUM)读寄存器的值,该寄存器基地址为BASE,偏移量为REGNUM。假设偏移量是相对总线地址宽度的偏移。IOWR(BASE,REGNUM,DATA)写数据DATA到寄存器中去,该寄存器基地址为BASE。偏移量为REGNUM,假设偏移量是相对总线地址宽度的偏移。IORD_32DIRECT(BASE,OFFSET)在地址BASE+OFFSET地址处进行一次32位的读操作。IOR
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- sopc 课件 第八
限制150内