历史上的今天
返回首页

历史上的今天

今天是:2024年09月30日(星期一)

正在发生

2021年09月30日 | TQ2440裸机中断(软中断swi)

2021-09-30 来源:eefocus

1. 引出:

一般情况下,比如调用open系统调用,大家会说此时系统陷入了内核态,继而调用内核的sys_open来进行实际的open处理,但是为什么用户态调用了open就会陷入内核态呢?所谓的用户态及内核态究竟是什么呢?


2. S3C2440软中断

ARM9处理器有7种工作模式,软中断,通俗的说就是为了从其他工作模式切换到管理模式(在管理模式,可以使用的资源最多),处理器提供软中断,主要是为了支持操作系统的系统调用功能。


ARM体系  CPU的7种工作模式:

· 用户模式(usr): ARM处理器正常的程序执行状态(对应于LINUX的用户态)

· 快速中断模式(fiq): 用于高速数据传输或通道处理

· 中断模式(irq):用于通用的中断处理

· 管理模式(svc):操作系统使用的保护模式(对应于内核态)

· 数据访问终止模式(abt): 当数据或指令预取时进入该模式,可用于虚拟存储及存储保护

· 系统模式(sys) :运行具有特权操作系统任务

· 未定义指令中止模式(und): 当为定义的指令执行时进入该模式,可用于支持硬件协处理的软件仿真


根据上面列表,可以知道Linux下用户态触发软中断进而进入内核态,对应的ARM工作模式就是从USR模式切换为SVC模式.


Q1.硬件中断和软中断有什么区别?

硬件中断是异步的,由外界触发,无法预知的,而软中断是调用特定函数而触发,是开发人员可以预测的.


回到前面的问题,为何调用open之后,就会陷入内核态,而进入SVC模式呢?其实这就像中断一样,当调用特定的函数之后,就像触发了中断条件,继而转到中断向量表中去执行这个中断,其实软中断大概也就是这样。而ADS中ARM声名一个软中断使用__swi关键字声名.具体看下面代码,和结合Reference[1]应该有个整体的了解.


3. 代码分析

下载地址:


/* forsakening @hdu @2013-6-1儿童节快乐 */

/******************************************************/

/*中断向量表部分*/

/******************************************************/

AREA    Init,CODE,READONLY

ENTRY

ResetEntry

 

b ResetHandler

b HandlerUndef ;handler for Undefined mode

b HandlerSWI ;handler for SWI interrupt /* 当触发软中断时,ARM会自动将PC指向这里 */

b HandlerPabort ;handler for PAbort

b HandlerDabort ;handler for DAbort

b . ;reserved

b HandlerIRQ ;handler for IRQ interrupt

b HandlerFIQ ;handler for FIQ interrupt

 

HandlerFIQ HANDLER HandleFIQ

HandlerIRQ HANDLER HandleIRQ

HandlerUndef HANDLER HandleUndef

;HandlerSWI HANDLER HandleSWI

HandlerDabort HANDLER HandleDabort

HandlerPabort HANDLER HandlePabort

 

/* 

 * 软中断服务程序:

 *       a)保存中断前的寄存器状态 

 *       b)跳转到C语言处理软中断函数

 */

HandlerSWI

stmfd sp!,{r0-r3,r12,lr}

ldr r0,[lr,#-4]

bic r0,r0,#0xff000000

bl C_Swi_Handler

ldmfd sp!,{r0-r3,r12,pc}^

/******************************************************/

/* C语言部分 */

/******************************************************/

#include "2440addr.h"

#include "def.h"

 

#define Led1_On()      {rGPBDAT &= (~(1 << 5));} 

#define Led1_Off()     {rGPBDAT |= (1 << 5);} 

#define Led2_On()      {rGPBDAT &= (~(1 << 6));} 

#define Led2_Off()     {rGPBDAT |= (1 << 6);} 

#define Led3_On()      {rGPBDAT &= (~(1 << 7));} 

#define Led3_Off()     {rGPBDAT |= (1 << 7);} 

#define Led4_On()      {rGPBDAT &= (~(1 << 8));} 

#define Led4_Off()     {rGPBDAT |= (1 << 8);} 

 

extern void C_Swi_Handler(unsigned num) ;

 

/*

 * __swi关键字声明了软中断,当调用led1()这个函数时候,即会触发软中断

 * __swi(0x01)括号中的数字表明了该函数对应的软中断号

 */

__swi(0x01) void led1(void);

__swi(0x02) void led2(void);

__swi(0x03) void led3(void);

__swi(0x04) void led4(void);

 

void Led_Init(void)

{

rGPBCON &= ~((3 << 10) | (3 << 12) | (3 << 14) |(3 << 16));

rGPBCON |= ((1<<10) | (1<<12) | (1<<14) | (1<<16)) ;

rGPBUP  &=  ~((1 << 5) | (1 << 6) | (1 << 7) || (1 << 8) ) ;

rGPBDAT |= (1 << 5) | (1 << 6) | (1 << 7) | (1 << 8) ;

}

 

void Delay_1(void)

{

int i;

for (i = 0; i < 100000; i++);

}

 

int Main()

{

Led_Init() ;

while(1)

{

led1() ;

Delay_1();

Led1_Off();

led2() ;

Delay_1();

Led2_Off();

led3() ;

Delay_1();

Led3_Off();

led4() ;

Delay_1();

Led4_Off();

return 0;

}

 

/*

 * 中断向量表中,软中断所跳转的服务函数,num代表了中断号

 */

void C_Swi_Handler(unsigned num)

{

switch(num)

{

case  0x01:

Led1_On() ;  break ;

case  0x02:

Led2_On() ;  break ;

case  0x03:

Led3_On() ;  break ;

case  0x04:

Led4_On() ;  break ;

default

break ;

}

}

 

/******************************************************/

/* Main的反汇编 */

/******************************************************/

Main

        0x00000050:    e92d4010    .@-.    STMFD    r13!,{r4,r14}

        0x00000054:    ebfffffe    ....    BL       Led_Init  ; 0x0

        0x00000058:    e3a04456    VD..    MOV      r4,#0x56000000

        0x0000005c:    ef000001    ....    SWI      0x1              /* 产生软中断,中断号1 */

        0x00000060:    ebfffffe    ....    BL       Delay_1  ; 0x38

        0x00000064:    e5940014    ....    LDR      r0,[r4,#0x14]

        0x00000068:    e3800020     ...    ORR      r0,r0,#0x20

        0x0000006c:    e5840014    ....    STR      r0,[r4,#0x14]

        0x00000070:    ef000002    ....    SWI      0x2              /* 产生软中断,中断号2 */

        0x00000074:    ebfffffe    ....    BL       Delay_1  ; 0x38

        0x00000078:    e5940014    ....    LDR      r0,[r4,#0x14]

        0x0000007c:    e3800040    @...    ORR      r0,r0,#0x40

        0x00000080:    e5840014    ....    STR      r0,[r4,#0x14]

        0x00000084:    ef000003    ....    SWI      0x3              /* 产生软中断,中断号3 */

        0x00000088:    ebfffffe    ....    BL       Delay_1  ; 0x38

        0x0000008c:    e5940014    ....    LDR      r0,[r4,#0x14]

        0x00000090:    e3800080    ....    ORR      r0,r0,#0x80

        0x00000094:    e5840014    ....    STR      r0,[r4,#0x14]

        0x00000098:    ef000004    ....    SWI      0x4              /* 产生软中断,中断号4 */

        0x0000009c:    ebfffffe    ....    BL       Delay_1  ; 0x38

        0x000000a0:    e5940014    ....    LDR      r0,[r4,#0x14]

        0x000000a4:    e3800f40    @...    ORR      r0,r0,#0x100

        0x000000a8:    e5840014    ....    STR      r0,[r4,#0x14]

        0x000000ac:    eaffffea    ....    B        {pc} - 0x50  ; 0x5c

4. Reference

[1]http://blog.csdn.net/forsakening/article/details/8940787 ARM Linux下系统调用

推荐阅读

史海拾趣

CONEXANT公司的发展小趣事

在电子行业的历史长河中,洛克维尔国际是一个不可忽视的名字。作为一家由威拉德·洛克维尔创立的大型公司,洛克维尔国际通过一系列合并与收购,逐渐壮大其业务版图。然而,随着时间的推移,公司进行了战略调整,并于1996年将其半导体部门剥离。这一剥离行动最终催生了科胜讯公司(Conexant Systems),一个专注于半导体技术的独立实体。科胜讯公司继承了洛克维尔在半导体领域的深厚技术积累和市场经验,为其后续的发展奠定了坚实基础。

驰兴电感(Coilank)公司的发展小趣事

驰兴电感自成立之初,就深知技术创新对于企业发展的重要性。公司投入大量资源进行研发,成功推出了一系列全自动、小型化的SMD绕线电感产品。这些产品不仅具有更高的性能和稳定性,而且满足了市场对小型化、轻量化的需求,迅速在市场上获得了广泛的认可。驰兴电感凭借技术创新的优势,逐渐在电子行业中崭露头角。

Everbuild公司的发展小趣事

Everbuild公司成立于2005年,创始人李明是一位对电子技术充满热情的年轻人。在创业初期,公司只有几个员工和一间狭小的办公室。李明带领团队日夜兼程地研发电子元器件,但由于资金短缺和市场竞争激烈,产品销量并不理想。然而,他们并没有放弃,通过不断的技术创新和成本控制,终于在一年后推出了一款具有竞争力的电源管理芯片,赢得了市场的认可。

Electrolube公司的发展小趣事

在电子行业的激烈竞争中,Electrolube公司始终坚持以客户需求为导向,不断创新和拓展产品线。除了UVCL涂层外,公司还推出了一系列树脂、涂料和热管理解决方案的产品组合,为EV电池提供全面保护。

这些产品不仅具有优异的性能表现,而且能够满足不同客户的需求。例如,某些产品具有优异的耐高温性能,适用于高温环境下的电子设备;而另一些产品则具有出色的耐化学腐蚀性能,能够在恶劣的工作环境中保持稳定的性能。

Electrolube公司通过不断的技术创新和产品优化,成功拓展了市场份额,并在电子行业中树立了良好的品牌形象。同时,公司还积极与各大汽车制造商合作,共同推动电动汽车产业的发展。

启攀微电子(Chiphomer)公司的发展小趣事

2009年,全球经济遭受金融海啸的冲击,启攀微电子也面临着巨大的市场压力。然而,公司并没有选择退缩,而是选择了坚守与创新。在经济危机的背景下,公司加强了产品推广和客户支持,同时加快了新品开发的步伐。经过几年的打拼,启攀微电子的消费类电子产品在手机领域取得了一定的市场认可,出货量大幅提升,市场份额稳步上升。

DBM Optix公司的发展小趣事

在竞争激烈的电子行业中,DBM Optix深知只有不断创新才能保持领先地位。因此,公司始终将研发作为核心竞争力之一,持续投入大量资金用于新技术、新产品的开发。通过与高校、研究机构等合作,DBM Optix不断引入新技术、新材料,并将其应用于产品中,从而不断提升产品的性能和品质。这些创新举措使得DBM Optix在光学通信领域始终保持领先地位。

问答坊 | AI 解惑

matlab第六课预告!

好不容易盼到这里啦! 这里我们一起来分享一下二维图形的绘制和修饰 对数坐标图,极坐标图 饼状图,梯形图,概率分布图,向量图等等的二维图形 如果你觉得不过瘾, 我们接着来三维图形 甚至是GUI的界面都可以的啦! 期待大家的帮助拉!…

查看全部问答>

【分享】ATmega16学习笔记PDF完整版下载(WinAVR)

笔记均为原创,欢迎转载,转载请注明出处! 持续更新中,敬请关注!…

查看全部问答>

USB的问题

现在碰到了一个问题。。。。在USB枚举这一块 在枚举的工程中 当插入USBdevice后。出现了一个RESET的中断,之后马上就会出现一个SUSPEND中断,这正常吗?出现这个中断我该怎么处理,是硬件的问题还是软件的问题…

查看全部问答>

求嵌入式开发的经典教材

本人是嵌入式开发的新手,请高人说说嵌入式开发的什么教材比较经典或则比较好的网站,谢谢!…

查看全部问答>

打印驱动问题(位图打印),请高手指教

我用的是DDK里的打印成位图驱动。并对OEMSendPage进行了Hook。主要是想把位图按页分成多个图片。当我打印多页时(以5页为例),在第一页插入一张图片,结果只打印后2,3,4,5页。当每页都插入图片,则只是打印成一张长长的位图(又回到了原始的DDK ...…

查看全部问答>

有关捕获单元的编程问题

我是新手,最近在编一个程序需要用到捕获单元,但有一点想不清楚,就是我需要在第一次捕获时屏蔽中断,第二次捕获后响应中断,从而读出这两个的差值,但程序应该怎么编写呢。感谢指点!…

查看全部问答>

DSP 28335

由于本人刚刚接触DSP28335,想学习一下这个处理器,哪位大哥有好的资料,麻烦给小弟分享一下。 还有就是DSP28335在什么软件基础上编程。 谢谢了。  …

查看全部问答>

谁遇到过SIM300,接受TCP数据后,串口读取数据时,发现数据丢失情况

谁遇到过SIM300,接受TCP数据后,串口读取数据时,发现数据丢失情况~~~急啊~~~高手解答一下啊~~急~!!!…

查看全部问答>

频率计

小弟要做个频率计  用32测外部输入频率   没接触过32  现在又急着用    那位大哥大姐有这个程序或者有这方面的程序    请发我下 1501806575@qq.com   万分感激。…

查看全部问答>