mirror of
https://github.com/espressif/esp-idf.git
synced 2025-10-09 22:21:10 +00:00
change(esp_libc): rename newlib component to esp_libc
This commit is contained in:
64
components/esp_libc/priv_include/string/local.h
Normal file
64
components/esp_libc/priv_include/string/local.h
Normal file
@@ -0,0 +1,64 @@
|
||||
/*
|
||||
* SPDX-FileCopyrightText: 1994-2009 Red Hat, Inc.
|
||||
*
|
||||
* SPDX-License-Identifier: BSD-2-Clause-FreeBSD AND Apache-2.0
|
||||
*
|
||||
* SPDX-FileContributor: 2025 Espressif Systems (Shanghai) CO LTD
|
||||
*/
|
||||
#include <_ansi.h>
|
||||
#include <limits.h>
|
||||
/*
|
||||
Taken from glibc:
|
||||
Add the compiler optimization to inhibit loop transformation to library
|
||||
calls. This is used to avoid recursive calls in memset and memmove
|
||||
default implementations.
|
||||
*/
|
||||
# define __inhibit_loop_to_libcall \
|
||||
__attribute__ ((__optimize__ ("-fno-tree-loop-distribute-patterns")))
|
||||
|
||||
/* Nonzero if X is not aligned on a "long" boundary.
|
||||
* This macro is used to skip a few bytes to find an aligned pointer.
|
||||
* It's better to keep it as is even if _HAVE_HW_MISALIGNED_ACCESS is enabled,
|
||||
* to avoid small performance penalties (if they are not zero). */
|
||||
#define UNALIGNED_X(X) ((long)X & (sizeof (long) - 1))
|
||||
|
||||
#ifndef _HAVE_HW_MISALIGNED_ACCESS
|
||||
#define _HAVE_HW_MISALIGNED_ACCESS (__riscv_misaligned_fast || __riscv_misaligned_slow)
|
||||
#endif
|
||||
|
||||
#if _HAVE_HW_MISALIGNED_ACCESS
|
||||
/* Hardware performs unaligned operations with little
|
||||
* to no penalty compared to byte-to-byte copy. */
|
||||
#define UNALIGNED_X_Y(X, Y) (0)
|
||||
#else /* _HAVE_HW_MISALIGNED_ACCESS */
|
||||
/* Nonzero if either X or Y is not aligned on a "long" boundary. */
|
||||
#define UNALIGNED_X_Y(X, Y) \
|
||||
(((long)X & (sizeof (long) - 1)) | ((long)Y & (sizeof (long) - 1)))
|
||||
#endif /* _HAVE_HW_MISALIGNED_ACCESS */
|
||||
|
||||
/* How many bytes are copied each iteration of the word copy loop. */
|
||||
#define LITTLE_BLOCK_SIZE (sizeof (long))
|
||||
|
||||
/* How many bytes are copied each iteration of the 4X unrolled loop. */
|
||||
#define BIG_BLOCK_SIZE (sizeof (long) << 2)
|
||||
|
||||
/* Threshold for punting to the little block byte copier. */
|
||||
#define TOO_SMALL_LITTLE_BLOCK(LEN) ((LEN) < LITTLE_BLOCK_SIZE)
|
||||
|
||||
/* Threshold for punting to the big block byte copier. */
|
||||
#define TOO_SMALL_BIG_BLOCK(LEN) ((LEN) < BIG_BLOCK_SIZE)
|
||||
|
||||
/* Macros for detecting endchar. */
|
||||
#if LONG_MAX == 2147483647L
|
||||
#define DETECT_NULL(X) (((X) - 0x01010101) & ~(X) & 0x80808080)
|
||||
#else
|
||||
#if LONG_MAX == 9223372036854775807L
|
||||
/* Nonzero if X (a long int) contains a NULL byte. */
|
||||
#define DETECT_NULL(X) (((X) - 0x0101010101010101) & ~(X) & 0x8080808080808080)
|
||||
#else
|
||||
#error long int is not a 32bit or 64bit type.
|
||||
#endif
|
||||
#endif
|
||||
|
||||
/* Returns nonzero if (long)X contains the byte used to fill (long)MASK. */
|
||||
#define DETECT_CHAR(X, MASK) (DETECT_NULL(X ^ MASK))
|
Reference in New Issue
Block a user