• Split out tcp_chr_recv() out of tcp_chr_read() and implement it on
    non-win32 using recvmsg(). This is needed for a subsequent patch
    which implements SCM_RIGHTS support.
    
    Signed-off-by: Mark McLoughlin <markmc@redhat.com>
    Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
    Mark McLoughlin authored
     
    Browse Code »
  • - implement "used" bit in tlb translation entry
    - mark tlb entry used if qemu code/data translation succeeds
    - fold i/d mmu replacement writes code into replace_tlb_1bit_lru which
    adds 1bit lru replacement algorithm; previously code tried to replace
    first unlocked entry only
    
    - extract more bitmasks to named macros
    - add "immu" or "dmmu" type name to debugging output where appropriate
    
    Signed-off-by: igor.v.kovalenko@gmail.com
    
    --
    Kind regards,
    Igor V. Kovalenko
    Igor Kovalenko authored
     
    Browse Code »
  • - add names to mmu registers, this helps understanding the code which
    uses/modifies them.
    - fold i/d mmu tlb entries tag and tte arrays into arrays of tlb entries
    - extract demap_tlb routine (code duplication)
    - extract replace_tlb routine (code duplication)
    
    - flush qemu tlb translations when replacing sparc64 mmu tlb entries
    
    I have no test case which demands flushing qemu translations,
    and this patch should have no other visible changes to runtime.
    
    Signed-off-by: igor.v.kovalenko@gmail.com
    
    --
    Kind regards,
    Igor V. Kovalenko
    Igor Kovalenko authored
     
    Browse Code »



  • KVM can have an in-kernel pit or irqchip. While we don't implement it
    yet, having a way for test for it (that always returns zero) will allow us
    to reuse code in qemu-kvm that tests for it.
    
    Signed-off-by: Glauber Costa <glommer@redhat.com>
    Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
    Glauber Costa authored
     
    Browse Code »
  • Fixes
    
    qemu-thread.c: In function `qemu_thread_equal':
    qemu-thread.c:161: error: invalid operands to binary ==
    
    Use of pthread_equal suggested by Filip Navara.
    
    Signed-off-by: Sebastian Herbszt <herbszt@gmx.de>
    Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
    Sebastian Herbszt authored
     
    Browse Code »
  • When starting a qemu binary directly from the build directory and that
    dir is located outside the source files, the search for bios files
    fails. Fix this by linking them from the build to the source directory.
    
    Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com>
    Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
    Jan Kiszka authored
     
    Browse Code »
  • Attached patch makes signrom.sh working on NetBSD.
    The output of the 'od' command leads to a syntax error
    which breaks the build.
    
    Signed-off-by: Christoph Egger <Christoph.Egger@amd.com>
    Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
    Christoph Egger authored
     
    Browse Code »
  • This is a backport from qemu-kvm. Just instead of using kvm's specific
    notification mechanism, we use qemu_notify_event()
    
    Signed-off-by: Glauber Costa <glommer@redhat.com>
    Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
    Glauber Costa authored
     
    Browse Code »
  • on_vcpu is a qemu-kvm function that will make sure that a specific
    piece of code will run on a requested cpu. We don't need that because
    we're restricted to -smp 1 right now, but those days are likely to end soon.
    
    So for the benefit of having qemu-kvm share more code with us, I'm
    introducing our own version of on_vcpu(). Right now, we either run
    a function on the current cpu, or abort the execution, because it would
    mean something is seriously wrong.
    
    As an example code, I "ported" kvm_update_guest_debug to use it,
    with some slight differences from qemu-kvm.
    
    This is probably 0.12 material
    
    Signed-off-by: Glauber Costa <glommer@redhat.com>
    CC: Jan Kiszka <jan.kiszka@siemens.com>
    Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
    Glauber Costa authored
     
    Browse Code »
  • Replace the use of atoi which is used for pattern parsing currently with
    strtol.  Atoi won't parse sedecimal pattern values (it always returns 0),
    but qemu-iotests use such pattern values.  Also reject every pattern
    that is not a unsigned char as we pass the pattern to memset which
    expect a bye value (despite having the pattern argument declared as int).
    
    Based on an earlier patch by Stefan Weil which did not include the
    error handling.
    
    Signed-off-by: Christoph Hellwig <hch@lst.de>
    Reported-by: Stefan Weil <weil@mail.berlios.de>
    Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
    Christoph Hellwig authored
     
    Browse Code »
  • The alloc command in qemu-io is mostly useless currently. Instead of doing a
    single call to bdrv_is_allocated, we must call bdrv_is_allocated in a loop
    until we have found out for each requested sector if it is allocated or not
    (bdrv_is_allocated returns a number of sectors that are known to be in the same
    state as the first one, but it is not required to include all of them)
    
    This changes the output format of the alloc command so that a change to the
    expected output of qemu-iotests 019 is necessary once this is included.
    
    Signed-off-by: Kevin Wolf <kwolf@redhat.com>
    Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
    Kevin Wolf authored
     
    Browse Code »
  • Make 'qemu-img convert' copies unallocated parts of the source image
    when -B option was not specified.
    
    Signed-off-by: Akkarit Sangpetch <asangpet@andrew.cmu.edu>
    Signed-off-by: Kevin Wolf <kwolf@redhat.com>
    Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
    Akkarit Sangpetch authored
     
    Browse Code »
  • Instead of storing the backing file in its own BlockDriverState, VMDK uses the
    BlockDriverState of the raw image file it opened. This is wrong and breaks
    functions that access the backing file or protocols. This fix replaces all
    occurrences of s->hd->backing_* with bs->backing_*.
    
    This fixes qemu-iotests failure in 020 (Commit changes to backing file).
    
    Signed-off-by: Kevin Wolf <kwolf@redhat.com>
    Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
    Kevin Wolf authored
     
    Browse Code »
  • Signed-off-by: Juan Quintela <quintela@redhat.com>
    Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
    Juan Quintela authored
     
    Browse Code »
  • This patch requires "Handle BH's queued by AIO completions in
    qemu_aio_flush()" to work reliably.  The combination of those two
    patches survived 300+ migrations with heavy IO load running in the
    guest.
    
    Signed-off-by: Nolan Leake <nolan <at> sigbus.net>
    Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
    Nolan authored
     
    Browse Code »
  • Without this, the call to qemu_aio_flush during migration doesn't
    actually flush all in-flight SCSI IOs.
    
    Signed-off-by: Nolan Leake <nolan <at> sigbus.net>
    Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
    Nolan authored
     
    Browse Code »
  • Some KVM platforms don't support dirty logging yet, like IA64 and PPC,
    so in order to still have screen updates on those, we need to fake it.
    
    This patch just tells the getter function for dirty bitmaps, that all
    pages within a slot are dirty when the slot has dirty logging enabled.
    
    That way we can implement dirty logging on those platforms sometime when
    it drags down performance, but share the rest of the code with dirty
    logging capable platforms.
    
    Signed-off-by: Alexander Graf <agraf@suse.de>
    Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
    Alexander Graf authored
     
    Browse Code »
  • 440 and desktop codes use different input constants for interrupt indication.
    
    Let's use the respective ones for KVM.
    
    Signed-off-by: Alexander Graf <agraf@suse.de>
    Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
    Alexander Graf authored
     
    Browse Code »
  • This fixes a warning I stumbled across while compiling qemu on PPC64.
    
    Signed-off-by: Alexander Graf <agraf@suse.de>
    Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
    Alexander Graf authored
     
    Browse Code »
  • We need to tell the kernel about some initial CPU state we don't have yet,
    so let's use the "sregs" IOCTL for that and simply put the Processor Version
    Register in there.
    
    Now the kernel knows which guest CPU to virtualize.
    
    Signed-off-by: Alexander Graf <agraf@suse.de>
    Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
    Alexander Graf authored
     
    Browse Code »
  • We now have KVM on PPC64 too and might get it on PPC32 as well, as soon
    as someone writes it.
    
    So let's enable KVM for PPC32 and PPC64 targets.
    
    Signed-off-by: Alexander Graf <agraf@suse.de>
    Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
    Alexander Graf authored
     
    Browse Code »