2022-06-19 09:56:24 -04:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2006-2022, RT-Thread Development Team
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*
|
|
|
|
* Change Logs:
|
|
|
|
* Date Author Notes
|
|
|
|
* 2021-02-15 Meco Man first version
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <rtthread.h>
|
2023-12-30 21:52:52 +08:00
|
|
|
#include <posix/stdlib.h>
|
2022-06-19 09:56:24 -04:00
|
|
|
|
|
|
|
#define DBG_TAG "stdlib"
|
|
|
|
#define DBG_LVL DBG_INFO
|
|
|
|
#include <rtdbg.h>
|
|
|
|
|
2023-11-01 17:31:57 +08:00
|
|
|
/**
|
|
|
|
* @brief This function is called when a thread exits. It can detach the thread and perform cleanup.
|
|
|
|
*
|
|
|
|
* @param status is the exit status of the thread.
|
|
|
|
*/
|
2022-06-19 09:56:24 -04:00
|
|
|
void __rt_libc_exit(int status)
|
|
|
|
{
|
|
|
|
rt_thread_t self = rt_thread_self();
|
|
|
|
|
|
|
|
if (self != RT_NULL)
|
|
|
|
{
|
2023-04-04 21:06:27 +08:00
|
|
|
LOG_W("thread:%s exit:%d!", self->parent.name, status);
|
2022-06-19 09:56:24 -04:00
|
|
|
#ifdef RT_USING_PTHREADS
|
2023-11-01 17:31:57 +08:00
|
|
|
if (self->pthread_data != RT_NULL)
|
2022-08-08 11:16:17 +08:00
|
|
|
{
|
|
|
|
extern void pthread_exit(void *value);
|
|
|
|
pthread_exit((void *)status);
|
|
|
|
}
|
2022-08-08 05:21:29 -04:00
|
|
|
else
|
2022-06-19 09:56:24 -04:00
|
|
|
#endif
|
2022-08-08 05:21:29 -04:00
|
|
|
{
|
|
|
|
rt_thread_control(self, RT_THREAD_CTRL_CLOSE, RT_NULL);
|
|
|
|
}
|
2022-06-19 09:56:24 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef RT_USING_MSH
|
2023-11-01 17:31:57 +08:00
|
|
|
/**
|
|
|
|
* @brief Execute a command using the Micro-Shell (MSH) subsystem.
|
|
|
|
*
|
|
|
|
* @param command is the command string to execute.
|
|
|
|
*
|
|
|
|
* @return Returns 0 after executing the command.
|
|
|
|
*/
|
2022-06-19 09:56:24 -04:00
|
|
|
int system(const char *command)
|
|
|
|
{
|
|
|
|
extern int msh_exec(char *cmd, rt_size_t length);
|
|
|
|
|
|
|
|
if (command)
|
|
|
|
{
|
|
|
|
msh_exec((char *)command, rt_strlen(command));
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
RTM_EXPORT(system);
|
|
|
|
#endif /* RT_USING_MSH */
|
|
|
|
|
2023-11-01 17:31:57 +08:00
|
|
|
/**
|
|
|
|
* @brief Convert a long integer to a string representation with a specified radix.
|
|
|
|
*
|
|
|
|
* @param value is the long integer to convert.
|
|
|
|
* @param string is the destination string where the result will be stored.
|
|
|
|
* @param radix is the base of the number system to be used for conversion.
|
|
|
|
*
|
|
|
|
* @return Returns a pointer to the destination string.
|
|
|
|
*/
|
2022-06-19 09:56:24 -04:00
|
|
|
char *ltoa(long value, char *string, int radix)
|
|
|
|
{
|
|
|
|
char tmp[33];
|
|
|
|
char *tp = tmp;
|
|
|
|
long i;
|
|
|
|
unsigned long v;
|
|
|
|
int sign;
|
|
|
|
char *sp;
|
|
|
|
|
|
|
|
if (string == NULL)
|
|
|
|
{
|
2023-11-01 17:31:57 +08:00
|
|
|
return 0;
|
2022-06-19 09:56:24 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
if (radix > 36 || radix <= 1)
|
|
|
|
{
|
2023-11-01 17:31:57 +08:00
|
|
|
return 0;
|
2022-06-19 09:56:24 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
sign = (radix == 10 && value < 0);
|
|
|
|
if (sign)
|
|
|
|
{
|
|
|
|
v = -value;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
v = (unsigned long)value;
|
|
|
|
}
|
|
|
|
|
|
|
|
while (v || tp == tmp)
|
|
|
|
{
|
|
|
|
i = v % radix;
|
|
|
|
v = v / radix;
|
|
|
|
if (i < 10)
|
2023-11-01 17:31:57 +08:00
|
|
|
*tp++ = (char)(i + '0');
|
2022-06-19 09:56:24 -04:00
|
|
|
else
|
2022-09-20 22:31:11 +08:00
|
|
|
*tp++ = (char)(i + 'a' - 10);
|
2022-06-19 09:56:24 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
sp = string;
|
|
|
|
|
|
|
|
if (sign)
|
|
|
|
*sp++ = '-';
|
|
|
|
while (tp > tmp)
|
|
|
|
*sp++ = *--tp;
|
|
|
|
*sp = 0;
|
|
|
|
|
|
|
|
return string;
|
|
|
|
}
|
|
|
|
|
2023-11-01 17:31:57 +08:00
|
|
|
/**
|
|
|
|
* @brief Convert an integer to a string representation with a specified radix.
|
|
|
|
*
|
|
|
|
* @param value is the integer to convert.
|
|
|
|
* @param string is the destination string where the result will be stored.
|
|
|
|
* @param radix is the base of the number system to be used for conversion.
|
|
|
|
*
|
|
|
|
* @return Returns a pointer to the destination string.
|
|
|
|
*/
|
2022-06-19 09:56:24 -04:00
|
|
|
char *itoa(int value, char *string, int radix)
|
|
|
|
{
|
2023-11-01 17:31:57 +08:00
|
|
|
return ltoa(value, string, radix);
|
2022-06-19 09:56:24 -04:00
|
|
|
}
|
|
|
|
|
2023-11-01 17:31:57 +08:00
|
|
|
/**
|
|
|
|
* @brief Convert an unsigned long integer to a string representation with a specified radix.
|
|
|
|
*
|
|
|
|
* @param value is the unsigned long integer to convert.
|
|
|
|
* @param string is the destination string where the result will be stored.
|
|
|
|
* @param radix is the base of the number system to be used for conversion.
|
|
|
|
*
|
|
|
|
* @return Returns a pointer to the destination string.
|
|
|
|
*/
|
2022-06-19 09:56:24 -04:00
|
|
|
char *ultoa(unsigned long value, char *string, int radix)
|
|
|
|
{
|
|
|
|
char tmp[33];
|
|
|
|
char *tp = tmp;
|
|
|
|
long i;
|
|
|
|
unsigned long v = value;
|
|
|
|
char *sp;
|
|
|
|
|
|
|
|
if (string == NULL)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (radix > 36 || radix <= 1)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
while (v || tp == tmp)
|
|
|
|
{
|
|
|
|
i = v % radix;
|
|
|
|
v = v / radix;
|
|
|
|
if (i < 10)
|
2023-11-01 17:31:57 +08:00
|
|
|
*tp++ = (char)(i + '0');
|
2022-06-19 09:56:24 -04:00
|
|
|
else
|
2022-09-20 22:31:11 +08:00
|
|
|
*tp++ = (char)(i + 'a' - 10);
|
2022-06-19 09:56:24 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
sp = string;
|
|
|
|
|
|
|
|
while (tp > tmp)
|
|
|
|
*sp++ = *--tp;
|
|
|
|
*sp = 0;
|
|
|
|
|
|
|
|
return string;
|
|
|
|
}
|
|
|
|
|
2023-11-01 17:31:57 +08:00
|
|
|
/**
|
|
|
|
* @brief Convert an unsigned integer to a string representation with a specified radix.
|
|
|
|
*
|
|
|
|
* @param value is the unsigned integer to convert.
|
|
|
|
* @param string is the destination string where the result will be stored.
|
|
|
|
* @param radix is the base of the number system to be used for conversion.
|
|
|
|
*
|
|
|
|
* @return Returns a pointer to the destination string.
|
|
|
|
*/
|
2022-06-19 09:56:24 -04:00
|
|
|
char *utoa(unsigned value, char *string, int radix)
|
|
|
|
{
|
2023-11-01 17:31:57 +08:00
|
|
|
return ultoa(value, string, radix);
|
2022-06-19 09:56:24 -04:00
|
|
|
}
|