.. | .. |
---|
| 1 | +/* SPDX-License-Identifier: GPL-2.0-or-later */ |
---|
1 | 2 | /* |
---|
2 | 3 | * RNG: Random Number Generator algorithms under the crypto API |
---|
3 | 4 | * |
---|
4 | 5 | * Copyright (c) 2008 Neil Horman <nhorman@tuxdriver.com> |
---|
5 | 6 | * Copyright (c) 2015 Herbert Xu <herbert@gondor.apana.org.au> |
---|
6 | | - * |
---|
7 | | - * This program is free software; you can redistribute it and/or modify it |
---|
8 | | - * under the terms of the GNU General Public License as published by the Free |
---|
9 | | - * Software Foundation; either version 2 of the License, or (at your option) |
---|
10 | | - * any later version. |
---|
11 | | - * |
---|
12 | 7 | */ |
---|
13 | 8 | |
---|
14 | 9 | #ifndef _CRYPTO_RNG_H |
---|
.. | .. |
---|
142 | 137 | const u8 *src, unsigned int slen, |
---|
143 | 138 | u8 *dst, unsigned int dlen) |
---|
144 | 139 | { |
---|
145 | | - return crypto_rng_alg(tfm)->generate(tfm, src, slen, dst, dlen); |
---|
| 140 | + struct crypto_alg *alg = tfm->base.__crt_alg; |
---|
| 141 | + int ret; |
---|
| 142 | + |
---|
| 143 | + crypto_stats_get(alg); |
---|
| 144 | + ret = crypto_rng_alg(tfm)->generate(tfm, src, slen, dst, dlen); |
---|
| 145 | + crypto_stats_rng_generate(alg, dlen, ret); |
---|
| 146 | + return ret; |
---|
146 | 147 | } |
---|
147 | 148 | |
---|
148 | 149 | /** |
---|