免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2476 | 回复: 5
打印 上一主题 下一主题

阅读linux内核情景分析 疑惑 求解? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-12-24 16:42 |只看该作者 |倒序浏览
内核 版本 2.4
在时钟中断分析章节里面,跟踪到do_timer函数后, 发现对jiffies 的自增采用了转指针类型方式自增
void do_timer(struct pt_regs *regs)
{
        (*(unsigned long *)&jiffies)++;

。。。。。。

}


linux内核情景分析上说这个目的是 gcc会将这个语句 翻译成一条对内存单元的inc自增指令
这样有利于保证原子性操作

但是我试了一下,发现还是 先把 jiffies mov到eax中,然后把eax 自增,然后通过mov到内存单元里面去


是书上说错了?  还是我验证的程序有问题

附上测试程序:
#include <stdio.h>
int main()
{
    int i = 1;
    (*(int*)&i)++;
   printf("i = %d \n", i);
    return (0);
}


gcc -S inc.c

cat inc.s
        .file   "inc.c"
        .section        .rodata
.LC0:
        .string " i = %d \n"
        .text
.globl main
        .type   main, @function
main:
.LFB2:
        pushq   %rbp
.LCFI0:
        movq    %rsp, %rbp
.LCFI1:
        subq    $16, %rsp
.LCFI2:
       movl    $1, -4(%rbp)
        movl    -4(%rbp), %eax
        addl    $1, %eax
        movl    %eax, -4(%rbp)
        movl    -4(%rbp), %esi
        
        movl    $.LC0, %edi
        movl    $0, %eax
        call    printf
        movl    $0, %eax
        leave
        ret
.LFE2:


麻烦大家指导一下。
谢谢

这个是针对2.4内核的, 可能有点老

论坛徽章:
0
2 [报告]
发表于 2010-12-24 17:08 |只看该作者
我还没有开始读中断

论坛徽章:
22
丑牛
日期:2014-08-15 14:32:0015-16赛季CBA联赛之同曦
日期:2017-12-14 15:28:14黑曼巴
日期:2017-08-10 08:14:342017金鸡报晓
日期:2017-02-08 10:39:42黑曼巴
日期:2016-11-15 15:48:38CU十四周年纪念徽章
日期:2016-11-09 13:19:1015-16赛季CBA联赛之同曦
日期:2016-04-08 18:00:03平安夜徽章
日期:2015-12-26 00:06:30程序设计版块每日发帖之星
日期:2015-12-03 06:20:002015七夕节徽章
日期:2015-08-21 11:06:17IT运维版块每日发帖之星
日期:2015-08-09 06:20:002015亚冠之吉达阿赫利
日期:2015-07-03 08:39:42
3 [报告]
发表于 2010-12-24 17:16 |只看该作者
lz读的好认真啊,我想可能是编译内核的时候,gcc加的选项更多,让它那么做的吧。
猜测而已..

论坛徽章:
0
4 [报告]
发表于 2010-12-24 17:50 |只看该作者
有可能是有编译选项的问题。
回去上网找找有什么选项可以控制。

我试了优化选项 -O,但是没有实现效果。

论坛徽章:
0
5 [报告]
发表于 2010-12-25 11:27 |只看该作者
Interrupt context is occasionally called atomic context because, as we shall see, code executing in this context is unable to block.
这个环境本身就在原子上下文中,个人感觉,应该没有必要保证原子性。

2.6内核中上述自加变成了以下形式
jiffies_64 += ticks;

论坛徽章:
0
6 [报告]
发表于 2010-12-25 16:56 |只看该作者
Interrupt context is occasionally called atomic context because, as we shall see, code executing in  ...
EZWORD 发表于 2010-12-25 11:27



我只想知道 gcc 里面是否有这样的编译选项 可以 使用 指针自增 来保持 原子行


假设可行的 话, 可以用在其他地方
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP