Skip to content
Snippets Groups Projects
  1. Jan 08, 2021
    • Bin Meng's avatar
      hw/arm: sabrelite: Connect the Ethernet PHY at address 6 · 37e33be7
      Bin Meng authored
      
      At present, when booting U-Boot on QEMU sabrelite, we see:
      
        Net:   Board Net Initialization Failed
        No ethernet found.
      
      U-Boot scans PHY at address 4/5/6/7 (see board_eth_init() in the
      U-Boot source: board/boundary/nitrogen6x/nitrogen6x.c). On the real
      board, the Ethernet PHY is at address 6. Adjust this by updating the
      "fec-phy-num" property of the fsl_imx6 SoC object.
      
      With this change, U-Boot sees the PHY but complains MAC address:
      
        Net:   using phy at 6
        FEC [PRIME]
        Error: FEC address not set.
      
      This is due to U-Boot tries to read the MAC address from the fuse,
      which QEMU does not have any valid content filled in. However this
      does not prevent the Ethernet from working in QEMU. We just need to
      set up the MAC address later in the U-Boot command shell, by:
      
        => setenv ethaddr 00:11:22:33:44:55
      
      Signed-off-by: default avatarBin Meng <bin.meng@windriver.com>
      Reviewed-by: default avatarAlex Bennée <alex.bennee@linaro.org>
      Message-id: 20210106063504.10841-4-bmeng.cn@gmail.com
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      37e33be7
    • Bin Meng's avatar
      hw/msic: imx6_ccm: Correct register value for silicon type · 45914971
      Bin Meng authored
      
      Currently when U-Boot boots, it prints "??" for i.MX processor:
      
        CPU:   Freescale i.MX?? rev1.0 at 792 MHz
      
      The register that was used to determine the silicon type is
      undocumented in the latest IMX6DQRM (Rev. 6, 05/2020), but we
      can refer to get_cpu_rev() in arch/arm/mach-imx/mx6/soc.c in
      the U-Boot source codes that USB_ANALOG_DIGPROG is used.
      
      Update its reset value to indicate i.MX6Q.
      
      Signed-off-by: default avatarBin Meng <bin.meng@windriver.com>
      Reviewed-by: default avatarAlex Bennée <alex.bennee@linaro.org>
      Message-id: 20210106063504.10841-3-bmeng.cn@gmail.com
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      45914971
    • Bin Meng's avatar
      hw/misc: imx6_ccm: Update PMU_MISC0 reset value · 56a11a9b
      Bin Meng authored
      
      U-Boot expects PMU_MISC0 register bit 7 is set (see init_bandgap()
      in arch/arm/mach-imx/mx6/soc.c) during boot. This bit indicates the
      bandgap has stabilized.
      
      With this change, the latest upstream U-Boot (v2021.01-rc3) for imx6
      sabrelite board (mx6qsabrelite_defconfig), with a slight change made
      by switching CONFIG_OF_SEPARATE to CONFIG_OF_EMBED, boots to U-Boot
      shell on QEMU with the following command:
      
      $ qemu-system-arm -M sabrelite -smp 4 -m 1G -kernel u-boot \
          -display none -serial null -serial stdio
      
      Boot log below:
      
        U-Boot 2021.01-rc3 (Dec 12 2020 - 17:40:02 +0800)
      
        CPU:   Freescale i.MX?? rev1.0 at 792 MHz
        Reset cause: POR
        Model: Freescale i.MX6 Quad SABRE Lite Board
        Board: SABRE Lite
        I2C:   ready
        DRAM:  1 GiB
        force_idle_bus: sda=0 scl=0 sda.gp=0x5c scl.gp=0x55
        force_idle_bus: failed to clear bus, sda=0 scl=0
        force_idle_bus: sda=0 scl=0 sda.gp=0x6d scl.gp=0x6c
        force_idle_bus: failed to clear bus, sda=0 scl=0
        force_idle_bus: sda=0 scl=0 sda.gp=0xcb scl.gp=0x5
        force_idle_bus: failed to clear bus, sda=0 scl=0
        MMC:   FSL_SDHC: 0, FSL_SDHC: 1
        Loading Environment from MMC... *** Warning - No block device, using default environment
      
        In:    serial
        Out:   serial
        Err:   serial
        Net:   Board Net Initialization Failed
        No ethernet found.
        starting USB...
        Bus usb@2184000: usb dr_mode not found
        USB EHCI 1.00
        Bus usb@2184200: USB EHCI 1.00
        scanning bus usb@2184000 for devices... 1 USB Device(s) found
        scanning bus usb@2184200 for devices... 1 USB Device(s) found
               scanning usb for storage devices... 0 Storage Device(s) found
               scanning usb for ethernet devices... 0 Ethernet Device(s) found
        Hit any key to stop autoboot:  0
        =>
      
      Signed-off-by: default avatarBin Meng <bin.meng@windriver.com>
      Reviewed-by: default avatarAlex Bennée <alex.bennee@linaro.org>
      Message-id: 20210106063504.10841-2-bmeng.cn@gmail.com
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      56a11a9b
    • Gan Qixin's avatar
      exynos4210_mct: Use ptimer_free() in the finalize function to avoid memleaks · d97d9152
      Gan Qixin authored
      
      When running device-introspect-test, a memory leak occurred in the
      exynos4210_mct_init function, so use ptimer_free() in the finalize function to
      avoid it.
      
      ASAN shows memory leak stack:
      
      Indirect leak of 96 byte(s) in 1 object(s) allocated from:
          #0 0xffffab97e1f0 in __interceptor_calloc (/lib64/libasan.so.5+0xee1f0)
          #1 0xffffab256800 in g_malloc0 (/lib64/libglib-2.0.so.0+0x56800)
          #2 0xaaabf555db78 in ptimer_init /qemu/hw/core/ptimer.c:432
          #3 0xaaabf56b01a0 in exynos4210_mct_init /qemu/hw/timer/exynos4210_mct.c:1505
          #4 0xaaabf6339f6c in object_initialize_with_type /qemu/qom/object.c:515
          #5 0xaaabf633a1e0 in object_new_with_type /qemu/qom/object.c:729
          #6 0xaaabf6375e40 in qmp_device_list_properties /qemu/qom/qom-qmp-cmds.c:153
          #7 0xaaabf653d8ec in qmp_marshal_device_list_properties /qemu/qapi/qapi-commands-qdev.c:59
          #8 0xaaabf6587d08 in do_qmp_dispatch_bh /qemu/qapi/qmp-dispatch.c:110
          #9 0xaaabf6552708 in aio_bh_call /qemu/util/async.c:136
          #10 0xaaabf6552708 in aio_bh_poll /qemu/util/async.c:164
          #11 0xaaabf655f19c in aio_dispatch /qemu/util/aio-posix.c:381
          #12 0xaaabf65523f4 in aio_ctx_dispatch /qemu/util/async.c:306
      
      Reported-by: default avatarEuler Robot <euler.robot@huawei.com>
      Signed-off-by: default avatarGan Qixin <ganqixin@huawei.com>
      Reviewed-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      d97d9152
    • Gan Qixin's avatar
      musicpal: Use ptimer_free() in the finalize function to avoid memleaks · a4bc0334
      Gan Qixin authored
      
      When running device-introspect-test, a memory leak occurred in the
      mv88w8618_pit_init function, so use ptimer_free() in the finalize function to
      avoid it.
      
      ASAN shows memory leak stack:
      
      Indirect leak of 192 byte(s) in 4 object(s) allocated from:
          #0 0xffffab97e1f0 in __interceptor_calloc (/lib64/libasan.so.5+0xee1f0)
          #1 0xffffab256800 in g_malloc0 (/lib64/libglib-2.0.so.0+0x56800)
          #2 0xaaabf555db84 in timer_new_full /qemu/include/qemu/timer.h:523
          #3 0xaaabf555db84 in timer_new /qemu/include/qemu/timer.h:544
          #4 0xaaabf555db84 in timer_new_ns /qemu/include/qemu/timer.h:562
          #5 0xaaabf555db84 in ptimer_init /qemu/hw/core/ptimer.c:433
          #6 0xaaabf5bb2290 in mv88w8618_timer_init /qemu/hw/arm/musicpal.c:862
          #7 0xaaabf5bb2290 in mv88w8618_pit_init /qemu/hw/arm/musicpal.c:954
          #8 0xaaabf6339f6c in object_initialize_with_type /qemu/qom/object.c:515
          #9 0xaaabf633a1e0 in object_new_with_type /qemu/qom/object.c:729
          #10 0xaaabf6375e40 in qmp_device_list_properties /qemu/qom/qom-qmp-cmds.c:153
          #11 0xaaabf5a95540 in qdev_device_help /qemu/softmmu/qdev-monitor.c:283
          #12 0xaaabf5a96940 in qmp_device_add /qemu/softmmu/qdev-monitor.c:801
      
      Reported-by: default avatarEuler Robot <euler.robot@huawei.com>
      Signed-off-by: default avatarGan Qixin <ganqixin@huawei.com>
      Reviewed-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      a4bc0334
    • Gan Qixin's avatar
      mss-timer: Use ptimer_free() in the finalize function to avoid memleaks · e4940041
      Gan Qixin authored
      
      When running device-introspect-test, a memory leak occurred in the
      mss_timer_init function, so use ptimer_free() in the finalize function to avoid
      it.
      
      ASAN shows memory leak stack:
      
      Indirect leak of 192 byte(s) in 2 object(s) allocated from:
          #0 0xffffab97e1f0 in __interceptor_calloc (/lib64/libasan.so.5+0xee1f0)
          #1 0xffffab256800 in g_malloc0 (/lib64/libglib-2.0.so.0+0x56800)
          #2 0xaaabf555db78 in ptimer_init /qemu/hw/core/ptimer.c:432
          #3 0xaaabf58a0010 in mss_timer_init /qemu/hw/timer/mss-timer.c:235
          #4 0xaaabf6339f6c in object_initialize_with_type /qemu/qom/object.c:515
          #5 0xaaabf633ca04 in object_initialize_child_with_propsv /qemu/qom/object.c:564
          #6 0xaaabf633cc08 in object_initialize_child_with_props /qemu/qom/object.c:547
          #7 0xaaabf5b8316c in m2sxxx_soc_initfn /qemu/hw/arm/msf2-soc.c:70
          #8 0xaaabf6339f6c in object_initialize_with_type /qemu/qom/object.c:515
          #9 0xaaabf633a1e0 in object_new_with_type /qemu/qom/object.c:729
          #10 0xaaabf6375e40 in qmp_device_list_properties /qemu/qom/qom-qmp-cmds.c:153
          #11 0xaaabf653d8ec in qmp_marshal_device_list_properties /qemu/qapi/qapi-commands-qdev.c:59
          #12 0xaaabf6587d08 in do_qmp_dispatch_bh /qemu/qapi/qmp-dispatch.c:110
      
      Reported-by: default avatarEuler Robot <euler.robot@huawei.com>
      Signed-off-by: default avatarGan Qixin <ganqixin@huawei.com>
      Reviewed-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      e4940041
    • Gan Qixin's avatar
      exynos4210_pwm: Use ptimer_free() in the finalize function to avoid memleaks · c9342c09
      Gan Qixin authored
      
      When running device-introspect-test, a memory leak occurred in the
      exynos4210_pwm_init function, so use ptimer_free() in the finalize function to
      avoid it.
      
      ASAN shows memory leak stack:
      
      Indirect leak of 240 byte(s) in 5 object(s) allocated from:
          #0 0xffffab97e1f0 in __interceptor_calloc (/lib64/libasan.so.5+0xee1f0)
          #1 0xffffab256800 in g_malloc0 (/lib64/libglib-2.0.so.0+0x56800)
          #2 0xaaabf555db84 in timer_new_full /qemu/include/qemu/timer.h:523
          #3 0xaaabf555db84 in timer_new /qemu/include/qemu/timer.h:544
          #4 0xaaabf555db84 in timer_new_ns /qemu/include/qemu/timer.h:562
          #5 0xaaabf555db84 in ptimer_init /qemu/hw/core/ptimer.c:433
          #6 0xaaabf56a36cc in exynos4210_pwm_init /qemu/hw/timer/exynos4210_pwm.c:401
          #7 0xaaabf6339f6c in object_initialize_with_type /qemu/qom/object.c:515
          #8 0xaaabf633a1e0 in object_new_with_type /qemu/qom/object.c:729
          #9 0xaaabf6375e40 in qmp_device_list_properties /qemu/qom/qom-qmp-cmds.c:153
          #10 0xaaabf653d8ec in qmp_marshal_device_list_properties /qemu/qapi/qapi-commands-qdev.c:59
          #11 0xaaabf6587d08 in do_qmp_dispatch_bh /qemu/qapi/qmp-dispatch.c:110
          #12 0xaaabf6552708 in aio_bh_call /qemu/util/async.c:136
      
      Reported-by: default avatarEuler Robot <euler.robot@huawei.com>
      Signed-off-by: default avatarGan Qixin <ganqixin@huawei.com>
      Reviewed-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      c9342c09
    • Gan Qixin's avatar
      exynos4210_rtc: Use ptimer_free() in the finalize function to avoid memleaks · 3fabd519
      Gan Qixin authored
      
      When running device-introspect-test, a memory leak occurred in the
      exynos4210_rtc_init function, so use ptimer_free() in the finalize function to
      avoid it.
      
      ASAN shows memory leak stack:
      
      Indirect leak of 96 byte(s) in 1 object(s) allocated from:
          #0 0xffffab97e1f0 in __interceptor_calloc (/lib64/libasan.so.5+0xee1f0)
          #1 0xffffab256800 in g_malloc0 (/lib64/libglib-2.0.so.0+0x56800)
          #2 0xaaabf555db78 in ptimer_init /qemu/hw/core/ptimer.c:432
          #3 0xaaabf57b3934 in exynos4210_rtc_init /qemu/hw/rtc/exynos4210_rtc.c:567
          #4 0xaaabf6339f6c in object_initialize_with_type /qemu/qom/object.c:515
          #5 0xaaabf633a1e0 in object_new_with_type /qemu/qom/object.c:729
          #6 0xaaabf6375e40 in qmp_device_list_properties /qemu/qom/qom-qmp-cmds.c:153
          #7 0xaaabf653d8ec in qmp_marshal_device_list_properties /qemu/qapi/qapi-commands-qdev.c:59
          #8 0xaaabf6587d08 in do_qmp_dispatch_bh /qemu/qapi/qmp-dispatch.c:110
          #9 0xaaabf6552708 in aio_bh_call /qemu/util/async.c:136
          #10 0xaaabf6552708 in aio_bh_poll /qemu/util/async.c:164
          #11 0xaaabf655f19c in aio_dispatch /qemu/util/aio-posix.c:381
          #12 0xaaabf65523f4 in aio_ctx_dispatch /qemu/util/async.c:306
      
      Reported-by: default avatarEuler Robot <euler.robot@huawei.com>
      Signed-off-by: default avatarGan Qixin <ganqixin@huawei.com>
      Reviewed-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      3fabd519
    • Gan Qixin's avatar
      allwinner-a10-pit: Use ptimer_free() in the finalize function to avoid memleaks · e1c5909b
      Gan Qixin authored
      
      When running device-introspect-test, a memory leak occurred in the a10_pit_init
      function, so use ptimer_free() in the finalize function to avoid it.
      
      ASAN shows memory leak stack:
      
      Indirect leak of 288 byte(s) in 6 object(s) allocated from:
          #0 0xffffab97e1f0 in __interceptor_calloc (/lib64/libasan.so.5+0xee1f0)
          #1 0xffffab256800 in g_malloc0 (/lib64/libglib-2.0.so.0+0x56800)
          #2 0xaaabf555db84 in timer_new_full /qemu/include/qemu/timer.h:523
          #3 0xaaabf555db84 in timer_new /qemu/include/qemu/timer.h:544
          #4 0xaaabf555db84 in timer_new_ns /qemu/include/qemu/timer.h:562
          #5 0xaaabf555db84 in ptimer_init /qemu/hw/core/ptimer.c:433
          #6 0xaaabf57415e8 in a10_pit_init /qemu/hw/timer/allwinner-a10-pit.c:278
          #7 0xaaabf6339f6c in object_initialize_with_type /qemu/qom/object.c:515
          #8 0xaaabf633ca04 in object_initialize_child_with_propsv /qemu/qom/object.c:564
          #9 0xaaabf633cc08 in object_initialize_child_with_props /qemu/qom/object.c:547
          #10 0xaaabf5b94680 in aw_a10_init /qemu/hw/arm/allwinner-a10.c:49
          #11 0xaaabf6339f6c in object_initialize_with_type /qemu/qom/object.c:515
          #12 0xaaabf633a1e0 in object_new_with_type /qemu/qom/object.c:729
      
      Reported-by: default avatarEuler Robot <euler.robot@huawei.com>
      Signed-off-by: default avatarGan Qixin <ganqixin@huawei.com>
      Reviewed-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      e1c5909b
    • Gan Qixin's avatar
      digic-timer: Use ptimer_free() in the finalize function to avoid memleaks · ea492b12
      Gan Qixin authored
      
      When running device-introspect-test, a memory leak occurred in the
      digic_timer_init function, so use ptimer_free() in the finalize function to
      avoid it.
      
      ASAN shows memory leak stack:
      
      Indirect leak of 288 byte(s) in 3 object(s) allocated from:
          #0 0xffffab97e1f0 in __interceptor_calloc (/lib64/libasan.so.5+0xee1f0)
          #1 0xffffab256800 in g_malloc0 (/lib64/libglib-2.0.so.0+0x56800)
          #2 0xaaabf555db78 in ptimer_init /qemu/hw/core/ptimer.c:432
          #3 0xaaabf5b04084 in digic_timer_init /qemu/hw/timer/digic-timer.c:142
          #4 0xaaabf6339f6c in object_initialize_with_type /qemu/qom/object.c:515
          #5 0xaaabf633ca04 in object_initialize_child_with_propsv /qemu/qom/object.c:564
          #6 0xaaabf633cc08 in object_initialize_child_with_props /qemu/qom/object.c:547
          #7 0xaaabf5b40e84 in digic_init /qemu/hw/arm/digic.c:46
          #8 0xaaabf6339f6c in object_initialize_with_type /qemu/qom/object.c:515
          #9 0xaaabf633a1e0 in object_new_with_type /qemu/qom/object.c:729
          #10 0xaaabf6375e40 in qmp_device_list_properties /qemu/qom/qom-qmp-cmds.c:153
          #11 0xaaabf653d8ec in qmp_marshal_device_list_properties /qemu/qapi/qapi-commands-qdev.c:59
          #12 0xaaabf6587d08 in do_qmp_dispatch_bh /qemu/qapi/qmp-dispatch.c:110
      
      Reported-by: default avatarEuler Robot <euler.robot@huawei.com>
      Signed-off-by: default avatarGan Qixin <ganqixin@huawei.com>
      Reviewed-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      ea492b12
    • Peter Maydell's avatar
      target/arm: Remove timer_del()/timer_deinit() before timer_free() · 2d3bf653
      Peter Maydell authored
      
      The Arm CPU finalize function uses a sequence of timer_del(), timer_deinit(),
      timer_free() to free the timer. The timer_deinit() step in this was always
      unnecessary, and now the timer_del() is implied by timer_free(), so we can
      collapse this down to simply calling timer_free().
      
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Reviewed-by: default avatarPhilippe Mathieu-Daudé <philmd@redhat.com>
      Reviewed-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      Message-id: 20201215154107.3255-5-peter.maydell@linaro.org
      2d3bf653
    • Peter Maydell's avatar
      Remove superfluous timer_del() calls · 729cc683
      Peter Maydell authored
      
      This commit is the result of running the timer-del-timer-free.cocci
      script on the whole source tree.
      
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Acked-by: default avatarCorey Minyard <cminyard@mvista.com>
      Acked-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
      Reviewed-by: default avatarPhilippe Mathieu-Daudé <philmd@redhat.com>
      Reviewed-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      Message-id: 20201215154107.3255-4-peter.maydell@linaro.org
      729cc683
    • Peter Maydell's avatar
      scripts/coccinelle: New script to remove unnecessary timer_del() calls · 01b3e68b
      Peter Maydell authored
      
      Now that timer_free() implicitly calls timer_del(), sequences
        timer_del(mytimer);
        timer_free(mytimer);
      
      can be simplified to just
        timer_free(mytimer);
      
      Add a Coccinelle script to do this transformation.
      
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Acked-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
      Reviewed-by: default avatarPhilippe Mathieu-Daudé <philmd@redhat.com>
      Reviewed-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      Message-id: 20201215154107.3255-3-peter.maydell@linaro.org
      01b3e68b
    • Peter Maydell's avatar
      util/qemu-timer: Make timer_free() imply timer_del() · 5f8e93c3
      Peter Maydell authored
      
      Currently timer_free() is a simple wrapper for g_free().  This means
      that the timer being freed must not be currently active, as otherwise
      QEMU might crash later when the active list is processed and still
      has a pointer to freed memory on it.  As a result almost all calls to
      timer_free() are preceded by a timer_del() call, as can be seen in
      the output of
        git grep -B1 '\<timer_free\>'
      
      This is unfortunate API design as it makes it easy to accidentally
      misuse (by forgetting the timer_del()), and the correct use is
      annoyingly verbose.
      
      Make timer_free() imply a timer_del().
      
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Reviewed-by: default avatarPhilippe Mathieu-Daudé <philmd@redhat.com>
      Reviewed-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      Message-id: 20201215154107.3255-2-peter.maydell@linaro.org
      5f8e93c3
    • Peter Maydell's avatar
      hw/arm/highbank: Drop dead KVM support code · 416dd952
      Peter Maydell authored
      
      Support for running KVM on 32-bit Arm hosts was removed in commit
      82bf7ae8.  You can still run a 32-bit guest on a 64-bit Arm
      host CPU, but because Arm KVM requires the host and guest CPU types
      to match, it is not possible to run a guest that requires a Cortex-A9
      or Cortex-A15 CPU there.  That means that the code in the
      highbank/midway board models to support KVM is no longer used, and we
      can delete it.
      
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Reviewed-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      Reviewed-by: default avatarPhilippe Mathieu-Daudé <f4bug@amsat.org>
      Message-id: 20201215144215.28482-1-peter.maydell@linaro.org
      416dd952
    • Peter Maydell's avatar
      target/arm: Implement Cortex-M55 model · 590e05d6
      Peter Maydell authored
      
      Now that we have implemented all the features needed by the v8.1M
      architecture, we can add the model of the Cortex-M55.  This is the
      configuration without MVE support; we'll add MVE later.
      
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Reviewed-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      Message-id: 20201210201433.26262-5-peter.maydell@linaro.org
      590e05d6
    • Peter Maydell's avatar
      target/arm: Implement FPCXT_NS fp system register · eb20dafd
      Peter Maydell authored
      
      Implement the v8.1M FPCXT_NS floating-point system register.  This is
      a little more complicated than FPCXT_S, because it has specific
      handling for "current FP state is inactive", and it only wants to do
      PreserveFPState(), not the full set of actions done by
      ExecuteFPCheck() which vfp_access_check() implements.
      
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Reviewed-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      Message-id: 20201210201433.26262-4-peter.maydell@linaro.org
      eb20dafd
    • Peter Maydell's avatar
      target/arm: Correct store of FPSCR value via FPCXT_S · 7fbf95a0
      Peter Maydell authored
      
      In commit 64f863ba we implemented the v8.1M FPCXT_S register,
      but we got the write behaviour wrong. On read, this register reads
      bits [27:0] of FPSCR plus the CONTROL.SFPA bit. On write, it doesn't
      just write back those bits -- it writes a value to the whole FPSCR,
      whose upper 4 bits are zeroes.
      
      We also incorrectly implemented the write-to-FPSCR as a simple store
      to vfp.xregs; this skips the "update the softfloat flags" part of
      the vfp_set_fpscr helper so the value would read back correctly but
      not actually take effect.
      
      Fix both of these things by doing a complete write to the FPSCR
      using the helper function.
      
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Reviewed-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      Message-id: 20201210201433.26262-3-peter.maydell@linaro.org
      7fbf95a0
    • Peter Maydell's avatar
      hw/intc/armv7m_nvic: Correct handling of CCR.BFHFNMIGN · 5b7d6370
      Peter Maydell authored
      
      The CCR is a register most of whose bits are banked between security
      states but where BFHFNMIGN is not, and we keep it in the non-secure
      entry of the v7m.ccr[] array.  The logic which tries to handle this
      bit fails to implement the "RAZ/WI from Nonsecure if AIRCR.BFHFNMINS
      is zero" requirement; correct the omission.
      
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Reviewed-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      Message-id: 20201210201433.26262-2-peter.maydell@linaro.org
      5b7d6370
    • Richard Henderson's avatar
      target/arm: Fix MTE0_ACTIVE · cc97b001
      Richard Henderson authored
      In 50244cc7 we updated mte_check_fail to match the ARM
      pseudocode, using the correct EL to select the TCF field.
      But we failed to update MTE0_ACTIVE the same way, which led
      to g_assert_not_reached().
      
      Cc: qemu-stable@nongnu.org
      Buglink: https://bugs.launchpad.net/bugs/1907137
      
      
      Signed-off-by: default avatarRichard Henderson <richard.henderson@linaro.org>
      Message-id: 20201221204426.88514-1-richard.henderson@linaro.org
      Reviewed-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      cc97b001
    • Andrew Jones's avatar
      hw/arm/virt: Remove virt machine state 'smp_cpus' · 9cd07db9
      Andrew Jones authored
      
      virt machine's 'smp_cpus' and machine->smp.cpus must always have the
      same value. And, anywhere we have virt machine state we have machine
      state. So let's remove the redundancy. Also, to make it easier to see
      that machine->smp is the true source for "smp_cpus" and "max_cpus",
      avoid passing them in function parameters, preferring instead to get
      them from the state.
      
      No functional change intended.
      
      Signed-off-by: default avatarAndrew Jones <drjones@redhat.com>
      Reviewed-by: default avatarDavid Edmondson <david.edmondson@oracle.com>
      Reviewed-by: default avatarYing Fang <fangying1@huawei.com>
      Message-id: 20201215174815.51520-1-drjones@redhat.com
      [PMM: minor formatting tweak to smp_cpus variable declaration]
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      9cd07db9
    • Edgar E. Iglesias's avatar
      intc/arm_gic: Fix gic_irq_signaling_enabled() for vCPUs · 4663b72a
      Edgar E. Iglesias authored
      
      Correct the indexing into s->cpu_ctlr for vCPUs.
      
      Signed-off-by: default avatarEdgar E. Iglesias <edgar.iglesias@xilinx.com>
      Reviewed-by: default avatarPhilippe Mathieu-Daudé <f4bug@amsat.org>
      Reviewed-by: default avatarLuc Michel <luc.michel@greensocs.com>
      Message-id: 20201214222154.3480243-2-edgar.iglesias@gmail.com
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      4663b72a
  2. Jan 07, 2021
Loading