
GIC400,支持最大8个core,在gicv2中,gic由两个大模块组成:distributor 和 cpu interface
Distributor:用来收集所有的中断来源,并且为每个中断源设置中断优先级,中断分组,中断目的core。
提供以下功能 地址0x1000 — 0x1FFF
全局中断使能
[GICD_CTRL] 0x000
每个中断的使能
GICD_ENABLE_CLEAR
中断的优先级
GIC-400 最大支持256级优先级
如果两个或多个中断具有相同的优先级,则仲裁取决于类型中断:由中断ID号来确定,SGI<PPI<SPI。中断号越小,优先级越高
写入中断优先级寄存器 GICD_IPRIORITYR 不会影响活动中断的优先级。
[中断的分组]
coer 0 irq or fiq (secure)
core 1 only irq (unsecure)
中断的目的core
Interrupt Processor Targets Registers, GICD_ITARGETSRn
中断触发方式
level-sensitive还是edge-triggered
每个中断的状态管理
提供软件,可以修改中断的状态
每个 CPU 接口向相应的处理器发出中断信号并接收确认和来自该处理器的 EOI(end of interrupt) 访问。这些 AXI 访问传达中断 ID 和其他有关中断的信息,还会触发对distribution服务器状态的更新。
CPU 接口为其连接的处理器获取最高优先级的挂起中断,确定中断是否具有足够的优先级以向处理器发出中断请求信号。到判断是否向处理器发出中断请求信号,CPU接口考虑中断优先级掩码和处理器的抢占设置。
At any time, the connected processor can read the priority of its highest priority active interrupt from its GICC_HPPIR, (CPU interface register)
提供以下功能
◾virtual cpu interface:将GICD发送的虚拟中断信息,通过VIRQ,VFIQ管脚,传输给core(需要CPU支持虚拟化)。每一个core,有一个virtual cpu interface。而在这virtual cpu interface中,又包含以下两个组件:

◾virtual interface control:寄存器使用 GICH_ 作为前缀
◾virtual cpu interface:寄存器使用 GICV_ 作为前缀
GICv2支持by pass mode,也就是gic外部的FIQ,IRQ直接接到core的FIQ,IRQ上,相当于gic是不使能的。也就是CFGSDISABLE是有效的,将GIC给无效掉.
gicv2,定义了自己的一些寄存器,这些寄存器,都是使用memory-mapped的方式去访问的,也就是在soc中,会留有一片空间给gic。CPU通过访问这部分空间,来对gic进行操作。
寄存器,分为以下:
◾GICD_*: distributor的寄存器
◾GICC_*: cpu interface的寄存器
◾GICH_*: 虚拟interface的控制寄存器
◾GICV_*:虚拟CPU的控制寄存器
givc2,将中断,分成了group0和group1。使用寄存器GICD_IGROUPRn来对每个中断,设置组。


◾group0:安全中断,由nFIQ或nirq驱动
◾group1:非安全中断,由nIRQ驱动
默认情况下,所有中断都是组 0 中断,并使用 IRQ 向连接的处理器发送信号中断请求
CPU 接口可以配置为使用 FIQ 向连接的处理器发送组 0 中断信号中断请求。
group0 或者group1都可以分别被disable,但是可能存在再group1的中断优先级大于group0,但是group1 is disable,group0 is enable,这时候如果产生一个中断在group1中,那么distribution将不会发送任何中断给cpu interface。所以需要建议总要保持高优先级的中断组是enable的,并且一个group中的中断优先级应该都大于或小于另外一个组。
!](https://img-blog.csdnimg.cn/e6c0604c12a645a9bade055d06fc818b.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBASUPnoo7noo7lv7U=,size_20,color_FFFFFF,t_70,g_se,x_16)
gic,支持最大1020个中断。其中断号分配如下:gicv2支持480个

中断认可,是指cpu响应该中断。此时中断状态从pending状态,变为active状态。通过访问GICC_IAR(read only)寄存器,来对中断进行认可。中断一旦被应答,Distributor就会把该中断的状态从pending状态修改成active或者pending and active(这是和该interrupt source的信号有关,例如如果是电平中断并且保持了该asserted电平,那么就是pending and active)。processor ack了中断之后,CPU interface就会deassert nIRQCPU和nFIQCPU信号线。
◾GICC_EOIR(0x0010):End of Interrupt,只写,中断处理完成后需要写该寄存器
◾GICC_IAR(0x000C):Interrupt Acknowledge,只读,可以查看当前pending的最高优先级中断
◾GICC_IAR: 认可group0的中断
◾GICC_AIAR: 认可group1的中断
中断完成,是指cpu处理完中断。此时中断状态从active状态,变为[inactive]状态。当interrupt handler处理完了一个中断的时候,会向写CPU interface的寄存器(GICC_EOIR(0x0010))从而通知GIC CPU已经处理完该中断。做这个动作一方面是通知Distributor将中断状态修改为deactive,另外一方面,CPU interface会priority drop,从而允许其他的pending的interrupt向CPU提交gic中,对中断完成,定义了以下两个stage:
◾优先级重置(priority drop):将当前中断mask的最高优先级进行重置,以便能够响应低优先级中断。group0中断,通过写GICC_EOIR寄存器,来实现优先级重置,group1中断,通过写 GICC_AEOIR 寄存器,来实现优先级重置。
◾中断无效(interrupt deactivation):将中断的状态,设置为inactive状态。通过写 GICC_DIR 寄存器,来实现中断无效。
对于中断来说,我们是希望中断处理程序越短越好,但是有些中断处理程序,就是比较长,在这种情况下,就会影响其他中断得到相应,从而影响实时性。比如当前cpu在响应优先级为4的中断A,但是这个中断A的中断处理程序比较长,此时如果有优先级为5的中断B到来,那么cpu是不会响应这个中断的。
在软件上,会将中断处理程序分为两部分,分为上半部分,和下半部分。在上半部分,完成中断最紧急的任务,然后就可以通知GIC,降低当前的中断处理优先级,以便其他中断能够得到响应。在下半部分,处理该中断的其他事情。在这种机制下,低优先级的中断,不用等待高优先级的中断,完全执行完中断处理程序后,就可以被cpu所响应,提高实时性。
为了实现上述机制,就将中断完成分成了2步。还是刚刚的例子,cpu在响应优先级为4的中断A,当中断A的上半部分完成后,通知GIC,优先级重置(drop priority),GIC将当前的最高优先级中断重置,重置到响应中断A之前的优先级,比如优先级6,那么此时优先级为5的中断B,就可以被cpu响应。最后中断A的下半部分完成后,通知GIC,将该中断A的状态,设置为inactive状态,此时中断A就真正的完成了。
当然,也可以不将中断完成分成2步,就1步。通过控制 GICC_CTLR寄存器的EOImode比特,来决定是否将中断完成分成2步。

中断处理流程,包含了以下几步:
通过设置GICD_ISENABLERn寄存器,来使中断使能,通过设置GICD_ICENABLERn寄存器,来使中断禁止。
这两个寄存器,都是bit有效的寄存器,一个bit,关联一个中断。

通过设置GICD_ISPENDRn或GICD_ICPENDRn寄存器,可以读取和修改中断的pending状态。这两个寄存器,也是bit有效的寄存器,一个bit,关联一个中断。
通过设置GICD_ISACTIVERn或GICD_ICACTIVERn寄存器,可以读取和修改中断的active状态。这两个寄存器,也是bit有效的寄存器,一个bit,关联一个中断
通过写 GICD_SGIR 寄存器,来产生软中断。软中断,可以指定产生中断,发往执行的core,也可以发送多个core。
对于软中断,是软件产生的中断。比如软件,想给执行自己的core,发送一个中断,就可以通过软中断来产生。或者软件,想起其他的core,发送一个中断,也可以通过软中断来产生。
寄存器如下:

对于TargetListFileter:决定distributor将软中断,如何发送给cpu interface。

◾0b00:按照CPUTargetList的指定,来发送软中断
◾0b01:按照CPUTargetList的指定,来发送软中断,但是不能发送给自己
◾0b10:软中断,只能发送给自己
描述如下:

对于多core的系统,会给每个core一个编号。gicv2支持最多8个core,因此core的编号就是0-7,刚好8个bit,可以表示。这样的CPUTargetList,就和8个cpu相对应。第0bit,表示core0,第7bit,表示core7。如果想给core1,core2,core7发送软中断,那么此时这个位域要填入0x84。

描述如下:
这个用来支持安全扩展,在gicv2中,将中断进行了分组
◾group0:安全中断 FIQ
◾group1:非安全中断 IRQ or FIQ
这个bit,用来表示发送的中断,是安全中断,还是非安全中断。而且这个bit,只有core处于安全状态的时候,才能写。如果core是处于非安全状态,那么这个bit被忽略,也就是只能发非安全的中断。
中断组影响中断是否可以转发到CPU接口,也对以后有影响CPU 接口中的路由决策,可能包括是否向处理器作为 FIQ 或 IRQ 异常请求
**SGIINTID:**发送的软中断的中断号
gicv2,支持最小16个,最大256个中断优先级,如下图所示:

如果实现的中断优先级小于256个,那么最低的几个bit,是为0的。
通过设置GICD_IPRIORITYRn寄存器,来设置中断的优先级。这个寄存器是字节有效的,也就是一个字节,对应一个中断的优先级。优先级数值越小,那么这个中断的优先级越高。
高优先级的中断,是可以抢占低优先级的中断。
下图是gic的使用例子:

外部的中断,连接到gic。由distributor进行中断分组。中断请求,由distributor发送给cpu interface,cpu interface再发送给处理器。
对于支持安全扩展,其应用如下:

安全中断,处于group0,非安全中断处于group1。
gicv2最多只能支持8个core,超过了8个core,那么就不能使用gicv2了。对于手机的arm处理器来说,最多也就8个core。但是对于服务器,桌面级的arm处理器,那么就可能会超过8个core,此时gicv2就不适用了,所以ARM后面又加入GICv3,v4架构。
GICv2的寄存器,都是通过memory-mapped的方式访问。但是中断在一个soc系统中,是经常会产生的,那么处理器就会经常的读取gic的寄存器,而使用memory-mapped的方式去访问,就会影响中断响应速度。在之后的GICv3,v3中,就加入了使用系统寄存器来进行访问,加快中断处理。
GICv2只是一个gic的架构,其实现的对应的IP是gic400
可配置的cpu_num(1~8)
可配置的spi_nums(0~480),需要是32 的整数倍
AXI_RID_BITS,axi的read id width,至少1bit。
AXI_WID_BITS: axi的write id width 至少1bit。
SGI 是通过写入软件生成的中断寄存器GICD_SGIR生成的。CPU 接口最多可为每个目标处理器生成 16 个 SGI,ID0-ID15。
PPI 是特定于单个处理器的中断。所有 PPI 信号都是低电平有效的电平敏感

(a)nLEGACYIRQ信号线。对应interrupt ID 31,在bypass mode下(这里的bypass是指bypass GIC functionality,直接连接到某个processor上),nLEGACYIRQ可以直接连到对应CPU的nIRQCPU信号线上。在这样的设置下,该CPU不参与其他属于该CPU的PPI以及SPI中断的响应,而是特别为这一根中断线服务。
(b)nCNTPNSIRQ信号线。来自Non-secure physical timer的中断事件,对应interrupt ID 30。
(c)nCNTPSIRQ信号线。来自secure physical timer的中断事件,对应interrupt ID 29。
(d)nLEGACYFIQ信号线。对应interrupt ID 28。概念同nLEGACYIRQ信号线,不再描述。
(e)nCNTVIRQ信号线。对应interrupt ID 27。Virtual Timer Event,和虚拟化相关,这里不与描述。
(f)nCNTHPIRQ信号线。对应interrupt ID 26。Hypervisor(管理程序) Timer Event,和虚拟化相关,这里不与描述
SPI 可以配置每个SPI是否是边沿触发在上升沿或高电平敏感。
所有信号,包括 SPI,必须与 GIC-400 中的时钟同步。因此,任何来自异步源的中断信号在连接之前必须同步到 GIC-400。
(1)设置distributor和CPU interface寄存器组的基地址;
(2)读取GICD_TYPER寄存器,计算当前GIC最大支持多少个中断源;
(3)初始化distributor:
a.disable distributor;
b.设置中断分组;
c.设置SPI中断的路由;
d.设置SPI中断的触发类型;
e.disactive和disable所有中断源;
f.enable distributor;
(4)初始化CPU Interface:
a.设置GIC_CPU_PRIMASK,设置中断优先级mask level;
b. enable CPU interface;
我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div
我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看rubyzip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d
类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
假设我做了一个模块如下:m=Module.newdoclassCendend三个问题:除了对m的引用之外,还有什么方法可以访问C和m中的其他内容?我可以在创建匿名模块后为其命名吗(就像我输入“module...”一样)?如何在使用完匿名模块后将其删除,使其定义的常量不再存在? 最佳答案 三个答案:是的,使用ObjectSpace.此代码使c引用你的类(class)C不引用m:c=nilObjectSpace.each_object{|obj|c=objif(Class===objandobj.name=~/::C$/)}当然这取决于
我正在尝试使用ruby和Savon来使用网络服务。测试服务为http://www.webservicex.net/WS/WSDetails.aspx?WSID=9&CATID=2require'rubygems'require'savon'client=Savon::Client.new"http://www.webservicex.net/stockquote.asmx?WSDL"client.get_quotedo|soap|soap.body={:symbol=>"AAPL"}end返回SOAP异常。检查soap信封,在我看来soap请求没有正确的命名空间。任何人都可以建议我
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
我在我的项目目录中完成了compasscreate.和compassinitrails。几个问题:我已将我的.sass文件放在public/stylesheets中。这是放置它们的正确位置吗?当我运行compasswatch时,它不会自动编译这些.sass文件。我必须手动指定文件:compasswatchpublic/stylesheets/myfile.sass等。如何让它自动运行?文件ie.css、print.css和screen.css已放在stylesheets/compiled。如何在编译后不让它们重新出现的情况下删除它们?我自己编译的.sass文件编译成compiled/t
我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h
我想为Heroku构建一个Rails3应用程序。他们使用Postgres作为他们的数据库,所以我通过MacPorts安装了postgres9.0。现在我需要一个postgresgem并且共识是出于性能原因你想要pggem。但是我对我得到的错误感到非常困惑当我尝试在rvm下通过geminstall安装pg时。我已经非常明确地指定了所有postgres目录的位置可以找到但仍然无法完成安装:$envARCHFLAGS='-archx86_64'geminstallpg--\--with-pg-config=/opt/local/var/db/postgresql90/defaultdb/po