Skip to content
Snippets Groups Projects
  1. Jul 07, 2023
    • Thomas Huth's avatar
      meson.build: Remove the logic to link C code with the C++ linker · 785abf0d
      Thomas Huth authored
      
      We are not mixing C++ with C code anymore, the only remaining
      C++ code in qga/vss-win32/ is used for a plain C++ executable.
      Thus we can remove the hacks for linking C code with the C++ linker
      now to simplify meson.build a little bit, and also to avoid that
      some C++ code sneaks in by accident again.
      
      Signed-off-by: default avatarThomas Huth <thuth@redhat.com>
      Message-ID: <20230706064736.178962-1-thuth@redhat.com>
      Signed-off-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
      785abf0d
    • Paolo Bonzini's avatar
      python: bump minimum requirements so they are compatible with 3.12 · 3d7b8974
      Paolo Bonzini authored
      
      There are many Python 3.12 issues right now, but a particularly
      problematic one when debugging them is that one cannot even use
      minreqs.txt in a Python 3.12 virtual environment to test with
      locked package versions.
      
      Bump the mypy and wrapt versions to fix this, while remaining
      within the realm of versions compatible with Python 3.7.
      
      This requires a workaround for a mypy false positive
      
          qemu/qmp/qmp_tui.py:350: error: Non-overlapping equality check (left operand type: "Literal[Runstate.DISCONNECTING]", right operand type: "Literal[Runstate.IDLE]")  [comparison-overlap]
      
      where mypy does not realize that self.disconnect() could change
      the value of self.runstate.
      
      Signed-off-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
      3d7b8974
  2. Jul 06, 2023
    • Richard Henderson's avatar
      Merge tag 'pull-9p-20230706' of https://github.com/cschoenebeck/qemu into staging · 97c81ef4
      Richard Henderson authored
      Administrative changes only:
      
      * Deprecate 9p 'proxy' backend.
      
      * Raise status of 9p to 'Maintained'.
      
      # -----BEGIN PGP SIGNATURE-----
      #
      # iQJLBAABCgA1FiEEltjREM96+AhPiFkBNMK1h2Wkc5UFAmSmkAsXHHFlbXVfb3Nz
      # QGNydWRlYnl0ZS5jb20ACgkQNMK1h2Wkc5We1xAAol+HbhQ2zNCJUbZ2/WY3Jf0H
      # K86DRQIs6w6UkL9msFz+id+tR5i50HoJ3+RnOKvy/fPqO8Rv6mb0d9r+bIG1JJCc
      # ubHP91x/nyDbP0XbLMtmtCz/T4g67E11Qqriq7lH1bPF7ccU3iXHZNup9HARjOoE
      # SQo9x4e7IDi1WdmM2vjvRXCh4ZLIlBv7c+2vAeP4V7FhJhDkL+1y+w6aCFw0xpd8
      # lto3Egnhz6pk7+SJfQwCl3rfozHhCxlNmcNa+7vqckVFpdJrvtKOQB4cn9yVDPr/
      # WjmYoB2J3MwYuZz+qAkdRJ6dUTLJb87YqJJe6lcKq0lqjiFBk7TccvIN9WgyJQd/
      # eLUPCCyo98g9RCaPzjLc4MgbpCPCmqJkg8A1vJzykvq51BqJZcdkwfJ7LFmsvTSo
      # IfR1Seq4OUUzTZ2gWh8wJBNcPpAbilHzQnumxBEupe0Dg/pwoQWCywTYJN6Yf/6+
      # PzcK39bVFKrEyc4Z1Y/yXvAzD7nX8X78kSHvxYYEQfzruLIVQjUUQ7Mp3TiJvljk
      # mLdcYqavjawgC2zmZU4L2Lx4Su7iVIkhNWj57WkfooSzLrAjueYQIJEltAt8Qmn6
      # x3+u3xI/myNKujMpaqgTAU5Gk2J2UApshq5Zwe8HpnVwWoxS3QetXdA/f4AXwZOk
      # TpnKPYQa7edPLSSAbAs=
      # =GzjR
      # -----END PGP SIGNATURE-----
      # gpg: Signature made Thu 06 Jul 2023 10:57:31 AM BST
      # gpg:                using RSA key 96D8D110CF7AF8084F88590134C2B58765A47395
      # gpg:                issuer "qemu_oss@crudebyte.com"
      # gpg: Good signature from "Christian Schoenebeck <qemu_oss@crudebyte.com>" [unknown]
      # gpg: WARNING: This key is not certified with a trusted signature!
      # gpg:          There is no indication that the signature belongs to the owner.
      # Primary key fingerprint: ECAB 1A45 4014 1413 BA38  4926 30DB 47C3 A012 D5F4
      #      Subkey fingerprint: 96D8 D110 CF7A F808 4F88  5901 34C2 B587 65A4 7395
      
      * tag 'pull-9p-20230706' of https://github.com/cschoenebeck/qemu
      
      :
        MAINTAINERS: raise status of 9p to 'Maintained'
        9pfs: deprecate 'proxy' backend
      
      Signed-off-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      97c81ef4
    • Richard Henderson's avatar
      Merge tag 'pull-target-arm-20230706' of... · 822cb97c
      Richard Henderson authored
      Merge tag 'pull-target-arm-20230706' of https://git.linaro.org/people/pmaydell/qemu-arm into staging
      
      target-arm queue:
       * Add raw_writes ops for register whose write induce TLB maintenance
       * hw/arm/sbsa-ref: use XHCI to replace EHCI
       * Avoid splitting Zregs across lines in dump
       * Dump ZA[] when active
       * Fix SME full tile indexing
       * Handle IC IVAU to improve compatibility with JITs
       * xlnx-canfd-test: Fix code coverity issues
       * gdbstub: Guard M-profile code with CONFIG_TCG
       * allwinner-sramc: Set class_size
       * target/xtensa: Assert that interrupt level is within bounds
       * Avoid over-length shift in arm_cpu_sve_finalize() error case
       * Define new 'neoverse-v1' CPU type
      
      # -----BEGIN PGP SIGNATURE-----
      #
      # iQJNBAABCAA3FiEE4aXFk81BneKOgxXPPCUl7RQ2DN4FAmSmwEEZHHBldGVyLm1h
      # eWRlbGxAbGluYXJvLm9yZwAKCRA8JSXtFDYM3vBcD/4vKUw6klRV7vyz/KBr2AOi
      # Z1FnkLmOhwdp7CKvAVfU58TbPEJ8Fjo7OjziByV5nn/Ht9XrXcdl/E+0JamgrJ/n
      # G90ZfpoY3Boan4XBukBz/KX63sT1erF4io1NxbvqLxZ2mbZWNb0D1v2qkxC5zPFE
      # 97knlbSle4/VB8N6VgaPaWKVy5gmBZQwl7NUlFtB8TTZp3HPo0V77E9p1Wqpwpls
      # BNbqdtgUre3dlJci2f24PmXHYraKa68qk9xGnsSae96EY2+pOHbKhoZ/Fobaor2C
      # u+dfgQ3fY3aLDVKx8UESIUoqkGoVqwEbmt+pWG2rJiljLkdsI3ZsVq7p3+VGbLAN
      # berL14kCC2vRQYeNUwxeh5wdNVXc58xhWI5KXQRe8hr1dKWS5LQEHWgr7g7mb0+m
      # zPHqbdF4FR1DAV29vQ9WyK4zttrinFAYl+zvLyd8dX2ogoUeivR+4o3YX4hlFr4H
      # vcrglZbCGqAb3oKQG3PSGliS9GYtBwodLqKEH8PfcwfOP5PIcnSVc0Kl9DSzf7um
      # dAuYpaK/XW3MPx5qpWjnip4dRWUV5m/6nSCJr+fELEv3A0sGZY4pywv5NS/Yg1wE
      # nXdi8D+nyx9+AAiWTcB+ePsLuDEO2gYtubfqed99TFoJbL6/b4NbH8YE6cF3N/gY
      # lqFyvEIYNJZ9klf7XKnX2w==
      # =/MkB
      # -----END PGP SIGNATURE-----
      # gpg: Signature made Thu 06 Jul 2023 02:23:13 PM BST
      # gpg:                using RSA key E1A5C593CD419DE28E8315CF3C2525ED14360CDE
      # gpg:                issuer "peter.maydell@linaro.org"
      # gpg: Good signature from "Peter Maydell <peter.maydell@linaro.org>" [full]
      # gpg:                 aka "Peter Maydell <pmaydell@gmail.com>" [full]
      # gpg:                 aka "Peter Maydell <pmaydell@chiark.greenend.org.uk>" [full]
      # gpg:                 aka "Peter Maydell <peter@archaic.org.uk>" [unknown]
      
      * tag 'pull-target-arm-20230706' of https://git.linaro.org/people/pmaydell/qemu-arm
      
      :
        target/arm: Avoid over-length shift in arm_cpu_sve_finalize() error case
        target/arm: Define neoverse-v1
        target/arm: Suppress more TCG unimplemented features in ID registers
        target/xtensa: Assert that interrupt level is within bounds
        hw: arm: allwinner-sramc: Set class_size
        target/arm: gdbstub: Guard M-profile code with CONFIG_TCG
        tests/qtest: xlnx-canfd-test: Fix code coverity issues
        target/arm: Handle IC IVAU to improve compatibility with JITs
        target/arm: Fix SME full tile indexing
        target/arm: Dump ZA[] when active
        target/arm: Avoid splitting Zregs across lines in dump
        tests/tcg/aarch64/sysregs.c: Use S syntax for id_aa64zfr0_el1 and id_aa64smfr0_el1
        hw/arm/sbsa-ref: use XHCI to replace EHCI
        target/arm: Add raw_writes ops for register whose write induce TLB maintenance
      
      Signed-off-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      822cb97c
    • Peter Maydell's avatar
      target/arm: Avoid over-length shift in arm_cpu_sve_finalize() error case · c4107723
      Peter Maydell authored
      
      If you build QEMU with the clang sanitizer enabled, you can see it
      fire when running the arm-cpu-features test:
      
      $ QTEST_QEMU_BINARY=./build/arm-clang/qemu-system-aarch64 ./build/arm-clang/tests/qtest/arm-cpu-features
      [...]
      ../../target/arm/cpu64.c:125:19: runtime error: shift exponent 64 is too large for 64-bit type 'unsigned long long'
      [...]
      
      This happens because the user can specify some incorrect SVE
      properties that result in our calculating a max_vq of 0.  We catch
      this and error out, but before we do that we calculate
      
       vq_mask = MAKE_64BIT_MASK(0, max_vq);$
      
      and the MAKE_64BIT_MASK() call is only valid for lengths that are
      greater than zero, so we hit the undefined behaviour.
      
      Change the logic so that if max_vq is 0 we specifically set vq_mask
      to 0 without going via MAKE_64BIT_MASK().  This lets us drop the
      max_vq check from the error-exit logic, because if max_vq is 0 then
      vq_map must now be 0.
      
      The UB only happens in the case where the user passed us an incorrect
      set of SVE properties, so it's not a big problem in practice.
      
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Reviewed-by: default avatarAlex Bennée <alex.bennee@linaro.org>
      Reviewed-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      Message-id: 20230704154332.3014896-1-peter.maydell@linaro.org
      c4107723
    • Peter Maydell's avatar
      target/arm: Define neoverse-v1 · c74138c6
      Peter Maydell authored
      
      Now that we have implemented support for FEAT_LSE2, we can define
      a CPU model for the Neoverse-V1, and enable it for the virt and
      sbsa-ref boards.
      
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Message-id: 20230704130647.2842917-3-peter.maydell@linaro.org
      Reviewed-by: default avatarAlex Bennée <alex.bennee@linaro.org>
      Reviewed-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      c74138c6
    • Peter Maydell's avatar
      target/arm: Suppress more TCG unimplemented features in ID registers · 7d8c283e
      Peter Maydell authored
      
      We already squash the ID register field for FEAT_SPE (the Statistical
      Profiling Extension) because TCG does not implement it and if we
      advertise it to the guest the guest will crash trying to look at
      non-existent system registers.  Do the same for some other features
      which a real hardware Neoverse-V1 implements but which TCG doesn't:
       * FEAT_TRF (Self-hosted Trace Extension)
       * Trace Macrocell system register access
       * Memory mapped trace
       * FEAT_AMU (Activity Monitors Extension)
       * FEAT_MPAM (Memory Partitioning and Monitoring Extension)
       * FEAT_NV (Nested Virtualization)
      
      Most of these, like FEAT_SPE, are "introspection/trace" type features
      which QEMU is unlikely to ever implement.  The odd-one-out here is
      FEAT_NV -- we could implement that and at some point we probably
      will.
      
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Message-id: 20230704130647.2842917-2-peter.maydell@linaro.org
      Reviewed-by: default avatarAlex Bennée <alex.bennee@linaro.org>
      Reviewed-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      7d8c283e
    • Peter Maydell's avatar
      target/xtensa: Assert that interrupt level is within bounds · ad18376b
      Peter Maydell authored
      
      In handle_interrupt() we use level as an index into the interrupt_vector[]
      array. This is safe because we have checked it against env->config->nlevel,
      but Coverity can't see that (and it is only true because each CPU config
      sets its XCHAL_NUM_INTLEVELS to something less than MAX_NLEVELS), so it
      complains about a possible array overrun (CID 1507131)
      
      Add an assert() which will make Coverity happy and catch the unlikely
      case of a mis-set XCHAL_NUM_INTLEVELS in future.
      
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Acked-by: default avatarMax Filippov <jcmvbkbc@gmail.com>
      Message-id: 20230623154135.1930261-1-peter.maydell@linaro.org
      ad18376b
    • Akihiko Odaki's avatar
      hw: arm: allwinner-sramc: Set class_size · 9057e5f7
      Akihiko Odaki authored
      
      AwSRAMCClass is larger than SysBusDeviceClass so the class size must be
      advertised accordingly.
      
      Fixes: 05def917 ("hw: arm: allwinner-sramc: Add SRAM Controller support for R40")
      Signed-off-by: default avatarAkihiko Odaki <akihiko.odaki@daynix.com>
      Reviewed-by: default avatarPhilippe Mathieu-Daudé <philmd@linaro.org>
      Reviewed-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      Message-id: 20230628110905.38125-1-akihiko.odaki@daynix.com
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      9057e5f7
    • Fabiano Rosas's avatar
      target/arm: gdbstub: Guard M-profile code with CONFIG_TCG · 893ca916
      Fabiano Rosas authored
      
      This code is only relevant when TCG is present in the build. Building
      with --disable-tcg --enable-xen on an x86 host we get:
      
      $ ../configure --target-list=x86_64-softmmu,aarch64-softmmu --disable-tcg --enable-xen
      $ make -j$(nproc)
      ...
      libqemu-aarch64-softmmu.fa.p/target_arm_gdbstub.c.o: in function `m_sysreg_ptr':
       ../target/arm/gdbstub.c:358: undefined reference to `arm_v7m_get_sp_ptr'
       ../target/arm/gdbstub.c:361: undefined reference to `arm_v7m_get_sp_ptr'
      
      libqemu-aarch64-softmmu.fa.p/target_arm_gdbstub.c.o: in function `arm_gdb_get_m_systemreg':
      ../target/arm/gdbstub.c:405: undefined reference to `arm_v7m_mrs_control'
      
      Signed-off-by: default avatarFabiano Rosas <farosas@suse.de>
      Message-id: 20230628164821.16771-1-farosas@suse.de
      Reviewed-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      893ca916
    • Vikram Garhwal's avatar
      tests/qtest: xlnx-canfd-test: Fix code coverity issues · b52aa865
      Vikram Garhwal authored
      
      Following are done to fix the coverity issues:
      1. Change read_data to fix the CID 1512899: Out-of-bounds access (OVERRUN)
      2. Fix match_rx_tx_data to fix CID 1512900: Logically dead code (DEADCODE)
      3. Replace rand() in generate_random_data() with g_rand_int()
      
      Signed-off-by: default avatarVikram Garhwal <vikram.garhwal@amd.com>
      Message-id: 20230628202758.16398-1-vikram.garhwal@amd.com
      Reviewed-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      b52aa865
    • John Högberg's avatar
      target/arm: Handle IC IVAU to improve compatibility with JITs · 9719f125
      John Högberg authored
      Unlike architectures with precise self-modifying code semantics
      (e.g. x86) ARM processors do not maintain coherency for instruction
      execution and memory, requiring an instruction synchronization
      barrier on every core that will execute the new code, and on many
      models also the explicit use of cache management instructions.
      
      While this is required to make JITs work on actual hardware, QEMU
      has gotten away with not handling this since it does not emulate
      caches, and unconditionally invalidates code whenever the softmmu
      or the user-mode page protection logic detects that code has been
      modified.
      
      Unfortunately the latter does not work in the face of dual-mapped
      code (a common W^X workaround), where one page is executable and
      the other is writable: user-mode has no way to connect one with the
      other as that is only known to the kernel and the emulated
      application.
      
      This commit works around the issue by telling software that
      instruction cache invalidation is required by clearing the
      CPR_EL0.DIC flag (regardless of whether the emulated processor
      needs it), and then invalidating code in IC IVAU instructions.
      
      Resolves: https://gitlab.com/qemu-project/qemu/-/issues/1034
      
      
      
      Co-authored-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      Signed-off-by: default avatarJohn Högberg <john.hogberg@ericsson.com>
      Reviewed-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      Message-id: 168778890374.24232.3402138851538068785-1@git.sr.ht
      [PMM: removed unnecessary AArch64 feature check; moved
       "clear CTR_EL1.DIC" code up a bit so it's not in the middle
       of the vfp/neon related tests]
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      9719f125
    • Richard Henderson's avatar
      target/arm: Fix SME full tile indexing · 1f51573f
      Richard Henderson authored
      For the outer product set of insns, which take an entire matrix
      tile as output, the argument is not a combined tile+column.
      Therefore using get_tile_rowcol was incorrect, as we extracted
      the tile number from itself.
      
      The test case relies only on assembler support for SME, since
      no release of GCC recognizes -march=armv9-a+sme yet.
      
      Cc: qemu-stable@nongnu.org
      Resolves: https://gitlab.com/qemu-project/qemu/-/issues/1620
      
      
      Signed-off-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      Message-id: 20230622151201.1578522-5-richard.henderson@linaro.org
      Reviewed-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      [PMM: dropped now-unneeded changes to sysregs CFLAGS]
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      1f51573f
    • Richard Henderson's avatar
      target/arm: Dump ZA[] when active · 270bea47
      Richard Henderson authored
      
      Always print each matrix row whole, one per line, so that we
      get the entire matrix in the proper shape.
      
      Signed-off-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      Message-id: 20230622151201.1578522-3-richard.henderson@linaro.org
      Reviewed-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      270bea47
    • Richard Henderson's avatar
      target/arm: Avoid splitting Zregs across lines in dump · a9d84070
      Richard Henderson authored
      
      Allow the line length to extend to 548 columns.  While annoyingly wide,
      it's still less confusing than the continuations we print.  Also, the
      default VL used by Linux (and max for A64FX) uses only 140 columns.
      
      Signed-off-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      Message-id: 20230622151201.1578522-2-richard.henderson@linaro.org
      Reviewed-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      a9d84070
    • Peter Maydell's avatar
      tests/tcg/aarch64/sysregs.c: Use S syntax for id_aa64zfr0_el1 and id_aa64smfr0_el1 · 3dc2afea
      Peter Maydell authored
      
      Some assemblers will complain about attempts to access
      id_aa64zfr0_el1 and id_aa64smfr0_el1 by name if the test
      binary isn't built for the right processor type:
      
       /tmp/ccASXpLo.s:782: Error: selected processor does not support system register name 'id_aa64zfr0_el1'
       /tmp/ccASXpLo.s:829: Error: selected processor does not support system register name 'id_aa64smfr0_el1'
      
      However, these registers are in the ID space and are guaranteed to
      read-as-zero on older CPUs, so the access is both safe and sensible.
      Switch to using the S syntax, as we already do for ID_AA64ISAR2_EL1
      and ID_AA64MMFR2_EL1.  This allows us to drop the HAS_ARMV9_SME check
      and the makefile machinery to adjust the CFLAGS for this test, so we
      don't rely on having a sufficiently new compiler to be able to check
      these registers.
      
      This means we're actually testing the SME ID register: no released
      GCC yet recognizes -march=armv9-a+sme, so that was always skipped.
      It also avoids a future problem if we try to switch the "do we have
      SME support in the toolchain" check from "in the compiler" to "in the
      assembler" (at which point we would otherwise run into the above
      errors).
      
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      3dc2afea
    • Christian Schoenebeck's avatar
      MAINTAINERS: raise status of 9p to 'Maintained' · 3548fa01
      Christian Schoenebeck authored
      
      Change status of 9p from 'Odd Fixes' to 'Maintained', as this better
      reflects current situation. I already take care of 9p patches for a
      while, which included new features as well.
      
      Based-on: <E1qDkmw-0007M1-8f@lizzy.crudebyte.com>
      Signed-off-by: default avatarChristian Schoenebeck <qemu_oss@crudebyte.com>
      Reviewed-by: default avatarGreg Kurz <groug@kaod.org>
      Reviewed-by: default avatarPhilippe Mathieu-Daudé <philmd@linaro.org>
      Message-Id: <E1qGKgV-0003Hj-01@lizzy.crudebyte.com>
      3548fa01
    • Christian Schoenebeck's avatar
      9pfs: deprecate 'proxy' backend · 71d72ece
      Christian Schoenebeck authored
      
      As recent CVE-2023-2861 (fixed by f6b0de53) once again showed, the 9p
      'proxy' fs driver is in bad shape. Using the 'proxy' backend was already
      discouraged for safety reasons before and we recommended to use the
      'local' backend (preferably in conjunction with its 'mapped' security
      model) instead, but now it is time to officially deprecate the 'proxy'
      backend.
      
      Signed-off-by: default avatarChristian Schoenebeck <qemu_oss@crudebyte.com>
      Reviewed-by: default avatarGreg Kurz <groug@kaod.org>
      Message-Id: <E1qDkmw-0007M1-8f@lizzy.crudebyte.com>
      71d72ece
  3. Jul 04, 2023
    • Richard Henderson's avatar
      Merge tag 'block-pull-request' of https://gitlab.com/stefanha/qemu into staging · 0618e72d
      Richard Henderson authored
      Pull request
      
      Fix --enable-modules with the blkio block driver.
      
      # -----BEGIN PGP SIGNATURE-----
      #
      # iQEzBAABCAAdFiEEhpWov9P5fNqsNXdanKSrs4Grc8gFAmSkOtQACgkQnKSrs4Gr
      # c8ipnQgAqrcwgJliN9wMopm5bFEiHkAppvGz/+qliEpQI5X7xt+YGhcEx7O7ZNMu
      # uSz47y5uQwNNbh4HA51gUkSopAcfH2FP8rD/FH5x7D7mmR3M61AH5LEzzlBbnneW
      # ZtuGSNIvV23mTlQOHqNOGQxV9k3QGrXfxQz0Hy4NKP6jiC1zNdAsCXC8dj9Fda+M
      # nobFXe21qhm0YHYGVgLurbjlTY3aBxL3SOSG550OjQT1Prpi+rw26aK0Gtg1jWL/
      # ynGEgxgUjvO2uqZk71NN5Xr6CLe/SLO9cdIeuhwXffna5uf80S254fMhr9Yr1h52
      # P5UFi4iQZi//fprGD72a6eyogdSzUg==
      # =USrv
      # -----END PGP SIGNATURE-----
      # gpg: Signature made Tue 04 Jul 2023 05:29:24 PM CEST
      # gpg:                using RSA key 8695A8BFD3F97CDAAC35775A9CA4ABB381AB73C8
      # gpg: Good signature from "Stefan Hajnoczi <stefanha@redhat.com>" [full]
      # gpg:                 aka "Stefan Hajnoczi <stefanha@gmail.com>" [full]
      
      * tag 'block-pull-request' of https://gitlab.com/stefanha/qemu
      
      :
        block/blkio: fix module_block.py parsing
      
      Signed-off-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      0618e72d
    • Stefan Hajnoczi's avatar
      block/blkio: fix module_block.py parsing · c21eae1c
      Stefan Hajnoczi authored
      
      When QEMU is built with --enable-modules, the module_block.py script
      parses block/*.c to find block drivers that are built as modules. The
      script generates a table of block drivers called block_driver_modules[].
      This table is used for block driver module loading.
      
      The blkio.c driver uses macros to define its BlockDriver structs. This
      was done to avoid code duplication but the module_block.py script is
      unable to parse the macro. The result is that libblkio-based block
      drivers can be built as modules but will not be found at runtime.
      
      One fix is to make the module_block.py script or build system fancier so
      it can parse C macros (e.g. by parsing the preprocessed source code). I
      chose not to do this because it raises the complexity of the build,
      making future issues harder to debug.
      
      Keep things simple: use the macro to avoid duplicating BlockDriver
      function pointers but define .format_name and .protocol_name manually
      for each BlockDriver. This way the module_block.py is able to parse the
      code.
      
      Also get rid of the block driver name macros (e.g. DRIVER_IO_URING)
      because module_block.py cannot parse them either.
      
      Fixes: fd66dbd4 ("blkio: add libblkio block driver")
      Reported-by: default avatarQing Wang <qinwang@redhat.com>
      Signed-off-by: default avatarStefan Hajnoczi <stefanha@redhat.com>
      Reviewed-by: default avatarStefano Garzarella <sgarzare@redhat.com>
      Message-id: 20230704123436.187761-1-stefanha@redhat.com
      Cc: Stefano Garzarella <sgarzare@redhat.com>
      Signed-off-by: default avatarStefan Hajnoczi <stefanha@redhat.com>
      c21eae1c
    • Yuquan Wang's avatar
      hw/arm/sbsa-ref: use XHCI to replace EHCI · 62c2b876
      Yuquan Wang authored
      
      The current sbsa-ref cannot use EHCI controller which is only
      able to do 32-bit DMA, since sbsa-ref doesn't have RAM below 4GB.
      Hence, this uses XHCI to provide a usb controller with 64-bit
      DMA capablity instead of EHCI.
      
      We bump the platform version to 0.3 with this change.  Although the
      hardware at the USB controller address changes, the firmware and
      Linux can both cope with this -- on an older non-XHCI-aware
      firmware/kernel setup the probe routine simply fails and the guest
      proceeds without any USB.  (This isn't a loss of functionality,
      because the old USB controller never worked in the first place.) So
      we can call this a backwards-compatible change and only bump the
      minor version.
      
      Signed-off-by: default avatarYuquan Wang <wangyuquan1236@phytium.com.cn>
      Message-id: 20230621103847.447508-2-wangyuquan1236@phytium.com.cn
      [PMM: tweaked commit message; add line to docs about what
       changes in platform version 0.3]
      Reviewed-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      62c2b876
    • Eric Auger's avatar
      target/arm: Add raw_writes ops for register whose write induce TLB maintenance · 587f8b33
      Eric Auger authored
      
      Some registers whose 'cooked' writefns induce TLB maintenance do
      not have raw_writefn ops defined. If only the writefn ops is set
      (ie. no raw_writefn is provided), it is assumed the cooked also
      work as the raw one. For those registers it is not obvious the
      tlb_flush works on KVM mode so better/safer setting the raw write.
      
      Signed-off-by: default avatarEric Auger <eric.auger@redhat.com>
      Suggested-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Reviewed-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      587f8b33
    • Richard Henderson's avatar
      Merge tag 'pull-maintainer-ominbus-030723-1' of https://gitlab.com/stsquad/qemu into staging · 2a6ae691
      Richard Henderson authored
      maintainer updates: testing, fuzz, plugins, docs, gdbstub
      
       - clean up gitlab artefact handling
       - ensure gitlab publishes artefacts with coverage data
       - reduce testing scope for coverage job
       - mention CI pipeline in developer docs
       - add ability to add plugin args to check-tcg
       - fix some memory leaks and UB in tests
       - suppress xcb leaks from fuzzing output
       - add a test-fuzz to mirror the CI run
       - allow lci-refresh to be run in $SRC
       - update lcitool to latest version
       - add qemu-minimal package set with gcc-native
       - convert riscv64-cross to lcitool
       - update sbsa-ref tests
       - don't include arm_casq_ptw emulation unless TCG
       - convert plugins to use g_memdup2
       - ensure plugins instrument SVE helper mem access
       - improve documentation of QOM/QDEV
       - make gdbstub send stop responses when it should
       - report user-mode pid in gdbstub
       - add support for info proc mappings in gdbstub
      
      # -----BEGIN PGP SIGNATURE-----
      #
      # iQEzBAABCgAdFiEEZoWumedRZ7yvyN81+9DbCVqeKkQFAmSiuH4ACgkQ+9DbCVqe
      # KkRt0Qf+N0oD/VuEcRSxK1bWlLtf5nxQpPKKzkRItPc5jqJnLWa/gh21sfQgs5Uq
      # BczAT+JfgTnMozbq0mjvQ+uAGI4MHzBs+UAn60+ZcXfk2inyk77XKBEoHOFuK1ry
      # rgQ4+p21/hcZedDiDLnLSfbGfUU0KkM/pbAegOz7HO0EQDV0CSXqeAW3WAuM1lne
      # +YmXkKwoFI1V8HvslzCT12GFiaUfmSSBtASqWcf67Ief97K24+rpkAVM7JChLm5X
      # fC1MOFNuNYV+jO+9U3KIs15P1WH12oMcpNUY+KqQ5ZWovBg83yOLtKY1o3f6Z2Y+
      # iQgFJr6F8ZVBdKNJtqVi8DkbiFfbsA==
      # =Ho/h
      # -----END PGP SIGNATURE-----
      # gpg: Signature made Mon 03 Jul 2023 02:01:02 PM CEST
      # gpg:                using RSA key 6685AE99E75167BCAFC8DF35FBD0DB095A9E2A44
      # gpg: Good signature from "Alex Bennée (Master Work Key) <alex.bennee@linaro.org>" [undefined]
      # gpg: WARNING: This key is not certified with a trusted signature!
      # gpg:          There is no indication that the signature belongs to the owner.
      # Primary key fingerprint: 6685 AE99 E751 67BC AFC8  DF35 FBD0 DB09 5A9E 2A44
      
      * tag 'pull-maintainer-ominbus-030723-1' of https://gitlab.com/stsquad/qemu
      
      : (38 commits)
        tests/tcg: Add a test for info proc mappings
        docs: Document security implications of debugging
        gdbstub: Add support for info proc mappings
        gdbstub: Report the actual qemu-user pid
        gdbstub: Expose gdb_get_process() and gdb_get_first_cpu_in_process()
        linux-user: Emulate /proc/self/smaps
        linux-user: Add "safe" parameter to do_guest_openat()
        linux-user: Expose do_guest_openat() and do_guest_readlink()
        gdbstub: clean-up vcont handling to avoid goto
        gdbstub: Permit reverse step/break to provide stop response
        gdbstub: lightly refactor connection to avoid snprintf
        docs/devel: introduce some key concepts for QOM development
        docs/devel: split qom-api reference into new file
        docs/devel/qom.rst: Correct code style
        include/hw/qdev-core: fixup kerneldoc annotations
        include/migration: mark vmstate_register() as a legacy function
        docs/devel: add some front matter to the devel index
        plugins: update lockstep to use g_memdup2
        plugins: fix memory leak while parsing options
        plugins: force slow path when plugins instrument memory ops
        ...
      
      Signed-off-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      2a6ae691
  4. Jul 03, 2023
Loading