Skip to content

Instantly share code, notes, and snippets.

@cederom
Created October 3, 2025 21:56
Show Gist options
  • Save cederom/3395770d28fe807d4189fe1f5d29ba2e to your computer and use it in GitHub Desktop.
Save cederom/3395770d28fe807d4189fe1f5d29ba2e to your computer and use it in GitHub Desktop.
****************************************
* NUTTX RTOS RELEASE BUILD TEST SCRIPT *
****************************************
NX BRANCH : nuttx-12.11.0-RC1
NX RTOS LOC : /tmp/nuttx/nuttx.git
NX APPS LOC : /tmp/nuttx/nuttx-apps.git
TARGET : ESP32C3
BUILD HOST : FreeBSD hexagon 14.3-RELEASE-p3 FreeBSD 14.3-RELEASE-p3 GENERIC amd64
MFLAGS : -j24 CROSSDEV=riscv32-esp-elf-
LOGFILE : log/nuttx-12.11.0-RC1-1759525556-ESP32C3.log
TIMESTAMP : 1759525556
=>
=> GIT REPO CLONE CHECK
=>
=>
=> INITIAL CLEAN AND SETUP
=>
++ set -e
++ cd /tmp/nuttx/nuttx.git
++ set +e
++ gmake clean distclean -j24 CROSSDEV=riscv32-esp-elf-
NuttX has not been configured!
NuttX has not been configured!
To configure the project:
To configure the project:
tools/configure.sh <config>
tools/configure.sh <config>
For a list of available configurations:
For a list of available configurations:
tools/configure.sh -L
tools/configure.sh -L
++ rm -f .config
++ set -e
++ git checkout master
Previous HEAD position was a00ac581c5 arch/xtensa/espressif: fix Wi-Fi netpkt copy error
Switched to branch 'master'
Your branch is up to date with 'origin/master'.
++ git fetch origin
++ git pull origin
Already up to date.
++ git checkout nuttx-12.11.0-RC1
Note: switching to 'nuttx-12.11.0-RC1'.
You are in 'detached HEAD' state. You can look around, make experimental
changes and commit them, and you can discard any commits you make in this
state without impacting any branches by switching back to a branch.
If you want to create a new branch to retain commits you create, you may
do so (now or later) by using -c with the switch command. Example:
git switch -c <new-branch-name>
Or undo this operation with:
git switch -
Turn off this advice by setting config variable advice.detachedHead to false
HEAD is now at a00ac581c5 arch/xtensa/espressif: fix Wi-Fi netpkt copy error
++ git reset --hard
HEAD is now at a00ac581c5 arch/xtensa/espressif: fix Wi-Fi netpkt copy error
++ cd /tmp/nuttx/nuttx-apps.git
++ git checkout master
Previous HEAD position was 61e82925d examples/i2schar: Implement loopback mode check
Switched to branch 'master'
Your branch is up to date with 'origin/master'.
++ git fetch origin
++ git pull origin
Already up to date.
++ git checkout nuttx-12.11.0-RC1
Note: switching to 'nuttx-12.11.0-RC1'.
You are in 'detached HEAD' state. You can look around, make experimental
changes and commit them, and you can discard any commits you make in this
state without impacting any branches by switching back to a branch.
If you want to create a new branch to retain commits you create, you may
do so (now or later) by using -c with the switch command. Example:
git switch -c <new-branch-name>
Or undo this operation with:
git switch -
Turn off this advice by setting config variable advice.detachedHead to false
HEAD is now at 61e82925d examples/i2schar: Implement loopback mode check
++ git reset --hard
HEAD is now at 61e82925d examples/i2schar: Implement loopback mode check
++ cd /tmp/nuttx/nuttx.git
+ set +x
=>
=> BUILDING ESP32C3
=>
==> LOGFILE: log/nuttx-12.11.0-RC1-1759525556-ESP32C3.log.
Press Return when ready.
+ riscv32-esp-elf-gcc --version
riscv32-esp-elf-gcc (crosstool-NG esp-2021r2-patch5) 8.4.0
Copyright (C) 2018 Free Software Foundation, Inc.
This is free software; see the source for copying conditions. There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+ for CFG in $CONFIGS
+ set +x
===>
===> ESP32C3: esp32c3-devkit:ostest
===>
+ /usr/bin/time -h gmake clean distclean -j24 CROSSDEV=riscv32-esp-elf-
NuttX has not been configured!
NuttX has not been configured!
To configure the project:
tools/configure.sh <config>
To configure the project:
For a list of available configurations:
tools/configure.sh <config>
tools/configure.sh -L
For a list of available configurations:
tools/configure.sh -L
0,00s real 0,00s user 0,00s sys
+ /usr/bin/time -h ./tools/configure.sh -B esp32c3-devkit:ostest
Copy files
Select CONFIG_HOST_BSD=y
Refreshing...
CP: arch/dummy/Kconfig to /tmp/nuttx/nuttx.git/arch/dummy/dummy_kconfig
CP: boards/dummy/Kconfig to /tmp/nuttx/nuttx.git/boards/dummy/dummy_kconfig
LN: platform/board to /tmp/nuttx/nuttx-apps.git/platform/dummy
LN: include/arch to arch/risc-v/include
LN: include/arch/board to /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/include
LN: drivers/platform to /tmp/nuttx/nuttx.git/drivers/dummy
LN: include/arch/chip to /tmp/nuttx/nuttx.git/arch/risc-v/include/esp32c3-legacy
LN: arch/risc-v/src/chip to /tmp/nuttx/nuttx.git/arch/risc-v/src/esp32c3-legacy
LN: arch/risc-v/src/board to /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common
LN: arch/risc-v/src/board/board to /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/src
mkkconfig in /tmp/nuttx/nuttx-apps.git/audioutils
mkkconfig in /tmp/nuttx/nuttx-apps.git/benchmarks
mkkconfig in /tmp/nuttx/nuttx-apps.git/boot
mkkconfig in /tmp/nuttx/nuttx-apps.git/canutils
mkkconfig in /tmp/nuttx/nuttx-apps.git/crypto
mkkconfig in /tmp/nuttx/nuttx-apps.git/database
mkkconfig in /tmp/nuttx/nuttx-apps.git/examples/mcuboot
mkkconfig in /tmp/nuttx/nuttx-apps.git/examples/module
mkkconfig in /tmp/nuttx/nuttx-apps.git/examples/rust
mkkconfig in /tmp/nuttx/nuttx-apps.git/examples/sotest
mkkconfig in /tmp/nuttx/nuttx-apps.git/examples
mkkconfig in /tmp/nuttx/nuttx-apps.git/fsutils
mkkconfig in /tmp/nuttx/nuttx-apps.git/games
mkkconfig in /tmp/nuttx/nuttx-apps.git/graphics
mkkconfig in /tmp/nuttx/nuttx-apps.git/industry
mkkconfig in /tmp/nuttx/nuttx-apps.git/inertial
mkkconfig in /tmp/nuttx/nuttx-apps.git/interpreters/luamodules
mkkconfig in /tmp/nuttx/nuttx-apps.git/interpreters
mkkconfig in /tmp/nuttx/nuttx-apps.git/logging
mkkconfig in /tmp/nuttx/nuttx-apps.git/lte
mkkconfig in /tmp/nuttx/nuttx-apps.git/math
mkkconfig in /tmp/nuttx/nuttx-apps.git/mlearning
mkkconfig in /tmp/nuttx/nuttx-apps.git/netutils
mkkconfig in /tmp/nuttx/nuttx-apps.git/sdr
mkkconfig in /tmp/nuttx/nuttx-apps.git/system
mkkconfig in /tmp/nuttx/nuttx-apps.git/tee
mkkconfig in /tmp/nuttx/nuttx-apps.git/testing/arch
mkkconfig in /tmp/nuttx/nuttx-apps.git/testing/cxx
mkkconfig in /tmp/nuttx/nuttx-apps.git/testing/drivers
mkkconfig in /tmp/nuttx/nuttx-apps.git/testing/fs
mkkconfig in /tmp/nuttx/nuttx-apps.git/testing/libc
mkkconfig in /tmp/nuttx/nuttx-apps.git/testing/mm
mkkconfig in /tmp/nuttx/nuttx-apps.git/testing/sched
mkkconfig in /tmp/nuttx/nuttx-apps.git/testing
mkkconfig in /tmp/nuttx/nuttx-apps.git/videoutils
mkkconfig in /tmp/nuttx/nuttx-apps.git/wireless/bluetooth
mkkconfig in /tmp/nuttx/nuttx-apps.git/wireless/ieee802154
mkkconfig in /tmp/nuttx/nuttx-apps.git/wireless
mkkconfig in /tmp/nuttx/nuttx-apps.git
#
# configuration written to .config
#
2,00s real 1,04s user 1,17s sys
+ /usr/bin/time -h gmake -j24 CROSSDEV=riscv32-esp-elf-
Create version.h
LN: platform/board to /tmp/nuttx/nuttx-apps.git/platform/dummy
Register: nsh
Register: sh
Register: dd
Register: ostest

CC: clock/clock.c 
CC: clock/clock_initialize.c 
CC: clock/clock_gettime.c 
CC: clock/clock_systime_ticks.c 
CC: clock/clock_perf.c 
CC: clock/clock_settime.c 
CC: clock/clock_systime_timespec.c 
CC: clock/clock_realtime2absticks.c 
CC: environ/env_getenvironptr.c 
CC: environ/env_dup.c 
CC: environ/env_release.c 
CC: environ/env_findvar.c 
CC: environ/env_removevar.c 
CC: environ/env_clearenv.c 
CC: environ/env_getenv.c 
CC: environ/env_putenv.c 
CC: environ/env_setenv.c 
CC: environ/env_unsetenv.c 
CC: environ/env_foreach.c 
CC: group/group_create.c 
CC: group/group_join.c 
CC: group/group_leave.c 
CC: group/group_setupidlefiles.c 






CC: group/group_setuptaskfiles.c 



CC: group/group_foreachchild.c 
CC: group/group_killchildren.c 
CC: group/group_signal.c 

CC: group/group_waiter.c 


CC: init/nx_start.c 

CC: init/nx_bringup.c 

CC: instrument/instrument.c 
CC: irq/irq_initialize.c 
CC: irq/irq_attach.c 

CC: irq/irq_dispatch.c 
CC: irq/irq_unexpectedisr.c 

CC: irq/irq_attach_thread.c 

CC: irq/irq_attach_wqueue.c 
CC: misc/assert.c 
CC: misc/reboot_notifier.c 
CC: misc/panic_notifier.c 


CC: mqueue/mq_initialize.c 

CC: mqueue/mq_waitirq.c 


CC: mqueue/mq_recover.c 
CC: mqueue/mq_send.c 
CC: mqueue/mq_sndinternal.c 

CC: mqueue/mq_receive.c 


CC: mqueue/mq_rcvinternal.c 
CC: mqueue/mq_getattr.c 




CC: mqueue/mq_msgfree.c 

CC: mqueue/mq_msgqalloc.c 

CC: mqueue/mq_msgqfree.c 
CC: mqueue/mq_setattr.c 


CC: mqueue/mq_notify.c 
CC: mqueue/msgctl.c 



CC: mqueue/msgget.c 

CC: mqueue/msginternal.c 
CC: mqueue/msgrcv.c 

CC: mqueue/msgsnd.c 
CC: pthread/pthread_create.c 
CC: pthread/pthread_exit.c 

CC: pthread/pthread_join.c 
CC: pthread/pthread_detach.c 



CC: pthread/pthread_getschedparam.c 
CC: pthread/pthread_setschedparam.c 
CC: pthread/pthread_mutexinit.c 





CC: pthread/pthread_mutexdestroy.c 

CC: pthread/pthread_mutextimedlock.c 
CC: pthread/pthread_mutextrylock.c 
CC: pthread/pthread_mutexunlock.c 


CC: pthread/pthread_condwait.c 
CC: pthread/pthread_condsignal.c 
CC: pthread/pthread_condbroadcast.c 

CC: pthread/pthread_condclockwait.c 
CC: pthread/pthread_sigmask.c 



CC: pthread/pthread_cancel.c 
CC: pthread/pthread_completejoin.c 

CC: pthread/pthread_findjoininfo.c 
CC: pthread/pthread_release.c 



CC: pthread/pthread_setschedprio.c 
CC: pthread/pthread_mutex.c 
CC: pthread/pthread_mutexconsistent.c 


CC: drivers_initialize.c 

CC: sched/sched_getfiles.c 
CC: loop/losetup.c 

CC: misc/dev_null.c 
CC: sched/sched_profil.c 


CC: sched/sched_addreadytorun.c 


CC: sched/sched_removereadytorun.c 
CC: sched/sched_addblocked.c 


CC: misc/dev_zero.c 


CC: misc/ramdisk.c 


CC: misc/mkrd.c 
CC: sched/sched_removeblocked.c 
CC: pipes/pipe.c 
CC: pipes/fifo.c 



CC: pipes/pipe_common.c 

CC: serial/serial.c 
CC: sched/sched_gettcb.c 
CC: serial/serial_io.c 


CC: syslog/vsyslog.c 
CC: syslog/syslog_channel.c 

CC: syslog/syslog_write.c 

CC: syslog/syslog_flush.c 


CC: sched/sched_verifytcb.c 
CC: sched/sched_releasetcb.c 


CC: sched/sched_setparam.c 


CC: sched/sched_setpriority.c 

CC: syslog/syslog_initialize.c 
CC: sched/sched_getparam.c 
CC: sched/sched_setscheduler.c 




CC: sched/sched_getscheduler.c 
CC: sched/sched_yield.c 

CC: sched/sched_rrgetinterval.c 
CC: sched/sched_foreach.c 
CC: sched/sched_lock.c 


CC: sched/sched_unlock.c 
CC: sched/sched_lockcount.c 


CC: sched/sched_idletask.c 

CC: sched/sched_self.c 
CC: sched/sched_get_stackinfo.c 

CC: sched/sched_get_tls.c 



CC: sched/sched_sysinfo.c 
CC: sched/sched_get_stateinfo.c 
CC: sched/sched_getcpu.c 

CC: sched/sched_reprioritizertr.c 


CC: sched/sched_mergepending.c 
CC: sched/sched_waitpid.c 



CC: sched/sched_roundrobin.c 



CC: sched/sched_resumescheduler.c 


CC: sched/sched_processtimer.c 
CC: semaphore/sem_destroy.c 

CC: semaphore/sem_wait.c 

CC: semaphore/sem_trywait.c 
CC: semaphore/sem_tickwait.c 
CC: semaphore/sem_timedwait.c 

CC: semaphore/sem_clockwait.c 
CC: semaphore/sem_timeout.c 
CC: semaphore/sem_post.c 



CC: semaphore/sem_recover.c 


CC: semaphore/sem_reset.c 
CC: semaphore/sem_waitirq.c 
CC: semaphore/sem_rw.c 

CC: signal/sig_initialize.c 
CC: signal/sig_action.c 


CC: signal/sig_procmask.c 


CC: signal/sig_pending.c 

CC: signal/sig_suspend.c 
CC: signal/sig_kill.c 
CC: signal/sig_tgkill.c 



CC: signal/sig_queue.c 


CC: signal/sig_waitinfo.c 

CC: signal/sig_timedwait.c 
CC: signal/sig_findaction.c 
CC: signal/sig_allocpendingsigaction.c 
CC: signal/sig_releasependingsigaction.c 



CC: signal/sig_unmaskpendingsignal.c 
CC: signal/sig_removependingsignal.c 
CC: signal/sig_releasependingsignal.c 




CC: signal/sig_lowest.c 
CC: signal/sig_notification.c 
CC: signal/sig_cleanup.c 
CC: dummy.c 



CC: boardctl.c 
CC: signal/sig_dispatch.c 
CC: signal/sig_deliver.c 



CC: signal/sig_pause.c 

CC: signal/sig_nanosleep.c 

CC: signal/sig_usleep.c 
CC: signal/sig_sleep.c 

CC: signal/sig_ppoll.c 

CC: signal/sig_pselect.c 



CC: task/task_argvstr.c 

CC: task/task_create.c 


CC: task/task_init.c 
CC: task/task_setup.c 
CC: task/task_activate.c 
CC: task/task_start.c 
CC: task/task_delete.c 



CC: task/task_exit.c 
CC: task/task_exithook.c 
CC: task/task_getgroup.c 


CC: task/task_getpid.c 
CC: task/task_prctl.c 

CC: task/task_recover.c 


CC: task/task_restart.c 



CC: task/task_spawnparms.c 


CC: task/task_cancelpt.c 
CC: task/task_terminate.c 

CC: task/task_gettid.c 
CC: task/exit.c 
CC: task/task_join.c 


CC: task/task_fork.c 

CC: task/task_spawn.c 
CC: timer/timer_initialize.c 

CC: timer/timer_create.c 




CC: timer/timer_delete.c 
CC: timer/timer_getoverrun.c 
CC: timer/timer_getitimer.c 
CC: timer/timer_gettime.c 



CC: timer/timer_setitimer.c 
CC: timer/timer_settime.c 
CC: timer/timer_release.c 


CC: tls/task_initinfo.c 
CC: tls/task_uninitinfo.c 

CC: tls/tls_initinfo.c 


CC: tls/tls_dupinfo.c 

CC: wdog/wd_initialize.c 



CC: wdog/wd_start.c 
CC: wdog/wd_cancel.c 

CC: wdog/wd_gettime.c 
CC: wdog/wd_recover.c 





















CC: assert/lib_assert.c 
CC: assert/lib_stackchk.c 
CC: builtin/lib_builtin_getname.c 
CC: builtin/lib_builtin_isavail.c 
CC: builtin/lib_builtin_forindex.c 
CC: ctype/lib_isalnum.c 
CC: ctype/lib_isalpha.c 
CC: ctype/lib_isascii.c 
CC: ctype/lib_isblank.c 
CC: ctype/lib_iscntrl.c 
CC: ctype/lib_isdigit.c 
CC: ctype/lib_isgraph.c 
CC: ctype/lib_islower.c 
CC: ctype/lib_isprint.c 
CC: ctype/lib_ispunct.c 
CC: ctype/lib_isspace.c 
CC: ctype/lib_isupper.c 
CC: ctype/lib_isxdigit.c 
CC: ctype/lib_tolower.c 
CC: ctype/lib_toupper.c 
CC: ctype/lib_ctype.c 
CC: dirent/lib_readdirr.c 






CC: dirent/lib_telldir.c 




CC: dirent/lib_alphasort.c 




CC: dirent/lib_scandir.c 

CC: dirent/lib_ftw.c 

CC: dirent/lib_nftw.c 


CC: dirent/lib_opendir.c 

CC: dirent/lib_fdopendir.c 

CC: dirent/lib_closedir.c 
CC: dirent/lib_readdir.c 
CC: dirent/lib_rewinddir.c 
CC: dirent/lib_seekdir.c 
CC: dirent/lib_dirfd.c 
CC: dirent/lib_versionsort.c 
CC: dlfcn/lib_dlfind_object.c 
CC: errno/lib_errno.c 

CC: fixedmath/lib_fixedmath.c 
CC: fixedmath/lib_b16sin.c 
CC: fixedmath/lib_b16cos.c 
CC: fixedmath/lib_b16atan2.c 
CC: fixedmath/lib_ubsqrt.c 
CC: grp/lib_getgrgid.c 
CC: grp/lib_getgrgidr.c 

CC: grp/lib_getgrnam.c 


CC: grp/lib_getgrnamr.c 
CC: grp/lib_initgroups.c 

CC: grp/lib_getgrbuf.c 







CC: grp/lib_getgrbufr.c 
CC: inttypes/lib_imaxabs.c 
CC: inttypes/lib_imaxdiv.c 
CC: inttypes/lib_strtoimax.c 

CC: inttypes/lib_strtoumax.c 
CC: libgen/lib_basename.c 

CC: libgen/lib_dirname.c 

CC: machine/arch_atomic.c 
CC: misc/lib_bitmap.c 

CC: misc/lib_circbuf.c 





CC: misc/lib_mknod.c 

CC: misc/lib_umask.c 


CC: misc/lib_utsname.c 

CC: misc/lib_getrandom.c 
CC: misc/lib_xorshift128.c 
CC: misc/lib_tea_encrypt.c 

CC: misc/lib_tea_decrypt.c 
CC: misc/lib_cxx_initialize.c 
CC: misc/lib_impure.c 
CC: mm_heap/mm_initialize.c 
CC: misc/lib_memfd.c 
CC: mm_heap/mm_lock.c 


CC: mm_heap/mm_malloc_size.c 

CC: mm_heap/mm_shrinkchunk.c 
CC: mm_heap/mm_brkaddr.c 

CC: mm_heap/mm_calloc.c 

CC: mm_heap/mm_extend.c 


CC: mm_heap/mm_free.c 



CC: misc/lib_mutex.c 

CC: mm_heap/mm_mallinfo.c 
CC: misc/lib_fchmodat.c 


CC: mm_heap/mm_malloc.c 


CC: mm_heap/mm_foreach.c 
CC: misc/lib_fstatat.c 
CC: misc/lib_getfullpath.c 
CC: mm_heap/mm_memalign.c 

CC: mm_heap/mm_realloc.c 

CC: misc/lib_openat.c 


CC: mm_heap/mm_zalloc.c 


CC: mm_heap/mm_heapmember.c 
CC: mm_heap/mm_memdump.c 

CC: misc/lib_mkdirat.c 

CC: misc/lib_utimensat.c 
CC: umm_heap/umm_globals.c 

CC: misc/lib_mallopt.c 

CC: misc/lib_idr.c 



CC: umm_heap/umm_initialize.c 
CC: misc/lib_getnprocs.c 



CC: misc/lib_tempbuffer.c 
CC: umm_heap/umm_addregion.c 

CC: umm_heap/umm_malloc_size.c 
CC: misc/lib_umul32.c 
CC: umm_heap/umm_brkaddr.c 

CC: umm_heap/umm_calloc.c 


CC: misc/lib_umul64.c 

CC: misc/lib_umul32x64.c 


CC: misc/lib_uadd32x64.c 

CC: misc/lib_uadd64.c 
CC: umm_heap/umm_extend.c 
CC: misc/lib_usub64x32.c 

CC: misc/lib_usub64.c 


CC: misc/lib_dumpbuffer.c 

CC: umm_heap/umm_free.c 

CC: misc/lib_dumpvbuffer.c 

CC: umm_heap/umm_mallinfo.c 

CC: umm_heap/umm_malloc.c 



CC: misc/lib_fnmatch.c 
CC: misc/lib_debug.c 
CC: misc/lib_crc64.c 


CC: umm_heap/umm_memalign.c 

CC: umm_heap/umm_realloc.c 
CC: misc/lib_crc32.c 


CC: misc/lib_crc16.c 
CC: umm_heap/umm_zalloc.c 
CC: misc/lib_crc16ccitt.c 



CC: umm_heap/umm_heapmember.c 
CC: umm_heap/umm_memdump.c 

CC: misc/lib_crc8.c 

CC: misc/lib_crc8ccitt.c 


CC: misc/lib_crc8table.c 
CC: mempool/mempool.c 
CC: misc/lib_crc8rohc.c 


CC: misc/lib_glob.c 
CC: misc/lib_backtrace.c 





CC: mempool/mempool_multiple.c 
CC: misc/lib_ftok.c 
CC: mempool/mempool_procfs.c 

CC: kasan/hook.c 

CC: map/mm_map.c 
CC: misc/lib_err.c 

CC: misc/lib_instrument.c 


CC: misc/lib_crc16ibm.c 



CC: misc/lib_crc16xmodem.c 

CC: net/lib_addrconfig.c 

CC: net/lib_base64.c 
CC: net/lib_htons.c 
CC: net/lib_htonl.c 


CC: net/lib_htonq.c 
CC: net/lib_inetaddr.c 
CC: net/lib_inetaton.c 
CC: net/lib_inetntoa.c 





CC: net/lib_inetntop.c 


CC: net/lib_inetpton.c 
CC: net/lib_inetnetwork.c 


CC: net/lib_etherntoa.c 
CC: net/lib_etheraton.c 
CC: obstack/lib_obstack_init.c 
CC: obstack/lib_obstack_alloc.c 
CC: obstack/lib_obstack_copy.c 



CC: obstack/lib_obstack_free.c 
CC: obstack/lib_obstack_make_room.c 
CC: obstack/lib_obstack_blank.c 
AS: chip/esp32c3_vectors.S 



CC: obstack/lib_obstack_grow.c 
AS: common/riscv_exception_common.S 

AS: common/riscv_saveusercontext.S 
AS: common/fork.S 

CC: obstack/lib_obstack_finish.c 


CC: obstack/lib_obstack_object_size.c 

CC: chip/esp32c3_allocateheap.c 
CC: obstack/lib_obstack_room.c 




CC: obstack/lib_obstack_printf.c 

CC: chip/esp32c3_start.c 

CC: chip/esp32c3_wdt.c 



CC: chip/esp32c3_idle.c 
CC: obstack/lib_obstack_vprintf.c 

CC: obstack/lib_obstack_malloc.c 

CC: chip/esp32c3_irq.c 

CC: pthread/pthread_attr_init.c 
CC: chip/esp32c3_libc_stubs.c 
CC: chip/esp32c3_clockconfig.c 
CC: pthread/pthread_attr_destroy.c 
CC: chip/esp32c3_gpio.c 


CC: pthread/pthread_attr_setschedpolicy.c 
CC: chip/esp32c3_rtc_gpio.c 




CC: pthread/pthread_attr_getschedpolicy.c 
CC: chip/esp32c3_lowputc.c 
CC: pthread/pthread_attr_setinheritsched.c 

CC: pthread/pthread_attr_getinheritsched.c 

CC: chip/esp32c3_serial.c 

CC: pthread/pthread_attr_setdetachstate.c 
CC: chip/esp32c3_systemreset.c 


CC: chip/esp32c3_resetcause.c 

CC: pthread/pthread_attr_getdetachstate.c 


CC: chip/esp32c3_uid.c 

CC: chip/esp32c3_perf.c 
CC: pthread/pthread_attr_setstackaddr.c 


CC: chip/esp32c3_region.c 
CC: pthread/pthread_attr_getstackaddr.c 
CC: chip/esp32c3_timerisr.c 



CC: chip/esp32c3_rtc.c 

CC: pthread/pthread_attr_setstacksize.c 


CC: pthread/pthread_attr_getstacksize.c 
CC: chip/esp32c3_brownout.c 
CC: pthread/pthread_attr_setstack.c 

CC: common/riscv_initialize.c 

CC: common/riscv_swint.c 

CC: pthread/pthread_attr_getstack.c 

CC: common/riscv_mtimer.c 


CC: common/riscv_allocateheap.c 
CC: pthread/pthread_attr_setschedparam.c 

CC: common/riscv_createstack.c 

CC: common/riscv_cpuinfo.c 


CC: common/riscv_cpuidlestack.c 


CC: pthread/pthread_attr_getschedparam.c 
CC: common/riscv_doirq.c 
CC: pthread/pthread_attr_setscope.c 
CC: common/riscv_exit.c 


CC: pthread/pthread_attr_getscope.c 

CC: pthread/pthread_attr_setguardsize.c 
CC: common/riscv_exception.c 



CC: pthread/pthread_attr_getguardsize.c 

CC: common/riscv_getnewintctx.c 
CC: pthread/pthread_barrierattr_init.c 
CC: common/riscv_getintstack.c 


CC: pthread/pthread_barrierattr_destroy.c 

CC: pthread/pthread_barrierattr_getpshared.c 

CC: common/riscv_initialstate.c 
CC: common/riscv_modifyreg32.c 

CC: common/riscv_nputs.c 




CC: common/riscv_releasestack.c 

CC: common/riscv_registerdump.c 
CC: pthread/pthread_barrierattr_setpshared.c 


CC: common/riscv_stackframe.c 


CC: pthread/pthread_barrierinit.c 
CC: common/riscv_schedulesigaction.c 
CC: common/riscv_sigdeliver.c 
CC: pthread/pthread_barrierdestroy.c 

CC: common/riscv_switchcontext.c 


CC: pthread/pthread_barrierwait.c 
CC: common/riscv_usestack.c 


CC: pthread/pthread_condattr_init.c 

CC: pthread/pthread_condattr_destroy.c 


CC: pthread/pthread_condattr_getpshared.c 




CC: pthread/pthread_condattr_setpshared.c 
CC: pthread/pthread_condattr_setclock.c 

CC: common/riscv_tcbinfo.c 







CC: common/riscv_idle.c 
CC: common/riscv_mdelay.c 
CC: pthread/pthread_condattr_getclock.c 
CC: common/riscv_udelay.c 
CC: common/riscv_debug.c 


CC: pthread/pthread_condinit.c 
CC: common/riscv_fork.c 


CC: builtin_list.c 

CC: common/riscv_pmp.c 

CC: pthread/pthread_conddestroy.c 
CC: exec_builtin.c 
CC: pthread/pthread_condtimedwait.c 


CC: pthread/pthread_create.c 
CC: pthread/pthread_exit.c 
CC: nsh_alias.c 


CC: nsh_builtin.c 
CC: pthread/pthread_kill.c 

CC: board/dummy.c 

CC: nsh_command.c 

CC: pthread/pthread_setname_np.c 
CC: pthread/pthread_getname_np.c 

CC: dd_main.c 
CC: nsh_console.c 
CC: nsh_main.c 


CC: sh_main.c 
CC: nsh_consolemain.c 
CC: readline.c 




CC: pthread/pthread_get_stackaddr_np.c 
CC: nsh_dbgcmds.c 



CC: readline_common.c 
CC: readline_fd.c 

CC: readline_stream.c 
CC: nsh_envcmds.c 
CC: barrier.c 


CC: cancel.c 
CC: pthread/pthread_get_stacksize_np.c 


CC: nsh_fscmds.c 

CC: cond.c 
CC: pthread/pthread_mutexattr_init.c 



CC: pthread/pthread_mutexattr_destroy.c 

CC: dev_null.c 
CC: nsh_fsutils.c 
CC: getopt.c 


CC: pthread/pthread_mutexattr_getpshared.c 
CC: libc_memmem.c 
CC: pthread/pthread_mutexattr_setpshared.c 

CC: pthread/pthread_mutexattr_setprotocol.c 



CC: pthread/pthread_mutexattr_getprotocol.c 
CC: nsh_init.c 
CC: pthread/pthread_mutexattr_settype.c 


CC: nsh_mmcmds.c 


CC: nsh_mntcmds.c 

CC: pthread/pthread_mutexattr_gettype.c 

CC: pthread/pthread_mutexattr_setrobust.c 
CC: fs_initialize.c 
CC: mqueue.c 



CC: fs_heap.c 


CC: nsh_parse.c 
CC: inode/fs_files.c 
CC: mutex.c 
CC: nsh_printf.c 
CC: ostest_main.c 




CC: posixtimer.c 
CC: inode/fs_foreachinode.c 
CC: pthread/pthread_mutexattr_getrobust.c 


CC: inode/fs_inode.c 


CC: pthread_exit.c 
CC: pthread_rwlock.c 

CC: inode/fs_inodeaddref.c 

CC: pthread_rwlock_cancel.c 

CC: restart.c 
CC: pthread/pthread_mutexattr_setprioceiling.c 
CC: nsh_proccmds.c 

CC: robust.c 



CC: nsh_prompt.c 
CC: pthread/pthread_mutexattr_getprioceiling.c 
CC: inode/fs_inodebasename.c 

CC: roundrobin.c 


CC: inode/fs_inodefind.c 
CC: pthread/pthread_mutex_lock.c 



CC: nsh_script.c 
CC: nsh_session.c 
CC: schedlock.c 


CC: inode/fs_inodefree.c 
CC: nsh_syscmds.c 

CC: inode/fs_inodegetpath.c 




CC: nsh_system.c 

CC: pthread/pthread_mutex_setprioceiling.c 

CC: sem.c 
CC: nsh_test.c 
CC: nsh_timcmds.c 
CC: inode/fs_inoderelease.c 



CC: pthread/pthread_mutex_getprioceiling.c 
CC: inode/fs_inoderemove.c 
CC: nsh_wait.c 

CC: inode/fs_inodereserve.c 




CC: pthread/pthread_once.c 
CC: inode/fs_inodesearch.c 

CC: vfs/fs_chstat.c 
CC: pthread/pthread_yield.c 


CC: semtimed.c 
CC: pthread/pthread_atfork.c 


CC: vfs/fs_close.c 
CC: pthread/pthread_rwlockattr_init.c 



CC: setvbuf.c 
CC: sighand.c 
CC: vfs/fs_dup.c 
CC: sighelper.c 

CC: vfs/fs_dup2.c 



CC: signest.c 
CC: pthread/pthread_rwlockattr_destroy.c 
CC: sigprocmask.c 


CC: timedmqueue.c 
CC: vfs/fs_dup3.c 



CC: vfs/fs_fcntl.c 


CC: vfs/fs_epoll.c 
CC: timedmutex.c 
CC: pthread/pthread_rwlockattr_getpshared.c 

CC: timedwait.c 

CC: vfs/fs_fchstat.c 

CC: vfork.c 

CC: pthread/pthread_rwlockattr_setpshared.c 

CC: pthread/pthread_rwlock.c 


CC: pthread/pthread_rwlock_rdlock.c 



CC: pthread/pthread_rwlock_wrlock.c 
CC: vfs/fs_fstat.c 
CC: waitpid.c 
CC: vfs/fs_fstatfs.c 
CC: vfs/fs_ioctl.c 


CC: wdog.c 

CC: vfs/fs_lseek.c 
CC: vfs/fs_mkdir.c 
CC: binfmt_globals.c 



CC: binfmt_initialize.c 
CC: binfmt_register.c 


CC: vfs/fs_open.c 



CC: pthread/pthread_setcancelstate.c 
CC: vfs/fs_poll.c 
CC: binfmt_unregister.c 

CC: vfs/fs_pread.c 



CC: pthread/pthread_setcanceltype.c 
CC: vfs/fs_pwrite.c 

CC: binfmt_loadmodule.c 
CC: vfs/fs_read.c 

CC: binfmt_unloadmodule.c 


CC: binfmt_execmodule.c 
CC: binfmt_exec.c 




CC: pthread/pthread_testcancel.c 
CC: vfs/fs_rename.c 


CC: vfs/fs_rmdir.c 
CC: pthread/pthread_getcpuclockid.c 

CC: binfmt_copyargv.c 

CC: binfmt_copyactions.c 
CC: pthread/pthread_self.c 
CC: vfs/fs_select.c 

CC: pthread/pthread_gettid_np.c 


CC: binfmt_dumpmodule.c 
CC: vfs/fs_sendfile.c 


CC: builtin.c 
CC: vfs/fs_stat.c 


CC: vfs/fs_statfs.c 
CC: vfs/fs_uio.c 

CC: pthread/pthread_concurrency.c 

CC: vfs/fs_unlink.c 



CC: pwd/lib_getpwnam.c 
CC: vfs/fs_write.c 
CC: vfs/fs_dir.c 

CC: vfs/fs_fsync.c 



CC: pwd/lib_getpwnamr.c 
CC: vfs/fs_syncfs.c 

CC: pwd/lib_getpwuid.c 
CC: vfs/fs_truncate.c 



CC: vfs/fs_link.c 
CC: pwd/lib_getpwuidr.c 

CC: pwd/lib_getpwent.c 
CC: vfs/fs_symlink.c 





CC: pwd/lib_pwd_globals.c 
CC: vfs/fs_readlink.c 
CC: pwd/lib_getspnam.c 
CC: driver/fs_registerdriver.c 
CC: driver/fs_unregisterdriver.c 


CC: pwd/lib_getpwbuf.c 
CC: driver/fs_registerpipedriver.c 



CC: driver/fs_unregisterpipedriver.c 

CC: pwd/lib_getpwbufr.c 


CC: driver/fs_registerblockdriver.c 

CC: queue/queue.c 
CC: driver/fs_unregisterblockdriver.c 
CC: sched/sched_getprioritymax.c 


CC: driver/fs_findblockdriver.c 
CC: driver/fs_openblockdriver.c 




CC: sched/sched_getprioritymin.c 
CC: driver/fs_closeblockdriver.c 
CC: driver/fs_blockpartition.c 


CC: sched/clock_getcpuclockid.c 
CC: sched/clock_getres.c 
CC: driver/fs_findmtddriver.c 

CC: sched/task_cancelpt.c 



CC: sched/task_setcancelstate.c 
CC: driver/fs_closemtddriver.c 
CC: driver/fs_blockmerge.c 

CC: mmap/fs_mmap.c 

CC: sched/task_setcanceltype.c 


CC: mmap/fs_munmap.c 

CC: sched/task_testcancel.c 
CC: mmap/fs_mmisc.c 

CC: sched/task_gettid.c 



CC: sched/task_startup.c 

CC: mmap/fs_msync.c 
CC: search/hcreate_r.c 

CC: mmap/fs_anonmap.c 
CC: board/esp32c3_boot.c 

CC: board/esp32c3_bringup.c 
CC: board/esp32c3_appinit.c 


CC: search/hcreate.c 

CC: mqueue/mq_open.c 


CC: mqueue/mq_close.c 

CC: search/hash_func.c 

CC: mqueue/mq_unlink.c 
CC: semaphore/sem_init.c 
CC: mount/fs_mount.c 

CC: mount/fs_umount2.c 
CC: semaphore/sem_setprotocol.c 

CC: semaphore/sem_getprotocol.c 


CC: mount/fs_foreachmountpoint.c 


CC: mount/fs_gettype.c 
CC: mount/fs_procfs_mount.c 

CC: semaphore/sem_getvalue.c 

CC: partition/fs_partition.c 
CC: procfs/fs_procfs.c 




CC: semaphore/sem_destroy.c 
CC: procfs/fs_procfscpuinfo.c 
CC: semaphore/sem_wait.c 
CC: procfs/fs_procfscpuload.c 

CC: semaphore/sem_trywait.c 



CC: semaphore/sem_timedwait.c 
CC: semaphore/sem_clockwait.c 


CC: semaphore/sem_post.c 
CC: procfs/fs_procfscritmon.c 



CC: procfs/fs_procfsfdt.c 

CC: signal/sig_addset.c 
CC: procfs/fs_procfsiobinfo.c 
CC: signal/sig_delset.c 



CC: signal/sig_emptyset.c 
CC: procfs/fs_procfsmeminfo.c 

CC: procfs/fs_procfsproc.c 
CC: procfs/fs_procfstcbinfo.c 


CC: signal/sig_fillset.c 
CC: procfs/fs_procfsuptime.c 

CC: signal/sig_nandset.c 
CC: procfs/fs_procfsutil.c 


CC: procfs/fs_procfsversion.c 
CC: signal/sig_andset.c 

CC: signal/sig_orset.c 



CC: signal/sig_xorset.c 



CC: signal/sig_isemptyset.c 

CC: signal/sig_killpg.c 
CC: signal/sig_altstack.c 
CC: signal/sig_interrupt.c 
CC: signal/sig_hold.c 

CC: signal/sig_ignore.c 
CC: signal/sig_ismember.c 


CC: signal/sig_pause.c 
CC: signal/sig_psignal.c 

IN: sched/libsched.a -> staging/libsched.a 

CC: signal/sig_raise.c 

CC: signal/sig_relse.c 



CC: signal/sig_set.c 
CC: signal/sig_signal.c 


CC: signal/sig_wait.c 

CC: spawn/lib_psfa_addaction.c 
CC: spawn/lib_psfa_addclose.c 


CC: spawn/lib_psfa_adddup2.c 
CC: spawn/lib_psfa_addopen.c 

CC: spawn/lib_psfa_destroy.c 

CC: spawn/lib_psfa_init.c 

CC: spawn/lib_psa_getflags.c 
CC: spawn/lib_psa_getschedparam.c 


CC: spawn/lib_psa_getschedpolicy.c 
CC: spawn/lib_psa_init.c 



CC: spawn/lib_psa_setflags.c 
CC: spawn/lib_psa_setschedparam.c 
CC: spawn/lib_psa_setschedpolicy.c 


CC: spawn/lib_psa_getsigmask.c 



CC: spawn/lib_psa_setsigmask.c 



CC: spawn/lib_psa_getstacksize.c 
CC: spawn/lib_psa_setstacksize.c 
CC: spawn/lib_psa_destroy.c 

CC: spawn/lib_psa_getstackaddr.c 


CC: spawn/lib_psa_setstackaddr.c 
CC: stdio/lib_fileno.c 
CC: stdio/lib_printf.c 
CC: stdio/lib_sprintf.c 
CC: stdio/lib_asprintf.c 


CC: stdio/lib_snprintf.c 
CC: stdio/lib_vsprintf.c 


CC: stdio/lib_vasprintf.c 



CC: stdio/lib_vsnprintf.c 


CC: stdio/lib_dprintf.c 
CC: stdio/lib_vdprintf.c 
CC: stdio/lib_vprintf.c 



CC: stdio/lib_perror.c 




CC: stdio/lib_putchar.c 
CC: stdio/lib_getchar.c 
CC: stdio/lib_puts.c 

CC: stdio/lib_gets_s.c 
CC: stdio/lib_gets.c 
CC: stdio/lib_libdgets.c 
CC: stdio/lib_sscanf.c 
CC: stdio/lib_vsscanf.c 
CC: stdio/lib_remove.c 

CC: stdio/lib_tempnam.c 


CC: stdio/lib_tmpnam.c 


CC: stdio/lib_renameat.c 



CC: stdio/lib_putwchar.c 
CC: stdio/lib_fopen.c 
CC: stdio/lib_freopen.c 
CC: stdio/lib_fclose.c 
CC: stdio/lib_fread.c 



CC: stdio/lib_libfread_unlocked.c 



CC: stdio/lib_fseek.c 

CC: stdio/lib_fseeko.c 

CC: stdio/lib_ftell.c 


CC: stdio/lib_ftello.c 
CC: stdio/lib_fsetpos.c 
CC: stdio/lib_getdelim.c 


CC: stdio/lib_fgetpos.c 
CC: stdio/lib_getc.c 
CC: stdio/lib_fgetc.c 
CC: stdio/lib_fgets.c 
CC: stdio/lib_libfgets.c 


CC: stdio/lib_fwrite.c 

CC: stdio/lib_libfwrite.c 
IN: drivers/libdrivers.a -> staging/libdrivers.a 

CC: stdio/lib_fflush.c 


CC: stdio/lib_libflushall.c 

CC: stdio/lib_libfflush.c 

CC: stdio/lib_rdflush_unlocked.c 
CC: stdio/lib_wrflush_unlocked.c 




CC: stdio/lib_putc.c 

CC: stdio/lib_fputc.c 
CC: stdio/lib_fputs.c 

CC: stdio/lib_ungetc.c 
CC: stdio/lib_fprintf.c 




CC: stdio/lib_vfprintf.c 


CC: stdio/lib_feof.c 
CC: stdio/lib_ferror.c 
CC: stdio/lib_rewind.c 

CC: stdio/lib_clearerr.c 
CC: stdio/lib_scanf.c 

CC: stdio/lib_vscanf.c 

CC: stdio/lib_fscanf.c 
CC: stdio/lib_vfscanf.c 

CC: stdio/lib_tmpfile.c 
CC: stdio/lib_setbuf.c 

CC: stdio/lib_setvbuf.c 

CC: stdio/lib_libfilelock.c 



CC: stdio/lib_libgetstreams.c 
CC: stdio/lib_setbuffer.c 
CC: stdio/lib_fputwc.c 

CC: stdio/lib_putwc.c 







CC: stdio/lib_fputws.c 

CC: stdio/lib_fopencookie.c 

CC: stdio/lib_fmemopen.c 
CC: stdio/lib_open_memstream.c 
CC: stdio/lib_fgetwc.c 



CC: stdio/lib_getwc.c 


CC: stdio/lib_ungetwc.c 
CC: stdlib/lib_abs.c 
CC: stdlib/lib_abort.c 

CC: stdlib/lib_atof.c 
CC: stdlib/lib_atoi.c 


CC: stdlib/lib_getprogname.c 
CC: stdlib/lib_atol.c 
CC: stdlib/lib_atoll.c 
CC: stdlib/lib_div.c 
CC: stdlib/lib_ldiv.c 
CC: stdlib/lib_lldiv.c 

CC: stdlib/lib_exit.c 




CC: stdlib/lib_itoa.c 


CC: stdlib/lib_labs.c 
CC: stdlib/lib_llabs.c 


CC: stdlib/lib_realpath.c 



CC: stdlib/lib_bsearch.c 
CC: stdlib/lib_rand.c 




CC: stdlib/lib_rand48.c 

CC: stdlib/lib_qsort.c 

CC: stdlib/lib_srand.c 
CC: stdlib/lib_strtol.c 

CC: stdlib/lib_strtoll.c 
CC: stdlib/lib_strtoul.c 
CC: stdlib/lib_strtoull.c 
CC: stdlib/lib_strtold.c 
CC: stdlib/lib_checkbase.c 

CC: stdlib/lib_mktemp.c 
CC: stdlib/lib_mkstemp.c 
CC: stdlib/lib_mkdtemp.c 
CC: stdlib/lib_aligned_alloc.c 



CC: stdlib/lib_posix_memalign.c 

CC: stdlib/lib_valloc.c 
CC: stdlib/lib_mblen.c 
CC: stdlib/lib_mbtowc.c 



CC: stdlib/lib_wctomb.c 
CC: stdlib/lib_mbstowcs.c 
CC: stdlib/lib_wcstombs.c 

CC: stdlib/lib_atexit.c 



CC: stdlib/lib_reallocarray.c 
CC: stdlib/lib_arc4random.c 

CC: stream/lib_meminstream.c 

IN: boards/libboards.a -> staging/libboards.a 
CC: stream/lib_memoutstream.c 


CC: stream/lib_memsistream.c 

CC: stream/lib_memsostream.c 



CC: stream/lib_lowoutstream.c 
CC: stream/lib_rawinstream.c 
CC: stream/lib_rawoutstream.c 


CC: stream/lib_rawsistream.c 
CC: stream/lib_rawsostream.c 




CC: stream/lib_zeroinstream.c 

CC: stream/lib_nullinstream.c 
CC: stream/lib_nulloutstream.c 

CC: stream/lib_mtdoutstream.c 

CC: stream/lib_libnoflush.c 


CC: stream/lib_libsnoflush.c 
CC: stream/lib_syslogstream.c 
CC: stream/lib_syslograwstream.c 
CC: stream/lib_bufferedoutstream.c 
CC: stream/lib_hexdumpstream.c 

CC: stream/lib_base64outstream.c 

CC: stream/lib_mtdsostream.c 


CC: stream/lib_fileinstream.c 
CC: stream/lib_fileoutstream.c 


CC: stream/lib_libbsprintf.c 






CC: stream/lib_libvscanf.c 



CC: stream/lib_libvsprintf.c 

CC: stream/lib_ultoa_invert.c 
CC: stream/lib_stdinstream.c 
CC: stream/lib_stdoutstream.c 

CC: stream/lib_stdsistream.c 

CC: stream/lib_stdsostream.c 
CC: stream/lib_blkoutstream.c 
CC: string/lib_ffs.c 
CC: string/lib_ffsl.c 
CC: string/lib_ffsll.c 

CC: string/lib_fls.c 
CC: string/lib_flsl.c 


CC: string/lib_flsll.c 
CC: string/lib_isbasedigit.c 
CC: string/lib_memmem.c 

CC: string/lib_popcount.c 

CC: string/lib_popcountl.c 




CC: string/lib_popcountll.c 



CC: string/lib_skipspace.c 
CC: string/lib_strcasecmp.c 
CC: string/lib_strcspn.c 

CC: string/lib_strdup.c 
CC: string/lib_strerror.c 
CC: string/lib_strncasecmp.c 
CC: string/lib_strncat.c 



CC: string/lib_strndup.c 


CC: string/lib_strcasestr.c 
CC: string/lib_strpbrk.c 
CC: string/lib_strspn.c 



CC: string/lib_strstr.c 

CC: string/lib_strtok.c 

CC: string/lib_strtokr.c 
CC: string/lib_strsep.c 

CC: string/lib_strerrorr.c 
CC: string/lib_explicit_bzero.c 
CC: string/lib_strsignal.c 

CC: string/lib_index.c 


CC: string/lib_rindex.c 




CC: string/lib_timingsafe_bcmp.c 


CC: string/lib_strverscmp.c 





CC: string/lib_mempcpy.c 





CC: string/lib_rawmemchr.c 
CC: string/lib_memmove.c 
IN: mm/libmm.a -> staging/libmm.a 
CC: string/lib_memset.c 

CC: string/lib_strlcat.c 

CC: string/lib_strlcpy.c 
CC: string/lib_strnlen.c 
CC: string/lib_memcpy.c 
CC: string/lib_memccpy.c 
CC: string/lib_memcmp.c 
CC: string/lib_memrchr.c 
CC: string/lib_stpncpy.c 
CC: string/lib_strchr.c 
CC: string/lib_strcmp.c 
CC: string/lib_strlen.c 

CC: string/lib_strncpy.c 
CC: string/lib_memchr.c 


CC: string/lib_stpcpy.c 

CC: string/lib_strcat.c 


CC: string/lib_strchrnul.c 
CC: string/lib_strcpy.c 

CC: string/lib_strncmp.c 



CC: string/lib_strrchr.c 


CC: symtab/symtab_findbyname.c 
CC: symtab/symtab_findbyvalue.c 

CC: symtab/symtab_sortbyname.c 

CC: syslog/lib_syslog.c 

CC: syslog/lib_setlogmask.c 

CC: termios/lib_cfspeed.c 



CC: termios/lib_cfmakeraw.c 
CC: termios/lib_isatty.c 



CC: termios/lib_tcflush.c 

CC: termios/lib_tcdrain.c 
CC: termios/lib_tcflow.c 
CC: termios/lib_tcgetattr.c 

CC: termios/lib_tcsetattr.c 
CC: termios/lib_tcsendbreak.c 
CC: termios/lib_ttyname.c 
CC: termios/lib_ttynamer.c 
CC: time/lib_strftime.c 



CC: time/lib_calendar2utc.c 




CC: time/lib_daysbeforemonth.c 



CC: time/lib_gettimeofday.c 

CC: time/lib_isleapyear.c 



CC: time/lib_settimeofday.c 



CC: time/lib_time.c 
CC: time/lib_timespec_get.c 



CC: time/lib_nanosleep.c 

CC: time/lib_difftime.c 

CC: time/lib_dayofweek.c 
CC: time/lib_asctime.c 
CC: time/lib_asctimer.c 
CC: time/lib_ctime.c 
CC: time/lib_ctimer.c 
CC: time/lib_gethrtime.c 
CC: time/lib_timegm.c 
CC: time/lib_gmtime.c 
CC: time/lib_gmtimer.c 
CC: tls/task_getinfo.c 
CC: tls/tls_getinfo.c 
CC: uio/lib_preadv.c 

CC: uio/lib_pwritev.c 
CC: unistd/lib_access.c 



CC: unistd/lib_daemon.c 

CC: unistd/lib_swab.c 




CC: unistd/lib_pathconf.c 
CC: unistd/lib_sysconf.c 

CC: unistd/lib_getcwd.c 


CC: unistd/lib_getentropy.c 

CC: unistd/lib_getopt_common.c 
CC: unistd/lib_getopt.c 
CC: unistd/lib_getopt_long.c 
CC: unistd/lib_getopt_longonly.c 

CC: unistd/lib_getoptvars.c 
CC: unistd/lib_getopterrp.c 
CC: unistd/lib_getoptargp.c 



CC: unistd/lib_getoptindp.c 


CC: unistd/lib_getoptoptp.c 

CC: unistd/lib_times.c 

CC: unistd/lib_alarm.c 



CC: unistd/lib_fstatvfs.c 
CC: unistd/lib_statvfs.c 
CC: unistd/lib_sleep.c 
IN: arch/risc-v/src/libarch.a -> staging/libarch.a 
CC: unistd/lib_nice.c 
CC: unistd/lib_setreuid.c 



CC: unistd/lib_setregid.c 





CC: unistd/lib_getrusage.c 

CC: unistd/lib_utime.c 



CC: unistd/lib_utimes.c 
CC: unistd/lib_setrlimit.c 
CC: unistd/lib_getrlimit.c 

CC: unistd/lib_setpriority.c 


CC: unistd/lib_getpriority.c 


CC: unistd/lib_futimes.c 
CC: unistd/lib_lutimes.c 


CC: unistd/lib_gethostname.c 
CC: unistd/lib_sethostname.c 

CC: unistd/lib_fchownat.c 

CC: unistd/lib_linkat.c 

CC: unistd/lib_readlinkat.c 

CC: unistd/lib_symlinkat.c 
CC: unistd/lib_unlinkat.c 
CC: unistd/lib_usleep.c 
CC: unistd/lib_getpgrp.c 

CC: unistd/lib_getpgid.c 
CC: unistd/lib_lockf.c 


CC: unistd/lib_flock.c 
CC: unistd/lib_getpass.c 

CC: unistd/lib_chdir.c 
CC: unistd/lib_fchdir.c 
CC: unistd/lib_confstr.c 
CC: unistd/lib_setuid.c 



CC: unistd/lib_setgid.c 

CC: unistd/lib_getuid.c 

CC: unistd/lib_getgid.c 
CC: unistd/lib_seteuid.c 


CC: unistd/lib_setegid.c 
CC: unistd/lib_geteuid.c 
CC: unistd/lib_getegid.c 


CC: unistd/lib_restoredir.c 

CC: unistd/lib_truncate.c 





CC: unistd/lib_posix_fallocate.c 

CC: unistd/lib_fork.c 



CC: uuid/lib_uuid_compare.c 
CC: uuid/lib_uuid_create.c 


CC: uuid/lib_uuid_create_nil.c 
CC: uuid/lib_uuid_equal.c 
CC: uuid/lib_uuid_from_string.c 

CC: uuid/lib_uuid_hash.c 
CC: uuid/lib_uuid_is_nil.c 
CC: uuid/lib_uuid_stream.c 





CC: uuid/lib_uuid_to_string.c 

CC: wchar/lib_wcscmp.c 

CC: wchar/lib_wcslen.c 
CC: wchar/lib_wmemchr.c 

CC: wchar/lib_wmemcmp.c 

CC: wchar/lib_wmemcpy.c 
CC: wchar/lib_wmemmove.c 
CC: wchar/lib_wmemset.c 
CC: wchar/lib_btowc.c 
CC: wchar/lib_mbrtowc.c 
CC: wchar/lib_wctob.c 
CC: wchar/lib_wcslcpy.c 




CC: wchar/lib_wcsxfrm.c 
CC: wchar/lib_wcrtomb.c 


CC: wchar/lib_wcsftime.c 


CC: wchar/lib_wcscoll.c 
CC: wchar/lib_wcstol.c 
CC: wchar/lib_wcstoll.c 
CC: wchar/lib_wcstoul.c 
CC: wchar/lib_wcstoull.c 

CC: wchar/lib_wcstold.c 

CC: wchar/lib_wcstof.c 



CC: wchar/lib_wcstod.c 




CC: wchar/lib_swprintf.c 

CC: wchar/lib_mbsnrtowcs.c 
IN: /tmp/nuttx/nuttx-apps.git/libapps.a -> staging/libapps.a 
CC: wchar/lib_wcsnrtombs.c 
CC: wchar/lib_mbsinit.c 

CC: wchar/lib_mbrlen.c 
CC: wchar/lib_mbsrtowcs.c 

CC: wchar/lib_wcsrtombs.c 


CC: wchar/lib_wcscpy.c 
CC: wchar/lib_wcscat.c 

CC: wchar/lib_wcslcat.c 
CC: wchar/lib_wcsncat.c 



CC: wchar/lib_wcsrchr.c 


CC: wchar/lib_wcschr.c 



CC: wchar/lib_wcsncpy.c 

CC: wchar/lib_wcsncmp.c 
CC: wchar/lib_wcscspn.c 
CC: wchar/lib_wcspbrk.c 
CC: wchar/lib_wcsspn.c 
CC: wchar/lib_wcsstr.c 
CC: wchar/lib_wcstok.c 

CC: wchar/lib_wcswcs.c 


CC: wchar/lib_wcwidth.c 

CC: wchar/lib_wcswidth.c 

CC: wctype/lib_wctype.c 



CC: wctype/lib_iswctype.c 

CC: wctype/lib_towlower.c 
CC: wctype/lib_towupper.c 





















IN: fs/libfs.a -> staging/libfs.a 

IN: binfmt/libbinfmt.a -> staging/libbinfmt.a 

IN: arch/risc-v/src/board/libboard.a -> staging/libboard.a 

IN: libs/libc/libc.a -> staging/libc.a 

AS: chip/esp32c3_head.S 
CPP: /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/esp32c3_rom.ld-> /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/esp32c3_rom.ld.tmp 
CPP: /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/flat_memory.ld-> /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/flat_memory.ld.tmp 
CPP: /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/legacy_sections.ld-> /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/legacy_sections.ld.tmp 



LD: nuttx
Memory region Used Size Region Size %age Used
iram0_0_seg: 6608 B 321296 B 2.06%
irom0_0_seg: 121516 B 4194272 B 2.90%
dram0_0_seg: 15552 B 321296 B 4.84%
drom0_0_seg: 175260 B 4194272 B 4.18%
rtc_seg: 0 GB 8 KB 0.00%
CP: nuttx.hex
MKIMAGE: ESP32-C3 binary
esptool.py -c esp32c3 elf2image -fs 4MB -fm dio -ff 40m -o nuttx.bin nuttx
esptool.py v4.9.0
Creating esp32c3 image...
Merged 1 ELF section
Successfully created esp32c3 image.
Generated: nuttx.bin (ESP32-C3 compatible)
4,75s real 21,29s user 12,65s sys
+ /usr/bin/time -h gmake flash -j24 CROSSDEV=riscv32-esp-elf-

CC: misc/lib_utsname.c 

IN: libs/libc/libc.a -> staging/libc.a 

CPP: /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/esp32c3_rom.ld-> /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/esp32c3_rom.ld.tmp 
CPP: /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/legacy_sections.ld-> /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/legacy_sections.ld.tmp 
CPP: /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/flat_memory.ld-> /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/flat_memory.ld.tmp 


LD: nuttx
Memory region Used Size Region Size %age Used
iram0_0_seg: 6608 B 321296 B 2.06%
irom0_0_seg: 121516 B 4194272 B 2.90%
dram0_0_seg: 15552 B 321296 B 4.84%
drom0_0_seg: 175260 B 4194272 B 4.18%
rtc_seg: 0 GB 8 KB 0.00%
CP: nuttx.hex
MKIMAGE: ESP32-C3 binary
esptool.py -c esp32c3 elf2image -fs 4MB -fm dio -ff 40m -o nuttx.bin nuttx
esptool.py v4.9.0
Creating esp32c3 image...
Merged 1 ELF section
Successfully created esp32c3 image.
Generated: nuttx.bin (ESP32-C3 compatible)
esptool.py -c esp32c3 -p /dev/cuaU0 -b 115200 write_flash -fs 4MB -fm dio -ff 40m 0x10000 nuttx.bin
esptool.py v4.9.0
Serial port /dev/cuaU0
Connecting....
Chip is ESP32-C3 (QFN32) (revision v0.3)
Features: WiFi, BLE
Crystal is 40MHz
MAC: 7c:df:a1:b1:58:00
Uploading stub...
Running stub...
Stub running...
Configuring flash size...
Flash will be erased from 0x00010000 to 0x0003dfff...
Compressed 187120 bytes to 100275...
Writing at 0x00010000... (14 %)
Writing at 0x0001bf42... (28 %)
Writing at 0x00024fce... (42 %)
Writing at 0x0002ad5d... (57 %)
Writing at 0x00030e86... (71 %)
Writing at 0x00037010... (85 %)
Writing at 0x0003d035... (100 %)
Wrote 187120 bytes (100275 compressed) at 0x00010000 in 9.3 seconds (effective 161.1 kbit/s)...
Hash of data verified.
Leaving...
Hard resetting via RTS pin...
14,23s real 1,70s user 2,13s sys
+ cu -l /dev/cuaU0 -s 115200
Connected
nsh> uname -a
NuttX 12.11.0 a00ac581c5 Oct 3 2025 23:06:11 risc-v esp32c3-devkit
nsh> free
total used free maxused maxfree nused nfree name
371612 5684 365928 6040 365928 21 1 Umem
nsh> help
help usage: help [-v] [<cmd>]
. cp expr mkdir rmdir umount
[ cmp false mkrd set unset
? dirname fdinfo mount sleep uptime
alias df free mv source usleep
unalias dmesg help pidof test watch
basename echo hexdump printf time xd
break env kill ps true wait
cat exec pkill pwd truncate
cd exit ls rm uname
Builtin Apps:
dd nsh ostest sh
nsh> ostest
stdio_test: write fd=1
stdio_test: Standard I/O Check: printf
stdio_test: write fd=2
stdio_test: Standard I/O Check: fprintf to stderr
ostest_main: putenv(Variable1=BadValue3)
ostest_main: setenv(Variable1, GoodValue1, TRUE)
ostest_main: setenv(Variable2, BadValue1, FALSE)
ostest_main: setenv(Variable2, GoodValue2, TRUE)
ostest_main: setenv(Variable3, GoodValue3, FALSE)
ostest_main: setenv(Variable3, BadValue2, FALSE)
show_variable: Variable=Variable1 has value=GoodValue1
show_variable: Variable=Variable2 has value=GoodValue2
show_variable: Variable=Variable3 has value=GoodValue3
ostest_main: Started user_main at PID=3
user_main: Begin argument test
user_main: Started with argc=5
user_main: argv[0]="ostest"
user_main: argv[1]="Arg1"
user_main: argv[2]="Arg2"
user_main: argv[3]="Arg3"
user_main: argv[4]="Arg4"
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 1 1
mxordblk 56980 56980
uordblks 421c 421c
fordblks 56980 56980
user_main: getopt() test
getopt(): Simple test
getopt(): Invalid argument
getopt(): Missing optional argument
getopt_long(): Simple test
getopt_long(): No short options
getopt_long(): Argument for --option=argument
getopt_long(): Invalid long option
getopt_long(): Mixed long and short options
getopt_long(): Invalid short option
getopt_long(): Missing optional arguments
getopt_long_only(): Mixed long and short options
getopt_long_only(): Single hyphen long options
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 1 1
mxordblk 56980 56980
uordblks 421c 421c
fordblks 56980 56980
user_main: libc tests
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 1 1
mxordblk 56980 56980
uordblks 421c 421c
fordblks 56980 56980
show_variable: Variable=Variable1 has value=GoodValue1
show_variable: Variable=Variable2 has value=GoodValue2
show_variable: Variable=Variable3 has value=GoodValue3
show_variable: Variable=Variable1 has no value
show_variable: Variable=Variable2 has value=GoodValue2
show_variable: Variable=Variable3 has value=GoodValue3
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 1 2
mxordblk 56980 56980
uordblks 421c 41fc
fordblks 56980 569a0
show_variable: Variable=Variable1 has no value
show_variable: Variable=Variable2 has no value
show_variable: Variable=Variable3 has no value
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 2 2
mxordblk 56980 56980
uordblks 41fc 4184
fordblks 569a0 56a18
user_main: setvbuf test
setvbuf_test: Test NO buffering
setvbuf_test: Using NO buffering
setvbuf_test: Test default FULL buffering
setvbuf_test: Using default FULL buffering
setvbuf_test: Test FULL buffering, buffer size 64
setvbuf_test: Using FULL buffering, buffer size 64
setvbuf_test: Test FULL buffering, pre-allocated buffer
setvbuf_test: Using FULL buffering, pre-allocated buffer
setvbuf_test: Test LINE buffering, buffer size 64
setvbuf_test: Using LINE buffering, buffer size 64
setvbuf_test: Test FULL buffering, pre-allocated buffer
setvbuf_test: Using FULL buffering, pre-allocated buffer
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 2 2
mxordblk 56980 56980
uordblks 4184 4184
fordblks 56a18 56a18
user_main: /dev/null test
dev_null: Read 0 bytes from /dev/null
dev_null: Wrote 1024 bytes to /dev/null
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 2 2
mxordblk 56980 56980
uordblks 4184 4184
fordblks 56a18 56a18
user_main: task_restart test
Test task_restart()
restart_main: setenv(VarName, VarValue, TRUE)
restart_main: Started restart_main at PID=4
restart_main: Started with argc=4
restart_main: argv[0]="ostest"
restart_main: argv[1]="This is argument 1"
restart_main: argv[2]="Argument 2 here"
restart_main: argv[3]="Lastly, the 3rd argument"
restart_main: Variable=VarName has value=VarValue
restart_main: I am still here
restart_main: I am still here
restart_main: Started restart_main at PID=4
restart_main: Started with argc=4
restart_main: argv[0]="ostest"
restart_main: argv[1]="This is argument 1"
restart_main: argv[2]="Argument 2 here"
restart_main: argv[3]="Lastly, the 3rd argument"
restart_main: Variable=VarName has value=VarValue
restart_main: Started with argc=4
restart_main: argv[0]="ostest"
restart_main: argv[1]="This is argument 1"
restart_main: argv[2]="Argument 2 here"
restart_main: argv[3]="Lastly, the 3rd argument"
restart_main: Variable=VarName has value=VarValue
restart_main: Exiting
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 2 2
mxordblk 56980 54608
uordblks 4184 6534
fordblks 56a18 54668
user_main: waitpid test
Test waitpid()
waitpid_start_child: Started waitpid_main at PID=5
waitpid_main: PID 5 Started
waitpid_start_child: Started waitpid_main at PID=6
waitpid_main: PID 6 Started
waitpid_start_child: Started waitpid_main at PID=7
waitpid_main: PID 7 Started
waitpid_test: Waiting for PID=5 with waitpid()
waitpid_main: PID 5 exitting with result=14
waitpid_test: PID 5 waitpid succeeded with stat_loc=0e00
waitpid_last: Waiting for PID=7 with waitpid()
waitpid_main: PID 6 exitting with result=14
waitpid_main: PID 7 exitting with result=14
waitpid_last: PASS: PID 7 waitpid succeeded with stat_loc=0e00
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 2 5
mxordblk 54608 4fec8
uordblks 6534 a544
fordblks 54668 50658
user_main: mutex test
Initializing mutex
Starting thread 1
Starting thread 2
Thread1 Thread2
Loops 32 32
Errors 0 0
Testing moved mutex
Starting moved mutex thread 1
Starting moved mutex thread 2
Thread1 Thread2
Moved Loops 32 32
Moved Errors 0 0
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 5 2
mxordblk 4fec8 560a0
uordblks a544 4a9c
fordblks 50658 56100
user_main: timed mutex test
mutex_test: Initializing mutex
mutex_test: Starting thread
pthread: Started
pthread: Waiting for lock or timeout
mutex_test: Unlocking
pthread: Got the lock
pthread: Waiting for lock or timeout
pthread: Got the timeout. Terminating
mutex_test: PASSED
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 2 2
mxordblk 560a0 560a0
uordblks 4a9c 4a9c
fordblks 56100 56100
user_main: cancel test
cancel_test: Test 1a: Normal Cancellation
cancel_test: Starting thread
start_thread: Initializing mutex
start_thread: Initializing cond
start_thread: Starting thread
start_thread: Yielding
sem_waiter: Taking mutex
sem_waiter: Starting wait for condition
cancel_test: Canceling thread
cancel_test: Joining
cancel_test: waiter exited with result=0xffffffff
cancel_test: PASS thread terminated with PTHREAD_CANCELED
cancel_test: Test 2: Asynchronous Cancellation
... Skipped
cancel_test: Test 3: Cancellation of detached thread
cancel_test: Re-starting thread
restart_thread: Destroying cond
restart_thread: Destroying mutex
restart_thread: Re-starting thread
start_thread: Initializing mutex
start_thread: Initializing cond
start_thread: Starting thread
start_thread: Yielding
sem_waiter: Taking mutex
sem_waiter: Starting wait for condition
cancel_test: Canceling thread
cancel_test: Joining
cancel_test: PASS pthread_join failed with status=ESRCH
cancel_test: Test 5: Non-cancelable threads
cancel_test: Re-starting thread (non-cancelable)
restart_thread: Destroying cond
restart_thread: Destroying mutex
restart_thread: Re-starting thread
start_thread: Initializing mutex
start_thread: Initializing cond
start_thread: Starting thread
start_thread: Yielding
sem_waiter: Taking mutex
sem_waiter: Starting wait for condition
sem_waiter: Setting non-cancelable
cancel_test: Canceling thread
cancel_test: Joining
sem_waiter: Releasing mutex
sem_waiter: Setting cancelable
cancel_test: waiter exited with result=0xffffffff
cancel_test: PASS thread terminated with PTHREAD_CANCELED
cancel_test: Test 6: Cancel message queue wait
cancel_test: Starting thread (cancelable)
Skipped
cancel_test: Test 7: Cancel signal wait
cancel_test: Starting thread (cancelable)
Skipped
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 2 2
mxordblk 560a0 548a0
uordblks 4a9c 629c
fordblks 56100 54900
user_main: robust test
robust_test: Initializing mutex
robust_test: Starting thread
robust_waiter: Taking mutex
robust_waiter: Exiting with mutex
robust_test: Take the lock again
robust_test: Make the mutex consistent again.
robust_test: Take the lock again
robust_test: Joining
robust_test: waiter exited with result=0
robust_test: Test complete with nerrors=0
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 2 2
mxordblk 548a0 548a0
uordblks 629c 629c
fordblks 54900 54900
user_main: semaphore test
sem_test: Initializing semaphore to 0
sem_test: Starting waiter thread 1
sem_test: Set thread 1 priority to 191
waiter_func: Thread 1 Started
waiter_func: Thread 1 initial semaphore value = 0
sem_test: Starting waiter thread 2
waiter_func: Thread 1 waiting on semaphore
sem_test: Set thread 2 priority to 128
waiter_func: Thread 2 Started
waiter_func: Thread 2 initial semaphore value = -1
waiter_func: Thread 2 waiting on semaphore
sem_test: Starting poster thread 3
sem_test: Set thread 3 priority to 64
poster_func: Thread 3 started
poster_func: Thread 3 semaphore value = -2
poster_func: Thread 3 posting semaphore
waiter_func: Thread 1 awakened
waiter_func: Thread 1 new semaphore value = -1
waiter_func: Thread 1 done
poster_func: Thread 3 new semaphore value = -1
poster_func: Thread 3 semaphore value = -1
poster_func: Thread 3 posting semaphore
waiter_func: Thread 2 awakened
waiter_func: Thread 2 new semaphore value = 0
poster_func: Thread 3 new semaphore value = 0
waiter_func: Thread 2 done
poster_func: Thread 3 done
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 2 2
mxordblk 548a0 54ee0
uordblks 629c 5c5c
fordblks 54900 54f40
user_main: timed semaphore test
semtimed_test: Initializing semaphore to 0
semtimed_test: Waiting for two second timeout
semtimed_test: PASS: first test returned timeout
BEFORE: (46 sec, 390000000 nsec)
AFTER: (48 sec, 390000000 nsec)
semtimed_test: Starting poster thread
semtimed_test: Set thread 1 priority to 191
semtimed_test: Starting poster thread 3
semtimed_test: Set thread 3 priority to 64
semtimed_test: Waiting for two second timeout
poster_func: Waiting for 1 second
poster_func: Posting
semtimed_test: PASS: sem_timedwait succeeded
BEFORE: (48 sec, 390000000 nsec)
AFTER: (49 sec, 400000000 nsec)
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 2 2
mxordblk 54ee0 560a0
uordblks 5c5c 4a9c
fordblks 54f40 56100
user_main: condition variable test
cond_test: Initializing mutex
cond_test: Initializing cond
cond_test: Starting waiter
cond_test: Set thread 1 priority to 128
waiter_thread: Started
cond_test: Starting signaler
cond_test: Set thread 2 priority to 64
thread_signaler: Started
thread_signaler: Terminating
cond_test: signaler terminated, now cancel the waiter
cond_test: Waiter Signaler
cond_test: Loops 32 32
cond_test: Errors 0 0
cond_test:
cond_test: 0 times, waiter did not have to wait for data
cond_test: 0 times, data was already available when the signaler run
cond_test: 0 times, the waiter was in an unexpected state when the signaler ran
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 2 3
mxordblk 560a0 557c0
uordblks 4a9c 4a9c
fordblks 56100 56100
user_main: pthread_exit() test
pthread_exit_test: Started pthread_exit_main at PID=27
pthread_exit_main 27: Starting pthread_exit_thread
pthread_exit_main 27: Sleeping for 5 seconds
pthread_exit_thread 28: Sleeping for 10 second
pthread_exit_main 27: Calling pthread_exit()
pthread_exit_thread 28: Still running...
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 3 2
mxordblk 557c0 53fc0
uordblks 4a9c 6b7c
fordblks 56100 54020
user_main: pthread_rwlock test
pthread_rwlock: Initializing rwlock
pthread_exit_thread 28: Exiting
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 2 3
mxordblk 53fc0 53fc0
uordblks 6b7c 4aac
fordblks 54020 560f0
user_main: pthread_rwlock_cancel test
pthread_rwlock_cancel: Starting test
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 3 2
mxordblk 53fc0 56980
uordblks 4aac 41cc
fordblks 560f0 569d0
user_main: timed wait test
thread_waiter: Initializing mutex
timedwait_test: Initializing cond
timedwait_test: Starting waiter
timedwait_test: Set thread 2 priority to 177
thread_waiter: Taking mutex
timedwait_test: Joining
thread_waiter: Starting 5 second wait for condition
thread_waiter: pthread_cond_timedwait timed out
thread_waiter: Releasing mutex
thread_waiter: Exit with status 0x12345678
timedwait_test: waiter exited with result=0x12345678
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 2 2
mxordblk 56980 560a0
uordblks 41cc 4aac
fordblks 569d0 560f0
user_main: message queue test
mqueue_test: Starting receiver
mqueue_test: Set receiver priority to 128
receiver_thread: Starting
mqueue_test: Starting sender
mqueue_test: Set sender thread priority to 64
mqueue_test: Waiting for sender to complete
sender_thread: Starting
receiver_thread: mq_receive succeeded on msg 0
sender_thread: mq_send succeeded on msg 0
receiver_thread: mq_receive succeeded on msg 1
sender_thread: mq_send succeeded on msg 1
receiver_thread: mq_receive succeeded on msg 2
sender_thread: mq_send succeeded on msg 2
receiver_thread: mq_receive succeeded on msg 3
sender_thread: mq_send succeeded on msg 3
receiver_thread: mq_receive succeeded on msg 4
sender_thread: mq_send succeeded on msg 4
receiver_thread: mq_receive succeeded on msg 5
sender_thread: mq_send succeeded on msg 5
receiver_thread: mq_receive succeeded on msg 6
sender_thread: mq_send succeeded on msg 6
receiver_thread: mq_receive succeeded on msg 7
sender_thread: mq_send succeeded on msg 7
receiver_thread: mq_receive succeeded on msg 8
sender_thread: mq_send succeeded on msg 8
receiver_thread: mq_receive succeeded on msg 9
sender_thread: mq_send succeeded on msg 9
sender_thread: returning nerrors=0
mqueue_test: Killing receiver
receiver_thread: mq_receive interrupted!
receiver_thread: returning nerrors=0
mqueue_test: Canceling receiver
mqueue_test: receiver has already terminated
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 2 3
mxordblk 560a0 526f8
uordblks 4aac 83f4
fordblks 560f0 527a8
user_main: timed message queue test
timedmqueue_test: Starting sender
timedmqueue_test: Waiting for sender to complete
sender_thread: Starting
sender_thread: mq_timedsend succeeded on msg 0
sender_thread: mq_timedsend succeeded on msg 1
sender_thread: mq_timedsend succeeded on msg 2
sender_thread: mq_timedsend succeeded on msg 3
sender_thread: mq_timedsend succeeded on msg 4
sender_thread: mq_timedsend succeeded on msg 5
sender_thread: mq_timedsend succeeded on msg 6
sender_thread: mq_timedsend succeeded on msg 7
sender_thread: mq_timedsend succeeded on msg 8
sender_thread: mq_timedsend 9 timed out as expected
sender_thread: returning nerrors=0
timedmqueue_test: Starting receiver
timedmqueue_test: Waiting for receiver to complete
receiver_thread: Starting
receiver_thread: mq_timedreceive succeed on msg 0
receiver_thread: mq_timedreceive succeed on msg 1
receiver_thread: mq_timedreceive succeed on msg 2
receiver_thread: mq_timedreceive succeed on msg 3
receiver_thread: mq_timedreceive succeed on msg 4
receiver_thread: mq_timedreceive succeed on msg 5
receiver_thread: mq_timedreceive succeed on msg 6
receiver_thread: mq_timedreceive succeed on msg 7
receiver_thread: mq_timedreceive succeed on msg 8
receiver_thread: Receive 9 timed out as expected
receiver_thread: returning nerrors=0
timedmqueue_test: Test complete
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 3 2
mxordblk 526f8 54870
uordblks 83f4 6314
fordblks 527a8 54888
user_main: sigprocmask test
sigprocmask_test: SUCCESS
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 2 2
mxordblk 54870 54870
uordblks 6314 6314
fordblks 54888 54888
user_main: signal handler test
sighand_test: Initializing semaphore to 0
sighand_test: Starting waiter task
sighand_test: Started waiter_main pid=44
waiter_main: Waiter started
waiter_main: Unmasking signal 32
waiter_main: Registering signal handler
waiter_main: oact.sigaction=0 oact.sa_flags=0 oact.sa_mask=0000000000000000
waiter_main: Waiting on semaphore
sighand_test: Signaling pid=44 with signo=32 sigvalue=42
waiter_main: sem_wait() successfully interrupted by signal
waiter_main: done
sighand_test: done
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 2 1
mxordblk 54870 54850
uordblks 6314 634c
fordblks 54888 54850
user_main: nested signal handler test
signest_test: Starting signal waiter task at priority 101
waiter_main: Waiter started
waiter_main: Setting signal mask
waiter_main: Registering signal handler
signest_test: Started waiter_main pid=45
waiter_main: Waiting on semaphore
signest_test: Starting interfering task at priority 102
interfere_main: Waiting on semaphore
signest_test: Started interfere_main pid=46
signest_test: Simple case:
Total signalled 1240 Odd=620 Even=620
Total handled 1240 Odd=620 Even=620
Total nested 0 Odd=0 Even=0
signest_test: With task locking
Total signalled 2480 Odd=1240 Even=1240
Total handled 2480 Odd=1240 Even=1240
Total nested 0 Odd=0 Even=0
signest_test: With intefering thread
Total signalled 3720 Odd=1860 Even=1860
Total handled 3720 Odd=1860 Even=1860
Total nested 0 Odd=0 Even=0
signest_test: done
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 1 5
mxordblk 54850 52020
uordblks 634c 638c
fordblks 54850 54810
user_main: wdog test
wdog_test start...
wdtest_once 0 ns
wdtest_once 0 ns
wdtest_once 0 ns
wdtest_once 0 ns
wdtest_once 1 ns
wdtest_once 1 ns
wdtest_once 1 ns
wdtest_once 1 ns
wdtest_once 10 ns
wdtest_once 10 ns
wdtest_once 10 ns
wdtest_once 10 ns
wdtest_once 100 ns
wdtest_once 100 ns
wdtest_once 100 ns
wdtest_once 100 ns
wdtest_once 1000 ns
wdtest_once 1000 ns
wdtest_once 1000 ns
wdtest_once 1000 ns
wdtest_once 10000 ns
wdtest_once 10000 ns
wdtest_once 10000 ns
wdtest_once 10000 ns
wdtest_once 100000 ns
wdtest_once 100000 ns
wdtest_once 100000 ns
wdtest_once 100000 ns
wdtest_once 1000000 ns
wdtest_once 1000000 ns
wdtest_once 1000000 ns
wdtest_once 1000000 ns
wd_start with maximum delay, cancel OK, rest 1073741822
wdtest_recursive 1000000ns
wd_start with maximum delay, cancel OK, rest 1073741822
wdtest_recursive 1000000ns
wd_start with maximum delay, cancel OK, rest 1073741822
wdtest_recursive 1000000ns
wd_start with maximum delay, cancel OK, rest 1073741822
wdtest_recursive 1000000ns
recursive wdog triggered 6 times, elapsed tick 12
wdtest_recursive 10000000ns
recursive wdog triggered 6 times, elapsed tick 12
wdtest_recursive 10000000ns
recursive wdog triggered 6 times, elapsed tick 12
wdtest_recursive 10000000ns
recursive wdog triggered 6 times, elapsed tick 12
wdtest_recursive 10000000ns
recursive wdog triggered 6 times, elapsed tick 12
recursive wdog triggered 6 times, elapsed tick 12
recursive wdog triggered 6 times, elapsed tick 12
recursive wdog triggered 6 times, elapsed tick 12
wdog_test end...
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 5 5
mxordblk 52020 52020
uordblks 638c 662c
fordblks 54810 54570
user_main: POSIX timer test
timer_test: Initializing semaphore to 0
timer_test: Unmasking signal 32
timer_test: Registering signal handler
timer_test: oact.sigaction=0 oact.sa_flags=0 oact.sa_mask=0000000000000000
timer_test: Creating timer
timer_test: Starting timer
timer_test: Waiting on semaphore
timer_expiration: Received signal 32
timer_expiration: sival_int=42
timer_expiration: si_code=2 (SI_TIMER)
timer_expiration: ucontext=0
timer_test: sem_wait() successfully interrupted by signal
timer_test: g_nsigreceived=1
timer_test: Waiting on semaphore
timer_expiration: Received signal 32
timer_expiration: sival_int=42
timer_expiration: si_code=2 (SI_TIMER)
timer_expiration: ucontext=0
timer_test: sem_wait() successfully interrupted by signal
timer_test: g_nsigreceived=2
timer_test: Waiting on semaphore
timer_expiration: Received signal 32
timer_expiration: sival_int=42
timer_expiration: si_code=2 (SI_TIMER)
timer_expiration: ucontext=0
timer_test: sem_wait() successfully interrupted by signal
timer_test: g_nsigreceived=3
timer_test: Waiting on semaphore
timer_expiration: Received signal 32
timer_expiration: sival_int=42
timer_expiration: si_code=2 (SI_TIMER)
timer_expiration: ucontext=0
timer_test: sem_wait() successfully interrupted by signal
timer_test: g_nsigreceived=4
timer_test: Waiting on semaphore
timer_expiration: Received signal 32
timer_expiration: sival_int=42
timer_expiration: si_code=2 (SI_TIMER)
timer_expiration: ucontext=0
timer_test: sem_wait() successfully interrupted by signal
timer_test: g_nsigreceived=5
timer_test: Deleting timer
timer_test: done
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 5 5
mxordblk 52020 52020
uordblks 662c 42ac
fordblks 54570 568f0
user_main: round-robin scheduler test
rr_test: Set thread priority to 1
rr_test: Set thread policy to SCHED_RR
rr_test: Starting first get_primes_thread
First get_primes_thread: 55
rr_test: Starting second get_primes_thread
Second get_primes_thread: 56
rr_test: Waiting for threads to complete -- this should take awhile
If RR scheduling is working, they should start and complete at
about the same time
get_primes_thread id=1 started, looking for primes < 10000, doing 10 run(s)
get_primes_thread id=2 started, looking for primes < 10000, doing 10 run(s)
get_primes_thread id=1 finished, found 1230 primes, last one was 9973
get_primes_thread id=2 finished, found 1230 primes, last one was 9973
rr_test: Done
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 5 5
mxordblk 52020 52020
uordblks 42ac 546c
fordblks 568f0 55730
user_main: barrier test
barrier_test: Initializing barrier
barrier_test: Thread 0 created
barrier_test: Thread 1 created
barrier_test: Thread 2 created
barrier_test: Thread 3 created
barrier_func: Thread 0 started
barrier_func: Thread 1 started
barrier_func: Thread 2 started
barrier_func: Thread 3 started
barrier_test: Thread 4 created
barrier_func: Thread 4 started
barrier_test: Thread 5 created
barrier_func: Thread 5 started
barrier_test: Thread 6 created
barrier_func: Thread 6 started
barrier_test: Thread 7 created
barrier_func: Thread 7 started
barrier_func: Thread 0 calling pthread_barrier_wait()
barrier_func: Thread 1 calling pthread_barrier_wait()
barrier_func: Thread 2 calling pthread_barrier_wait()
barrier_func: Thread 3 calling pthread_barrier_wait()
barrier_func: Thread 4 calling pthread_barrier_wait()
barrier_func: Thread 5 calling pthread_barrier_wait()
barrier_func: Thread 6 calling pthread_barrier_wait()
barrier_func: Thread 7 calling pthread_barrier_wait()
barrier_func: Thread 7, back with status=PTHREAD_BARRIER_SERIAL_THREAD (I AM SPECIAL)
barrier_func: Thread 0, back with status=0 (I am not special)
barrier_func: Thread 1, back with status=0 (I am not special)
barrier_func: Thread 2, back with status=0 (I am not special)
barrier_func: Thread 3, back with status=0 (I am not special)
barrier_func: Thread 4, back with status=0 (I am not special)
barrier_func: Thread 5, back with status=0 (I am not special)
barrier_func: Thread 6, back with status=0 (I am not special)
barrier_func: Thread 7 done
barrier_func: Thread 0 done
barrier_func: Thread 1 done
barrier_func: Thread 2 done
barrier_test: Thread 0 completed with result=0
barrier_test: Thread 1 completed with result=0
barrier_test: Thread 2 completed with result=0
barrier_func: Thread 3 done
barrier_func: Thread 4 done
barrier_test: Thread 3 completed with result=0
barrier_test: Thread 4 completed with result=0
barrier_func: Thread 5 done
barrier_func: Thread 6 done
barrier_test: Thread 5 completed with result=0
barrier_test: Thread 6 completed with result=0
barrier_test: Thread 7 completed with result=0
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 5 7
mxordblk 52020 52020
uordblks 546c 4b8c
fordblks 55730 56010
user_main: scheduler lock test
sched_lock: Starting lowpri_thread at 97
sched_lock: Set lowpri_thread priority to 97
sched_lock: Starting highpri_thread at 98
sched_lock: Set highpri_thread priority to 98
sched_lock: Waiting...
sched_lock: PASSED No pre-emption occurred while scheduler was locked.
sched_lock: Starting lowpri_thread at 97
sched_lock: Set lowpri_thread priority to 97
sched_lock: Starting highpri_thread at 98
sched_lock: Set highpri_thread priority to 98
sched_lock: Waiting...
sched_lock: PASSED No pre-emption occurred while scheduler was locked.
sched_lock: Finished
End of test memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 7 6
mxordblk 52020 52020
uordblks 4b8c 4b8c
fordblks 56010 56010
user_main: vfork() test
vfork_test: Child 73 ran successfully
Final memory usage:
VARIABLE BEFORE AFTER
======== ======== ========
arena 5ab9c 5ab9c
ordblks 1 5
mxordblk 56980 52020
uordblks 421c 62ac
fordblks 56980 548f0
user_main: Exiting
ostest_main: Exiting with status 0
nsh> free
total used free maxused maxfree nused nfree name
371612 5788 365824 44600 346224 23 3 Umem
nsh> ~
[EOT]
+ for CFG in $CONFIGS
+ set +x
===>
===> ESP32C3: esp32c3-devkit:coremark
===>
+ /usr/bin/time -h gmake clean distclean -j24 CROSSDEV=riscv32-esp-elf-
5,19s real 3,67s user 5,10s sys
+ /usr/bin/time -h ./tools/configure.sh -B esp32c3-devkit:coremark
Copy files
Select CONFIG_HOST_BSD=y
Refreshing...
CP: arch/dummy/Kconfig to /tmp/nuttx/nuttx.git/arch/dummy/dummy_kconfig
CP: boards/dummy/Kconfig to /tmp/nuttx/nuttx.git/boards/dummy/dummy_kconfig
LN: platform/board to /tmp/nuttx/nuttx-apps.git/platform/dummy
LN: include/arch to arch/risc-v/include
LN: include/arch/board to /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/include
LN: drivers/platform to /tmp/nuttx/nuttx.git/drivers/dummy
LN: include/arch/chip to /tmp/nuttx/nuttx.git/arch/risc-v/include/esp32c3-legacy
LN: arch/risc-v/src/chip to /tmp/nuttx/nuttx.git/arch/risc-v/src/esp32c3-legacy
LN: arch/risc-v/src/board to /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common
LN: arch/risc-v/src/board/board to /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/src
mkkconfig in /tmp/nuttx/nuttx-apps.git/audioutils
mkkconfig in /tmp/nuttx/nuttx-apps.git/benchmarks
mkkconfig in /tmp/nuttx/nuttx-apps.git/boot
mkkconfig in /tmp/nuttx/nuttx-apps.git/canutils
mkkconfig in /tmp/nuttx/nuttx-apps.git/crypto
mkkconfig in /tmp/nuttx/nuttx-apps.git/database
mkkconfig in /tmp/nuttx/nuttx-apps.git/examples/mcuboot
mkkconfig in /tmp/nuttx/nuttx-apps.git/examples/module
mkkconfig in /tmp/nuttx/nuttx-apps.git/examples/rust
mkkconfig in /tmp/nuttx/nuttx-apps.git/examples/sotest
mkkconfig in /tmp/nuttx/nuttx-apps.git/examples
mkkconfig in /tmp/nuttx/nuttx-apps.git/fsutils
mkkconfig in /tmp/nuttx/nuttx-apps.git/games
mkkconfig in /tmp/nuttx/nuttx-apps.git/graphics
mkkconfig in /tmp/nuttx/nuttx-apps.git/industry
mkkconfig in /tmp/nuttx/nuttx-apps.git/inertial
mkkconfig in /tmp/nuttx/nuttx-apps.git/interpreters/luamodules
mkkconfig in /tmp/nuttx/nuttx-apps.git/interpreters
mkkconfig in /tmp/nuttx/nuttx-apps.git/logging
mkkconfig in /tmp/nuttx/nuttx-apps.git/lte
mkkconfig in /tmp/nuttx/nuttx-apps.git/math
mkkconfig in /tmp/nuttx/nuttx-apps.git/mlearning
mkkconfig in /tmp/nuttx/nuttx-apps.git/netutils
mkkconfig in /tmp/nuttx/nuttx-apps.git/sdr
mkkconfig in /tmp/nuttx/nuttx-apps.git/system
mkkconfig in /tmp/nuttx/nuttx-apps.git/tee
mkkconfig in /tmp/nuttx/nuttx-apps.git/testing/arch
mkkconfig in /tmp/nuttx/nuttx-apps.git/testing/cxx
mkkconfig in /tmp/nuttx/nuttx-apps.git/testing/drivers
mkkconfig in /tmp/nuttx/nuttx-apps.git/testing/fs
mkkconfig in /tmp/nuttx/nuttx-apps.git/testing/libc
mkkconfig in /tmp/nuttx/nuttx-apps.git/testing/mm
mkkconfig in /tmp/nuttx/nuttx-apps.git/testing/sched
mkkconfig in /tmp/nuttx/nuttx-apps.git/testing
mkkconfig in /tmp/nuttx/nuttx-apps.git/videoutils
mkkconfig in /tmp/nuttx/nuttx-apps.git/wireless/bluetooth
mkkconfig in /tmp/nuttx/nuttx-apps.git/wireless/ieee802154
mkkconfig in /tmp/nuttx/nuttx-apps.git/wireless
mkkconfig in /tmp/nuttx/nuttx-apps.git
#
# configuration written to .config
#
1,58s real 0,92s user 0,84s sys
+ /usr/bin/time -h gmake -j24 CROSSDEV=riscv32-esp-elf-
Create version.h
LN: platform/board to /tmp/nuttx/nuttx-apps.git/platform/dummy
Downloading: https://github.com/eembc/coremark/archive/main.zip
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed
0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0
0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0
0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0
100 479k 0 479k 0 0 680k 0 --:--:-- --:--:-- --:--:-- 680k
Unpacking: main.zip -> coremark
Hmm... Looks like a unified diff to me...
The text leading up to this was:
--------------------------
|--- coremark/posix/core_portme.c
|+++ coremark/posix/core_portme.c
--------------------------
Patching file coremark/posix/core_portme.c using Plan A...
Hunk #1 succeeded at 208.
done
Register: dd
Register: coremark

CC: clock/clock_settime.c 
CC: clock/clock_perf.c 
CC: clock/clock_systime_ticks.c 
CC: environ/env_dup.c 
CC: environ/env_release.c 
CC: clock/clock.c 
CC: environ/env_findvar.c 
CC: clock/clock_initialize.c 
CC: clock/clock_gettime.c 
CC: clock/clock_systime_timespec.c 
CC: clock/clock_realtime2absticks.c 
CC: environ/env_getenvironptr.c 
CC: environ/env_clearenv.c 
CC: environ/env_getenv.c 
CC: environ/env_putenv.c 
CC: environ/env_setenv.c 
CC: environ/env_removevar.c 
CC: environ/env_foreach.c 
CC: group/group_join.c 
CC: group/group_leave.c 
CC: group/group_create.c 
CC: group/group_setupidlefiles.c 
CC: group/group_setuptaskfiles.c 
CC: environ/env_unsetenv.c 


CC: group/group_foreachchild.c 

CC: group/group_killchildren.c 







CC: group/group_signal.c 

CC: group/group_waiter.c 
CC: init/nx_start.c 

CC: init/nx_bringup.c 
CC: instrument/instrument.c 
CC: irq/irq_initialize.c 
CC: irq/irq_attach.c 
CC: irq/irq_dispatch.c 

CC: irq/irq_unexpectedisr.c 


CC: irq/irq_attach_thread.c 
CC: irq/irq_attach_wqueue.c 
CC: misc/assert.c 


CC: misc/panic_notifier.c 
CC: misc/reboot_notifier.c 






CC: mqueue/mq_initialize.c 
CC: mqueue/mq_waitirq.c 
CC: mqueue/mq_recover.c 
CC: mqueue/mq_send.c 
CC: mqueue/mq_sndinternal.c 

CC: mqueue/mq_receive.c 
CC: mqueue/mq_rcvinternal.c 

CC: mqueue/mq_getattr.c 



CC: mqueue/mq_msgfree.c 
CC: mqueue/mq_msgqalloc.c 

CC: mqueue/mq_msgqfree.c 
CC: mqueue/mq_setattr.c 

CC: mqueue/mq_notify.c 



CC: mqueue/msgctl.c 
CC: mqueue/msgget.c 

CC: mqueue/msginternal.c 
CC: mqueue/msgrcv.c 


CC: mqueue/msgsnd.c 

CC: pthread/pthread_create.c 

CC: pthread/pthread_exit.c 

CC: pthread/pthread_join.c 

CC: pthread/pthread_detach.c 


CC: pthread/pthread_getschedparam.c 
CC: pthread/pthread_setschedparam.c 
CC: pthread/pthread_mutexinit.c 



CC: pthread/pthread_mutexdestroy.c 

CC: pthread/pthread_mutextimedlock.c 

CC: pthread/pthread_mutextrylock.c 
CC: pthread/pthread_mutexunlock.c 
CC: pthread/pthread_condwait.c 


CC: pthread/pthread_condsignal.c 

CC: pthread/pthread_condbroadcast.c 
CC: pthread/pthread_condclockwait.c 



CC: pthread/pthread_sigmask.c 
CC: pthread/pthread_cancel.c 
CC: pthread/pthread_completejoin.c 









CC: pthread/pthread_findjoininfo.c 
CC: pthread/pthread_release.c 
CC: pthread/pthread_setschedprio.c 

CC: pthread/pthread_mutex.c 
CC: pthread/pthread_mutexconsistent.c 
CC: sched/sched_getfiles.c 
CC: sched/sched_profil.c 
CC: sched/sched_addreadytorun.c 
CC: sched/sched_removereadytorun.c 

CC: sched/sched_addblocked.c 




CC: sched/sched_removeblocked.c 

CC: drivers_initialize.c 
CC: loop/losetup.c 
CC: sched/sched_gettcb.c 
CC: misc/dev_null.c 


CC: misc/dev_zero.c 

CC: sched/sched_verifytcb.c 
CC: misc/ramdisk.c 

CC: sched/sched_releasetcb.c 
CC: pipes/pipe.c 
CC: sched/sched_setparam.c 


CC: pipes/fifo.c 

CC: pipes/pipe_common.c 



CC: serial/serial.c 
CC: serial/serial_io.c 
CC: syslog/vsyslog.c 





CC: syslog/syslog_channel.c 

CC: sched/sched_setpriority.c 
CC: syslog/syslog_write.c 
CC: sched/sched_getparam.c 

CC: syslog/syslog_flush.c 

CC: sched/sched_setscheduler.c 
CC: syslog/syslog_initialize.c 




CC: sched/sched_getscheduler.c 
CC: sched/sched_yield.c 
CC: sched/sched_rrgetinterval.c 
CC: sched/sched_foreach.c 



CC: sched/sched_lock.c 
CC: sched/sched_unlock.c 
CC: sched/sched_lockcount.c 
CC: sched/sched_idletask.c 


CC: sched/sched_self.c 
CC: sched/sched_get_stackinfo.c 

CC: sched/sched_get_tls.c 




CC: sched/sched_sysinfo.c 




CC: sched/sched_get_stateinfo.c 
CC: sched/sched_getcpu.c 
CC: sched/sched_reprioritizertr.c 

CC: sched/sched_mergepending.c 
CC: sched/sched_waitpid.c 
CC: sched/sched_roundrobin.c 

CC: sched/sched_resumescheduler.c 

CC: sched/sched_processtimer.c 

CC: semaphore/sem_destroy.c 
CC: semaphore/sem_wait.c 

CC: semaphore/sem_trywait.c 

CC: semaphore/sem_tickwait.c 



CC: semaphore/sem_timedwait.c 
CC: semaphore/sem_clockwait.c 

CC: semaphore/sem_timeout.c 
CC: semaphore/sem_post.c 
CC: semaphore/sem_recover.c 

CC: semaphore/sem_reset.c 

CC: semaphore/sem_waitirq.c 

CC: semaphore/sem_rw.c 

CC: signal/sig_initialize.c 

CC: signal/sig_action.c 

CC: signal/sig_procmask.c 


CC: signal/sig_pending.c 



CC: signal/sig_suspend.c 

CC: signal/sig_kill.c 
CC: signal/sig_tgkill.c 
CC: signal/sig_queue.c 



CC: signal/sig_waitinfo.c 

CC: signal/sig_timedwait.c 
CC: signal/sig_findaction.c 
CC: signal/sig_allocpendingsigaction.c 
CC: signal/sig_releasependingsigaction.c 




CC: signal/sig_unmaskpendingsignal.c 
CC: signal/sig_removependingsignal.c 
CC: signal/sig_releasependingsignal.c 
CC: signal/sig_lowest.c 


CC: signal/sig_notification.c 

CC: signal/sig_cleanup.c 
CC: signal/sig_dispatch.c 

CC: signal/sig_deliver.c 


CC: signal/sig_pause.c 
CC: dummy.c 


CC: signal/sig_nanosleep.c 


CC: signal/sig_usleep.c 



CC: signal/sig_sleep.c 


CC: signal/sig_ppoll.c 
CC: signal/sig_pselect.c 

CC: task/task_argvstr.c 
CC: task/task_create.c 
CC: task/task_init.c 

CC: task/task_setup.c 
CC: task/task_activate.c 

CC: task/task_start.c 
CC: task/task_delete.c 



CC: task/task_exit.c 
CC: task/task_exithook.c 

CC: task/task_getgroup.c 

CC: task/task_getpid.c 

CC: task/task_prctl.c 
CC: task/task_recover.c 


CC: task/task_restart.c 

CC: task/task_spawnparms.c 
CC: task/task_cancelpt.c 



CC: task/task_terminate.c 
CC: task/task_gettid.c 

CC: task/exit.c 
CC: task/task_join.c 




CC: task/task_fork.c 

CC: task/task_spawn.c 
CC: timer/timer_initialize.c 


CC: timer/timer_create.c 
CC: timer/timer_delete.c 
CC: timer/timer_getoverrun.c 


CC: timer/timer_getitimer.c 

CC: timer/timer_gettime.c 
CC: timer/timer_setitimer.c 
CC: timer/timer_settime.c 


CC: timer/timer_release.c 


CC: tls/task_initinfo.c 
CC: tls/task_uninitinfo.c 
CC: tls/tls_initinfo.c 




CC: tls/tls_dupinfo.c 

CC: wdog/wd_initialize.c 
CC: wdog/wd_start.c 


CC: wdog/wd_cancel.c 

CC: wdog/wd_gettime.c 
CC: wdog/wd_recover.c 




















CC: assert/lib_assert.c 
CC: assert/lib_stackchk.c 

CC: ctype/lib_isalnum.c 
CC: ctype/lib_isalpha.c 
CC: ctype/lib_isascii.c 
CC: ctype/lib_isblank.c 
CC: ctype/lib_iscntrl.c 
CC: ctype/lib_isdigit.c 
CC: ctype/lib_isgraph.c 
CC: ctype/lib_islower.c 
CC: ctype/lib_isprint.c 
CC: ctype/lib_ispunct.c 
CC: ctype/lib_isspace.c 
CC: ctype/lib_isupper.c 
CC: ctype/lib_isxdigit.c 
CC: ctype/lib_tolower.c 
CC: ctype/lib_toupper.c 
CC: ctype/lib_ctype.c 
CC: dirent/lib_readdirr.c 
CC: dirent/lib_telldir.c 
CC: dirent/lib_alphasort.c 
CC: dirent/lib_scandir.c 




CC: dirent/lib_ftw.c 




CC: dirent/lib_nftw.c 



CC: dirent/lib_opendir.c 


CC: dirent/lib_fdopendir.c 
CC: dirent/lib_closedir.c 

CC: dirent/lib_readdir.c 

CC: dirent/lib_rewinddir.c 

CC: dirent/lib_seekdir.c 
CC: dirent/lib_dirfd.c 


CC: dirent/lib_versionsort.c 

CC: dlfcn/lib_dlfind_object.c 
CC: errno/lib_errno.c 
CC: fixedmath/lib_fixedmath.c 
CC: fixedmath/lib_b16sin.c 
CC: fixedmath/lib_b16cos.c 
CC: fixedmath/lib_b16atan2.c 
CC: fixedmath/lib_ubsqrt.c 

CC: grp/lib_getgrgid.c 
CC: grp/lib_getgrgidr.c 
CC: grp/lib_getgrnam.c 
CC: grp/lib_getgrnamr.c 


CC: grp/lib_initgroups.c 
CC: grp/lib_getgrbuf.c 




CC: grp/lib_getgrbufr.c 


CC: inttypes/lib_imaxabs.c 
CC: inttypes/lib_imaxdiv.c 

CC: inttypes/lib_strtoimax.c 
CC: inttypes/lib_strtoumax.c 
CC: libgen/lib_basename.c 




CC: libgen/lib_dirname.c 


CC: machine/arch_atomic.c 
CC: misc/lib_bitmap.c 
CC: misc/lib_circbuf.c 

CC: misc/lib_mknod.c 




CC: misc/lib_umask.c 


CC: misc/lib_utsname.c 
CC: misc/lib_getrandom.c 
CC: misc/lib_xorshift128.c 
CC: misc/lib_tea_encrypt.c 
CC: misc/lib_tea_decrypt.c 
CC: misc/lib_cxx_initialize.c 

CC: misc/lib_impure.c 
CC: misc/lib_memfd.c 
CC: misc/lib_mutex.c 


CC: misc/lib_fchmodat.c 
CC: misc/lib_fstatat.c 

CC: misc/lib_getfullpath.c 


CC: misc/lib_openat.c 
CC: misc/lib_mkdirat.c 


CC: misc/lib_utimensat.c 
CC: mm_heap/mm_initialize.c 
CC: misc/lib_mallopt.c 



CC: mm_heap/mm_lock.c 


CC: mm_heap/mm_malloc_size.c 



CC: mm_heap/mm_brkaddr.c 
CC: mm_heap/mm_shrinkchunk.c 
CC: misc/lib_idr.c 

CC: misc/lib_getnprocs.c 
CC: mm_heap/mm_calloc.c 
CC: misc/lib_tempbuffer.c 

CC: misc/lib_umul32.c 


CC: mm_heap/mm_extend.c 
CC: mm_heap/mm_free.c 

CC: mm_heap/mm_mallinfo.c 

CC: mm_heap/mm_malloc.c 



CC: misc/lib_umul32x64.c 

CC: mm_heap/mm_foreach.c 
CC: misc/lib_umul64.c 

CC: misc/lib_uadd32x64.c 
CC: mm_heap/mm_memalign.c 

CC: mm_heap/mm_realloc.c 


CC: misc/lib_uadd64.c 
CC: mm_heap/mm_zalloc.c 


CC: mm_heap/mm_heapmember.c 
CC: misc/lib_usub64x32.c 


CC: misc/lib_usub64.c 

CC: mm_heap/mm_memdump.c 



CC: umm_heap/umm_globals.c 
CC: misc/lib_dumpbuffer.c 
CC: umm_heap/umm_initialize.c 

CC: misc/lib_dumpvbuffer.c 
CC: misc/lib_fnmatch.c 


CC: umm_heap/umm_addregion.c 


CC: misc/lib_debug.c 
CC: umm_heap/umm_malloc_size.c 
CC: misc/lib_crc64.c 


CC: umm_heap/umm_brkaddr.c 

CC: misc/lib_crc32.c 
CC: umm_heap/umm_calloc.c 

CC: umm_heap/umm_extend.c 


CC: umm_heap/umm_free.c 
CC: misc/lib_crc16.c 


CC: umm_heap/umm_mallinfo.c 

CC: misc/lib_crc16ccitt.c 

CC: misc/lib_crc8.c 

CC: misc/lib_crc8ccitt.c 
CC: umm_heap/umm_malloc.c 




CC: umm_heap/umm_memalign.c 
CC: misc/lib_crc8table.c 


CC: umm_heap/umm_realloc.c 

CC: misc/lib_crc8rohc.c 

CC: umm_heap/umm_zalloc.c 
CC: misc/lib_glob.c 
CC: umm_heap/umm_heapmember.c 



CC: umm_heap/umm_memdump.c 

CC: misc/lib_backtrace.c 
CC: mempool/mempool.c 
CC: misc/lib_ftok.c 
CC: misc/lib_err.c 

CC: misc/lib_instrument.c 



CC: mempool/mempool_multiple.c 

CC: mempool/mempool_procfs.c 


CC: kasan/hook.c 

CC: map/mm_map.c 
CC: misc/lib_crc16ibm.c 


CC: misc/lib_crc16xmodem.c 



CC: net/lib_addrconfig.c 
CC: net/lib_base64.c 

CC: net/lib_htons.c 
CC: net/lib_htonl.c 


CC: net/lib_htonq.c 
CC: net/lib_inetaddr.c 
CC: net/lib_inetaton.c 
CC: net/lib_inetntoa.c 
CC: net/lib_inetntop.c 


CC: net/lib_inetpton.c 


CC: net/lib_inetnetwork.c 





CC: net/lib_etherntoa.c 

CC: net/lib_etheraton.c 
CC: obstack/lib_obstack_init.c 

CC: obstack/lib_obstack_alloc.c 
CC: obstack/lib_obstack_copy.c 
CC: obstack/lib_obstack_free.c 



CC: obstack/lib_obstack_make_room.c 
CC: obstack/lib_obstack_blank.c 
CC: obstack/lib_obstack_grow.c 
AS: chip/esp32c3_vectors.S 
AS: common/riscv_exception_common.S 
CC: obstack/lib_obstack_finish.c 


AS: common/riscv_saveusercontext.S 
AS: common/fork.S 

CC: chip/esp32c3_allocateheap.c 


CC: chip/esp32c3_start.c 
CC: obstack/lib_obstack_object_size.c 



CC: obstack/lib_obstack_room.c 




CC: chip/esp32c3_wdt.c 

CC: chip/esp32c3_idle.c 
CC: obstack/lib_obstack_printf.c 


CC: chip/esp32c3_irq.c 
CC: obstack/lib_obstack_vprintf.c 
CC: chip/esp32c3_libc_stubs.c 

CC: obstack/lib_obstack_malloc.c 
CC: chip/esp32c3_clockconfig.c 


CC: chip/esp32c3_rtc_gpio.c 
CC: chip/esp32c3_gpio.c 

CC: chip/esp32c3_lowputc.c 
CC: pthread/pthread_attr_init.c 

CC: chip/esp32c3_serial.c 

CC: pthread/pthread_attr_destroy.c 
CC: chip/esp32c3_systemreset.c 

CC: chip/esp32c3_resetcause.c 


CC: chip/esp32c3_uid.c 
CC: pthread/pthread_attr_setschedpolicy.c 


CC: chip/esp32c3_perf.c 
CC: pthread/pthread_attr_getschedpolicy.c 

CC: pthread/pthread_attr_setinheritsched.c 



CC: chip/esp32c3_region.c 
CC: pthread/pthread_attr_getinheritsched.c 



CC: chip/esp32c3_timerisr.c 

CC: chip/esp32c3_rtc.c 

CC: pthread/pthread_attr_setdetachstate.c 
CC: chip/esp32c3_brownout.c 
CC: pthread/pthread_attr_getdetachstate.c 


CC: pthread/pthread_attr_setstackaddr.c 
CC: common/riscv_initialize.c 
CC: pthread/pthread_attr_getstackaddr.c 



CC: common/riscv_swint.c 


CC: common/riscv_mtimer.c 
CC: pthread/pthread_attr_setstacksize.c 
CC: common/riscv_allocateheap.c 
CC: pthread/pthread_attr_getstacksize.c 

CC: common/riscv_createstack.c 

CC: pthread/pthread_attr_setstack.c 





CC: common/riscv_cpuinfo.c 

CC: common/riscv_cpuidlestack.c 
CC: pthread/pthread_attr_getstack.c 


CC: common/riscv_doirq.c 
CC: pthread/pthread_attr_setschedparam.c 
CC: pthread/pthread_attr_getschedparam.c 
CC: common/riscv_exit.c 
CC: common/riscv_exception.c 

CC: pthread/pthread_attr_setscope.c 

CC: pthread/pthread_attr_getscope.c 


CC: common/riscv_getnewintctx.c 


CC: pthread/pthread_attr_setguardsize.c 
CC: common/riscv_getintstack.c 
CC: common/riscv_initialstate.c 


CC: common/riscv_modifyreg32.c 

CC: pthread/pthread_attr_getguardsize.c 

CC: pthread/pthread_barrierattr_init.c 

CC: pthread/pthread_barrierattr_destroy.c 

CC: common/riscv_nputs.c 


CC: common/riscv_releasestack.c 


CC: common/riscv_registerdump.c 

CC: common/riscv_stackframe.c 
CC: pthread/pthread_barrierattr_getpshared.c 
CC: common/riscv_schedulesigaction.c 

CC: common/riscv_sigdeliver.c 
CC: common/riscv_switchcontext.c 


CC: common/riscv_usestack.c 
CC: pthread/pthread_barrierattr_setpshared.c 




CC: pthread/pthread_barrierinit.c 
CC: common/riscv_tcbinfo.c 

CC: common/riscv_idle.c 


CC: pthread/pthread_barrierdestroy.c 
CC: common/riscv_mdelay.c 
CC: pthread/pthread_barrierwait.c 



CC: common/riscv_udelay.c 

CC: pthread/pthread_condattr_init.c 

CC: pthread/pthread_condattr_destroy.c 
CC: pthread/pthread_condattr_getpshared.c 


CC: pthread/pthread_condattr_setpshared.c 
CC: pthread/pthread_condattr_setclock.c 



CC: pthread/pthread_condattr_getclock.c 

CC: common/riscv_debug.c 


CC: common/riscv_fork.c 

CC: pthread/pthread_condinit.c 
CC: common/riscv_pmp.c 


CC: pthread/pthread_conddestroy.c 
CC: pthread/pthread_condtimedwait.c 


CC: pthread/pthread_create.c 
CC: pthread/pthread_exit.c 

CC: pthread/pthread_kill.c 
CC: pthread/pthread_setname_np.c 


CC: pthread/pthread_getname_np.c 
CC: pthread/pthread_get_stackaddr_np.c 

CC: pthread/pthread_get_stacksize_np.c 



CC: pthread/pthread_mutexattr_init.c 

CC: pthread/pthread_mutexattr_destroy.c 
CC: pthread/pthread_mutexattr_getpshared.c 
CC: pthread/pthread_mutexattr_setpshared.c 


CC: pthread/pthread_mutexattr_setprotocol.c 

CC: pthread/pthread_mutexattr_getprotocol.c 
CC: pthread/pthread_mutexattr_settype.c 
CC: coremark/core_list_join.c 

CC: board/dummy.c 


CC: coremark/core_main.c 


CC: pthread/pthread_mutexattr_gettype.c 
CC: coremark/core_matrix.c 
CC: pthread/pthread_mutexattr_setrobust.c 
CC: coremark/posix/core_portme.c 


CC: coremark/core_state.c 
CC: coremark/core_util.c 


CC: dd_main.c 
CC: pthread/pthread_mutexattr_getrobust.c 

CC: pthread/pthread_mutexattr_setprioceiling.c 


CC: pthread/pthread_mutexattr_getprioceiling.c 

CC: pthread/pthread_mutex_lock.c 

CC: pthread/pthread_mutex_setprioceiling.c 


CC: pthread/pthread_mutex_getprioceiling.c 
CC: pthread/pthread_once.c 
CC: pthread/pthread_yield.c 



CC: pthread/pthread_atfork.c 

CC: pthread/pthread_rwlockattr_init.c 
CC: pthread/pthread_rwlockattr_destroy.c 
CC: pthread/pthread_rwlockattr_getpshared.c 

CC: pthread/pthread_rwlockattr_setpshared.c 
CC: pthread/pthread_rwlock.c 



CC: pthread/pthread_rwlock_rdlock.c 
CC: pthread/pthread_rwlock_wrlock.c 


CC: pthread/pthread_setcancelstate.c 

CC: pthread/pthread_setcanceltype.c 
CC: pthread/pthread_testcancel.c 

CC: pthread/pthread_getcpuclockid.c 
CC: pthread/pthread_self.c 

CC: pthread/pthread_gettid_np.c 

CC: pthread/pthread_concurrency.c 



CC: pwd/lib_getpwnam.c 

CC: pwd/lib_getpwnamr.c 
CC: pwd/lib_getpwuid.c 

CC: pwd/lib_getpwuidr.c 
CC: pwd/lib_getpwent.c 


CC: pwd/lib_pwd_globals.c 
CC: pwd/lib_getspnam.c 
CC: fs_initialize.c 



CC: fs_heap.c 


CC: inode/fs_files.c 
CC: inode/fs_foreachinode.c 
CC: pwd/lib_getpwbuf.c 
CC: pwd/lib_getpwbufr.c 



CC: queue/queue.c 
CC: inode/fs_inode.c 




CC: inode/fs_inodeaddref.c 
CC: inode/fs_inodebasename.c 

CC: inode/fs_inodefind.c 


CC: inode/fs_inodefree.c 
CC: sched/sched_getprioritymax.c 
CC: sched/sched_getprioritymin.c 


CC: sched/clock_getcpuclockid.c 

CC: inode/fs_inodegetpath.c 


CC: inode/fs_inoderelease.c 
CC: sched/clock_getres.c 
CC: inode/fs_inoderemove.c 

CC: sched/task_cancelpt.c 

CC: inode/fs_inodereserve.c 


CC: inode/fs_inodesearch.c 

CC: sched/task_setcancelstate.c 
CC: sched/task_setcanceltype.c 

CC: sched/task_testcancel.c 







CC: vfs/fs_chstat.c 

CC: sched/task_gettid.c 

CC: vfs/fs_close.c 
CC: sched/task_startup.c 
CC: vfs/fs_dup.c 
CC: vfs/fs_dup2.c 
CC: vfs/fs_dup3.c 
CC: search/hcreate_r.c 
CC: vfs/fs_fcntl.c 


CC: search/hcreate.c 
CC: vfs/fs_epoll.c 


CC: vfs/fs_fchstat.c 


CC: search/hash_func.c 
CC: vfs/fs_fstat.c 
CC: vfs/fs_fstatfs.c 

CC: semaphore/sem_init.c 



CC: vfs/fs_ioctl.c 
CC: semaphore/sem_setprotocol.c 

CC: vfs/fs_lseek.c 
CC: semaphore/sem_getprotocol.c 


CC: vfs/fs_mkdir.c 
CC: vfs/fs_open.c 

CC: vfs/fs_poll.c 


CC: semaphore/sem_getvalue.c 

CC: vfs/fs_pread.c 

CC: vfs/fs_pwrite.c 

CC: semaphore/sem_destroy.c 


CC: semaphore/sem_wait.c 
CC: vfs/fs_read.c 
CC: vfs/fs_rename.c 
CC: vfs/fs_rmdir.c 



CC: vfs/fs_select.c 
CC: semaphore/sem_trywait.c 
CC: semaphore/sem_timedwait.c 

CC: semaphore/sem_clockwait.c 

CC: vfs/fs_sendfile.c 

CC: semaphore/sem_post.c 



CC: vfs/fs_stat.c 
CC: vfs/fs_statfs.c 

CC: vfs/fs_uio.c 
CC: signal/sig_addset.c 


CC: signal/sig_delset.c 


CC: signal/sig_emptyset.c 
CC: signal/sig_fillset.c 



CC: signal/sig_nandset.c 
CC: vfs/fs_unlink.c 
CC: vfs/fs_write.c 
CC: vfs/fs_dir.c 



CC: binfmt_globals.c 
CC: vfs/fs_fsync.c 
CC: vfs/fs_syncfs.c 

CC: signal/sig_andset.c 
CC: binfmt_initialize.c 

CC: binfmt_register.c 




CC: vfs/fs_truncate.c 
CC: signal/sig_orset.c 

CC: binfmt_unregister.c 
CC: signal/sig_xorset.c 


CC: vfs/fs_link.c 



CC: binfmt_loadmodule.c 
CC: signal/sig_isemptyset.c 
CC: binfmt_unloadmodule.c 

CC: vfs/fs_symlink.c 
CC: binfmt_execmodule.c 


CC: binfmt_exec.c 
CC: binfmt_copyargv.c 



CC: binfmt_copyactions.c 
CC: vfs/fs_readlink.c 
CC: binfmt_dumpmodule.c 



CC: signal/sig_killpg.c 
CC: driver/fs_registerdriver.c 
CC: signal/sig_altstack.c 

CC: driver/fs_unregisterdriver.c 

CC: signal/sig_interrupt.c 


CC: driver/fs_registerpipedriver.c 
CC: signal/sig_hold.c 


CC: driver/fs_unregisterpipedriver.c 



CC: signal/sig_ignore.c 



CC: signal/sig_ismember.c 
CC: driver/fs_registerblockdriver.c 
CC: driver/fs_unregisterblockdriver.c 
CC: driver/fs_findblockdriver.c 

CC: driver/fs_openblockdriver.c 

CC: signal/sig_pause.c 

CC: signal/sig_psignal.c 
CC: signal/sig_raise.c 


CC: driver/fs_closeblockdriver.c 

CC: driver/fs_blockpartition.c 
CC: signal/sig_relse.c 
CC: driver/fs_findmtddriver.c 



CC: signal/sig_set.c 
CC: driver/fs_closemtddriver.c 
CC: signal/sig_signal.c 


CC: driver/fs_blockmerge.c 


CC: mmap/fs_mmap.c 


CC: signal/sig_wait.c 
CC: spawn/lib_psfa_addaction.c 

CC: mmap/fs_munmap.c 
CC: mmap/fs_mmisc.c 


CC: mmap/fs_msync.c 
CC: spawn/lib_psfa_addclose.c 


CC: spawn/lib_psfa_adddup2.c 
CC: mmap/fs_anonmap.c 




CC: mqueue/mq_open.c 
CC: spawn/lib_psfa_addopen.c 


CC: spawn/lib_psfa_destroy.c 


CC: spawn/lib_psfa_init.c 
CC: mqueue/mq_close.c 
CC: mqueue/mq_unlink.c 
CC: spawn/lib_psa_getflags.c 
CC: mount/fs_mount.c 



CC: spawn/lib_psa_getschedparam.c 



CC: spawn/lib_psa_getschedpolicy.c 
CC: mount/fs_umount2.c 
CC: mount/fs_foreachmountpoint.c 
CC: spawn/lib_psa_init.c 
CC: mount/fs_procfs_mount.c 


CC: mount/fs_gettype.c 

CC: partition/fs_partition.c 
CC: spawn/lib_psa_setflags.c 





CC: procfs/fs_procfs.c 
CC: procfs/fs_procfscpuinfo.c 
CC: spawn/lib_psa_setschedparam.c 

CC: procfs/fs_procfscpuload.c 
CC: spawn/lib_psa_setschedpolicy.c 
CC: spawn/lib_psa_getsigmask.c 


CC: spawn/lib_psa_setsigmask.c 
CC: spawn/lib_psa_getstacksize.c 

CC: procfs/fs_procfscritmon.c 

CC: spawn/lib_psa_setstacksize.c 




CC: spawn/lib_psa_destroy.c 
CC: procfs/fs_procfsfdt.c 
CC: spawn/lib_psa_getstackaddr.c 
CC: procfs/fs_procfsiobinfo.c 





CC: procfs/fs_procfsmeminfo.c 
CC: spawn/lib_psa_setstackaddr.c 

CC: procfs/fs_procfsproc.c 
CC: procfs/fs_procfstcbinfo.c 

CC: stdio/lib_fileno.c 

CC: procfs/fs_procfsuptime.c 

CC: stdio/lib_printf.c 

CC: procfs/fs_procfsutil.c 
CC: stdio/lib_sprintf.c 
CC: procfs/fs_procfsversion.c 
CC: board/esp32c3_boot.c 

CC: board/esp32c3_bringup.c 




CC: stdio/lib_asprintf.c 

CC: stdio/lib_snprintf.c 
CC: stdio/lib_vsprintf.c 
CC: stdio/lib_vasprintf.c 
CC: stdio/lib_vsnprintf.c 




CC: stdio/lib_dprintf.c 
CC: stdio/lib_vdprintf.c 
CC: stdio/lib_vprintf.c 

CC: stdio/lib_perror.c 

CC: stdio/lib_putchar.c 
CC: stdio/lib_getchar.c 

CC: stdio/lib_puts.c 



CC: stdio/lib_gets_s.c 
CC: stdio/lib_gets.c 

CC: stdio/lib_libdgets.c 
CC: stdio/lib_sscanf.c 






CC: stdio/lib_vsscanf.c 
CC: stdio/lib_remove.c 
CC: stdio/lib_tempnam.c 


CC: stdio/lib_tmpnam.c 





CC: stdio/lib_renameat.c 
CC: stdio/lib_putwchar.c 
CC: stdio/lib_fopen.c 
CC: stdio/lib_freopen.c 

CC: stdio/lib_fclose.c 
CC: stdio/lib_fread.c 
CC: stdio/lib_libfread_unlocked.c 

CC: stdio/lib_fseek.c 
CC: stdio/lib_fseeko.c 

CC: stdio/lib_ftell.c 
CC: stdio/lib_ftello.c 



CC: stdio/lib_fsetpos.c 

CC: stdio/lib_getdelim.c 
CC: stdio/lib_fgetpos.c 
CC: stdio/lib_getc.c 




CC: stdio/lib_fgetc.c 

CC: stdio/lib_fgets.c 
CC: stdio/lib_libfgets.c 

CC: stdio/lib_fwrite.c 
CC: stdio/lib_libfwrite.c 


CC: stdio/lib_fflush.c 


CC: stdio/lib_libflushall.c 
CC: stdio/lib_libfflush.c 
CC: stdio/lib_rdflush_unlocked.c 
IN: sched/libsched.a -> staging/libsched.a 
CC: stdio/lib_wrflush_unlocked.c 



CC: stdio/lib_putc.c 

CC: stdio/lib_fputc.c 
CC: stdio/lib_fputs.c 
CC: stdio/lib_ungetc.c 


CC: stdio/lib_fprintf.c 
CC: stdio/lib_vfprintf.c 

CC: stdio/lib_feof.c 


CC: stdio/lib_ferror.c 

CC: stdio/lib_rewind.c 

CC: stdio/lib_clearerr.c 


CC: stdio/lib_scanf.c 




CC: stdio/lib_vscanf.c 
CC: stdio/lib_fscanf.c 
CC: stdio/lib_vfscanf.c 
CC: stdio/lib_tmpfile.c 
CC: stdio/lib_setbuf.c 
CC: stdio/lib_setvbuf.c 



CC: stdio/lib_libfilelock.c 
CC: stdio/lib_libgetstreams.c 

CC: stdio/lib_setbuffer.c 
CC: stdio/lib_fputwc.c 


CC: stdio/lib_putwc.c 

CC: stdio/lib_fputws.c 


CC: stdio/lib_fopencookie.c 

CC: stdio/lib_fmemopen.c 
CC: stdio/lib_open_memstream.c 
CC: stdio/lib_fgetwc.c 


CC: stdio/lib_getwc.c 

CC: stdio/lib_ungetwc.c 
CC: stdlib/lib_abs.c 



CC: stdlib/lib_abort.c 

CC: stdlib/lib_atof.c 



CC: stdlib/lib_atoi.c 
CC: stdlib/lib_getprogname.c 
CC: stdlib/lib_atol.c 
CC: stdlib/lib_atoll.c 

CC: stdlib/lib_div.c 


CC: stdlib/lib_ldiv.c 


CC: stdlib/lib_lldiv.c 
CC: stdlib/lib_exit.c 
CC: stdlib/lib_itoa.c 


CC: stdlib/lib_labs.c 
CC: stdlib/lib_llabs.c 



CC: stdlib/lib_realpath.c 




CC: stdlib/lib_bsearch.c 
CC: stdlib/lib_rand.c 
CC: stdlib/lib_rand48.c 
CC: stdlib/lib_qsort.c 
CC: stdlib/lib_srand.c 

CC: stdlib/lib_strtol.c 

CC: stdlib/lib_strtoll.c 


CC: stdlib/lib_strtoul.c 
CC: stdlib/lib_strtoull.c 
CC: stdlib/lib_strtold.c 
CC: stdlib/lib_checkbase.c 



CC: stdlib/lib_mktemp.c 
CC: stdlib/lib_mkstemp.c 

CC: stdlib/lib_mkdtemp.c 

CC: stdlib/lib_aligned_alloc.c 


CC: stdlib/lib_posix_memalign.c 
CC: stdlib/lib_valloc.c 

IN: drivers/libdrivers.a -> staging/libdrivers.a 

CC: stdlib/lib_mblen.c 
CC: stdlib/lib_mbtowc.c 


CC: stdlib/lib_wctomb.c 
CC: stdlib/lib_mbstowcs.c 



CC: stdlib/lib_wcstombs.c 
CC: stdlib/lib_atexit.c 

CC: stdlib/lib_reallocarray.c 
CC: stdlib/lib_arc4random.c 

CC: stream/lib_meminstream.c 


CC: stream/lib_memoutstream.c 

CC: stream/lib_memsistream.c 

CC: stream/lib_memsostream.c 




CC: stream/lib_lowoutstream.c 

CC: stream/lib_rawinstream.c 

CC: stream/lib_rawoutstream.c 
CC: stream/lib_rawsistream.c 
CC: stream/lib_rawsostream.c 


CC: stream/lib_zeroinstream.c 
CC: stream/lib_nullinstream.c 
CC: stream/lib_nulloutstream.c 
CC: stream/lib_mtdoutstream.c 


CC: stream/lib_libnoflush.c 
CC: stream/lib_libsnoflush.c 



CC: stream/lib_syslogstream.c 
CC: stream/lib_syslograwstream.c 
CC: stream/lib_bufferedoutstream.c 

CC: stream/lib_hexdumpstream.c 

CC: stream/lib_base64outstream.c 

CC: stream/lib_mtdsostream.c 


CC: stream/lib_fileinstream.c 

CC: stream/lib_fileoutstream.c 



CC: stream/lib_libbsprintf.c 


CC: stream/lib_libvscanf.c 

CC: stream/lib_libvsprintf.c 


CC: stream/lib_ultoa_invert.c 



CC: stream/lib_dtoa_engine.c 
CC: stream/lib_dtoa_data.c 
CC: stream/lib_stdinstream.c 
CC: stream/lib_stdoutstream.c 
CC: stream/lib_stdsistream.c 

CC: stream/lib_stdsostream.c 
CC: stream/lib_blkoutstream.c 
CC: string/lib_ffs.c 

CC: string/lib_ffsl.c 

CC: string/lib_ffsll.c 
CC: string/lib_fls.c 


CC: string/lib_flsl.c 

CC: string/lib_flsll.c 
CC: string/lib_isbasedigit.c 





CC: string/lib_memmem.c 
CC: string/lib_popcount.c 
CC: string/lib_popcountl.c 
CC: string/lib_popcountll.c 
CC: string/lib_skipspace.c 




CC: string/lib_strcasecmp.c 

CC: string/lib_strcspn.c 

CC: string/lib_strdup.c 
IN: boards/libboards.a -> staging/libboards.a 
CC: string/lib_strerror.c 

CC: string/lib_strncasecmp.c 


CC: string/lib_strncat.c 
CC: string/lib_strndup.c 
CC: string/lib_strcasestr.c 


CC: string/lib_strpbrk.c 


CC: string/lib_strspn.c 

CC: string/lib_strstr.c 
CC: string/lib_strtok.c 
CC: string/lib_strtokr.c 


CC: string/lib_strsep.c 

CC: string/lib_strerrorr.c 


CC: string/lib_explicit_bzero.c 
CC: string/lib_strsignal.c 
CC: string/lib_index.c 

CC: string/lib_rindex.c 

CC: string/lib_timingsafe_bcmp.c 





CC: string/lib_strverscmp.c 



CC: string/lib_mempcpy.c 
CC: string/lib_rawmemchr.c 
CC: string/lib_memmove.c 
CC: string/lib_memset.c 

CC: string/lib_strlcat.c 




CC: string/lib_strlcpy.c 


CC: string/lib_strnlen.c 
CC: string/lib_memcpy.c 
CC: string/lib_memccpy.c 


CC: string/lib_memcmp.c 

CC: string/lib_memrchr.c 
CC: string/lib_stpncpy.c 
CC: string/lib_strchr.c 
CC: string/lib_strcmp.c 
CC: string/lib_strlen.c 
CC: string/lib_strncpy.c 
CC: string/lib_memchr.c 

CC: string/lib_stpcpy.c 


CC: string/lib_strcat.c 
CC: string/lib_strchrnul.c 


CC: string/lib_strcpy.c 
CC: string/lib_strncmp.c 




CC: string/lib_strrchr.c 


CC: symtab/symtab_findbyname.c 


CC: symtab/symtab_findbyvalue.c 
CC: symtab/symtab_sortbyname.c 
CC: syslog/lib_syslog.c 


CC: syslog/lib_setlogmask.c 
CC: termios/lib_cfspeed.c 

CC: termios/lib_cfmakeraw.c 
CC: termios/lib_isatty.c 


CC: termios/lib_tcflush.c 
CC: termios/lib_tcdrain.c 
CC: termios/lib_tcflow.c 


CC: termios/lib_tcgetattr.c 

CC: termios/lib_tcsetattr.c 

CC: termios/lib_tcsendbreak.c 
CC: termios/lib_ttyname.c 

CC: termios/lib_ttynamer.c 
CC: time/lib_strftime.c 




CC: time/lib_calendar2utc.c 

CC: time/lib_daysbeforemonth.c 

CC: time/lib_gettimeofday.c 
CC: time/lib_isleapyear.c 

CC: time/lib_settimeofday.c 



CC: time/lib_time.c 
CC: time/lib_timespec_get.c 

CC: time/lib_nanosleep.c 


CC: time/lib_difftime.c 

CC: time/lib_dayofweek.c 

IN: mm/libmm.a -> staging/libmm.a 
CC: time/lib_asctime.c 


CC: time/lib_asctimer.c 
CC: time/lib_ctime.c 
CC: time/lib_ctimer.c 


CC: time/lib_gethrtime.c 
CC: time/lib_timegm.c 
CC: time/lib_gmtime.c 
CC: time/lib_gmtimer.c 

CC: tls/task_getinfo.c 



CC: tls/tls_getinfo.c 




CC: uio/lib_preadv.c 


CC: uio/lib_pwritev.c 
CC: unistd/lib_access.c 

CC: unistd/lib_daemon.c 

CC: unistd/lib_swab.c 

CC: unistd/lib_pathconf.c 
CC: unistd/lib_sysconf.c 
CC: unistd/lib_getcwd.c 

CC: unistd/lib_getentropy.c 
CC: unistd/lib_getopt_common.c 

CC: unistd/lib_getopt.c 
CC: unistd/lib_getopt_long.c 
CC: unistd/lib_getopt_longonly.c 

CC: unistd/lib_getoptvars.c 


CC: unistd/lib_getoptargp.c 

CC: unistd/lib_getopterrp.c 





CC: unistd/lib_getoptindp.c 
CC: unistd/lib_getoptoptp.c 

CC: unistd/lib_times.c 

CC: unistd/lib_alarm.c 

CC: unistd/lib_fstatvfs.c 
CC: unistd/lib_statvfs.c 
CC: unistd/lib_sleep.c 

CC: unistd/lib_nice.c 
CC: unistd/lib_setreuid.c 
CC: unistd/lib_setregid.c 




CC: unistd/lib_getrusage.c 

CC: unistd/lib_utime.c 
CC: unistd/lib_utimes.c 

CC: unistd/lib_setrlimit.c 

CC: unistd/lib_getrlimit.c 
CC: unistd/lib_setpriority.c 
CC: unistd/lib_getpriority.c 



CC: unistd/lib_futimes.c 
CC: unistd/lib_lutimes.c 

CC: unistd/lib_gethostname.c 

CC: unistd/lib_sethostname.c 




CC: unistd/lib_fchownat.c 



CC: unistd/lib_linkat.c 
CC: unistd/lib_readlinkat.c 


CC: unistd/lib_symlinkat.c 

CC: unistd/lib_unlinkat.c 
CC: unistd/lib_usleep.c 

CC: unistd/lib_getpgrp.c 
CC: unistd/lib_getpgid.c 
CC: unistd/lib_lockf.c 

CC: unistd/lib_flock.c 
CC: unistd/lib_getpass.c 

CC: unistd/lib_chdir.c 
CC: unistd/lib_fchdir.c 


CC: unistd/lib_confstr.c 




CC: unistd/lib_setuid.c 
CC: unistd/lib_setgid.c 
CC: unistd/lib_getuid.c 
CC: unistd/lib_getgid.c 
CC: unistd/lib_seteuid.c 
CC: unistd/lib_setegid.c 


CC: unistd/lib_geteuid.c 

CC: unistd/lib_getegid.c 
CC: unistd/lib_restoredir.c 


IN: arch/risc-v/src/libarch.a -> staging/libarch.a 


CC: unistd/lib_truncate.c 


CC: unistd/lib_posix_fallocate.c 

CC: unistd/lib_fork.c 

CC: uuid/lib_uuid_compare.c 
CC: uuid/lib_uuid_create.c 

CC: uuid/lib_uuid_create_nil.c 


CC: uuid/lib_uuid_equal.c 


CC: uuid/lib_uuid_from_string.c 




CC: uuid/lib_uuid_hash.c 
CC: uuid/lib_uuid_is_nil.c 

CC: uuid/lib_uuid_stream.c 
CC: uuid/lib_uuid_to_string.c 

CC: wchar/lib_wcscmp.c 

CC: wchar/lib_wcslen.c 
CC: wchar/lib_wmemchr.c 

CC: wchar/lib_wmemcmp.c 

CC: wchar/lib_wmemcpy.c 
CC: wchar/lib_wmemmove.c 
CC: wchar/lib_wmemset.c 
CC: wchar/lib_btowc.c 
CC: wchar/lib_mbrtowc.c 

CC: wchar/lib_wctob.c 



CC: wchar/lib_wcslcpy.c 

CC: wchar/lib_wcsxfrm.c 


CC: wchar/lib_wcrtomb.c 


CC: wchar/lib_wcsftime.c 
CC: wchar/lib_wcscoll.c 

CC: wchar/lib_wcstol.c 
CC: wchar/lib_wcstoll.c 
CC: wchar/lib_wcstoul.c 


CC: wchar/lib_wcstoull.c 
CC: wchar/lib_wcstold.c 

CC: wchar/lib_wcstof.c 

CC: wchar/lib_wcstod.c 


CC: wchar/lib_swprintf.c 




CC: wchar/lib_mbsnrtowcs.c 

CC: wchar/lib_wcsnrtombs.c 
CC: wchar/lib_mbsinit.c 

CC: wchar/lib_mbrlen.c 
CC: wchar/lib_mbsrtowcs.c 

CC: wchar/lib_wcsrtombs.c 
CC: wchar/lib_wcscpy.c 
CC: wchar/lib_wcscat.c 
CC: wchar/lib_wcslcat.c 



CC: wchar/lib_wcsncat.c 


CC: wchar/lib_wcsrchr.c 

CC: wchar/lib_wcschr.c 
CC: wchar/lib_wcsncpy.c 


CC: wchar/lib_wcsncmp.c 


CC: wchar/lib_wcscspn.c 
CC: wchar/lib_wcspbrk.c 
CC: wchar/lib_wcsspn.c 

CC: wchar/lib_wcsstr.c 

CC: wchar/lib_wcstok.c 
CC: wchar/lib_wcswcs.c 
CC: wchar/lib_wcwidth.c 

CC: wchar/lib_wcswidth.c 

CC: wctype/lib_wctype.c 


CC: wctype/lib_iswctype.c 


CC: wctype/lib_towlower.c 

CC: wctype/lib_towupper.c 










IN: /tmp/nuttx/nuttx-apps.git/libapps.a -> staging/libapps.a 












IN: fs/libfs.a -> staging/libfs.a 

IN: binfmt/libbinfmt.a -> staging/libbinfmt.a 

IN: arch/risc-v/src/board/libboard.a -> staging/libboard.a 

IN: libs/libc/libc.a -> staging/libc.a 

AS: chip/esp32c3_head.S 
CPP: /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/legacy_sections.ld-> /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/legacy_sections.ld.tmp 

CPP: /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/flat_memory.ld-> /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/flat_memory.ld.tmp 
CPP: /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/esp32c3_rom.ld-> /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/esp32c3_rom.ld.tmp 


LD: nuttx
Memory region Used Size Region Size %age Used
iram0_0_seg: 7760 B 321296 B 2.42%
irom0_0_seg: 58494 B 4194272 B 1.39%
dram0_0_seg: 14656 B 321296 B 4.56%
drom0_0_seg: 68352 B 4194272 B 1.63%
rtc_seg: 0 GB 8 KB 0.00%
CP: nuttx.hex
MKIMAGE: ESP32-C3 binary
esptool.py -c esp32c3 elf2image -fs 4MB -fm dio -ff 40m -o nuttx.bin nuttx
esptool.py v4.9.0
Creating esp32c3 image...
Merged 1 ELF section
Successfully created esp32c3 image.
Generated: nuttx.bin (ESP32-C3 compatible)
6,05s real 20,82s user 13,04s sys
+ /usr/bin/time -h gmake flash -j24 CROSSDEV=riscv32-esp-elf-

CC: misc/lib_utsname.c 

IN: libs/libc/libc.a -> staging/libc.a 

CPP: /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/esp32c3_rom.ld-> /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/esp32c3_rom.ld.tmp 
CPP: /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/flat_memory.ld-> /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/flat_memory.ld.tmp 
CPP: /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/legacy_sections.ld-> /tmp/nuttx/nuttx.git/boards/risc-v/esp32c3-legacy/esp32c3-devkit/../common/scripts/legacy_sections.ld.tmp 


LD: nuttx
Memory region Used Size Region Size %age Used
iram0_0_seg: 7760 B 321296 B 2.42%
irom0_0_seg: 58494 B 4194272 B 1.39%
dram0_0_seg: 14656 B 321296 B 4.56%
drom0_0_seg: 68352 B 4194272 B 1.63%
rtc_seg: 0 GB 8 KB 0.00%
CP: nuttx.hex
MKIMAGE: ESP32-C3 binary
esptool.py -c esp32c3 elf2image -fs 4MB -fm dio -ff 40m -o nuttx.bin nuttx
esptool.py v4.9.0
Creating esp32c3 image...
Merged 1 ELF section
Successfully created esp32c3 image.
Generated: nuttx.bin (ESP32-C3 compatible)
esptool.py -c esp32c3 -p /dev/cuaU0 -b 115200 write_flash -fs 4MB -fm dio -ff 40m 0x10000 nuttx.bin
esptool.py v4.9.0
Serial port /dev/cuaU0
Connecting....
Chip is ESP32-C3 (QFN32) (revision v0.3)
Features: WiFi, BLE
Crystal is 40MHz
MAC: 7c:df:a1:b1:58:00
Uploading stub...
Running stub...
Stub running...
Configuring flash size...
Flash will be erased from 0x00010000 to 0x0002efff...
Compressed 124112 bytes to 46714...
Writing at 0x00010000... (33 %)
Writing at 0x000236c4... (66 %)
Writing at 0x00029311... (100 %)
Wrote 124112 bytes (46714 compressed) at 0x00010000 in 4.5 seconds (effective 221.9 kbit/s)...
Hash of data verified.
Leaving...
Hard resetting via RTS pin...
9,65s real 1,98s user 2,24s sys
+ cu -l /dev/cuaU0 -s 115200
Connected
2K performance run parameters for coremark.
CoreMark Size : 666
Total ticks : 1472
Total time (secs): 14.720000
Iterations/Sec : 407.608696
Iterations : 6000
Compiler version : GCC8.4.0
Compiler flags : -O3 -fno-strict-aliasing -fomit-frame-pointer -ffunction-sections -fdata-sections -nostdlib
Memory location : HEAP
seedcrc : 0xe9f5
[0]crclist : 0xe714
[0]crcmatrix : 0x1fd7
[0]crcstate : 0x8e3a
[0]crcfinal : 0xa14c
Correct operation validated. See README.md for run and reporting rules.
CoreMark 1.0 : 407.608696 / GCC8.4.0 -O3 -fno-strict-aliasing -fomit-frame-pointer -ffunction-sections -fdata-sections -nostdlib / HEAP
~
[EOT]
+ /usr/bin/time -h gmake clean distclean -j24 CROSSDEV=riscv32-esp-elf-
4,09s real 3,15s user 4,03s sys
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment