CryptoUtils.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2019-2021, Texas Instruments Incorporated
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  *
9  * * Redistributions of source code must retain the above copyright
10  * notice, this list of conditions and the following disclaimer.
11  *
12  * * Redistributions in binary form must reproduce the above copyright
13  * notice, this list of conditions and the following disclaimer in the
14  * documentation and/or other materials provided with the distribution.
15  *
16  * * Neither the name of Texas Instruments Incorporated nor the names of
17  * its contributors may be used to endorse or promote products derived
18  * from this software without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
22  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
23  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
24  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
25  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
26  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
27  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
28  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
29  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
30  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31  */
39 #ifndef ti_drivers_cryptoutils_utils_CryptoUtils__include
40 #define ti_drivers_cryptoutils_utils_CryptoUtils__include
41 
42 #include <stdint.h>
43 #include <stdbool.h>
44 #include <string.h>
45 
46 
47 #ifdef __cplusplus
48 extern "C" {
49 #endif
50 
54 typedef enum {
58 
68 extern const uint8_t *CryptoUtils_limitZero;
69 
79 extern const uint8_t *CryptoUtils_limitOne;
80 
100 bool CryptoUtils_buffersMatch(const volatile void *volatile buffer0,
101  const volatile void *volatile buffer1,
102  size_t bufferByteLength);
103 
132 bool CryptoUtils_buffersMatchWordAligned(const volatile uint32_t *volatile buffer0,
133  const volatile uint32_t *volatile buffer1,
134  size_t bufferByteLength);
135 
145 bool CryptoUtils_isBufferAllZeros(const void *buffer, size_t bufferByteLength);
146 
157 void CryptoUtils_memset(void *dest, size_t destSize, uint8_t val, size_t count);
158 
167 void CryptoUtils_reverseBufferBytewise(void * buffer, size_t bufferByteLength);
168 
185 void CryptoUtils_copyPad(const void *source,
186  uint32_t *destination,
187  size_t sourceLength);
188 
205 void CryptoUtils_reverseCopyPad(const void *source,
206  uint32_t *destination,
207  size_t sourceLength);
208 
221 void CryptoUtils_reverseCopy(const void *source,
222  void *destination,
223  size_t sourceLength);
224 
260 bool CryptoUtils_isNumberInRange(const void *number,
261  size_t bitLength,
262  CryptoUtils_Endianess endianess,
263  const void *lowerLimit,
264  const void *upperLimit);
265 
266 #ifdef __cplusplus
267 }
268 #endif
269 
270 #endif /* ti_drivers_cryptoutils_utils_CryptoUtils__include */
void CryptoUtils_reverseBufferBytewise(void *buffer, size_t bufferByteLength)
Reverses the byte order in a buffer of a given length.
const uint8_t * CryptoUtils_limitOne
Limit value of 1.
const uint8_t * CryptoUtils_limitZero
Limit value of 0.
Definition: CryptoUtils.h:56
Definition: CryptoUtils.h:55
bool CryptoUtils_isNumberInRange(const void *number, size_t bitLength, CryptoUtils_Endianess endianess, const void *lowerLimit, const void *upperLimit)
Checks if number is within the range [lowerLimit, upperLimit)
void CryptoUtils_reverseCopy(const void *source, void *destination, size_t sourceLength)
Reverses and copies an array of bytes.
void CryptoUtils_memset(void *dest, size_t destSize, uint8_t val, size_t count)
Copies val into the first count bytes of the buffer pointed to by dest.
void CryptoUtils_reverseCopyPad(const void *source, uint32_t *destination, size_t sourceLength)
Reverses, copies, and pads an array of words.
bool CryptoUtils_buffersMatch(const volatile void *volatile buffer0, const volatile void *volatile buffer1, size_t bufferByteLength)
Compares two buffers for equality without branching.
bool CryptoUtils_isBufferAllZeros(const void *buffer, size_t bufferByteLength)
Check whether the provided buffer only contains 0x00 bytes.
void CryptoUtils_copyPad(const void *source, uint32_t *destination, size_t sourceLength)
Copies and pads an array of words.
CryptoUtils_Endianess
Indicates the endianess (byte order) of a multi-byte value.
Definition: CryptoUtils.h:54
bool CryptoUtils_buffersMatchWordAligned(const volatile uint32_t *volatile buffer0, const volatile uint32_t *volatile buffer1, size_t bufferByteLength)
Compares two buffers for equality word-by-word without branching.
© Copyright 1995-2022, Texas Instruments Incorporated. All rights reserved.
Trademarks | Privacy policy | Terms of use | Terms of sale