This patch creates two sysfs files to export where VMCSINFO is allocated and what maximum size of VMCSINFO is, as below: $ cat /sys/kernel/vmcsinfo 1cb88a0 $ cat /sys/kernel/vmcsinfo_maxsize 1000 /sys/kernel/vmcsinfo shows the physical address of VMCSINFO, while /sys/kernel/vmcsinfo_maxsize shows the max size of VMCSINFO. Signed-off-by: zhangyanfei <zhangyanfei@xxxxxxxxxxxxxx> --- kernel/ksysfs.c | 29 +++++++++++++++++++++++++++++ 1 files changed, 29 insertions(+), 0 deletions(-) diff --git a/kernel/ksysfs.c b/kernel/ksysfs.c index 4e316e1..8a27ece 100644 --- a/kernel/ksysfs.c +++ b/kernel/ksysfs.c @@ -18,6 +18,8 @@ #include <linux/stat.h> #include <linux/sched.h> #include <linux/capability.h> +#include <asm/vmcsinfo.h> +#include <asm/virtext.h> #define KERNEL_ATTR_RO(_name) \ static struct kobj_attribute _name##_attr = __ATTR_RO(_name) @@ -133,6 +135,29 @@ KERNEL_ATTR_RO(vmcoreinfo); #endif /* CONFIG_KEXEC */ +#ifdef CONFIG_X86 +static ssize_t vmcsinfo_show(struct kobject *kobj, + struct kobj_attribute *attr, char *buf) +{ + if (cpu_has_vmx()) + return sprintf(buf, "%lx\n", + paddr_vmcsinfo_note()); + return 0; +} +KERNEL_ATTR_RO(vmcsinfo); + +static ssize_t vmcsinfo_maxsize_show(struct kobject *kobj, + struct kobj_attribute *attr, char *buf) +{ + if (cpu_has_vmx()) + return sprintf(buf, "%x\n", + (unsigned int)vmcsinfo_max_size); + return 0; +} +KERNEL_ATTR_RO(vmcsinfo_maxsize); + +#endif /* CONFIG_X86 */ + /* whether file capabilities are enabled */ static ssize_t fscaps_show(struct kobject *kobj, struct kobj_attribute *attr, char *buf) @@ -182,6 +207,10 @@ static struct attribute * kernel_attrs[] = { &kexec_crash_size_attr.attr, &vmcoreinfo_attr.attr, #endif +#ifdef CONFIG_X86 + &vmcsinfo_attr.attr, + &vmcsinfo_maxsize_attr.attr, +#endif NULL }; -- 1.7.1 -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html