ObjFW  Diff

Differences From Artifact [2a97d56e0e]:

To Artifact [75597e6dd2]:


22
23
24
25
26
27
28
29

30
31
32
33

34
35
36
37

38
39

40
41

42
43

44
45

46
47

48
49

50
51

52
53

54
55
56
57
58
59

60
61
62
63
64
65
66
67
68
69
70
71
72

73
74
75
76
77
78
79
80
81
82
22
23
24
25
26
27
28

29
30
31
32

33
34
35
36

37
38

39
40

41
42

43
44

45
46

47
48

49
50

51
52

53
54
55
56
57
58

59
60
61
62
63
64
65
66
67
68
69
70
71

72
73
74
75
76
77
78
79
80
81
82







-
+



-
+



-
+

-
+

-
+

-
+

-
+

-
+

-
+

-
+

-
+





-
+












-
+










# define __STDC_CONSTANT_MACROS
#endif

#import "macros.h"

OF_ASSUME_NONNULL_BEGIN

/*! @file */
/** @file */

@class OFHMAC;

/*!
/**
 * @brief The parameters for @ref of_scrypt.
 */
typedef struct of_scrypt_parameters_t {
	/*! @brief The block size to use. */
	/** @brief The block size to use. */
	size_t blockSize;
	/*! @brief The CPU/memory cost factor to use. */
	/** @brief The CPU/memory cost factor to use. */
	size_t costFactor;
	/*! @brief The parallelization to use. */
	/** @brief The parallelization to use. */
	size_t parallelization;
	/*! @brief The salt to derive a key with. */
	/** @brief The salt to derive a key with. */
	const unsigned char *salt;
	/*! @brief The length of the salt. */
	/** @brief The length of the salt. */
	size_t saltLength;
	/*! @brief The password to derive a key from. */
	/** @brief The password to derive a key from. */
	const char *password;
	/*! @brief The length of the password. */
	/** @brief The length of the password. */
	size_t passwordLength;
	/*! @brief The buffer to write the key to. */
	/** @brief The buffer to write the key to. */
	unsigned char *key;
	/*!
	/**
	 * @brief The desired length for the derived key.
	 *
	 * @ref key needs to have enough storage.
	 */
	size_t keyLength;
	/*! @brief Whether data may be stored in swappable memory. */
	/** @brief Whether data may be stored in swappable memory. */
	bool allowsSwappableMemory;
} of_scrypt_parameters_t;

#ifdef __cplusplus
extern "C" {
#endif
extern void of_salsa20_8_core(uint32_t buffer[_Nonnull 16]);
extern void of_scrypt_block_mix(uint32_t *output, const uint32_t *input,
    size_t blockSize);
extern void of_scrypt_romix(uint32_t *buffer, size_t blockSize,
    size_t costFactor, uint32_t *tmp);

/*!
/**
 * @brief Derives a key from a password and a salt using scrypt.
 *
 * @param param The parameters to use
 */
extern void of_scrypt(of_scrypt_parameters_t param);
#ifdef __cplusplus
}
#endif

OF_ASSUME_NONNULL_END