Skip to content

Commit

Permalink
C library: Add ffs(). Add strings.h. Move strcasecmp, strncasecmp, bz…
Browse files Browse the repository at this point in the history
…ero, 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.
  • Loading branch information
gregory-nutt committed Feb 16, 2017
1 parent 6d1f3da commit 4f5879f
Show file tree
Hide file tree
Showing 11 changed files with 194 additions and 28 deletions.
11 changes: 9 additions & 2 deletions include/cxx/cstring
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@

#include <nuttx/config.h>
#include <string.h>
#include <strings.h>

//***************************************************************************
// Namespace
Expand All @@ -51,6 +52,8 @@ namespace std
{
using ::size_t;

// Declared in string.h

using ::strdup;
using ::strndup;
using ::strerror;
Expand All @@ -60,8 +63,6 @@ namespace std
using ::strncat;
using ::strcmp;
using ::strncmp;
using ::strcasecmp;
using ::strncasecmp;
using ::strcoll;
using ::stpcpy;
using ::strcpy;
Expand All @@ -83,6 +84,12 @@ namespace std
using ::memcpy;
using ::memmove;
using ::memset;

// Declared in legacy strings.h

using ::ffs;
using ::strcasecmp;
using ::strncasecmp;
}

#endif // __INCLUDE_CXX_CSTRING
13 changes: 1 addition & 12 deletions include/string.h
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
/****************************************************************************
* 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>
*
* Redistribution and use in source and binary forms, with or without
Expand Down Expand Up @@ -47,15 +47,6 @@
/****************************************************************************
* 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
Expand All @@ -79,8 +70,6 @@ FAR char *strcat(FAR char *, FAR const char *);
FAR char *strncat(FAR char *, FAR const char *, size_t);
int strcmp(FAR const char *, FAR const char *);
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);
FAR char *strcpy(char *dest, FAR const char *src);
FAR char *stpcpy(char *dest, FAR const char *src);
Expand Down
83 changes: 83 additions & 0 deletions include/strings.h
Original file line number Diff line number Diff line change
@@ -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 */
2 changes: 1 addition & 1 deletion libc/README.txt
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ we have:
semaphore - semaphore.h
stdio - stdio.h
stdlib - stdlib.h
string - string.h
string - string.h (and legacy strings.h)
time - time.h
unistd - unistd.h
wchar - wchar.h
Expand Down
2 changes: 1 addition & 1 deletion libc/stdlib/Make.defs
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@
# 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_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_strtol.c lib_strtoll.c lib_strtoul.c lib_strtoull.c
CSRCS += lib_strtod.c lib_strtof.c lib_strtold.c lib_checkbase.c
Expand Down
17 changes: 9 additions & 8 deletions libc/string/Make.defs
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
############################################################################
# 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>
#
# Redistribution and use in source and binary forms, with or without
Expand Down Expand Up @@ -35,13 +35,14 @@

# Add the string C files to the build

CSRCS += lib_isbasedigit.c lib_memset.c lib_memchr.c lib_memccpy.c
CSRCS += lib_memcmp.c lib_memmove.c lib_skipspace.c lib_stpcpy.c
CSRCS += lib_strcasecmp.c lib_strcat.c lib_strchr.c lib_strcpy.c
CSRCS += lib_strcmp.c lib_strcspn.c lib_strdup.c lib_strerror.c lib_strlen.c
CSRCS += lib_strnlen.c lib_strncasecmp.c lib_strncat.c lib_strncmp.c
CSRCS += lib_strncpy.c lib_strndup.c lib_strcasestr.c lib_strpbrk.c
CSRCS += lib_strrchr.c lib_strspn.c lib_strstr.c lib_strtok.c lib_strtokr.c
CSRCS += lib_ffs.c lib_isbasedigit.c lib_memset.c lib_memchr.c
CSRCS += lib_memccpy.c lib_memcmp.c lib_memmove.c lib_skipspace.c
CSRCS += lib_stpcpy.c lib_strcasecmp.c lib_strcat.c lib_strchr.c
CSRCS += lib_strcpy.c lib_strcmp.c lib_strcspn.c lib_strdup.c
CSRCS += lib_strerror.c lib_strlen.c lib_strnlen.c lib_strncasecmp.c
CSRCS += lib_strncat.c lib_strncmp.c lib_strncpy.c lib_strndup.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)
ifeq ($(CONFIG_MEMCPY_VIK),y)
Expand Down
87 changes: 87 additions & 0 deletions libc/string/lib_ffs.c
Original file line number Diff line number Diff line change
@@ -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 change: 0 additions & 1 deletion libc/string/lib_memset.c
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@

/****************************************************************************
* libc/string/lib_memset.c
*
Expand Down
2 changes: 1 addition & 1 deletion libc/string/lib_strcasecmp.c
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@

#include <nuttx/config.h>

#include <string.h>
#include <strings.h>
#include <ctype.h>

/****************************************************************************
Expand Down
2 changes: 1 addition & 1 deletion libc/string/lib_strncasecmp.c
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@
#include <nuttx/config.h>

#include <sys/types.h>
#include <string.h>
#include <strings.h>
#include <ctype.h>

/****************************************************************************
Expand Down
2 changes: 1 addition & 1 deletion sched/init/os_start.c
Original file line number Diff line number Diff line change
Expand Up @@ -442,7 +442,7 @@ void os_start(void)
* 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.task_state = TSTATE_TASK_RUNNING;

Expand Down

0 comments on commit 4f5879f

Please sign in to comment.