mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-02-28 06:27:06 +08:00
[picolibc] fix the errno declaration conflict
/home/runner/work/rt-thread/rt-thread/components/libc/compilers/picolibc/syscall.c:13:5: error: conflicting types for 'pico_get_errno' int pico_get_errno(void) ^ /opt/LLVMEmbeddedToolchainForArm-16.0.0-Linux-x86_64/bin/../lib/clang-runtimes/arm-none-eabi/armv7em_hard_fpv4_sp_d16/include/sys/errno.h:59:6: note: previous declaration is here int *__PICOLIBC_ERRNO_FUNCTION(void);
This commit is contained in:
parent
8e6f9cf1be
commit
7732f8618b
@ -9,13 +9,31 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <rtthread.h>
|
#include <rtthread.h>
|
||||||
|
#include <sys/types.h>
|
||||||
|
|
||||||
int pico_get_errno(void)
|
/* global errno */
|
||||||
|
static volatile int __pico_errno;
|
||||||
|
|
||||||
|
int *pico_get_errno(void)
|
||||||
{
|
{
|
||||||
return rt_get_errno();
|
rt_thread_t tid = RT_NULL;
|
||||||
|
|
||||||
|
if (rt_interrupt_get_nest() != 0)
|
||||||
|
{
|
||||||
|
/* it's in interrupt context */
|
||||||
|
return &__pico_errno;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef RT_USING_HEAP /* Memory routine */
|
tid = rt_thread_self();
|
||||||
|
if (tid == RT_NULL)
|
||||||
|
{
|
||||||
|
return &__pico_errno;
|
||||||
|
}
|
||||||
|
|
||||||
|
return &tid->error;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef RT_USING_HEAP
|
||||||
void *malloc(size_t n)
|
void *malloc(size_t n)
|
||||||
{
|
{
|
||||||
return rt_malloc(n);
|
return rt_malloc(n);
|
||||||
@ -39,4 +57,4 @@ void free(void *rmem)
|
|||||||
rt_free(rmem);
|
rt_free(rmem);
|
||||||
}
|
}
|
||||||
RTM_EXPORT(free);
|
RTM_EXPORT(free);
|
||||||
#endif
|
#endif /* RT_USING_HEAP */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user