diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2015-04-16 15:01:03 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2015-04-16 15:01:03 -0400 |
| commit | 497a5df7bf6ffd136ae21c49d1a01292930d7ca2 (patch) | |
| tree | 774215d43cdc9fbd8660086d1801400163dcbd52 /drivers/block | |
| parent | 714d8e7e27197dd39b2550e762a6a6fcf397a471 (diff) | |
| parent | 0b97b03d88b40bfbd7ff0e069186a137d9786d43 (diff) | |
Merge tag 'stable/for-linus-4.1-rc0-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/xen/tip
Pull xen features and fixes from David Vrabel:
- use a single source list of hypercalls, generating other tables etc.
at build time.
- add a "Xen PV" APIC driver to support >255 VCPUs in PV guests.
- significant performance improve to guest save/restore/migration.
- scsiback/front save/restore support.
- infrastructure for multi-page xenbus rings.
- misc fixes.
* tag 'stable/for-linus-4.1-rc0-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/xen/tip:
xen/pci: Try harder to get PXM information for Xen
xenbus_client: Extend interface to support multi-page ring
xen-pciback: also support disabling of bus-mastering and memory-write-invalidate
xen: support suspend/resume in pvscsi frontend
xen: scsiback: add LUN of restored domain
xen-scsiback: define a pr_fmt macro with xen-pvscsi
xen/mce: fix up xen_late_init_mcelog() error handling
xen/privcmd: improve performance of MMAPBATCH_V2
xen: unify foreign GFN map/unmap for auto-xlated physmap guests
x86/xen/apic: WARN with details.
x86/xen: Provide a "Xen PV" APIC driver to support >255 VCPUs
xen/pciback: Don't print scary messages when unsupported by hypervisor.
xen: use generated hypercall symbols in arch/x86/xen/xen-head.S
xen: use generated hypervisor symbols in arch/x86/xen/trace.c
xen: synchronize include/xen/interface/xen.h with xen
xen: build infrastructure for generating hypercall depending symbols
xen: balloon: Use static attribute groups for sysfs entries
xen: pcpu: Use static attribute groups for sysfs entry
Diffstat (limited to 'drivers/block')
| -rw-r--r-- | drivers/block/xen-blkback/xenbus.c | 5 | ||||
| -rw-r--r-- | drivers/block/xen-blkfront.c | 5 |
2 files changed, 6 insertions, 4 deletions
diff --git a/drivers/block/xen-blkback/xenbus.c b/drivers/block/xen-blkback/xenbus.c index e3afe97280b1..ff3025922c14 100644 --- a/drivers/block/xen-blkback/xenbus.c +++ b/drivers/block/xen-blkback/xenbus.c | |||
| @@ -193,7 +193,7 @@ fail: | |||
| 193 | return ERR_PTR(-ENOMEM); | 193 | return ERR_PTR(-ENOMEM); |
| 194 | } | 194 | } |
| 195 | 195 | ||
| 196 | static int xen_blkif_map(struct xen_blkif *blkif, unsigned long shared_page, | 196 | static int xen_blkif_map(struct xen_blkif *blkif, grant_ref_t gref, |
| 197 | unsigned int evtchn) | 197 | unsigned int evtchn) |
| 198 | { | 198 | { |
| 199 | int err; | 199 | int err; |
| @@ -202,7 +202,8 @@ static int xen_blkif_map(struct xen_blkif *blkif, unsigned long shared_page, | |||
| 202 | if (blkif->irq) | 202 | if (blkif->irq) |
| 203 | return 0; | 203 | return 0; |
| 204 | 204 | ||
| 205 | err = xenbus_map_ring_valloc(blkif->be->dev, shared_page, &blkif->blk_ring); | 205 | err = xenbus_map_ring_valloc(blkif->be->dev, &gref, 1, |
| 206 | &blkif->blk_ring); | ||
| 206 | if (err < 0) | 207 | if (err < 0) |
| 207 | return err; | 208 | return err; |
| 208 | 209 | ||
diff --git a/drivers/block/xen-blkfront.c b/drivers/block/xen-blkfront.c index 37779e4c4585..2c61cf8c6f61 100644 --- a/drivers/block/xen-blkfront.c +++ b/drivers/block/xen-blkfront.c | |||
| @@ -1245,6 +1245,7 @@ static int setup_blkring(struct xenbus_device *dev, | |||
| 1245 | struct blkfront_info *info) | 1245 | struct blkfront_info *info) |
| 1246 | { | 1246 | { |
| 1247 | struct blkif_sring *sring; | 1247 | struct blkif_sring *sring; |
| 1248 | grant_ref_t gref; | ||
| 1248 | int err; | 1249 | int err; |
| 1249 | 1250 | ||
| 1250 | info->ring_ref = GRANT_INVALID_REF; | 1251 | info->ring_ref = GRANT_INVALID_REF; |
| @@ -1257,13 +1258,13 @@ static int setup_blkring(struct xenbus_device *dev, | |||
| 1257 | SHARED_RING_INIT(sring); | 1258 | SHARED_RING_INIT(sring); |
| 1258 | FRONT_RING_INIT(&info->ring, sring, PAGE_SIZE); | 1259 | FRONT_RING_INIT(&info->ring, sring, PAGE_SIZE); |
| 1259 | 1260 | ||
| 1260 | err = xenbus_grant_ring(dev, virt_to_mfn(info->ring.sring)); | 1261 | err = xenbus_grant_ring(dev, info->ring.sring, 1, &gref); |
| 1261 | if (err < 0) { | 1262 | if (err < 0) { |
| 1262 | free_page((unsigned long)sring); | 1263 | free_page((unsigned long)sring); |
| 1263 | info->ring.sring = NULL; | 1264 | info->ring.sring = NULL; |
| 1264 | goto fail; | 1265 | goto fail; |
| 1265 | } | 1266 | } |
| 1266 | info->ring_ref = err; | 1267 | info->ring_ref = gref; |
| 1267 | 1268 | ||
| 1268 | err = xenbus_alloc_evtchn(dev, &info->evtchn); | 1269 | err = xenbus_alloc_evtchn(dev, &info->evtchn); |
| 1269 | if (err) | 1270 | if (err) |
