14bfca0dec
The TYPE_XLNX_VERSAL_TRNG device creates a register block with register_init_block32() in its instance_init method; we must therefore destroy it in our instance_finalize method to avoid a leak in the QOM introspection "init-inspect-finalize" lifecycle: Direct leak of 304 byte(s) in 1 object(s) allocated from: #0 0x55842ec799d8 in __interceptor_calloc (/mnt/nvmedisk/linaro/qemu-from-laptop/qemu/build/asan/qemu-system-aarch64+0x294e9d8) (BuildId: 47496e53f3e779f1c7e9b82cbea07407152b498b) #1 0x7fe793c75c50 in g_malloc0 debian/build/deb/../../../glib/gmem.c:161:13 #2 0x55842f0aec5d in register_init_block hw/core/register.c:248:34 #3 0x55842f0af6be in register_init_block32 hw/core/register.c:299:12 #4 0x55842f801588 in trng_init hw/misc/xlnx-versal-trng.c:614:9 #5 0x558431c411a1 in object_init_with_type qom/object.c:420:9 #6 0x558431c2847b in object_initialize_with_type qom/object.c:562:5 #7 0x558431c29d1d in object_new_with_type qom/object.c:782:5 #8 0x558431c29df1 in object_new qom/object.c:797:12 #9 0x558432427c1d in qmp_device_list_properties qom/qom-qmp-cmds.c:144:11 Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Reviewed-by: Edgar E. Iglesias <edgar.iglesias@amd.com> Reviewed-by: Francisco Iglesias <francisco.iglesias@amd.com> Reviewed-by: Alistair Francis <alistair.francis@wdc.com> Message-id: 20240822162127.705879-6-peter.maydell@linaro.org
60 lines
2.0 KiB
C
60 lines
2.0 KiB
C
/*
|
|
* Non-crypto strength model of the True Random Number Generator
|
|
* in the AMD/Xilinx Versal device family.
|
|
*
|
|
* Copyright (c) 2017-2020 Xilinx Inc.
|
|
* Copyright (c) 2023 Advanced Micro Devices, Inc.
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
* in the Software without restriction, including without limitation the rights
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
* furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in
|
|
* all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
* THE SOFTWARE.
|
|
*/
|
|
#ifndef XLNX_VERSAL_TRNG_H
|
|
#define XLNX_VERSAL_TRNG_H
|
|
|
|
#include "hw/irq.h"
|
|
#include "hw/sysbus.h"
|
|
#include "hw/register.h"
|
|
|
|
#define TYPE_XLNX_VERSAL_TRNG "xlnx.versal-trng"
|
|
OBJECT_DECLARE_SIMPLE_TYPE(XlnxVersalTRng, XLNX_VERSAL_TRNG);
|
|
|
|
#define RMAX_XLNX_VERSAL_TRNG ((0xf0 / 4) + 1)
|
|
|
|
typedef struct XlnxVersalTRng {
|
|
SysBusDevice parent_obj;
|
|
qemu_irq irq;
|
|
GRand *prng;
|
|
|
|
uint32_t hw_version;
|
|
uint32_t forced_faults;
|
|
|
|
uint32_t rand_count;
|
|
uint64_t rand_reseed;
|
|
|
|
uint64_t forced_prng_seed;
|
|
uint64_t forced_prng_count;
|
|
uint64_t tst_seed[2];
|
|
|
|
RegisterInfoArray *reg_array;
|
|
uint32_t regs[RMAX_XLNX_VERSAL_TRNG];
|
|
RegisterInfo regs_info[RMAX_XLNX_VERSAL_TRNG];
|
|
} XlnxVersalTRng;
|
|
|
|
#undef RMAX_XLNX_VERSAL_TRNG
|
|
#endif
|