190c58941SSteffen Görtz /* 290c58941SSteffen Görtz * nRF51 Random Number Generator 390c58941SSteffen Görtz * 490c58941SSteffen Görtz * QEMU interface: 590c58941SSteffen Görtz * + Property "period_unfiltered_us": Time between two biased values in 690c58941SSteffen Görtz * microseconds. 790c58941SSteffen Görtz * + Property "period_filtered_us": Time between two unbiased values in 890c58941SSteffen Görtz * microseconds. 990c58941SSteffen Görtz * + sysbus MMIO regions 0: Memory Region with tasks, events and registers 1090c58941SSteffen Görtz * to be mapped to the peripherals instance address by the SOC. 1190c58941SSteffen Görtz * + Named GPIO output "irq": Interrupt line of the peripheral. Must be 1290c58941SSteffen Görtz * connected to the associated peripheral interrupt line of the NVIC. 1390c58941SSteffen Görtz * + Named GPIO output "eep_valrdy": Event set when new random value is ready 1490c58941SSteffen Görtz * to be read. 1590c58941SSteffen Görtz * + Named GPIO input "tep_start": Task that triggers start of continuous 1690c58941SSteffen Görtz * generation of random values. 1790c58941SSteffen Görtz * + Named GPIO input "tep_stop": Task that ends continuous generation of 1890c58941SSteffen Görtz * random values. 1990c58941SSteffen Görtz * 2090c58941SSteffen Görtz * Accuracy of the peripheral model: 2190c58941SSteffen Görtz * + Stochastic properties of different configurations of the random source 2290c58941SSteffen Görtz * are not modeled. 2390c58941SSteffen Görtz * + Generation of unfiltered and filtered random values take at least the 2490c58941SSteffen Görtz * average generation time stated in the production specification; 2590c58941SSteffen Görtz * non-deterministic generation times are not modeled. 2690c58941SSteffen Görtz * 2790c58941SSteffen Görtz * Copyright 2018 Steffen Görtz <contrib@steffen-goertz.de> 2890c58941SSteffen Görtz * 2990c58941SSteffen Görtz * This code is licensed under the GPL version 2 or later. See 3090c58941SSteffen Görtz * the COPYING file in the top-level directory. 3190c58941SSteffen Görtz * 3290c58941SSteffen Görtz */ 336834c3f4SMarkus Armbruster 3490c58941SSteffen Görtz #ifndef NRF51_RNG_H 3590c58941SSteffen Görtz #define NRF51_RNG_H 3690c58941SSteffen Görtz 3790c58941SSteffen Görtz #include "hw/sysbus.h" 3890c58941SSteffen Görtz #include "qemu/timer.h" 39db1015e9SEduardo Habkost #include "qom/object.h" 4090c58941SSteffen Görtz #define TYPE_NRF51_RNG "nrf51_soc.rng" 41*8063396bSEduardo Habkost OBJECT_DECLARE_SIMPLE_TYPE(NRF51RNGState, NRF51_RNG) 4290c58941SSteffen Görtz 4390c58941SSteffen Görtz #define NRF51_RNG_SIZE 0x1000 4490c58941SSteffen Görtz 4590c58941SSteffen Görtz #define NRF51_RNG_TASK_START 0x000 4690c58941SSteffen Görtz #define NRF51_RNG_TASK_STOP 0x004 4790c58941SSteffen Görtz #define NRF51_RNG_EVENT_VALRDY 0x100 4890c58941SSteffen Görtz #define NRF51_RNG_REG_SHORTS 0x200 4990c58941SSteffen Görtz #define NRF51_RNG_REG_SHORTS_VALRDY_STOP 0 5090c58941SSteffen Görtz #define NRF51_RNG_REG_INTEN 0x300 5190c58941SSteffen Görtz #define NRF51_RNG_REG_INTEN_VALRDY 0 5290c58941SSteffen Görtz #define NRF51_RNG_REG_INTENSET 0x304 5390c58941SSteffen Görtz #define NRF51_RNG_REG_INTENCLR 0x308 5490c58941SSteffen Görtz #define NRF51_RNG_REG_CONFIG 0x504 5590c58941SSteffen Görtz #define NRF51_RNG_REG_CONFIG_DECEN 0 5690c58941SSteffen Görtz #define NRF51_RNG_REG_VALUE 0x508 5790c58941SSteffen Görtz 58db1015e9SEduardo Habkost struct NRF51RNGState { 5990c58941SSteffen Görtz SysBusDevice parent_obj; 6090c58941SSteffen Görtz 6190c58941SSteffen Görtz MemoryRegion mmio; 6290c58941SSteffen Görtz qemu_irq irq; 6390c58941SSteffen Görtz 6490c58941SSteffen Görtz /* Event End Points */ 6590c58941SSteffen Görtz qemu_irq eep_valrdy; 6690c58941SSteffen Görtz 6790c58941SSteffen Görtz QEMUTimer timer; 6890c58941SSteffen Görtz 6990c58941SSteffen Görtz /* Time between generation of successive unfiltered values in us */ 7090c58941SSteffen Görtz uint16_t period_unfiltered_us; 7190c58941SSteffen Görtz /* Time between generation of successive filtered values in us */ 7290c58941SSteffen Görtz uint16_t period_filtered_us; 7390c58941SSteffen Görtz 7490c58941SSteffen Görtz uint8_t value; 7590c58941SSteffen Görtz 7690c58941SSteffen Görtz uint32_t active; 7790c58941SSteffen Görtz uint32_t event_valrdy; 7890c58941SSteffen Görtz uint32_t shortcut_stop_on_valrdy; 7990c58941SSteffen Görtz uint32_t interrupt_enabled; 8090c58941SSteffen Görtz uint32_t filter_enabled; 8190c58941SSteffen Görtz 82db1015e9SEduardo Habkost }; 8390c58941SSteffen Görtz 8490c58941SSteffen Görtz 856834c3f4SMarkus Armbruster #endif /* NRF51_RNG_H */ 86