~ubuntu-branches/ubuntu/trusty/qemu/trusty

« back to all changes in this revision

Viewing changes to .pc/ubuntu/CVE-2013-4377.patch/include/hw/virtio/virtio-rng.h

  • Committer: Package Import Robot
  • Author(s): Serge Hallyn
  • Date: 2014-02-04 12:13:08 UTC
  • mfrom: (10.1.45 sid)
  • Revision ID: package-import@ubuntu.com-20140204121308-1xq92lrfs75agw2g
Tags: 1.7.0+dfsg-3ubuntu1~ppa1
* Merge 1.7.0+dfsg-3 from debian.  Remaining changes:
  - debian/patches/ubuntu:
    * expose-vmx_qemu64cpu.patch
    * linaro (omap3) and arm64 patches
    * ubuntu/target-ppc-add-stubs-for-kvm-breakpoints: fix FTBFS
      on ppc
    * ubuntu/CVE-2013-4377.patch: fix denial of service via virtio
  - debian/qemu-system-x86.modprobe: set kvm_intel nested=1 options
  - debian/control:
    * add arm64 to Architectures
    * add qemu-common and qemu-system-aarch64 packages
  - debian/qemu-system-common.install: add debian/tmp/usr/lib
  - debian/qemu-system-common.preinst: add kvm group
  - debian/qemu-system-common.postinst: remove acl placed by udev,
    and add udevadm trigger.
  - qemu-system-x86.links: add eepro100.rom, remove pxe-virtio,
    pxe-e1000 and pxe-rtl8139.
  - add qemu-system-x86.qemu-kvm.upstart and .default
  - qemu-user-static.postinst-in: remove arm64 binfmt
  - debian/rules:
    * allow parallel build
    * add aarch64 to system_targets and sys_systems
    * add qemu-kvm-spice links
    * install qemu-system-x86.modprobe
  - add debian/qemu-system-common.links for OVMF.fd link
* Remove kvm-img, kvm-nbd, kvm-ifup and kvm-ifdown symlinks.

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
/*
 
2
 * Virtio RNG Support
 
3
 *
 
4
 * Copyright Red Hat, Inc. 2012
 
5
 * Copyright Amit Shah <amit.shah@redhat.com>
 
6
 *
 
7
 * This work is licensed under the terms of the GNU GPL, version 2 or
 
8
 * (at your option) any later version.  See the COPYING file in the
 
9
 * top-level directory.
 
10
 */
 
11
 
 
12
#ifndef _QEMU_VIRTIO_RNG_H
 
13
#define _QEMU_VIRTIO_RNG_H
 
14
 
 
15
#include "sysemu/rng.h"
 
16
#include "sysemu/rng-random.h"
 
17
 
 
18
#define TYPE_VIRTIO_RNG "virtio-rng-device"
 
19
#define VIRTIO_RNG(obj) \
 
20
        OBJECT_CHECK(VirtIORNG, (obj), TYPE_VIRTIO_RNG)
 
21
 
 
22
/* The Virtio ID for the virtio rng device */
 
23
#define VIRTIO_ID_RNG    4
 
24
 
 
25
struct VirtIORNGConf {
 
26
    RngBackend *rng;
 
27
    uint64_t max_bytes;
 
28
    uint32_t period_ms;
 
29
    RndRandom *default_backend;
 
30
};
 
31
 
 
32
typedef struct VirtIORNG {
 
33
    VirtIODevice parent_obj;
 
34
 
 
35
    /* Only one vq - guest puts buffer(s) on it when it needs entropy */
 
36
    VirtQueue *vq;
 
37
 
 
38
    VirtIORNGConf conf;
 
39
 
 
40
    RngBackend *rng;
 
41
 
 
42
    /* We purposefully don't migrate this state.  The quota will reset on the
 
43
     * destination as a result.  Rate limiting is host state, not guest state.
 
44
     */
 
45
    QEMUTimer *rate_limit_timer;
 
46
    int64_t quota_remaining;
 
47
} VirtIORNG;
 
48
 
 
49
/* Set a default rate limit of 2^47 bytes per minute or roughly 2TB/s.  If
 
50
   you have an entropy source capable of generating more entropy than this
 
51
   and you can pass it through via virtio-rng, then hats off to you.  Until
 
52
   then, this is unlimited for all practical purposes.
 
53
*/
 
54
#define DEFINE_VIRTIO_RNG_PROPERTIES(_state, _conf_field)                    \
 
55
        DEFINE_PROP_UINT64("max-bytes", _state, _conf_field.max_bytes,       \
 
56
                           INT64_MAX),                                       \
 
57
        DEFINE_PROP_UINT32("period", _state, _conf_field.period_ms, 1 << 16)
 
58
 
 
59
#endif