1. 19 6月, 2014 1 次提交
  2. 25 4月, 2014 1 次提交
  3. 12 4月, 2014 1 次提交
  4. 20 3月, 2014 4 次提交
    • S
      qom: Add check() argument to object_property_add_link() · 39f72ef9
      Stefan Hajnoczi 提交于
      There are currently three types of object_property_add_link() callers:
      
      1. The link property may be set at any time.
      2. The link property of a DeviceState instance may only be set before
         realize.
      3. The link property may never be set, it is read-only.
      
      Something similar can already be achieved with
      object_property_add_str()'s set() argument.  Follow its example and add
      a check() argument to object_property_add_link().
      
      Also provide default check() functions for case #1 and #2.  Case #3 is
      covered by passing a NULL function pointer.
      
      Cc: Peter Crosthwaite <peter.crosthwaite@petalogix.com>
      Cc: Alexander Graf <agraf@suse.de>
      Cc: Anthony Liguori <aliguori@amazon.com>
      Cc: "Michael S. Tsirkin" <mst@redhat.com>
      Signed-off-by: NStefan Hajnoczi <stefanha@redhat.com>
      Reviewed-by: NPaolo Bonzini <pbonzini@redhat.com>
      [AF: Tweaked documentation comment]
      Signed-off-by: NAndreas Färber <afaerber@suse.de>
      39f72ef9
    • S
      qom: Make QOM link property unref optional · 9561fda8
      Stefan Hajnoczi 提交于
      Some object_property_add_link() callers expect property deletion to
      unref the link property object.  Other callers expect to manage the
      refcount themselves.  The former are currently broken and therefore leak
      the link property object.
      
      This patch adds a flags argument to object_property_add_link() so the
      caller can specify which refcount behavior they require.  The new
      OBJ_PROP_LINK_UNREF_ON_RELEASE flag causes the link pointer to be
      unreferenced when the property is deleted.
      
      This fixes refcount leaks in qdev.c, xilinx_axidma.c, xilinx_axienet.c,
      s390-virtio-bus.c, virtio-pci.c, virtio-rng.c, and ui/console.c.
      
      Rationale for refcount behavior:
      
       * hw/core/qdev.c
         - bus children are explicitly unreferenced, don't interfere
         - parent_bus is essentially a read-only property that doesn't hold a
           refcount, don't unref
         - hotplug_handler is leaked, do unref
      
       * hw/dma/xilinx_axidma.c
         - rx stream "dma" links are set using set_link, therefore they
           need unref
         - tx streams are set using set_link, therefore they need unref
      
       * hw/net/xilinx_axienet.c
         - same reasoning as hw/dma/xilinx_axidma.c
      
       * hw/pcmcia/pxa2xx.c
         - pxa2xx bypasses set_link and therefore does not use refcounts
      
       * hw/s390x/s390-virtio-bus.c
       * hw/virtio/virtio-pci.c
       * hw/virtio/virtio-rng.c
       * ui/console.c
         - set_link is used and there is no explicit unref, do unref
      
      Cc: Peter Crosthwaite <peter.crosthwaite@petalogix.com>
      Cc: Alexander Graf <agraf@suse.de>
      Cc: Anthony Liguori <aliguori@amazon.com>
      Cc: "Michael S. Tsirkin" <mst@redhat.com>
      Signed-off-by: NStefan Hajnoczi <stefanha@redhat.com>
      Reviewed-by: NPaolo Bonzini <pbonzini@redhat.com>
      Signed-off-by: NAndreas Färber <afaerber@suse.de>
      9561fda8
    • S
      qom: Don't make link NULL on object_property_set_link() failure · c6aed983
      Stefan Hajnoczi 提交于
      The error behavior of object_property_set_link() is dangerous.  It sets
      the link property object to NULL if an error occurs.  A setter function
      should either succeed or fail, it shouldn't leave the value NULL on
      failure.
      Signed-off-by: NStefan Hajnoczi <stefanha@redhat.com>
      Reviewed-by: NPaolo Bonzini <pbonzini@redhat.com>
      Signed-off-by: NAndreas Färber <afaerber@suse.de>
      c6aed983
    • S
      qom: Split object_property_set_link() · f5ec6704
      Stefan Hajnoczi 提交于
      The path resolution logic in object_property_set_link() should be a
      separate function.  This makes the code easier to read and maintain.
      Signed-off-by: NStefan Hajnoczi <stefanha@redhat.com>
      Reviewed-by: NPaolo Bonzini <pbonzini@redhat.com>
      Signed-off-by: NAndreas Färber <afaerber@suse.de>
      f5ec6704
  5. 13 3月, 2014 2 次提交
  6. 15 2月, 2014 1 次提交
  7. 07 1月, 2014 1 次提交
  8. 25 12月, 2013 3 次提交
  9. 19 11月, 2013 1 次提交
  10. 14 10月, 2013 1 次提交
  11. 31 8月, 2013 2 次提交
  12. 17 8月, 2013 1 次提交
  13. 10 7月, 2013 1 次提交
  14. 04 7月, 2013 1 次提交
  15. 22 5月, 2013 1 次提交
  16. 14 5月, 2013 1 次提交
    • A
      qom: aggressively optimize qom casting · 03587328
      Anthony Liguori 提交于
      This patch adds a small typename cache to ObjectClass.  This allows
      caching positive casts within each ObjectClass.  Benchmarking a
      PPC workload provided by Aurelien, this patch eliminates every
      single g_hash_table_lookup() happening during the benchmark (which
      was about 2 million per-second).
      
      With this patch applied, I get exactly the same performance (within
      the margin of error) as with --disable-qom-cast-debug.
      
      N.B. it's safe to cache typenames only from the _assert() macros
      because they are always called with string literals.
      Signed-off-by: NAnthony Liguori <aliguori@us.ibm.com>
      03587328
  17. 13 5月, 2013 5 次提交
  18. 30 4月, 2013 2 次提交
  19. 17 4月, 2013 1 次提交
  20. 27 3月, 2013 1 次提交
  21. 26 3月, 2013 1 次提交
  22. 22 2月, 2013 2 次提交
    • P
      qom/object.c: Allow itf cast with num_itfs = 0 · 00e2ceae
      Peter Crosthwaite 提交于
      num_interfaces only tells you how many interfaces the concrete child class has
      (as defined in the TypeInfo). This means if you have a child class which defines
      no interfaces of its own, but its parent has interfaces you cannot cast to those
      parent interfaces.
      
      Fixed changing the guard to check the class->interfaces list instead (which is
      a complete flattened list of implemented interfaces).
      Signed-off-by: NPeter Crosthwaite <peter.crosthwaite@xilinx.com>
      Message-id: a8c2db3b9b1f3c4bb81aca352b69e33260f36545.1361246206.git.peter.crosthwaite@xilinx.com
      Signed-off-by: NAnthony Liguori <aliguori@us.ibm.com>
      00e2ceae
    • P
      qom/object.c: Reset interface list on inheritance · 3e407de4
      Peter Crosthwaite 提交于
      The QOM framework will attempt the recreate a classes interface list from
      scratch for each class. This means that a child class should zero out the
      list of interfaces when cloned from the parent class.
      
      Currently the list is memcpy()d from the parent to the child. As the interface
      list is just a pointer to a list, this means the parent and child will share
      the same list of interfaces. When the child inits, it will append its own
      interfaces to the parents list. This is incorrect as the parent should not pick
      up its childs interfaces.
      
      This actually causes an infinite loop at class init time, as the child will
      iterate through the parent interface list adding each itf to its own list(in
      type_initialize()). As the list is (erroneously) shared, the new interface
      instances for the child are appended to the parent, and the iterator never hits
      the tail and loops forever.
      Signed-off-by: NPeter Crosthwaite <peter.crosthwaite@xilinx.com>
      Reviewed-by: NPaolo Bonzini <pbonzini@redhat.com>
      Message-id: 1f58d2b629d82865dbb2fd5ba8445854049c4382.1361246206.git.peter.crosthwaite@xilinx.com
      Signed-off-by: NAnthony Liguori <aliguori@us.ibm.com>
      3e407de4
  23. 02 2月, 2013 2 次提交
  24. 28 1月, 2013 1 次提交
  25. 15 1月, 2013 1 次提交
  26. 19 12月, 2012 1 次提交