进程guesttime的统计计算流程

11 篇文章 0 订阅

主要流程是qemu调用kvm_vcpu_ioctl(cpu, KVM_RUN, 0)后陷入内核态,然后kvm模块会进入vcpu_run,成功运行,则会进入

kvm_guest_enter,并把进程task_struct  current->flags |= PF_VCPU;,标识进入guest运行。当从guest退回到内核的时候会执行kvm_guest_exit,删除之前设置的PF_VCPU标识current->flags &= ~PF_VCPU;

 

统计流程: 周期性调度会统计这个时间,tick_sched_timer 会调用 account_process_tick → account_system_time,看到没,其实是调用的 account_system_time, 但是没关系,因为我们之前设置了进程的 flags |= PF_VCPU,所以这里判断 这个标识并调用account_guest_time.  在这个方法里会同时把utime和gtime加上cpu_time。这里就比较奇怪,主要是方法名比较怪了,通过account_system_time 函数进来的,结果cputime时间加到 用户态和guest态时间了,也说明用户态时间utime包含 guest态时间。

 

 

同时发现个问题,我看我们好像打开了 CONFIG_VIRT_CPU_ACCOUNTING_GEN,从一些资料来看,说打开这个会有显著的性能影响。

CONFIG_VIRT_CPU_ACCOUNTING_GEN利用上下文跟踪子系统,通过观察每一个内核与用户空间的边界进行统计.该选项对性能有显著的不良影响,目前仅用于完全无滴答子系统(CONFIG_NO_HZ_FULL)的调试

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值