1. 07 6月, 2016 14 次提交
  2. 06 6月, 2016 8 次提交
  3. 04 6月, 2016 1 次提交
  4. 03 6月, 2016 5 次提交
    • D
      Refresh po files from zanata · d57e73d0
      Daniel P. Berrange 提交于
      Signed-off-by: NDaniel P. Berrange <berrange@redhat.com>
      d57e73d0
    • M
      Fix building with -Og · 3470cd86
      Martin Kletzander 提交于
      When building using -Og, gcc sees that some variables can be used
      uninitialized  It can be debatable whether it is possible with our
      codeflow, but functions should be self-contained and initializations are
      always good.  The return instead of goto is due to actualType being used
      in the cleanup.
      Signed-off-by: NMartin Kletzander <mkletzan@redhat.com>
      3470cd86
    • M
      virPerfEventIsEnabled: Don't crash on shut off domains · 5a72397e
      Michal Privoznik 提交于
      So imagine the following. You connect read only to a daemon and
      try to fetch stats for a shut off domain, e.g.:
      
        virsh -r domstats $dom
      
      but all of a sudden, virsh instead of printing the stats throws
      the following error at you:
      
        error: Disconnected from qemu:///system due to I/O error
        error: End of file while reading data: Input/output error
      
      The daemon crashed. This is its backtrace:
      
      #0  0x00007fa43e3751a8 in virPerfEventIsEnabled (perf=0x0, type=VIR_PERF_EVENT_MBMT) at util/virperf.c:241
      #1  0x00007fa424a9f042 in qemuDomainGetStatsPerf (driver=0x7fa3f4022a30, dom=0x7fa3f40e24c0, record=0x7fa41c000e20, maxparams=0x7fa4360b38d0, privflags=1) at qemu/qemu_driver.c:19110
      #2  0x00007fa424a9f2e7 in qemuDomainGetStats (conn=0x7fa41c001b20, dom=0x7fa3f40e24c0, stats=127, record=0x7fa4360b3970, flags=1) at qemu/qemu_driver.c:19213
      #3  0x00007fa424a9f672 in qemuConnectGetAllDomainStats (conn=0x7fa41c001b20, doms=0x7fa41c0017f0, ndoms=1, stats=127, retStats=0x7fa4360b3a50, flags=0) at qemu/qemu_driver.c:19303
      #4  0x00007fa43e4e15f6 in virDomainListGetStats (doms=0x7fa41c0017f0, stats=0, retStats=0x7fa4360b3a50, flags=0) at libvirt-domain.c:11615
      
      Program received signal SIGSEGV, Segmentation fault.
      [Switching to Thread 0x7f28d1a38700 (LWP 16154)]
      0x00007f28da4fa1a8 in virPerfEventIsEnabled (perf=0x0, type=VIR_PERF_EVENT_MBMT) at util/virperf.c:241
      241         return event->enabled;
      
      Problem is, shut off domains don't have priv->perf allocated.
      Therefore if in frame #1 qemuDomainGetStatsPerf() tries to check
      if perf events are enabled, NULL is passed to
      virPerfEventIsEnabled() which due to some incredible
      implementation dereference it. Fix this by checking whether
      passed object is not NULL.
      Signed-off-by: NMichal Privoznik <mprivozn@redhat.com>
      5a72397e
    • M
      Drop virPerfGetEventFd · 89ef1589
      Michal Privoznik 提交于
      This function is not used anywhere. Moreover, the code that would
      use lives in virperf.c and therefore has access to the FD anyway.
      Well, for instance virPerfReadEvent is doing just that.
      Signed-off-by: NMichal Privoznik <mprivozn@redhat.com>
      89ef1589
    • M
      virDomainChrGetDomainPtrsInternal: Return an integer · 43395f19
      Michal Privoznik 提交于
      There's this problem on the recent gcc-6.1:
      
      In file included from conf/domain_conf.c:37:0:
      conf/domain_conf.c: In function 'virDomainChrPreAlloc':
      conf/domain_conf.c:14109:35: error: potential null pointer dereference [-Werror=null-dereference]
           return VIR_REALLOC_N(*arrPtr, *cntPtr + 1);
                                         ^~
      ./util/viralloc.h:158:73: note: in definition of macro 'VIR_REALLOC_N'
       # define VIR_REALLOC_N(ptr, count) virReallocN(&(ptr), sizeof(*(ptr)), (count), \
                                                                               ^~~~~
      conf/domain_conf.c: In function 'virDomainChrRemove':
      conf/domain_conf.c:14133:21: error: potential null pointer dereference [-Werror=null-dereference]
           for (i = 0; i < *cntPtr; i++) {
                           ^~~~~~~
      
      GCC basically fails to see, that the
      virDomainChrGetDomainPtrsInternal will never actually return NULL
      because it's never called over a domain char device with _LAST
      type. But to make it shut up, lets turn this function into
      returning an integer and check in the callers if a zero value
      value was returned.
      Signed-off-by: NMichal Privoznik <mprivozn@redhat.com>
      43395f19
  5. 02 6月, 2016 3 次提交
    • M
      virDomainFormatSchedDef: Avoid false positive NULL dereference · f916194c
      Michal Privoznik 提交于
      Okay, I admit that our code here is complex. It's not easy to
      spot that NULL deref can't really happen here. So it's no wonder
      that a dumb compiler fails to see all the connections and
      produces the following errors:
      
        CC       conf/libvirt_conf_la-domain_conf.lo
      conf/domain_conf.c: In function 'virDomainDefFormatInternal':
      conf/domain_conf.c:22162:22: error: potential null pointer dereference [-Werror=null-dereference]
                   if (sched->policy == i)
                       ~~~~~^~~~~~~~
      <snip/>
      cc1: all warnings being treated as errors
      Signed-off-by: NMichal Privoznik <mprivozn@redhat.com>
      f916194c
    • M
      ppc64Compute: Avoid possible NULL dereference · 09258c3c
      Michal Privoznik 提交于
      cpu/cpu_ppc64.c: In function 'ppc64Compute':
      cpu/cpu_ppc64.c:620:27: error: potential null pointer dereference [-Werror=null-dereference]
           if (STRNEQ(guest_model->name, host_model->name)) {
                      ~~~~~~~~~~~^~~
      cpu/cpu_ppc64.c:620:9: note: in expansion of macro 'STRNEQ'
           if (STRNEQ(guest_model->name, host_model->name)) {
               ^~~~~~
      cc1: all warnings being treated as errors
      Signed-off-by: NMichal Privoznik <mprivozn@redhat.com>
      09258c3c
    • M
      virNetDevBridgeGet: Don't require users to virNetDevSetupControl · 263a8880
      Michal Privoznik 提交于
      So far, this function has just three callers. Two of them call
      virNetDevSetupControl to create a socket that we can then
      optionally use for ioctl() to fetch data. However, querying sysfs
      is preferred. Therefore it doesn't make much sense to require
      users to set up the socket if they don't even know it will be
      used in favour of sysfs. We can set up the socket iff we need to.
      Signed-off-by: NMichal Privoznik <mprivozn@redhat.com>
      263a8880
  6. 01 6月, 2016 2 次提交
  7. 31 5月, 2016 2 次提交
    • M
      esxStorageVolGetXMLDesc: Lookup SCSI lun properly · 99809fd4
      Michal Privoznik 提交于
      So the idea is as follows: firstly we obtain a list of all the
      luns, then iterate over it trying to find the one we want to work
      with and after all the iterations we detect whether we have found
      something. Now, the last check is broken, because it compares a
      value form previous iteration, not the one we've just been
      through.
      
      Then, when computing md5 sum of lun's UUID, we use wrong variable
      again. Well, @hostScsiDisk which is type of esxVI_HostScsiDisk
      extends esxVI_ScsiLun type so they both have the uuid member, but
      it just doesn't feel right to access the data via two different
      variables in one function call.
      Signed-off-by: NMichal Privoznik <mprivozn@redhat.com>
      99809fd4
    • M
      qemuMonitorTextGetAllBlockStatsInfo: Fix line validation · c94720f8
      Michal Privoznik 提交于
      There's a bug in the function. We expect the following format for
      the data we are parsing here:
      
        key: value
      
      So we use strchr() to find ':' and then see if it is followed by
      space. But the check that does just that is slightly incorrect.
      Signed-off-by: NMichal Privoznik <mprivozn@redhat.com>
      c94720f8
  8. 30 5月, 2016 2 次提交
    • M
      virSocketAddrIsPrivate: Work on 32bits platforms · 2bd61c84
      Michal Privoznik 提交于
      Yet another one of those where signed int (or long int) is not
      enough. And useless to as we're aiming at unsigned anyway.
      
      ../../src/util/virsocketaddr.c: In function 'virSocketAddrIsPrivate':
      ../../src/util/virsocketaddr.c:289:45: error: result of '192l << 24' requires 33 bits to represent, but 'long int' only has 32 bits [-Werror=shift-overflow=]
              return ((val & 0xFFFF0000) == ((192L << 24) + (168 << 16)) ||
                                                   ^~
      ../../src/util/virsocketaddr.c:290:45: error: result of '172l << 24' requires 33 bits to represent, but 'long int' only has 32 bits [-Werror=shift-overflow=]
                      (val & 0xFFF00000) == ((172L << 24) + (16  << 16)) ||
                                                   ^~
      cc1: all warnings being treated as errors
      Signed-off-by: NMichal Privoznik <mprivozn@redhat.com>
      2bd61c84
    • M
      apibuild: Substitute only pure number tokens · 3864d863
      Michal Privoznik 提交于
      In 38df47c9 I've tried to prepare our apibuild.py script for
      change made in 0628f349 (1U << 31). What I've done in the
      former commit was to replace \d+U in parsed tokens with \d.
      Problem was, my regular expression there was not quite right as
      it also translated VIR_123U_VAL into VIR_123_VAL.
      Signed-off-by: NMichal Privoznik <mprivozn@redhat.com>
      3864d863
  9. 29 5月, 2016 1 次提交
  10. 28 5月, 2016 2 次提交
    • M
      Turn 1<<31 into 1U<<31 · 0628f349
      Michal Privoznik 提交于
      Apparently, 1 << 31 is signed which in turn does not fit into
      a signed integer variable:
      
      ../../include/libvirt/libvirt-domain.h:1881:57: error: result of '1 << 31' requires 33 bits to represent, but 'int' only has 32 bits [-Werror=shift-overflow=]
           VIR_CONNECT_GET_ALL_DOMAINS_STATS_ENFORCE_STATS = 1 << 31, /* enforce requested stats */
                                                               ^~
      cc1: all warnings being treated as errors
      
      The solution is to make it an unsigned value. I've found only two
      such occurrences in our code base.
      Signed-off-by: NMichal Privoznik <mprivozn@redhat.com>
      0628f349
    • M
      docs: Teach apibuild to deal with (1U << 31) too · 38df47c9
      Michal Privoznik 提交于
      The apibuild script is a terrifying beast that parses some source
      files of ours and produces an XML representation of them. When it
      comes to parsing enums we have in some header files, it tries to
      be clever and detect a value that an enum member has (or if it is
      an alias for a different member). Whilst doing that it has to
      deal with values we give to the members in many formats. At some
      places we just pass the value in decimal:
      
          VIR_DOMAIN_BLOCK_JOB_TYPE_PULL = 1,
      
      in other places, we use the aliasing:
      
          VIR_CONNECT_GET_ALL_DOMAINS_STATS_ACTIVE = VIR_CONNECT_LIST_DOMAINS_ACTIVE,
      
      and in other places bitwise shifts are used:
      
          VIR_CONNECT_GET_ALL_DOMAINS_STATS_ENFORCE_STATS = 1 << 31, /* enforce requested stats */
      
      The script tries to parse all of these resulting in the following
      tokens: "1", "VIR_CONNECT_LIST_DOMAINS_ACTIVE", "1<<31"; Then, the
      script tries to turn these into integers using python's eval()
      function. This function succeeds on the first and the last
      tokens. But, if we were to modify the last example so that it's
      of the following form:
      
          VIR_CONNECT_GET_ALL_DOMAINS_STATS_ENFORCE_STATS = 1U << 31, /* enforce requested stats */
      
      the token representing enum's member value will then be "1U<<31".
      So our parsing is good. Unfortunately, python is not aware of the
      difference between signed and unsigned C types, therefore eval()
      fails over this token and the parser falls back thinking it's an
      alias to another enum member. Well it's not.
      
      The solution is to transform [0-9]U into [0-9] as for our
      purposes here it's the same thing.
      Signed-off-by: NMichal Privoznik <mprivozn@redhat.com>
      38df47c9