VirtualBox

source: vbox/trunk/include/iprt/crypto/misc.h@ 74730

Last change on this file since 74730 was 74312, checked in by vboxsync, 6 years ago

IPRT/crypto: Added RTCrRandBytes and RTCrPkcs5Pbkdf2Hmac. The latter means openssl 1.0.0 or higher is now required. bugref:9246

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 2.1 KB
Line 
1/** @file
2 * IPRT - Crypto - Miscellaneous.
3 */
4
5/*
6 * Copyright (C) 2018 Oracle Corporation
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * The contents of this file may alternatively be used under the terms
17 * of the Common Development and Distribution License Version 1.0
18 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
19 * VirtualBox OSE distribution, in which case the provisions of the
20 * CDDL are applicable instead of those of the GPL.
21 *
22 * You may elect to license modified versions of this file under the
23 * terms and conditions of either the GPL or the CDDL or both.
24 */
25
26#ifndef ___iprt_crypto_misc_h
27#define ___iprt_crypto_misc_h
28
29#include <iprt/types.h>
30
31
32RT_C_DECLS_BEGIN
33
34/** @defgroup grp_rt_crmisc RTCrMisc - Miscellaneous
35 * @ingroup grp_rt_crypto
36 * @{
37 */
38
39/**
40 * Get cryptographically strong random bytes.
41 *
42 * The buffer will always be filled with random bytes, however only
43 * on @c VINF_SUCCESS is it guaranteed to be strong random bytes.
44 *
45 * @retval VINF_SUCCESS
46 * @retval VERR_CR_RANDOM_FAILED if insufficient strong random bytes or some similar failure.
47 * @retval VERR_CR_RANDOM_SETUP_FAILED if setting up strong random failed
48 * and no strong bytes returned.
49 *
50 * @param pvDst Where to return the random bytes.
51 * @param cbDst How many random bytes to return.
52 */
53RTDECL(int) RTCrRandBytes(void *pvDst, size_t cbDst);
54
55RTDECL(int) RTCrPkcs5Pbkdf2Hmac(void const *pvInput, size_t cbInput, void const *pvSalt, size_t cbSalt, uint32_t cIterations,
56 RTDIGESTTYPE enmDigestType, size_t cbKeyLen, void *pvOutput);
57
58/** @} */
59
60RT_C_DECLS_END
61
62#endif
63
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette