mirror of
https://github.com/apache/nuttx.git
synced 2026-05-27 19:36:35 +08:00
C library: Add ffs(). Add strings.h. Move strcasecmp, strncasecmp, bzero, bcmp, and bcopy to where they belong in strings.h.h, not string.h. bzero, bcmp, and bcopy are legacy functions; the contemporary counterparts should be used instead.
This commit is contained in:
+9
-2
@@ -42,6 +42,7 @@
|
|||||||
|
|
||||||
#include <nuttx/config.h>
|
#include <nuttx/config.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <strings.h>
|
||||||
|
|
||||||
//***************************************************************************
|
//***************************************************************************
|
||||||
// Namespace
|
// Namespace
|
||||||
@@ -51,6 +52,8 @@ namespace std
|
|||||||
{
|
{
|
||||||
using ::size_t;
|
using ::size_t;
|
||||||
|
|
||||||
|
// Declared in string.h
|
||||||
|
|
||||||
using ::strdup;
|
using ::strdup;
|
||||||
using ::strndup;
|
using ::strndup;
|
||||||
using ::strerror;
|
using ::strerror;
|
||||||
@@ -60,8 +63,6 @@ namespace std
|
|||||||
using ::strncat;
|
using ::strncat;
|
||||||
using ::strcmp;
|
using ::strcmp;
|
||||||
using ::strncmp;
|
using ::strncmp;
|
||||||
using ::strcasecmp;
|
|
||||||
using ::strncasecmp;
|
|
||||||
using ::strcoll;
|
using ::strcoll;
|
||||||
using ::stpcpy;
|
using ::stpcpy;
|
||||||
using ::strcpy;
|
using ::strcpy;
|
||||||
@@ -83,6 +84,12 @@ namespace std
|
|||||||
using ::memcpy;
|
using ::memcpy;
|
||||||
using ::memmove;
|
using ::memmove;
|
||||||
using ::memset;
|
using ::memset;
|
||||||
|
|
||||||
|
// Declared in legacy strings.h
|
||||||
|
|
||||||
|
using ::ffs;
|
||||||
|
using ::strcasecmp;
|
||||||
|
using ::strncasecmp;
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // __INCLUDE_CXX_CSTRING
|
#endif // __INCLUDE_CXX_CSTRING
|
||||||
|
|||||||
+1
-12
@@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* include/string.h
|
* include/string.h
|
||||||
*
|
*
|
||||||
* Copyright (C) 2007-2012, 2014, 2016 Gregory Nutt. All rights reserved.
|
* Copyright (C) 2007-2012, 2014, 2016-2017 Gregory Nutt. All rights reserved.
|
||||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
@@ -47,15 +47,6 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Pre-processor Definitions
|
* Pre-processor Definitions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
/* Compatibility definitions */
|
|
||||||
|
|
||||||
#ifndef CONFIG_LIBC_ARCH_BZERO
|
|
||||||
# define bzero(s,n) (void)memset(s,0,n)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define bcopy(b1,b2,len) (void)memmove(b2,b1,len)
|
|
||||||
|
|
||||||
#define rindex(s,c) strrchr(s,c)
|
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Public Function Prototypes
|
* Public Function Prototypes
|
||||||
@@ -79,8 +70,6 @@ FAR char *strcat(FAR char *, FAR const char *);
|
|||||||
FAR char *strncat(FAR char *, FAR const char *, size_t);
|
FAR char *strncat(FAR char *, FAR const char *, size_t);
|
||||||
int strcmp(FAR const char *, FAR const char *);
|
int strcmp(FAR const char *, FAR const char *);
|
||||||
int strncmp(FAR const char *, FAR const char *, size_t);
|
int strncmp(FAR const char *, FAR const char *, size_t);
|
||||||
int strcasecmp(FAR const char *, FAR const char *);
|
|
||||||
int strncasecmp(FAR const char *, FAR const char *, size_t);
|
|
||||||
int strcoll(FAR const char *, FAR const char *s2);
|
int strcoll(FAR const char *, FAR const char *s2);
|
||||||
FAR char *strcpy(char *dest, FAR const char *src);
|
FAR char *strcpy(char *dest, FAR const char *src);
|
||||||
FAR char *stpcpy(char *dest, FAR const char *src);
|
FAR char *stpcpy(char *dest, FAR const char *src);
|
||||||
|
|||||||
@@ -0,0 +1,83 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
* include/strings.h
|
||||||
|
*
|
||||||
|
* Copyright (C) 2017 Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in
|
||||||
|
* the documentation and/or other materials provided with the
|
||||||
|
* distribution.
|
||||||
|
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||||
|
* used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||||
|
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||||
|
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||||
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||||
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||||
|
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||||
|
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||||
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
* POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifndef __INCLUDE_STRINGS_H
|
||||||
|
#define __INCLUDE_STRINGS_H
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Included Files
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#include <nuttx/config.h>
|
||||||
|
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Pre-processor Definitions
|
||||||
|
****************************************************************************/
|
||||||
|
/* Compatibility definitions */
|
||||||
|
|
||||||
|
#define bcmp(b1,b2,len) memcmp(b1,b2,(size_t)len)
|
||||||
|
#define bcopy(b1,b2,len) (void)memmove(b2,b1,len)
|
||||||
|
|
||||||
|
#ifndef CONFIG_LIBC_ARCH_BZERO
|
||||||
|
# define bzero(s,n) (void)memset(s,0,n)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define index(s,c) strchr(s,c)
|
||||||
|
#define rindex(s,c) strrchr(s,c)
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Function Prototypes
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#undef EXTERN
|
||||||
|
#if defined(__cplusplus)
|
||||||
|
#define EXTERN extern "C"
|
||||||
|
extern "C"
|
||||||
|
{
|
||||||
|
#else
|
||||||
|
#define EXTERN extern
|
||||||
|
#endif
|
||||||
|
|
||||||
|
int ffs(int j);
|
||||||
|
int strcasecmp(FAR const char *, FAR const char *);
|
||||||
|
int strncasecmp(FAR const char *, FAR const char *, size_t);
|
||||||
|
|
||||||
|
#undef EXTERN
|
||||||
|
#if defined(__cplusplus)
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#endif /* __INCLUDE_STRINGS_H */
|
||||||
+1
-1
@@ -45,7 +45,7 @@ we have:
|
|||||||
semaphore - semaphore.h
|
semaphore - semaphore.h
|
||||||
stdio - stdio.h
|
stdio - stdio.h
|
||||||
stdlib - stdlib.h
|
stdlib - stdlib.h
|
||||||
string - string.h
|
string - string.h (and legacy strings.h)
|
||||||
time - time.h
|
time - time.h
|
||||||
unistd - unistd.h
|
unistd - unistd.h
|
||||||
wchar - wchar.h
|
wchar - wchar.h
|
||||||
|
|||||||
@@ -36,7 +36,7 @@
|
|||||||
# Add the stdlib C files to the build
|
# Add the stdlib C files to the build
|
||||||
|
|
||||||
CSRCS += lib_abs.c lib_abort.c lib_div.c lib_ldiv.c lib_lldiv.c
|
CSRCS += lib_abs.c lib_abort.c lib_div.c lib_ldiv.c lib_lldiv.c
|
||||||
CSRCS += lib_imaxabs.c lib_itoa.c lib_labs.c lib_llabs.c
|
CSRCS += lib_itoa.c lib_labs.c lib_llabs.c
|
||||||
CSRCS += lib_bsearch.c lib_rand.c lib_qsort.c lib_srand.c
|
CSRCS += lib_bsearch.c lib_rand.c lib_qsort.c lib_srand.c
|
||||||
CSRCS += lib_strtol.c lib_strtoll.c lib_strtoul.c lib_strtoull.c
|
CSRCS += lib_strtol.c lib_strtoll.c lib_strtoul.c lib_strtoull.c
|
||||||
CSRCS += lib_strtod.c lib_strtof.c lib_strtold.c lib_checkbase.c
|
CSRCS += lib_strtod.c lib_strtof.c lib_strtold.c lib_checkbase.c
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
############################################################################
|
############################################################################
|
||||||
# libc/string/Make.defs
|
# libc/string/Make.defs
|
||||||
#
|
#
|
||||||
# Copyright (C) 2011-2012, 2014, 2016 Gregory Nutt. All rights reserved.
|
# Copyright (C) 2011-2012, 2014, 2016-2017 Gregory Nutt. All rights reserved.
|
||||||
# Author: Gregory Nutt <gnutt@nuttx.org>
|
# Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
#
|
#
|
||||||
# Redistribution and use in source and binary forms, with or without
|
# Redistribution and use in source and binary forms, with or without
|
||||||
@@ -35,13 +35,14 @@
|
|||||||
|
|
||||||
# Add the string C files to the build
|
# Add the string C files to the build
|
||||||
|
|
||||||
CSRCS += lib_isbasedigit.c lib_memset.c lib_memchr.c lib_memccpy.c
|
CSRCS += lib_ffs.c lib_isbasedigit.c lib_memset.c lib_memchr.c
|
||||||
CSRCS += lib_memcmp.c lib_memmove.c lib_skipspace.c lib_stpcpy.c
|
CSRCS += lib_memccpy.c lib_memcmp.c lib_memmove.c lib_skipspace.c
|
||||||
CSRCS += lib_strcasecmp.c lib_strcat.c lib_strchr.c lib_strcpy.c
|
CSRCS += lib_stpcpy.c lib_strcasecmp.c lib_strcat.c lib_strchr.c
|
||||||
CSRCS += lib_strcmp.c lib_strcspn.c lib_strdup.c lib_strerror.c lib_strlen.c
|
CSRCS += lib_strcpy.c lib_strcmp.c lib_strcspn.c lib_strdup.c
|
||||||
CSRCS += lib_strnlen.c lib_strncasecmp.c lib_strncat.c lib_strncmp.c
|
CSRCS += lib_strerror.c lib_strlen.c lib_strnlen.c lib_strncasecmp.c
|
||||||
CSRCS += lib_strncpy.c lib_strndup.c lib_strcasestr.c lib_strpbrk.c
|
CSRCS += lib_strncat.c lib_strncmp.c lib_strncpy.c lib_strndup.c
|
||||||
CSRCS += lib_strrchr.c lib_strspn.c lib_strstr.c lib_strtok.c lib_strtokr.c
|
CSRCS += lib_strcasestr.c lib_strpbrk.c lib_strrchr.c lib_strspn.c
|
||||||
|
CSRCS += lib_strstr.c lib_strtok.c lib_strtokr.c
|
||||||
|
|
||||||
ifneq ($(CONFIG_LIBC_ARCH_MEMCPY),y)
|
ifneq ($(CONFIG_LIBC_ARCH_MEMCPY),y)
|
||||||
ifeq ($(CONFIG_MEMCPY_VIK),y)
|
ifeq ($(CONFIG_MEMCPY_VIK),y)
|
||||||
|
|||||||
@@ -0,0 +1,87 @@
|
|||||||
|
/****************************************************************************
|
||||||
|
* libc/string/lib_ffs.c
|
||||||
|
*
|
||||||
|
* Copyright (C) 2017 Gregory Nutt. All rights reserved.
|
||||||
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in
|
||||||
|
* the documentation and/or other materials provided with the
|
||||||
|
* distribution.
|
||||||
|
* 3. Neither the name NuttX nor the names of its contributors may be
|
||||||
|
* used to endorse or promote products derived from this software
|
||||||
|
* without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||||
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||||
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
|
||||||
|
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
|
||||||
|
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||||
|
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
|
||||||
|
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
|
||||||
|
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
|
||||||
|
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
|
||||||
|
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
* POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Included Files
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#include <strings.h>
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Pre-processor Definitions
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#define NBITS (8 * sizeof(unsigned int))
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Public Functions
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: ffs
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* The ffs() function will find the first bit set (beginning with the least
|
||||||
|
* significant bit) in i, and return the index of that bit. Bits are
|
||||||
|
* numbered starting at one (the least significant bit).
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* The ffs() function will return the index of the first bit set. If i is
|
||||||
|
* 0, then ffs() will return 0.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
int ffs(int j)
|
||||||
|
{
|
||||||
|
int ret = 0;
|
||||||
|
|
||||||
|
if (j != 0)
|
||||||
|
{
|
||||||
|
unsigned int value = (unsigned int)j;
|
||||||
|
int bitno;
|
||||||
|
|
||||||
|
for (bitno = 1; bitno <= NBITS; bitno++, value >>= 1)
|
||||||
|
{
|
||||||
|
if ((value & 1) != 0)
|
||||||
|
{
|
||||||
|
ret = bitno;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
@@ -1,4 +1,3 @@
|
|||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* libc/string/lib_memset.c
|
* libc/string/lib_memset.c
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -39,7 +39,7 @@
|
|||||||
|
|
||||||
#include <nuttx/config.h>
|
#include <nuttx/config.h>
|
||||||
|
|
||||||
#include <string.h>
|
#include <strings.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
|
|||||||
@@ -40,7 +40,7 @@
|
|||||||
#include <nuttx/config.h>
|
#include <nuttx/config.h>
|
||||||
|
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <string.h>
|
#include <strings.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
|
|||||||
@@ -442,7 +442,7 @@ void os_start(void)
|
|||||||
* that has pid == 0 and sched_priority == 0.
|
* that has pid == 0 and sched_priority == 0.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
bzero((void *)&g_idletcb[cpu], sizeof(struct task_tcb_s));
|
memset((void *)&g_idletcb[cpu], 0, sizeof(struct task_tcb_s));
|
||||||
g_idletcb[cpu].cmn.pid = g_lastpid;
|
g_idletcb[cpu].cmn.pid = g_lastpid;
|
||||||
g_idletcb[cpu].cmn.task_state = TSTATE_TASK_RUNNING;
|
g_idletcb[cpu].cmn.task_state = TSTATE_TASK_RUNNING;
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user