921923583f
This adds a non-cryptographic grade implementation of the model for the True Random Number Generator (TRNG) component in AMD/Xilinx Versal device family. This implements all 3 modes defined by the actual hardware specs, all of which selectable by guest software at will at anytime: 1) PRNG mode, in which the generated sequence is required to be reproducible after reseeded by the same 384-bit value as supplied by guest software. 2) Test mode, in which the generated sequence is required to be reproducible ater reseeded by the same 128-bit test seed supplied by guest software. 3) TRNG mode, in which non-reproducible sequence is generated based on periodic reseed by a suitable entropy source. This model is only intended for non-real world testing of guest software, where cryptographically strong PRNG or TRNG is not needed. This model supports versions 1 & 2 of the device, with default to be version 2; the 'hw-version' uint32 property can be set to 0x0100 to override the default. Other implemented properties: - 'forced-prng', uint64 When set to non-zero, mode 3's entropy source is implemented as a deterministic sequence based on the given value and other deterministic parameters. This option allows the emulation to test guest software using mode 3 and to reproduce data-dependent defects. - 'fips-fault-events', uint32, bit-mask bit 3: Triggers the SP800-90B entropy health test fault irq bit 1: Triggers the FIPS 140-2 continuous test fault irq Signed-off-by: Tong Ho <tong.ho@amd.com> Message-id: 20231031184611.3029156-2-tong.ho@amd.com Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Peter Maydell <peter.maydell@linaro.org> |
||
---|---|---|
.. | ||
macio | ||
a9scu.h | ||
allwinner-a10-ccm.h | ||
allwinner-a10-dramc.h | ||
allwinner-cpucfg.h | ||
allwinner-h3-ccu.h | ||
allwinner-h3-dramc.h | ||
allwinner-h3-sysctrl.h | ||
allwinner-r40-ccu.h | ||
allwinner-r40-dramc.h | ||
allwinner-sid.h | ||
allwinner-sramc.h | ||
arm11scu.h | ||
arm_integrator_debug.h | ||
armsse-cpu-pwrctrl.h | ||
armsse-cpuid.h | ||
armsse-mhu.h | ||
armv7m_ras.h | ||
aspeed_hace.h | ||
aspeed_i3c.h | ||
aspeed_lpc.h | ||
aspeed_peci.h | ||
aspeed_sbc.h | ||
aspeed_scu.h | ||
aspeed_sdmc.h | ||
aspeed_xdma.h | ||
auxbus.h | ||
avr_power.h | ||
bcm2835_cprman_internals.h | ||
bcm2835_cprman.h | ||
bcm2835_mbox_defs.h | ||
bcm2835_mbox.h | ||
bcm2835_mphi.h | ||
bcm2835_powermgt.h | ||
bcm2835_property.h | ||
bcm2835_rng.h | ||
bcm2835_thermal.h | ||
cbus.h | ||
djmemc.h | ||
empty_slot.h | ||
grlib_ahb_apb_pnp.h | ||
imx6_ccm.h | ||
imx6_src.h | ||
imx6ul_ccm.h | ||
imx7_ccm.h | ||
imx7_gpr.h | ||
imx7_snvs.h | ||
imx7_src.h | ||
imx25_ccm.h | ||
imx31_ccm.h | ||
imx_ccm.h | ||
imx_rngc.h | ||
iosb.h | ||
iotkit-secctl.h | ||
iotkit-sysctl.h | ||
iotkit-sysinfo.h | ||
ivshmem.h | ||
lasi.h | ||
led.h | ||
mac_via.h | ||
mchp_pfsoc_dmc.h | ||
mchp_pfsoc_ioscb.h | ||
mchp_pfsoc_sysreg.h | ||
mips_cmgcr.h | ||
mips_cpc.h | ||
mips_itu.h | ||
mos6522.h | ||
mps2-fpgaio.h | ||
mps2-scc.h | ||
msf2-sysreg.h | ||
npcm7xx_clk.h | ||
npcm7xx_gcr.h | ||
npcm7xx_mft.h | ||
npcm7xx_pwm.h | ||
npcm7xx_rng.h | ||
nrf51_rng.h | ||
pca9552_regs.h | ||
pca9552.h | ||
pvpanic.h | ||
sifive_e_aon.h | ||
sifive_e_prci.h | ||
sifive_test.h | ||
sifive_u_otp.h | ||
sifive_u_prci.h | ||
stm32f2xx_syscfg.h | ||
stm32f4xx_exti.h | ||
stm32f4xx_syscfg.h | ||
tz-mpc.h | ||
tz-msc.h | ||
tz-ppc.h | ||
unimp.h | ||
virt_ctrl.h | ||
vmcoreinfo.h | ||
xlnx-cfi-if.h | ||
xlnx-versal-cframe-reg.h | ||
xlnx-versal-cfu.h | ||
xlnx-versal-crl.h | ||
xlnx-versal-pmc-iou-slcr.h | ||
xlnx-versal-trng.h | ||
xlnx-versal-xramc.h | ||
xlnx-zynqmp-apu-ctrl.h | ||
xlnx-zynqmp-crf.h |