/Linux-v4.19/drivers/crypto/ |
D | exynos-rng.c | 66 struct exynos_rng_dev *rng; member 87 static u32 exynos_rng_readl(struct exynos_rng_dev *rng, u32 offset) in exynos_rng_readl() argument 89 return readl_relaxed(rng->mem + offset); in exynos_rng_readl() 92 static void exynos_rng_writel(struct exynos_rng_dev *rng, u32 val, u32 offset) in exynos_rng_writel() argument 94 writel_relaxed(val, rng->mem + offset); in exynos_rng_writel() 97 static int exynos_rng_set_seed(struct exynos_rng_dev *rng, in exynos_rng_set_seed() argument 117 exynos_rng_writel(rng, val, EXYNOS_RNG_SEED(seed_reg)); in exynos_rng_set_seed() 120 val = exynos_rng_readl(rng, EXYNOS_RNG_STATUS); in exynos_rng_set_seed() 122 dev_warn(rng->dev, "Seed setting not finished\n"); in exynos_rng_set_seed() 126 rng->last_seeding = jiffies; in exynos_rng_set_seed() [all …]
|
D | qcom-rng.c | 36 struct qcom_rng *rng; member 41 static int qcom_rng_read(struct qcom_rng *rng, u8 *data, unsigned int max) in qcom_rng_read() argument 48 val = readl_relaxed(rng->base + PRNG_STATUS); in qcom_rng_read() 52 val = readl_relaxed(rng->base + PRNG_DATA_OUT); in qcom_rng_read() 75 struct qcom_rng *rng = ctx->rng; in qcom_rng_generate() local 78 ret = clk_prepare_enable(rng->clk); in qcom_rng_generate() 82 mutex_lock(&rng->lock); in qcom_rng_generate() 84 ret = qcom_rng_read(rng, dstn, dlen); in qcom_rng_generate() 86 mutex_unlock(&rng->lock); in qcom_rng_generate() 87 clk_disable_unprepare(rng->clk); in qcom_rng_generate() [all …]
|
/Linux-v4.19/drivers/char/hw_random/ |
D | core.c | 53 static int hwrng_init(struct hwrng *rng); 56 static inline int rng_get_data(struct hwrng *rng, u8 *buffer, size_t size, 64 static void add_early_randomness(struct hwrng *rng) in add_early_randomness() argument 70 bytes_read = rng_get_data(rng, rng_buffer, size, 1); in add_early_randomness() 78 struct hwrng *rng = container_of(kref, struct hwrng, ref); in cleanup_rng() local 80 if (rng->cleanup) in cleanup_rng() 81 rng->cleanup(rng); in cleanup_rng() 83 complete(&rng->cleanup_done); in cleanup_rng() 86 static int set_current_rng(struct hwrng *rng) in set_current_rng() argument 92 err = hwrng_init(rng); in set_current_rng() [all …]
|
D | Makefile | 6 obj-$(CONFIG_HW_RANDOM) += rng-core.o 7 rng-core-y := core.o 8 obj-$(CONFIG_HW_RANDOM_TIMERIOMEM) += timeriomem-rng.o 9 obj-$(CONFIG_HW_RANDOM_INTEL) += intel-rng.o 10 obj-$(CONFIG_HW_RANDOM_AMD) += amd-rng.o 11 obj-$(CONFIG_HW_RANDOM_ATMEL) += atmel-rng.o 12 obj-$(CONFIG_HW_RANDOM_GEODE) += geode-rng.o 13 obj-$(CONFIG_HW_RANDOM_N2RNG) += n2-rng.o 14 n2-rng-y := n2-drv.o n2-asm.o 15 obj-$(CONFIG_HW_RANDOM_VIA) += via-rng.o [all …]
|
D | hisi-rng.c | 26 #define to_hisi_rng(p) container_of(p, struct hisi_rng, rng) 34 struct hwrng rng; member 37 static int hisi_rng_init(struct hwrng *rng) in hisi_rng_init() argument 39 struct hisi_rng *hrng = to_hisi_rng(rng); in hisi_rng_init() 60 static void hisi_rng_cleanup(struct hwrng *rng) in hisi_rng_cleanup() argument 62 struct hisi_rng *hrng = to_hisi_rng(rng); in hisi_rng_cleanup() 67 static int hisi_rng_read(struct hwrng *rng, void *buf, size_t max, bool wait) in hisi_rng_read() argument 69 struct hisi_rng *hrng = to_hisi_rng(rng); in hisi_rng_read() 78 struct hisi_rng *rng; in hisi_rng_probe() local 82 rng = devm_kzalloc(&pdev->dev, sizeof(*rng), GFP_KERNEL); in hisi_rng_probe() [all …]
|
D | cavium-rng-vf.c | 24 static int cavium_rng_read(struct hwrng *rng, void *dat, size_t max, bool wait) in cavium_rng_read() argument 26 struct cavium_rng *p = container_of(rng, struct cavium_rng, ops); in cavium_rng_read() 46 struct cavium_rng *rng; in cavium_rng_probe_vf() local 49 rng = devm_kzalloc(&pdev->dev, sizeof(*rng), GFP_KERNEL); in cavium_rng_probe_vf() 50 if (!rng) in cavium_rng_probe_vf() 54 rng->result = pcim_iomap(pdev, 0, 0); in cavium_rng_probe_vf() 55 if (!rng->result) { in cavium_rng_probe_vf() 60 rng->ops.name = devm_kasprintf(&pdev->dev, GFP_KERNEL, in cavium_rng_probe_vf() 62 if (!rng->ops.name) in cavium_rng_probe_vf() 65 rng->ops.read = cavium_rng_read; in cavium_rng_probe_vf() [all …]
|
D | octeon-rng.c | 28 static int octeon_rng_init(struct hwrng *rng) in octeon_rng_init() argument 31 struct octeon_rng *p = container_of(rng, struct octeon_rng, ops); in octeon_rng_init() 40 static void octeon_rng_cleanup(struct hwrng *rng) in octeon_rng_cleanup() argument 43 struct octeon_rng *p = container_of(rng, struct octeon_rng, ops); in octeon_rng_cleanup() 50 static int octeon_rng_data_read(struct hwrng *rng, u32 *data) in octeon_rng_data_read() argument 52 struct octeon_rng *p = container_of(rng, struct octeon_rng, ops); in octeon_rng_data_read() 62 struct octeon_rng *rng; in octeon_rng_probe() local 71 rng = devm_kzalloc(&pdev->dev, sizeof(*rng), GFP_KERNEL); in octeon_rng_probe() 72 if (!rng) in octeon_rng_probe() 84 rng->control_status = devm_ioremap_nocache(&pdev->dev, in octeon_rng_probe() [all …]
|
D | mtk-rng.c | 42 #define to_mtk_rng(p) container_of(p, struct mtk_rng, rng) 47 struct hwrng rng; member 50 static int mtk_rng_init(struct hwrng *rng) in mtk_rng_init() argument 52 struct mtk_rng *priv = to_mtk_rng(rng); in mtk_rng_init() 67 static void mtk_rng_cleanup(struct hwrng *rng) in mtk_rng_cleanup() argument 69 struct mtk_rng *priv = to_mtk_rng(rng); in mtk_rng_cleanup() 79 static bool mtk_rng_wait_ready(struct hwrng *rng, bool wait) in mtk_rng_wait_ready() argument 81 struct mtk_rng *priv = to_mtk_rng(rng); in mtk_rng_wait_ready() 92 static int mtk_rng_read(struct hwrng *rng, void *buf, size_t max, bool wait) in mtk_rng_read() argument 94 struct mtk_rng *priv = to_mtk_rng(rng); in mtk_rng_read() [all …]
|
D | stm32-rng.c | 40 struct hwrng rng; member 47 static int stm32_rng_read(struct hwrng *rng, void *data, size_t max, bool wait) in stm32_rng_read() argument 50 container_of(rng, struct stm32_rng_private, rng); in stm32_rng_read() 54 pm_runtime_get_sync((struct device *) priv->rng.priv); in stm32_rng_read() 66 dev_err((struct device *)priv->rng.priv, in stm32_rng_read() 85 pm_runtime_mark_last_busy((struct device *) priv->rng.priv); in stm32_rng_read() 86 pm_runtime_put_sync_autosuspend((struct device *) priv->rng.priv); in stm32_rng_read() 91 static int stm32_rng_init(struct hwrng *rng) in stm32_rng_init() argument 94 container_of(rng, struct stm32_rng_private, rng); in stm32_rng_init() 113 static void stm32_rng_cleanup(struct hwrng *rng) in stm32_rng_cleanup() argument [all …]
|
D | cavium-rng.c | 29 struct cavium_rng_pf *rng; in cavium_rng_probe() local 32 rng = devm_kzalloc(&pdev->dev, sizeof(*rng), GFP_KERNEL); in cavium_rng_probe() 33 if (!rng) in cavium_rng_probe() 37 rng->control_status = pcim_iomap(pdev, 0, 0); in cavium_rng_probe() 38 if (!rng->control_status) { in cavium_rng_probe() 46 rng->control_status); in cavium_rng_probe() 48 pci_set_drvdata(pdev, rng); in cavium_rng_probe() 54 writeq(0, rng->control_status); in cavium_rng_probe() 67 struct cavium_rng_pf *rng; in cavium_rng_remove() local 69 rng = pci_get_drvdata(pdev); in cavium_rng_remove() [all …]
|
D | mxc-rnga.c | 61 struct hwrng rng; member 66 static int mxc_rnga_data_present(struct hwrng *rng, int wait) in mxc_rnga_data_present() argument 69 struct mxc_rng *mxc_rng = container_of(rng, struct mxc_rng, rng); in mxc_rnga_data_present() 82 static int mxc_rnga_data_read(struct hwrng *rng, u32 * data) in mxc_rnga_data_read() argument 86 struct mxc_rng *mxc_rng = container_of(rng, struct mxc_rng, rng); in mxc_rnga_data_read() 105 static int mxc_rnga_init(struct hwrng *rng) in mxc_rnga_init() argument 108 struct mxc_rng *mxc_rng = container_of(rng, struct mxc_rng, rng); in mxc_rnga_init() 128 static void mxc_rnga_cleanup(struct hwrng *rng) in mxc_rnga_cleanup() argument 131 struct mxc_rng *mxc_rng = container_of(rng, struct mxc_rng, rng); in mxc_rnga_cleanup() 150 mxc_rng->rng.name = "mxc-rnga"; in mxc_rnga_probe() [all …]
|
D | bcm2835-rng.c | 34 struct hwrng rng; member 40 static inline struct bcm2835_rng_priv *to_rng_priv(struct hwrng *rng) in to_rng_priv() argument 42 return container_of(rng, struct bcm2835_rng_priv, rng); in to_rng_priv() 65 static int bcm2835_rng_read(struct hwrng *rng, void *buf, size_t max, in bcm2835_rng_read() argument 68 struct bcm2835_rng_priv *priv = to_rng_priv(rng); in bcm2835_rng_read() 88 static int bcm2835_rng_init(struct hwrng *rng) in bcm2835_rng_init() argument 90 struct bcm2835_rng_priv *priv = to_rng_priv(rng); in bcm2835_rng_init() 114 static void bcm2835_rng_cleanup(struct hwrng *rng) in bcm2835_rng_cleanup() argument 116 struct bcm2835_rng_priv *priv = to_rng_priv(rng); in bcm2835_rng_cleanup() 169 priv->rng.name = pdev->name; in bcm2835_rng_probe() [all …]
|
D | pic32-rng.c | 46 struct hwrng rng; member 57 static int pic32_rng_read(struct hwrng *rng, void *buf, size_t max, in pic32_rng_read() argument 60 struct pic32_rng *priv = container_of(rng, struct pic32_rng, rng); in pic32_rng_read() 106 priv->rng.name = pdev->name; in pic32_rng_probe() 107 priv->rng.read = pic32_rng_read; in pic32_rng_probe() 109 ret = hwrng_register(&priv->rng); in pic32_rng_probe() 124 struct pic32_rng *rng = platform_get_drvdata(pdev); in pic32_rng_remove() local 126 hwrng_unregister(&rng->rng); in pic32_rng_remove() 127 writel(0, rng->base + RNGCON); in pic32_rng_remove() 128 clk_disable_unprepare(rng->clk); in pic32_rng_remove()
|
D | tx4939-rng.c | 29 struct hwrng rng; member 65 static int tx4939_rng_data_present(struct hwrng *rng, int wait) in tx4939_rng_data_present() argument 67 struct tx4939_rng *rngdev = container_of(rng, struct tx4939_rng, rng); in tx4939_rng_data_present() 98 static int tx4939_rng_data_read(struct hwrng *rng, u32 *buffer) in tx4939_rng_data_read() argument 100 struct tx4939_rng *rngdev = container_of(rng, struct tx4939_rng, rng); in tx4939_rng_data_read() 121 rngdev->rng.name = dev_name(&dev->dev); in tx4939_rng_probe() 122 rngdev->rng.data_present = tx4939_rng_data_present; in tx4939_rng_probe() 123 rngdev->rng.data_read = tx4939_rng_data_read; in tx4939_rng_probe() 142 if (!tx4939_rng_data_present(&rngdev->rng, 1)) in tx4939_rng_probe() 147 return devm_hwrng_register(&dev->dev, &rngdev->rng); in tx4939_rng_probe()
|
D | iproc-rng200.c | 51 struct hwrng rng; member 55 #define to_rng_priv(rng) container_of(rng, struct iproc_rng200_dev, rng) argument 94 static int iproc_rng200_read(struct hwrng *rng, void *buf, size_t max, in iproc_rng200_read() argument 97 struct iproc_rng200_dev *priv = to_rng_priv(rng); in iproc_rng200_read() 155 static int iproc_rng200_init(struct hwrng *rng) in iproc_rng200_init() argument 157 struct iproc_rng200_dev *priv = to_rng_priv(rng); in iproc_rng200_init() 169 static void iproc_rng200_cleanup(struct hwrng *rng) in iproc_rng200_cleanup() argument 171 struct iproc_rng200_dev *priv = to_rng_priv(rng); in iproc_rng200_cleanup() 205 priv->rng.name = "iproc-rng200", in iproc_rng200_probe() 206 priv->rng.read = iproc_rng200_read, in iproc_rng200_probe() [all …]
|
D | ks-sa-rng.c | 92 struct hwrng rng; member 98 static int ks_sa_rng_init(struct hwrng *rng) in ks_sa_rng_init() argument 101 struct device *dev = (struct device *)rng->priv; in ks_sa_rng_init() 134 static void ks_sa_rng_cleanup(struct hwrng *rng) in ks_sa_rng_cleanup() argument 136 struct device *dev = (struct device *)rng->priv; in ks_sa_rng_cleanup() 145 static int ks_sa_rng_data_read(struct hwrng *rng, u32 *data) in ks_sa_rng_data_read() argument 147 struct device *dev = (struct device *)rng->priv; in ks_sa_rng_data_read() 159 static int ks_sa_rng_data_present(struct hwrng *rng, int wait) in ks_sa_rng_data_present() argument 161 struct device *dev = (struct device *)rng->priv; in ks_sa_rng_data_present() 192 ks_sa_rng->rng = (struct hwrng) { in ks_sa_rng_probe() [all …]
|
D | exynos-trng.c | 52 struct hwrng rng; member 55 static int exynos_trng_do_read(struct hwrng *rng, void *data, size_t max, in exynos_trng_do_read() argument 63 trng = (struct exynos_trng_dev *)rng->priv; in exynos_trng_do_read() 76 static int exynos_trng_init(struct hwrng *rng) in exynos_trng_init() argument 78 struct exynos_trng_dev *trng = (struct exynos_trng_dev *)rng->priv; in exynos_trng_init() 119 trng->rng.name = devm_kstrdup(&pdev->dev, dev_name(&pdev->dev), in exynos_trng_probe() 121 if (!trng->rng.name) in exynos_trng_probe() 124 trng->rng.init = exynos_trng_init; in exynos_trng_probe() 125 trng->rng.read = exynos_trng_do_read; in exynos_trng_probe() 126 trng->rng.priv = (unsigned long) trng; in exynos_trng_probe() [all …]
|
D | pasemi-rng.c | 46 static int pasemi_rng_data_present(struct hwrng *rng, int wait) in pasemi_rng_data_present() argument 48 void __iomem *rng_regs = (void __iomem *)rng->priv; in pasemi_rng_data_present() 61 static int pasemi_rng_data_read(struct hwrng *rng, u32 *data) in pasemi_rng_data_read() argument 63 void __iomem *rng_regs = (void __iomem *)rng->priv; in pasemi_rng_data_read() 68 static int pasemi_rng_init(struct hwrng *rng) in pasemi_rng_init() argument 70 void __iomem *rng_regs = (void __iomem *)rng->priv; in pasemi_rng_init() 80 static void pasemi_rng_cleanup(struct hwrng *rng) in pasemi_rng_cleanup() argument 82 void __iomem *rng_regs = (void __iomem *)rng->priv; in pasemi_rng_cleanup()
|
/Linux-v4.19/arch/powerpc/platforms/powernv/ |
D | rng.c | 38 struct powernv_rng *rng; in powernv_hwrng_present() local 40 rng = get_cpu_var(powernv_rng); in powernv_hwrng_present() 41 put_cpu_var(rng); in powernv_hwrng_present() 42 return rng != NULL; in powernv_hwrng_present() 45 static unsigned long rng_whiten(struct powernv_rng *rng, unsigned long val) in rng_whiten() argument 53 val ^= rng->mask; in rng_whiten() 56 rng->mask = (rng->mask << 1) | (parity & 1); in rng_whiten() 63 struct powernv_rng *rng; in powernv_get_random_real_mode() local 65 rng = raw_cpu_read(powernv_rng); in powernv_get_random_real_mode() 67 *v = rng_whiten(rng, __raw_rm_readq(rng->regs_real)); in powernv_get_random_real_mode() [all …]
|
/Linux-v4.19/crypto/ |
D | jitterentropy-kcapi.c | 126 struct jitterentropy *rng = crypto_tfm_ctx(tfm); in jent_kcapi_init() local 129 rng->entropy_collector = jent_entropy_collector_alloc(1, 0); in jent_kcapi_init() 130 if (!rng->entropy_collector) in jent_kcapi_init() 133 spin_lock_init(&rng->jent_lock); in jent_kcapi_init() 139 struct jitterentropy *rng = crypto_tfm_ctx(tfm); in jent_kcapi_cleanup() local 141 spin_lock(&rng->jent_lock); in jent_kcapi_cleanup() 142 if (rng->entropy_collector) in jent_kcapi_cleanup() 143 jent_entropy_collector_free(rng->entropy_collector); in jent_kcapi_cleanup() 144 rng->entropy_collector = NULL; in jent_kcapi_cleanup() 145 spin_unlock(&rng->jent_lock); in jent_kcapi_cleanup() [all …]
|
/Linux-v4.19/drivers/crypto/amcc/ |
D | crypto4xx_trng.c | 31 static int ppc4xx_trng_data_present(struct hwrng *rng, int wait) in ppc4xx_trng_data_present() argument 33 struct crypto4xx_device *dev = (void *)rng->priv; in ppc4xx_trng_data_present() 48 static int ppc4xx_trng_data_read(struct hwrng *rng, u32 *data) in ppc4xx_trng_data_read() argument 50 struct crypto4xx_device *dev = (void *)rng->priv; in ppc4xx_trng_data_read() 78 struct hwrng *rng = NULL; in ppc4xx_trng_probe() local 91 rng = kzalloc(sizeof(*rng), GFP_KERNEL); in ppc4xx_trng_probe() 92 if (!rng) in ppc4xx_trng_probe() 95 rng->name = KBUILD_MODNAME; in ppc4xx_trng_probe() 96 rng->data_present = ppc4xx_trng_data_present; in ppc4xx_trng_probe() 97 rng->data_read = ppc4xx_trng_data_read; in ppc4xx_trng_probe() [all …]
|
/Linux-v4.19/include/linux/ |
D | hw_random.h | 40 int (*init)(struct hwrng *rng); 41 void (*cleanup)(struct hwrng *rng); 42 int (*data_present)(struct hwrng *rng, int wait); 43 int (*data_read)(struct hwrng *rng, u32 *data); 44 int (*read)(struct hwrng *rng, void *data, size_t max, bool wait); 57 extern int hwrng_register(struct hwrng *rng); 58 extern int devm_hwrng_register(struct device *dev, struct hwrng *rng); 60 extern void hwrng_unregister(struct hwrng *rng); 61 extern void devm_hwrng_unregister(struct device *dve, struct hwrng *rng);
|
/Linux-v4.19/Documentation/devicetree/bindings/rng/ |
D | brcm,bcm2835.txt | 6 "brcm,bcm2835-rng" 7 "brcm,bcm-nsp-rng" 8 "brcm,bcm5301x-rng" or 9 "brcm,bcm6368-rng" 23 rng { 24 compatible = "brcm,bcm2835-rng"; 29 rng@18033000 { 30 compatible = "brcm,bcm-nsp-rng"; 34 random: rng@10004180 { 35 compatible = "brcm,bcm6368-rng";
|
D | mtk-rng.txt | 6 "mediatek,mt7622-rng", "mediatek,mt7623-rng" : for MT7622 7 "mediatek,mt7623-rng" : for MT7623 10 - clock-names : Should contain "rng" entries; 15 rng: rng@1020f000 { 16 compatible = "mediatek,mt7623-rng"; 19 clock-names = "rng";
|
D | sparc_sun_oracle_rng.txt | 7 - 'SUNW,n2-rng' for Niagara 2 Platform (SUN UltraSPARC T2 CPU) 8 - 'SUNW,vf-rng' for Victoria Falls Platform (SUN UltraSPARC T2 Plus CPU) 9 …- 'SUNW,kt-rng' for Rainbow/Yosemite Falls Platform (SUN SPARC T3/T4), (UltraSPARC KT/Niagara 3 - … 11 - 'ORCL,m4-rng' for SPARC T5/M5 12 - 'ORCL,m7-rng' for SPARC T7/M7 18 rng-#units: 00000002 19 compatible: 'ORCL,m4-rng' 25 rng-#units: 00000003 26 compatible: 'ORCL,m7-rng'
|