diff options
| author | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-10-25 18:38:19 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-10-25 18:38:19 -0400 |
| commit | 2c7505570353af02e48c58ab4d109edd9bbbdd81 (patch) | |
| tree | ece17dd6b25fa7a66eedf57a87174f13eb7b483a /include/linux | |
| parent | fc42dabe465d478311423039448d9dc9051e5f6b (diff) | |
| parent | e1e72965ec2c02db99b415cd06c17ea90767e3a4 (diff) | |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/rusty/linux-2.6-lguest
* git://git.kernel.org/pub/scm/linux/kernel/git/rusty/linux-2.6-lguest:
lguest: documentation update
lguest: Add to maintainers file.
lguest: build fix
lguest: clean up lguest_launcher.h
lguest: remove unused "wake" element from struct lguest
lguest: use defines from x86 headers instead of magic numbers
lguest: example launcher header cleanup.
Diffstat (limited to 'include/linux')
| -rw-r--r-- | include/linux/lguest.h | 4 | ||||
| -rw-r--r-- | include/linux/lguest_launcher.h | 24 |
2 files changed, 11 insertions, 17 deletions
diff --git a/include/linux/lguest.h b/include/linux/lguest.h index 8beb29134626..175e63f4a8c0 100644 --- a/include/linux/lguest.h +++ b/include/linux/lguest.h | |||
| @@ -12,8 +12,8 @@ | |||
| 12 | #define LG_CLOCK_MAX_DELTA ULONG_MAX | 12 | #define LG_CLOCK_MAX_DELTA ULONG_MAX |
| 13 | 13 | ||
| 14 | /*G:032 The second method of communicating with the Host is to via "struct | 14 | /*G:032 The second method of communicating with the Host is to via "struct |
| 15 | * lguest_data". The Guest's very first hypercall is to tell the Host where | 15 | * lguest_data". Once the Guest's initialization hypercall tells the Host where |
| 16 | * this is, and then the Guest and Host both publish information in it. :*/ | 16 | * this is, the Guest and Host both publish information in it. :*/ |
| 17 | struct lguest_data | 17 | struct lguest_data |
| 18 | { | 18 | { |
| 19 | /* 512 == enabled (same as eflags in normal hardware). The Guest | 19 | /* 512 == enabled (same as eflags in normal hardware). The Guest |
diff --git a/include/linux/lguest_launcher.h b/include/linux/lguest_launcher.h index 61e1e3e6b1cc..697104da91f1 100644 --- a/include/linux/lguest_launcher.h +++ b/include/linux/lguest_launcher.h | |||
| @@ -1,17 +1,7 @@ | |||
| 1 | #ifndef _ASM_LGUEST_USER | 1 | #ifndef _LINUX_LGUEST_LAUNCHER |
| 2 | #define _ASM_LGUEST_USER | 2 | #define _LINUX_LGUEST_LAUNCHER |
| 3 | /* Everything the "lguest" userspace program needs to know. */ | 3 | /* Everything the "lguest" userspace program needs to know. */ |
| 4 | #include <linux/types.h> | 4 | #include <linux/types.h> |
| 5 | /* They can register up to 32 arrays of lguest_dma. */ | ||
| 6 | #define LGUEST_MAX_DMA 32 | ||
| 7 | /* At most we can dma 16 lguest_dma in one op. */ | ||
| 8 | #define LGUEST_MAX_DMA_SECTIONS 16 | ||
| 9 | |||
| 10 | /* How many devices? Assume each one wants up to two dma arrays per device. */ | ||
| 11 | #define LGUEST_MAX_DEVICES (LGUEST_MAX_DMA/2) | ||
| 12 | |||
| 13 | /* Where the Host expects the Guest to SEND_DMA console output to. */ | ||
| 14 | #define LGUEST_CONSOLE_DMA_KEY 0 | ||
| 15 | 5 | ||
| 16 | /*D:010 | 6 | /*D:010 |
| 17 | * Drivers | 7 | * Drivers |
| @@ -20,7 +10,11 @@ | |||
| 20 | * real devices (think of the damage it could do!) we provide virtual devices. | 10 | * real devices (think of the damage it could do!) we provide virtual devices. |
| 21 | * We could emulate a PCI bus with various devices on it, but that is a fairly | 11 | * We could emulate a PCI bus with various devices on it, but that is a fairly |
| 22 | * complex burden for the Host and suboptimal for the Guest, so we have our own | 12 | * complex burden for the Host and suboptimal for the Guest, so we have our own |
| 23 | * "lguest" bus and simple drivers. | 13 | * simple lguest bus and we use "virtio" drivers. These drivers need a set of |
| 14 | * routines from us which will actually do the virtual I/O, but they handle all | ||
| 15 | * the net/block/console stuff themselves. This means that if we want to add | ||
| 16 | * a new device, we simply need to write a new virtio driver and create support | ||
| 17 | * for it in the Launcher: this code won't need to change. | ||
| 24 | * | 18 | * |
| 25 | * Devices are described by a simplified ID, a status byte, and some "config" | 19 | * Devices are described by a simplified ID, a status byte, and some "config" |
| 26 | * bytes which describe this device's configuration. This is placed by the | 20 | * bytes which describe this device's configuration. This is placed by the |
| @@ -51,9 +45,9 @@ struct lguest_vqconfig { | |||
| 51 | /* Write command first word is a request. */ | 45 | /* Write command first word is a request. */ |
| 52 | enum lguest_req | 46 | enum lguest_req |
| 53 | { | 47 | { |
| 54 | LHREQ_INITIALIZE, /* + pfnlimit, pgdir, start, pageoffset */ | 48 | LHREQ_INITIALIZE, /* + base, pfnlimit, pgdir, start */ |
| 55 | LHREQ_GETDMA, /* No longer used */ | 49 | LHREQ_GETDMA, /* No longer used */ |
| 56 | LHREQ_IRQ, /* + irq */ | 50 | LHREQ_IRQ, /* + irq */ |
| 57 | LHREQ_BREAK, /* + on/off flag (on blocks until someone does off) */ | 51 | LHREQ_BREAK, /* + on/off flag (on blocks until someone does off) */ |
| 58 | }; | 52 | }; |
| 59 | #endif /* _ASM_LGUEST_USER */ | 53 | #endif /* _LINUX_LGUEST_LAUNCHER */ |
