Commit 1107ba88 authored by Alex Zeffertt's avatar Alex Zeffertt Committed by Linus Torvalds

xen: add xenfs to allow usermode <-> Xen interaction

The xenfs filesystem exports various interfaces to usermode.  Initially
this exports a file to allow usermode to interact with xenbus/xenstore.

Traditionally this appeared in /proc/xen.  Rather than extending procfs,
this patch adds a backward-compat mountpoint on /proc/xen, and provides
a xenfs filesystem which can be mounted there.
Signed-off-by: default avatarAlex Zeffertt <alex.zeffertt@eu.citrix.com>
Signed-off-by: default avatarJeremy Fitzhardinge <jeremy.fitzhardinge@citrix.com>
Cc: Ingo Molnar <mingo@elte.hu>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent d8220347
...@@ -17,3 +17,27 @@ config XEN_SCRUB_PAGES ...@@ -17,3 +17,27 @@ config XEN_SCRUB_PAGES
is not accidentally visible to other domains. Is it more is not accidentally visible to other domains. Is it more
secure, but slightly less efficient. secure, but slightly less efficient.
If in doubt, say yes. If in doubt, say yes.
config XENFS
tristate "Xen filesystem"
depends on XEN
default y
help
The xen filesystem provides a way for domains to share
information with each other and with the hypervisor.
For example, by reading and writing the "xenbus" file, guests
may pass arbitrary information to the initial domain.
If in doubt, say yes.
config XEN_COMPAT_XENFS
bool "Create compatibility mount point /proc/xen"
depends on XENFS
default y
help
The old xenstore userspace tools expect to find "xenbus"
under /proc/xen, but "xenbus" is now found at the root of the
xenfs filesystem. Selecting this causes the kernel to create
the compatibilty mount point /proc/xen if it is running on
a xen platform.
If in doubt, say yes.
obj-y += grant-table.o features.o events.o manage.o obj-y += grant-table.o features.o events.o manage.o
obj-y += xenbus/ obj-y += xenbus/
obj-$(CONFIG_HOTPLUG_CPU) += cpu_hotplug.o obj-$(CONFIG_HOTPLUG_CPU) += cpu_hotplug.o
obj-$(CONFIG_XEN_XENCOMM) += xencomm.o obj-$(CONFIG_XEN_XENCOMM) += xencomm.o
obj-$(CONFIG_XEN_BALLOON) += balloon.o obj-$(CONFIG_XEN_BALLOON) += balloon.o
obj-$(CONFIG_XENFS) += xenfs/
\ No newline at end of file
...@@ -40,6 +40,7 @@ ...@@ -40,6 +40,7 @@
#include <linux/ctype.h> #include <linux/ctype.h>
#include <linux/fcntl.h> #include <linux/fcntl.h>
#include <linux/mm.h> #include <linux/mm.h>
#include <linux/proc_fs.h>
#include <linux/notifier.h> #include <linux/notifier.h>
#include <linux/kthread.h> #include <linux/kthread.h>
#include <linux/mutex.h> #include <linux/mutex.h>
...@@ -55,7 +56,10 @@ ...@@ -55,7 +56,10 @@
#include "xenbus_comms.h" #include "xenbus_comms.h"
#include "xenbus_probe.h" #include "xenbus_probe.h"
int xen_store_evtchn; int xen_store_evtchn;
EXPORT_SYMBOL(xen_store_evtchn);
struct xenstore_domain_interface *xen_store_interface; struct xenstore_domain_interface *xen_store_interface;
static unsigned long xen_store_mfn; static unsigned long xen_store_mfn;
...@@ -166,6 +170,9 @@ static int read_backend_details(struct xenbus_device *xendev) ...@@ -166,6 +170,9 @@ static int read_backend_details(struct xenbus_device *xendev)
return read_otherend_details(xendev, "backend-id", "backend"); return read_otherend_details(xendev, "backend-id", "backend");
} }
static struct device_attribute xenbus_dev_attrs[] = {
__ATTR_NULL
};
/* Bus type for frontend drivers. */ /* Bus type for frontend drivers. */
static struct xen_bus_type xenbus_frontend = { static struct xen_bus_type xenbus_frontend = {
...@@ -174,12 +181,13 @@ static struct xen_bus_type xenbus_frontend = { ...@@ -174,12 +181,13 @@ static struct xen_bus_type xenbus_frontend = {
.get_bus_id = frontend_bus_id, .get_bus_id = frontend_bus_id,
.probe = xenbus_probe_frontend, .probe = xenbus_probe_frontend,
.bus = { .bus = {
.name = "xen", .name = "xen",
.match = xenbus_match, .match = xenbus_match,
.uevent = xenbus_uevent, .uevent = xenbus_uevent,
.probe = xenbus_dev_probe, .probe = xenbus_dev_probe,
.remove = xenbus_dev_remove, .remove = xenbus_dev_remove,
.shutdown = xenbus_dev_shutdown, .shutdown = xenbus_dev_shutdown,
.dev_attrs = xenbus_dev_attrs,
}, },
}; };
...@@ -852,6 +860,14 @@ static int __init xenbus_probe_init(void) ...@@ -852,6 +860,14 @@ static int __init xenbus_probe_init(void)
if (!xen_initial_domain()) if (!xen_initial_domain())
xenbus_probe(NULL); xenbus_probe(NULL);
#ifdef CONFIG_XEN_COMPAT_XENFS
/*
* Create xenfs mountpoint in /proc for compatibility with
* utilities that expect to find "xenbus" under "/proc/xen".
*/
proc_mkdir("xen", NULL);
#endif
return 0; return 0;
out_unreg_back: out_unreg_back:
......
...@@ -184,6 +184,7 @@ void *xenbus_dev_request_and_reply(struct xsd_sockmsg *msg) ...@@ -184,6 +184,7 @@ void *xenbus_dev_request_and_reply(struct xsd_sockmsg *msg)
return ret; return ret;
} }
EXPORT_SYMBOL(xenbus_dev_request_and_reply);
/* Send message to xs, get kmalloc'ed reply. ERR_PTR() on error. */ /* Send message to xs, get kmalloc'ed reply. ERR_PTR() on error. */
static void *xs_talkv(struct xenbus_transaction t, static void *xs_talkv(struct xenbus_transaction t,
......
obj-$(CONFIG_XENFS) += xenfs.o
xenfs-objs = super.o xenbus.o
\ No newline at end of file
/*
* xenfs.c - a filesystem for passing info between the a domain and
* the hypervisor.
*
* 2008-10-07 Alex Zeffertt Replaced /proc/xen/xenbus with xenfs filesystem
* and /proc/xen compatibility mount point.
* Turned xenfs into a loadable module.
*/
#include <linux/kernel.h>
#include <linux/errno.h>
#include <linux/module.h>
#include <linux/fs.h>
#include <linux/magic.h>
#include "xenfs.h"
#include <asm/xen/hypervisor.h>
MODULE_DESCRIPTION("Xen filesystem");
MODULE_LICENSE("GPL");
static int xenfs_fill_super(struct super_block *sb, void *data, int silent)
{
static struct tree_descr xenfs_files[] = {
[2] = {"xenbus", &xenbus_file_ops, S_IRUSR|S_IWUSR},
{""},
};
return simple_fill_super(sb, XENFS_SUPER_MAGIC, xenfs_files);
}
static int xenfs_get_sb(struct file_system_type *fs_type,
int flags, const char *dev_name,
void *data, struct vfsmount *mnt)
{
return get_sb_single(fs_type, flags, data, xenfs_fill_super, mnt);
}
static struct file_system_type xenfs_type = {
.owner = THIS_MODULE,
.name = "xenfs",
.get_sb = xenfs_get_sb,
.kill_sb = kill_litter_super,
};
static int __init xenfs_init(void)
{
if (xen_pv_domain())
return register_filesystem(&xenfs_type);
printk(KERN_INFO "XENFS: not registering filesystem on non-xen platform\n");
return 0;
}
static void __exit xenfs_exit(void)
{
if (xen_pv_domain())
unregister_filesystem(&xenfs_type);
}
module_init(xenfs_init);
module_exit(xenfs_exit);
This diff is collapsed.
#ifndef _XENFS_XENBUS_H
#define _XENFS_XENBUS_H
extern const struct file_operations xenbus_file_ops;
#endif /* _XENFS_XENBUS_H */
...@@ -13,6 +13,7 @@ ...@@ -13,6 +13,7 @@
#define EFS_SUPER_MAGIC 0x414A53 #define EFS_SUPER_MAGIC 0x414A53
#define EXT2_SUPER_MAGIC 0xEF53 #define EXT2_SUPER_MAGIC 0xEF53
#define EXT3_SUPER_MAGIC 0xEF53 #define EXT3_SUPER_MAGIC 0xEF53
#define XENFS_SUPER_MAGIC 0xabba1974
#define EXT4_SUPER_MAGIC 0xEF53 #define EXT4_SUPER_MAGIC 0xEF53
#define HPFS_SUPER_MAGIC 0xf995e849 #define HPFS_SUPER_MAGIC 0xf995e849
#define ISOFS_SUPER_MAGIC 0x9660 #define ISOFS_SUPER_MAGIC 0x9660
......
...@@ -136,8 +136,6 @@ struct xenbus_transaction ...@@ -136,8 +136,6 @@ struct xenbus_transaction
/* Nil transaction ID. */ /* Nil transaction ID. */
#define XBT_NIL ((struct xenbus_transaction) { 0 }) #define XBT_NIL ((struct xenbus_transaction) { 0 })
int __init xenbus_dev_init(void);
char **xenbus_directory(struct xenbus_transaction t, char **xenbus_directory(struct xenbus_transaction t,
const char *dir, const char *node, unsigned int *num); const char *dir, const char *node, unsigned int *num);
void *xenbus_read(struct xenbus_transaction t, void *xenbus_read(struct xenbus_transaction t,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment