无法读取 APIC 定时器寄存器
Failed to read APIC timer registers
我正在编写一个 Linux 内核模块来读取转储本地 APIC 计时器寄存器。
我在 X86_64 平台上使用 Ubuntu 16.04 桌面。
X2APIC 被禁用,grub.cfg 中的 nohz=off。
我正在使用以下代码读取 APIC 定时器寄存器。
#include <linux/slab.h>
#include <linux/time.h>
#include <asm/string.h>
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/hrtimer.h>
#include <linux/ktime.h>
#include <asm/apic.h>
void read_apic_timer(void)
{
printk("APIC_TDCR = 0x%x\n", apic_read(APIC_TDCR));
printk("APIC_TMICT = 0x%x\n", apic_read(APIC_TMICT));
printk("APIC_TMCCT = 0x%x\n", apic_read(APIC_TMCCT));
}
static int __init timer_init(void)
{
read_apic_timer();
return 0;
}
static void __exit timer_exit(void)
{
printk("module uninstalling\n");
}
module_init(timer_init);
module_exit(timer_exit);
MODULE_LICENSE("GPL");
我得到了这些,
[ 5619.047497] APIC_TDCR = 0x0
[ 5619.047498] APIC_TMICT = 0x0
[ 5619.047499] APIC_TMCCT = 0x0
令我惊讶的是,初始计数器和当前计数器都为0,对吗?
还是我遗漏了什么或做错了什么?
我想我得到了答案。这是因为 CPU 支持 LAPIC 计时器的 TSC 截止日期 feature/mode。在这种模式下,APIC_TDCR/TMICT/TMCCT 没有被使用。就是这样。
我正在编写一个 Linux 内核模块来读取转储本地 APIC 计时器寄存器。
我在 X86_64 平台上使用 Ubuntu 16.04 桌面。
X2APIC 被禁用,grub.cfg 中的 nohz=off。
我正在使用以下代码读取 APIC 定时器寄存器。
#include <linux/slab.h>
#include <linux/time.h>
#include <asm/string.h>
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/hrtimer.h>
#include <linux/ktime.h>
#include <asm/apic.h>
void read_apic_timer(void)
{
printk("APIC_TDCR = 0x%x\n", apic_read(APIC_TDCR));
printk("APIC_TMICT = 0x%x\n", apic_read(APIC_TMICT));
printk("APIC_TMCCT = 0x%x\n", apic_read(APIC_TMCCT));
}
static int __init timer_init(void)
{
read_apic_timer();
return 0;
}
static void __exit timer_exit(void)
{
printk("module uninstalling\n");
}
module_init(timer_init);
module_exit(timer_exit);
MODULE_LICENSE("GPL");
我得到了这些,
[ 5619.047497] APIC_TDCR = 0x0
[ 5619.047498] APIC_TMICT = 0x0
[ 5619.047499] APIC_TMCCT = 0x0
令我惊讶的是,初始计数器和当前计数器都为0,对吗?
还是我遗漏了什么或做错了什么?
我想我得到了答案。这是因为 CPU 支持 LAPIC 计时器的 TSC 截止日期 feature/mode。在这种模式下,APIC_TDCR/TMICT/TMCCT 没有被使用。就是这样。