Nathan Yonkee / Mbed 2 deprecated Nucleo_sinewave_output_copy

Dependencies:   mbed

Embed: (wiki syntax)

« Back to documentation index

md.h File Reference

md.h File Reference

Generic message digest wrapper. More...

Go to the source code of this file.

Data Structures

struct  mbedtls_md_context_t
 Generic message digest context. More...

Typedefs

typedef struct mbedtls_md_info_t mbedtls_md_info_t
 Opaque struct defined in md_internal.h.

Functions

const int * mbedtls_md_list (void)
 Returns the list of digests supported by the generic digest module.
const mbedtls_md_info_tmbedtls_md_info_from_string (const char *md_name)
 Returns the message digest information associated with the given digest name.
const mbedtls_md_info_tmbedtls_md_info_from_type (mbedtls_md_type_t md_type)
 Returns the message digest information associated with the given digest type.
void mbedtls_md_init (mbedtls_md_context_t *ctx)
 Initialize a md_context (as NONE) This should always be called first.
void mbedtls_md_free (mbedtls_md_context_t *ctx)
 Free and clear the internal structures of ctx.
int mbedtls_md_init_ctx (mbedtls_md_context_t *ctx, const mbedtls_md_info_t *md_info) MBEDTLS_DEPRECATED
 Select MD to use and allocate internal structures.
int mbedtls_md_setup (mbedtls_md_context_t *ctx, const mbedtls_md_info_t *md_info, int hmac)
 Select MD to use and allocate internal structures.
int mbedtls_md_clone (mbedtls_md_context_t *dst, const mbedtls_md_context_t *src)
 Clone the state of an MD context.
unsigned char mbedtls_md_get_size (const mbedtls_md_info_t *md_info)
 Returns the size of the message digest output.
mbedtls_md_type_t mbedtls_md_get_type (const mbedtls_md_info_t *md_info)
 Returns the type of the message digest output.
const char * mbedtls_md_get_name (const mbedtls_md_info_t *md_info)
 Returns the name of the message digest output.
int mbedtls_md_starts (mbedtls_md_context_t *ctx)
 Prepare the context to digest a new message.
int mbedtls_md_update (mbedtls_md_context_t *ctx, const unsigned char *input, size_t ilen)
 Generic message digest process buffer Called between mbedtls_md_starts() and mbedtls_md_finish().
int mbedtls_md_finish (mbedtls_md_context_t *ctx, unsigned char *output)
 Generic message digest final digest Called after mbedtls_md_update().
int mbedtls_md (const mbedtls_md_info_t *md_info, const unsigned char *input, size_t ilen, unsigned char *output)
 Output = message_digest( input buffer )
int mbedtls_md_file (const mbedtls_md_info_t *md_info, const char *path, unsigned char *output)
 Output = message_digest( file contents )
int mbedtls_md_hmac_starts (mbedtls_md_context_t *ctx, const unsigned char *key, size_t keylen)
 Set HMAC key and prepare to authenticate a new message.
int mbedtls_md_hmac_update (mbedtls_md_context_t *ctx, const unsigned char *input, size_t ilen)
 Generic HMAC process buffer.
int mbedtls_md_hmac_finish (mbedtls_md_context_t *ctx, unsigned char *output)
 Output HMAC.
int mbedtls_md_hmac_reset (mbedtls_md_context_t *ctx)
 Prepare to authenticate a new message with the same key.
int mbedtls_md_hmac (const mbedtls_md_info_t *md_info, const unsigned char *key, size_t keylen, const unsigned char *input, size_t ilen, unsigned char *output)
 Output = Generic_HMAC( hmac key, input buffer )

Detailed Description

Generic message digest wrapper.

Author:
Adriaan de Jong <dejong@fox-it.com>

Copyright (C) 2006-2015, ARM Limited, All Rights Reserved SPDX-License-Identifier: Apache-2.0

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

This file is part of mbed TLS (https://tls.mbed.org)

Definition in file md.h.


Typedef Documentation

Opaque struct defined in md_internal.h.

Definition at line 61 of file md.h.


Function Documentation

int mbedtls_md ( const mbedtls_md_info_t md_info,
const unsigned char *  input,
size_t  ilen,
unsigned char *  output 
)

Output = message_digest( input buffer )

Parameters:
md_infomessage digest info
inputbuffer holding the data
ilenlength of the input data
outputGeneric message digest checksum result
Returns:
0 on success, MBEDTLS_ERR_MD_BAD_INPUT_DATA if parameter verification fails.

Definition at line 278 of file md.c.

int mbedtls_md_clone ( mbedtls_md_context_t dst,
const mbedtls_md_context_t src 
)

Clone the state of an MD context.

Note:
The two contexts must have been setup to the same type (cloning from SHA-256 to SHA-512 make no sense).
Warning:
Only clones the MD state, not the HMAC state! (for now)
Parameters:
dstThe destination context
srcThe context to be cloned
Returns:
0 on success, MBEDTLS_ERR_MD_BAD_INPUT_DATA on parameter failure.

Definition at line 203 of file md.c.

int mbedtls_md_file ( const mbedtls_md_info_t md_info,
const char *  path,
unsigned char *  output 
)

Output = message_digest( file contents )

Parameters:
md_infomessage digest info
pathinput file name
outputgeneric message digest checksum result
Returns:
0 if successful, MBEDTLS_ERR_MD_FILE_IO_ERROR if file input failed, MBEDTLS_ERR_MD_BAD_INPUT_DATA if md_info was NULL.

Definition at line 290 of file md.c.

int mbedtls_md_finish ( mbedtls_md_context_t ctx,
unsigned char *  output 
)

Generic message digest final digest Called after mbedtls_md_update().

Usually followed by mbedtls_md_free() or mbedtls_md_starts().

Parameters:
ctxGeneric message digest context
outputGeneric message digest checksum result
Returns:
0 on success, MBEDTLS_ERR_MD_BAD_INPUT_DATA if parameter verification fails.

Definition at line 268 of file md.c.

void mbedtls_md_free ( mbedtls_md_context_t ctx )

Free and clear the internal structures of ctx.

Can be called at any time after mbedtls_md_init(). Mandatory once mbedtls_md_setup() has been called.

Definition at line 186 of file md.c.

const char* mbedtls_md_get_name ( const mbedtls_md_info_t md_info )

Returns the name of the message digest output.

Parameters:
md_infomessage digest info
Returns:
name of the message digest output.

Definition at line 463 of file md.c.

unsigned char mbedtls_md_get_size ( const mbedtls_md_info_t md_info )

Returns the size of the message digest output.

Parameters:
md_infomessage digest info
Returns:
size of the message digest output in bytes.

Definition at line 447 of file md.c.

mbedtls_md_type_t mbedtls_md_get_type ( const mbedtls_md_info_t md_info )

Returns the type of the message digest output.

Parameters:
md_infomessage digest info
Returns:
type of the message digest output.

Definition at line 455 of file md.c.

int mbedtls_md_hmac ( const mbedtls_md_info_t md_info,
const unsigned char *  key,
size_t  keylen,
const unsigned char *  input,
size_t  ilen,
unsigned char *  output 
)

Output = Generic_HMAC( hmac key, input buffer )

Parameters:
md_infomessage digest info
keyHMAC secret key
keylenlength of the HMAC key in bytes
inputbuffer holding the data
ilenlength of the input data
outputGeneric HMAC-result
Returns:
0 on success, MBEDTLS_ERR_MD_BAD_INPUT_DATA if parameter verification fails.

Definition at line 413 of file md.c.

int mbedtls_md_hmac_finish ( mbedtls_md_context_t ctx,
unsigned char *  output 
)

Output HMAC.

Called after mbedtls_md_hmac_update(). Usually followed by mbedtls_md_hmac_reset(), mbedtls_md_hmac_starts(), or mbedtls_md_free().

Parameters:
ctxHMAC context
outputGeneric HMAC checksum result
Returns:
0 on success, MBEDTLS_ERR_MD_BAD_INPUT_DATA if parameter verification fails.

Definition at line 379 of file md.c.

int mbedtls_md_hmac_reset ( mbedtls_md_context_t ctx )

Prepare to authenticate a new message with the same key.

Called after mbedtls_md_hmac_finish() and before mbedtls_md_hmac_update().

Parameters:
ctxHMAC context to be reset
Returns:
0 on success, MBEDTLS_ERR_MD_BAD_INPUT_DATA if parameter verification fails.

Definition at line 398 of file md.c.

int mbedtls_md_hmac_starts ( mbedtls_md_context_t ctx,
const unsigned char *  key,
size_t  keylen 
)

Set HMAC key and prepare to authenticate a new message.

Usually called after mbedtls_md_setup() or mbedtls_md_hmac_finish().

Parameters:
ctxHMAC context
keyHMAC secret key
keylenlength of the HMAC key in bytes
Returns:
0 on success, MBEDTLS_ERR_MD_BAD_INPUT_DATA if parameter verification fails.

Definition at line 330 of file md.c.

int mbedtls_md_hmac_update ( mbedtls_md_context_t ctx,
const unsigned char *  input,
size_t  ilen 
)

Generic HMAC process buffer.

Called between mbedtls_md_hmac_starts() or mbedtls_md_hmac_reset() and mbedtls_md_hmac_finish(). May be called repeatedly.

Parameters:
ctxHMAC context
inputbuffer holding the data
ilenlength of the input data
Returns:
0 on success, MBEDTLS_ERR_MD_BAD_INPUT_DATA if parameter verification fails.

Definition at line 369 of file md.c.

const mbedtls_md_info_t* mbedtls_md_info_from_string ( const char *  md_name )

Returns the message digest information associated with the given digest name.

Parameters:
md_nameName of the digest to search for.
Returns:
The message digest information associated with md_name or NULL if not found.

Definition at line 99 of file md.c.

const mbedtls_md_info_t* mbedtls_md_info_from_type ( mbedtls_md_type_t  md_type )

Returns the message digest information associated with the given digest type.

Parameters:
md_typetype of digest to search for.
Returns:
The message digest information associated with md_type or NULL if not found.

Definition at line 140 of file md.c.

void mbedtls_md_init ( mbedtls_md_context_t ctx )

Initialize a md_context (as NONE) This should always be called first.

Prepares the context for mbedtls_md_setup() or mbedtls_md_free().

Definition at line 181 of file md.c.

int mbedtls_md_init_ctx ( mbedtls_md_context_t ctx,
const mbedtls_md_info_t md_info 
)

Select MD to use and allocate internal structures.

Should be called after mbedtls_md_init() or mbedtls_md_free(). Makes it necessary to call mbedtls_md_free() later.

Parameters:
ctxContext to set up.
md_infoMessage digest to use.
Returns:
0 on success, MBEDTLS_ERR_MD_BAD_INPUT_DATA on parameter failure, MBEDTLS_ERR_MD_ALLOC_FAILED memory allocation failure.

Definition at line 219 of file md.c.

const int* mbedtls_md_list ( void   )

Returns the list of digests supported by the generic digest module.

Returns:
a statically allocated array of digests, the last entry is 0.

Definition at line 94 of file md.c.

int mbedtls_md_setup ( mbedtls_md_context_t ctx,
const mbedtls_md_info_t md_info,
int  hmac 
)

Select MD to use and allocate internal structures.

Should be called after mbedtls_md_init() or mbedtls_md_free(). Makes it necessary to call mbedtls_md_free() later.

Parameters:
ctxContext to set up.
md_infoMessage digest to use.
hmac0 to save some memory if HMAC will not be used, non-zero is HMAC is going to be used with this context.
Returns:
0 on success, MBEDTLS_ERR_MD_BAD_INPUT_DATA on parameter failure, MBEDTLS_ERR_MD_ALLOC_FAILED memory allocation failure.

Definition at line 225 of file md.c.

int mbedtls_md_starts ( mbedtls_md_context_t ctx )

Prepare the context to digest a new message.

Generally called after mbedtls_md_setup() or mbedtls_md_finish(). Followed by mbedtls_md_update().

Parameters:
ctxgeneric message digest context.
Returns:
0 on success, MBEDTLS_ERR_MD_BAD_INPUT_DATA if parameter verification fails.

Definition at line 248 of file md.c.

int mbedtls_md_update ( mbedtls_md_context_t ctx,
const unsigned char *  input,
size_t  ilen 
)

Generic message digest process buffer Called between mbedtls_md_starts() and mbedtls_md_finish().

May be called repeatedly.

Parameters:
ctxGeneric message digest context
inputbuffer holding the datal
ilenlength of the input data
Returns:
0 on success, MBEDTLS_ERR_MD_BAD_INPUT_DATA if parameter verification fails.

Definition at line 258 of file md.c.