12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- /*############################################################################
- # Copyright 2017 Intel Corporation
- #
- # 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.
- ############################################################################*/
- /// Tiny portable implementations of standard library functions
- /*! \file */
- #ifndef EPID_MEMBER_TINY_STDLIB_TINY_STDLIB_H_
- #define EPID_MEMBER_TINY_STDLIB_TINY_STDLIB_H_
- #include <stddef.h>
- /// Fill block of memory
- /*!
- * Sets the first num bytes of the block of memory pointed by ptr
- * to the specified value (interpreted as an unsigned char)
- *
- * \param ptr Pointer to the block of memory to fill.
- * \param value Value to be set. The value is passed as an int,
- * but the function fills the block of memory using the
- * unsigned char conversion of this value.
- * \param num Number of bytes to be set to the value. size_t is
- * an unsigned integral type.
- * \result ptr is returned.
- */
- void* memset(void* ptr, int value, size_t num);
- /// Compare two blocks of memory
- /*!
- * Compares the first num bytes of the block of memory pointed by
- * ptr1 to the first num bytes pointed by ptr2, returning zero if
- * they all match or a value different from zero representing which
- * is greater if they do not.
- *
- * Notice that, unlike strcmp, the function does not stop comparing
- * after finding a null character.
- *
- * \param ptr1 Pointer to block of memory.
- * \param ptr2 Pointer to block of memory.
- * \param num Number of bytes to compare.
- * \result an integral value indicating the relationship between the
- * content of the memory blocks:
- * \retval <0 the first byte that does not match in both memory
- * blocks has a lower value in ptr1 than in ptr2 (if
- * evaluated as unsigned char values)
- * \retval 0 the contents of both memory blocks are equal
- * \retval >0 the first byte that does not match in both memory blocks
- * has a greater value in ptr1 than in ptr2 (if evaluated
- * as unsigned char values)
- */
- int memcmp(const void* ptr1, const void* ptr2, size_t num);
- #endif // EPID_MEMBER_TINY_STDLIB_TINY_STDLIB_H_
|