Skip to content

testing/{ostest,sched/smp}: Remove BOARD_LOOPSPERMSEC references#3401

Open
linguini1 wants to merge 1 commit intoapache:masterfrom
linguini1:remove-loopspermsec
Open

testing/{ostest,sched/smp}: Remove BOARD_LOOPSPERMSEC references#3401
linguini1 wants to merge 1 commit intoapache:masterfrom
linguini1:remove-loopspermsec

Conversation

@linguini1
Copy link
Contributor

Summary

In an effort to avoid unexpected behaviour from users not calibrating BOARD_LOOPSPERMSEC, a compilation error occurs when it is undefined. On some systems, this is allowed (those that use timer implementations instead of busy-looping for delays). In these cases, we should busy-loop using the clock time instead of relying on a possibly undefined/uncalibrated macro.

Closes #3345

Impact

Impacts the OSTest cases sporadic and sporadic2, as well as the sched/smp
test.

Testing

Compilation for qemu-armv8a:nsh_smp now passes (this is the configuration
failing due to missing symbol CONFIG_BOARDLOOPSPERMSEC in apache/nuttx#17011).

Details
$ ./tools/configure.sh qemu-armv8a:nsh_smp
$ make -j
Create version.h
LN: platform/board to /home/linguini/coding/nuttx-space/apps/platform/dummy
Register: getprime
Register: hello
Register: taskset
Register: gcov
Register: nsh
Register: sh
Register: ostest
Register: osperf
Register: smp
Register: dd
CPP:  /home/linguini/coding/nuttx-space/nuttx/boards/arm64/qemu/qemu-armv8a/scripts/dramboot.ld-> /home/linguini/coding/nuttx-space/nuttx/boards/arm64/qemu/qemu-armv8a/scriptLD: nuttx
Memory region         Used Size  Region Size  %age Used
CP: nuttx.hex
CP: nuttx.bin

Running the SMP test on this configuration as-is passes:

Details
$ qemu-system-aarch64 -cpu cortex-a53 -smp 4 -nographic \
   -machine virt,virtualization=on,gic-version=3 \
   -net none -chardev stdio,id=con,mux=on -serial chardev:con \
   -mon chardev=con,mode=readline -kernel ./nuttx
- Ready to Boot Primary CPU
- Boot from EL2
- Boot from EL1
- Boot to C runtime for OS Initialize
- Ready to Boot Second CPU
- Boot from EL2
- Boot from EL1
- Boot to C runtime for OS Initialize

NuttShell (NSH) NuttX-12.12.0
nsh> smp
  Main[0]: Running on CPU1
  Main[0]: Initializing barrier
  Main[0]: Thread 1 created
Thread[1]: Started
  Main[0]: Thread 2 created
Thread[2]: Started
Thread[1]: Running on CPU0
  Main[0]: Now running on CPU0
Thread[2]: Running on CPU0
  Main[0]: Thread 3 created
Thread[3]: Started
Thread[2]: Now running on CPU1
Thread[1]: Now running on CPU1
  Main[0]: Thread 4 created
Thread[3]: Running on CPU1
Thread[4]: Started
  Main[0]: Thread 5 created
Thread[5]: Started
Thread[4]: Running on CPU0
Thread[1]: Now running on CPU0
Thread[2]: Now running on CPU0
  Main[0]: Thread 6 created
Thread[5]: Running on CPU0
Thread[6]: Started
Thread[3]: Now running on CPU0
Thread[4]: Now running on CPU1
  Main[0]: Now running on CPU1
Thread[1]: Now running on CPU1
Thread[6]: Running on CPU0
Thread[5]: Now running on CPU1
  Main[0]: Thread 7 created
Thread[7]: Started
Thread[3]: Now running on CPU1
Thread[2]: Now running on CPU1
Thread[4]: Now running on CPU0
Thread[1]: Now running on CPU0
  Main[0]: Now running on CPU0
Thread[7]: Running on CPU1
Thread[6]: Now running on CPU1
  Main[0]: Thread 8 created
Thread[3]: Now running on CPU0
Thread[1]: Now running on CPU1
Thread[8]: Started
Thread[5]: Now running on CPU0
Thread[2]: Now running on CPU0
Thread[4]: Now running on CPU1
  Main[0]: Now running on CPU1
Thread[8]: Running on CPU0
Thread[6]: Now running on CPU0
Thread[7]: Now running on CPU0
Thread[1]: Now running on CPU0
Thread[3]: Now running on CPU1
Thread[2]: Now running on CPU1
Thread[4]: Now running on CPU0
Thread[5]: Now running on CPU1
Thread[1]: Now running on CPU1
Thread[7]: Now running on CPU1
Thread[8]: Now running on CPU1
Thread[6]: Now running on CPU1
Thread[3]: Now running on CPU0
Thread[4]: Now running on CPU1
Thread[2]: Now running on CPU0
Thread[1]: Now running on CPU0
Thread[5]: Now running on CPU0
Thread[6]: Now running on CPU0
Thread[3]: Now running on CPU1
Thread[2]: Calling pthread_barrier_wait()
Thread[8]: Now running on CPU0
Thread[5]: Now running on CPU1
Thread[7]: Now running on CPU0
Thread[1]: Calling pthread_barrier_wait()
Thread[3]: Now running on CPU0
Thread[6]: Now running on CPU1
Thread[4]: Calling pthread_barrier_wait()
Thread[2]: Now running on CPU1
Thread[5]: Calling pthread_barrier_wait()
Thread[7]: Now running on CPU1
Thread[3]: Calling pthread_barrier_wait()
Thread[6]: Calling pthread_barrier_wait()
Thread[4]: Now running on CPU0
Thread[8]: Now running on CPU1
Thread[5]: Now running on CPU0
Thread[7]: Calling pthread_barrier_wait()
Thread[8]: Now running on CPU0
Thread[8]: Calling pthread_barrier_wait()
Thread[8]: Back with ret=PTHREAD_BARRIER_SERIAL_THREAD (I AM SPECIAL)
Thread[1]: Back with ret=0 (I am not special)
Thread[2]: Back with ret=0 (I am not special)
Thread[3]: Back with ret=0 (I am not special)
Thread[4]: Back with ret=0 (I am not special)
Thread[6]: Back with ret=0 (I am not special)
Thread[5]: Back with ret=0 (I am not special)
Thread[7]: Back with ret=0 (I am not special)
Thread[1]: Now running on CPU1
Thread[2]: Now running on CPU0
Thread[3]: Now running on CPU1
Thread[4]: Now running on CPU1
Thread[6]: Now running on CPU0
Thread[8]: Now running on CPU1
Thread[5]: Now running on CPU1
Thread[7]: Now running on CPU0
Thread[1]: Now running on CPU0
Thread[4]: Now running on CPU0
Thread[2]: Now running on CPU1
Thread[3]: Now running on CPU0
Thread[5]: Now running on CPU0
Thread[6]: Now running on CPU1
Thread[7]: Now running on CPU1
Thread[1]: Now running on CPU1
Thread[8]: Now running on CPU0
Thread[4]: Now running on CPU1
Thread[5]: Now running on CPU1
Thread[2]: Now running on CPU0
Thread[6]: Now running on CPU0
Thread[3]: Now running on CPU1
Thread[1]: Now running on CPU0
Thread[7]: Now running on CPU0
Thread[4]: Now running on CPU0
Thread[2]: Now running on CPU1
Thread[5]: Now running on CPU0
Thread[8]: Now running on CPU1
Thread[1]: Now running on CPU1
Thread[6]: Now running on CPU1
Thread[3]: Now running on CPU0
Thread[2]: Now running on CPU0
Thread[7]: Now running on CPU1
Thread[4]: Now running on CPU1
Thread[8]: Now running on CPU0
Thread[6]: Now running on CPU0
Thread[5]: Now running on CPU1
Thread[1]: Now running on CPU0
Thread[7]: Now running on CPU0
Thread[2]: Now running on CPU1
Thread[8]: Done
Thread[3]: Done
Thread[4]: Now running on CPU0
Thread[1]: Now running on CPU1
Thread[6]: Now running on CPU1
Thread[5]: Done
Thread[2]: Done
Thread[8]: Now running on CPU1
Thread[7]: Now running on CPU1
Thread[4]: Done
Thread[1]: Now running on CPU0
Thread[7]: Done
Thread[5]: Now running on CPU0
Thread[6]: Done
Thread[4]: Now running on CPU1
Thread[1]: Done
  Main[0]: Now running on CPU0
  Main[0]: Thread 1 completed with result=0
  Main[0]: Thread 2 completed with result=0
  Main[0]: Thread 3 completed with result=0
  Main[0]: Thread 4 completed with result=0
  Main[0]: Thread 5 completed with result=0
  Main[0]: Thread 6 completed with result=0
  Main[0]: Thread 7 completed with result=0
  Main[0]: Thread 8 completed with result=0

With CONFIG_SCHED_SPORADIC=y (so modified code is compiled into ostest), ostest passes:

Details
$ qemu-system-aarch64 -cpu cortex-a53 -smp 4 -nographic \
   -machine virt,virtualization=on,gic-version=3 \
   -net none -chardev stdio,id=con,mux=on -serial chardev:con \
   -mon chardev=con,mode=readline -kernel ./nuttx
- Ready to Boot Primary CPU
- Boot from EL2
- Boot from EL1
- Boot to C runtime for OS Initialize
- Ready to Boot Second CPU
- Boot from EL2
- Boot from EL1
- Boot to C runtime for OS Initialize

NuttShell (NSH) NuttX-12.12.0
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=5

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     7b8e000  7b8e000
ordblks         2        2
mxordblk  7b7be30  7b7be30
uordblks    12198    12198
fordblks  7b7be68  7b7be68

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     7b8e000  7b8e000
ordblks         2        2
mxordblk  7b7be30  7b7be30
uordblks    12198    12198
fordblks  7b7be68  7b7be68

user_main: libc tests

End of test memory usage:
VARIABLE  BEFORE   AFTER
======== ======== ========
arena     7b8e000  7b8e000
ordblks         2        2
mxordblk  7b7be30  7b7be30
uordblks    12198    12198
fordblks  7b7be68  7b7be68
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     7b8e000  7b8e000
ordblks         2        3
mxordblk  7b7be30  7b7be30
uordblks    12198    12178
fordblks  7b7be68  7b7be88
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     7b8e000  7b8e000
ordblks         3        2
mxordblk  7b7be30  7b7be30
uordblks    12178    12068
fordblks  7b7be88  7b7bf98

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     7b8e000  7b8e000
ordblks         2        2
mxordblk  7b7be30  7b7be30
uordblks    12068    12068
fordblks  7b7bf98  7b7bf98

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     7b8e000  7b8e000
ordblks         2        2
mxordblk  7b7be30  7b7be30
uordblks    12068    12068
fordblks  7b7bf98  7b7bf98

user_main: FPU test
Starting task FPU#1
fpu_test: Started task FPU#1 at PID=6
FPU#1: pass 1
Starting task FPU#2
fpu_test: Started task FPU#2 at PID=7
FPU#2: pass 1
FPU#1: pass 2
FPU#2: pass 2
FPU#1: pass 3
FPU#2: pass 3
FPU#1: pass 4
FPU#2: pass 4
FPU#1: pass 5
FPU#2: pass 5
FPU#1: pass 6
FPU#2: pass 6
FPU#1: pass 7
FPU#2: pass 7
FPU#1: pass 8
FPU#2: pass 8
FPU#1: pass 9
FPU#2: pass 9
FPU#1: pass 10
FPU#2: pass 10
FPU#1: pass 11
FPU#2: pass 11
FPU#1: pass 12
FPU#2: pass 12
FPU#1: pass 13
FPU#2: pass 13
FPU#1: pass 14
FPU#2: pass 14
FPU#1: pass 15
FPU#2: pass 15
FPU#1: pass 16
FPU#2: pass 16
FPU#1: Succeeded
FPU#2: Succeeded
fpu_test: Returning

End of test memory usage:
VARIABLE  BEFORE   AFTER
======== ======== ========
arena     7b8e000  7b8e000
ordblks         2        4
mxordblk  7b7be30  7b73298
uordblks    12068    1a358
fordblks  7b7bf98  7b73ca8

user_main: task_restart test

Test task_restart()
restart_main: setenv(VarName, VarValue, TRUE)
restart_main: Started restart_main at PID=8
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 with argc=4
restart_main: Started restart_main at PID=8
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     7b8e000  7b8e000
ordblks         4        5
mxordblk  7b73298  7b73298
uordblks    1a358    1a3b0
fordblks  7b73ca8  7b73c50

user_main: waitpid test

Test waitpid()
waitpid_start_child: Started waitpid_main at PID=9
waitpid_main: PID 9 Started
waitpid_start_child: Started waitpid_main at PID=10
waitpid_main: PID 10 Started
waitpid_start_child: Started waitpid_main at PID=11
waitpid_main: PID 11 Started
waitpid_test: Waiting for PID=9 with waitpid()
waitpid_main: PID 9 exitting with result=14
waitpid_test: PID 9 waitpid succeeded with stat_loc=0e00
waitpid_main: PID 10 exitting with result=14
waitpid_last: Waiting for PID=11 with waitpid()
waitpid_main: PID 11 exitting with result=14
waitpid_last: PASS: PID 11 waitpid succeeded with stat_loc=0e00

End of test memory usage:
VARIABLE  BEFORE   AFTER
======== ======== ========
arena     7b8e000  7b8e000
ordblks         5        6
mxordblk  7b73298  7b6a998
uordblks    1a3b0    226c0
fordblks  7b73c50  7b6b940

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     7b8e000  7b8e000
ordblks         6        4
mxordblk  7b6a998  7b73ab0
uordblks    226c0    1a3d8
fordblks  7b6b940  7b73c28

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     7b8e000  7b8e000
ordblks         4        5
mxordblk  7b73ab0  7b6f8f8
uordblks    1a3d8    1e560
fordblks  7b73c28  7b6faa0

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=0xffffffffffffffff
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=0xffffffffffffffff
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     7b8e000  7b8e000
ordblks         5        3
mxordblk  7b6f8f8  7b77c78
uordblks    1e560    16248
fordblks  7b6faa0  7b77db8

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     7b8e000  7b8e000
ordblks         3        4
mxordblk  7b77c78  7b73ab0
uordblks    16248    1a3d8
fordblks  7b77db8  7b73c28

user_main: semaphore test
sem_test: Initializing semaphore to 0
sem_test: Starting waiter thread 1
sem_test: Set thread 1 priority to 191
sem_test: Starting waiter thread 2
waiter_func: Thread 1 Started
sem_test: Set thread 2 priority to 128
waiter_func: Thread 1 initial semaphore value = 0
waiter_func: Thread 1 waiting on semaphore
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
poster_func: Thread 3 new semaphore value = -1
waiter_func: Thread 1 new semaphore value = -1
poster_func: Thread 3 semaphore value = -1
waiter_func: Thread 1 done
poster_func: Thread 3 posting semaphore
waiter_func: Thread 2 awakened
poster_func: Thread 3 new semaphore value = 0
waiter_func: Thread 2 new semaphore value = 0
poster_func: Thread 3 done
waiter_func: Thread 2 done

End of test memory usage:
VARIABLE  BEFORE   AFTER
======== ======== ========
arena     7b8e000  7b8e000
ordblks         4        6
mxordblk  7b73ab0  7b6b730
uordblks    1a3d8    1e568
fordblks  7b73c28  7b6fa98

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: (1646092844 sec, 650381344 nsec)
AFTER:  (1646092846 sec, 650926128 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: (1646092846 sec, 651638672 nsec)
AFTER:  (1646092847 sec, 653312784 nsec)

End of test memory usage:
VARIABLE  BEFORE   AFTER
======== ======== ========
arena     7b8e000  7b8e000
ordblks         6        3
mxordblk  7b6b730  7b77c78
uordblks    1e568    16248
fordblks  7b6fa98  7b77db8

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     7b8e000  7b8e000
ordblks         3        5
mxordblk  7b77c78  7b6f8f8
uordblks    16248    1a3d0
fordblks  7b77db8  7b73c30

user_main: pthread_exit() test
pthread_exit_test: Started pthread_exit_main at PID=39
pthread_exit_main 39: Starting pthread_exit_thread
pthread_exit_main 39: Sleeping for 5 seconds
pthread_exit_thread 40: Sleeping for 10 second
pthread_exit_thread 40: Still running...
pthread_exit_main 39: Calling pthread_exit()

End of test memory usage:
VARIABLE  BEFORE   AFTER
======== ======== ========
arena     7b8e000  7b8e000
ordblks         5        6
mxordblk  7b6f8f8  7b6b730
uordblks    1a3d0    226f0
fordblks  7b73c30  7b6b910

user_main: pthread_rwlock test
pthread_rwlock: Initializing rwlock
pthread_exit_thread 40: Exiting

End of test memory usage:
VARIABLE  BEFORE   AFTER
======== ======== ========
arena     7b8e000  7b8e000
ordblks         6        7
mxordblk  7b6b730  7b633b0
uordblks    226f0    268b0
fordblks  7b6b910  7b67750

user_main: pthread_rwlock_cancel test
pthread_rwlock_cancel: Starting test

End of test memory usage:
VARIABLE  BEFORE   AFTER
======== ======== ========
arena     7b8e000  7b8e000
ordblks         7        6
mxordblk  7b633b0  7b633b0
uordblks    268b0    22720
fordblks  7b67750  7b6b8e0

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
timedwait_test: Joining
thread_waiter: Taking mutex
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     7b8e000  7b8e000
ordblks         6        7
mxordblk  7b633b0  7b633b0
uordblks    22720    268b0
fordblks  7b6b8e0  7b67750

user_main: message queue test
mqueue_test: Starting receiver
mqueue_test: Set receiver priority to 128
mqueue_test: Starting sender
mqueue_test: Set sender thread priority to 64
receiver_thread: Starting
mqueue_test: Waiting for sender to complete
sender_thread: Starting
sender_thread: mq_send succeeded on msg 0
sender_thread: mq_send succeeded on msg 1
receiver_thread: mq_receive succeeded on msg 0
sender_thread: mq_send succeeded on msg 2
receiver_thread: mq_receive succeeded on msg 1
sender_thread: mq_send succeeded on msg 3
receiver_thread: mq_receive succeeded on msg 2
sender_thread: mq_send succeeded on msg 4
receiver_thread: mq_receive succeeded on msg 3
sender_thread: mq_send succeeded on msg 5
receiver_thread: mq_receive succeeded on msg 4
sender_thread: mq_send succeeded on msg 6
receiver_thread: mq_receive succeeded on msg 5
sender_thread: mq_send succeeded on msg 7
receiver_thread: mq_receive succeeded on msg 6
sender_thread: mq_send succeeded on msg 8
receiver_thread: mq_receive succeeded on msg 7
sender_thread: mq_send succeeded on msg 9
receiver_thread: mq_receive succeeded on msg 8
receiver_thread: mq_receive 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     7b8e000  7b8e000
ordblks         7        6
mxordblk  7b633b0  7b6b730
uordblks    268b0    16330
fordblks  7b67750  7b77cd0

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     7b8e000  7b8e000
ordblks         6        5
mxordblk  7b6b730  7b73900
uordblks    16330    16330
fordblks  7b77cd0  7b77cd0

user_main: sigprocmask test
sigprocmask_test: SUCCESS

End of test memory usage:
VARIABLE  BEFORE   AFTER
======== ======== ========
arena     7b8e000  7b8e000
ordblks         5        5
mxordblk  7b73900  7b73900
uordblks    16330    16330
fordblks  7b77cd0  7b77cd0

user_main: signal handler test
sighand_test: Initializing semaphore to 0
sighand_test: Starting waiter task
sighand_test: Started waiter_main pid=58
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=58 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     7b8e000  7b8e000
ordblks         5        4
mxordblk  7b73900  7b73900
uordblks    16330    16350
fordblks  7b77cd0  7b77cb0

user_main: nested signal handler test
signest_test: Starting signal waiter task at priority 101
signest_test: Started waiter_main pid=59
waiter_main: Waiter started
signest_test: Starting interfering task at priority 102
waiter_main: Setting signal mask
waiter_main: Registering signal handler
interfere_main: Waiting on semaphore
signest_test: Started interfere_main pid=60
waiter_main: Waiting on semaphore
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     7b8e000  7b8e000
ordblks         4        7
mxordblk  7b73900  7b6f8f8
uordblks    16350    1a590
fordblks  7b77cb0  7b73a70

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 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 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 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 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 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 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 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
wdtest_once 1000000 ns
wdtest_once 1000000 ns
wdtest_once 1000000 ns
wdtest_once 1000000 ns
wd_start with maximum delay, cancel OK, rest 4611686018427387900
wd_start with maximum delay, cancel OK, rest 4611686018427387900
wd_start with maximum delay, cancel OK, rest 4611686018427387900
wd_start with maximum delay, cancel OK, rest 4611686018427387900
wd_start with maximum delay, cancel OK, rest 4611686018427387900
wd_start with maximum delay, cancel OK, rest 4611686018427387900
wd_start with maximum delay, cancel OK, rest 4611686018427387900
wdtest_recursive 1000000ns
wdtest_recursive 1000000ns
wdtest_recursive 1000000ns
wd_start with maximum delay, cancel OK, rest 4611686018427387900
wdtest_recursive 1000000ns
wdtest_recursive 1000000ns
wdtest_recursive 1000000ns
wdtest_recursive 1000000ns
wdtest_recursive 1000000ns
recursive wdog triggered 51 times, elapsed tick 102
recursive wdog triggered 51 times, elapsed tick 102
recursive wdog triggered 51 times, elapsed tick 102
recursive wdog triggered 51 times, elapsed tick 102
wdtest_recursive 10000000ns
wdtest_recursive 10000000ns
recursive wdog triggered 51 times, elapsed tick 102
recursive wdog triggered 51 times, elapsed tick 102
recursive wdog triggered 51 times, elapsed tick 102
wdtest_recursive 10000000ns
recursive wdog triggered 51 times, elapsed tick 102
wdtest_recursive 10000000ns
wdtest_recursive 10000000ns
wdtest_recursive 10000000ns
wdtest_recursive 10000000ns
wdtest_recursive 10000000ns
recursive wdog triggered 9 times, elapsed tick 99
recursive wdog triggered 9 times, elapsed tick 99
recursive wdog triggered 9 times, elapsed tick 99
recursive wdog triggered 9 times, elapsed tick 99
recursive wdog triggered 9 times, elapsed tick 99
recursive wdog triggered 9 times, elapsed tick 99
recursive wdog triggered 9 times, elapsed tick 99
recursive wdog triggered 9 times, elapsed tick 99
wdog_test end...

End of test memory usage:
VARIABLE  BEFORE   AFTER
======== ======== ========
arena     7b8e000  7b8e000
ordblks         7       10
mxordblk  7b6f8f8  7b5b7b0
uordblks    1a590    1e728
fordblks  7b73a70  7b6f8d8

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     7b8e000  7b8e000
ordblks        10       10
mxordblk  7b5b7b0  7b5b7b0
uordblks    1e728    1e728
fordblks  7b6f8d8  7b6f8d8

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: 75
rr_test: Starting second get_primes_thread
         Second get_primes_thread: 76
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 < 30000, doing 10 run(s)
get_primes_thread id=2 started, looking for primes < 30000, doing 10 run(s)
get_primes_thread id=1 finished, found 3246 primes, last one was 29989
get_primes_thread id=2 finished, found 3246 primes, last one was 29989
rr_test: Done

End of test memory usage:
VARIABLE  BEFORE   AFTER
======== ======== ========
arena     7b8e000  7b8e000
ordblks        10        9
mxordblk  7b5b7b0  7b67878
uordblks    1e728    1e720
fordblks  7b6f8d8  7b6f8e0

user_main: sporadic scheduler test
sporadic_test: CONFIG_SCHED_SPORADIC_MAXREPL is small: 3
  -- There will some errors in the replenishment interval
sporadic_test: Initializing semaphore to 0
sporadic_test: Starting FIFO thread at priority 128
sporadic_test: Starting sporadic thread at priority 192 (hi) 64 (lo)
   0 SPORADIC: 0->192
   1 SPORADIC: 192->192
   1 FIFO:     128
   2 SPORADIC: 192->192
   2 FIFO:     128
   2 SPORADIC: 192->64
   3 SPORADIC: 64->64
   3 FIFO:     128
   4 FIFO:     128
   4 SPORADIC: 64->64
   5 SPORADIC: 64->64
   5 FIFO:     128
   5 SPORADIC: 64->192
   6 FIFO:     128
   6 SPORADIC: 192->192
   7 SPORADIC: 192->192
   7 FIFO:     128
   7 SPORADIC: 192->64
   8 FIFO:     128
   8 SPORADIC: 64->64
   9 SPORADIC: 64->64
   9 FIFO:     128
  10 SPORADIC: 64->64
  10 FIFO:     128
  10 SPORADIC: 64->192
  11 SPORADIC: 192->192
  11 FIFO:     128
  12 SPORADIC: 192->192
  12 FIFO:     128
  12 SPORADIC: 192->64
  13 SPORADIC: 64->64
  13 FIFO:     128
  14 FIFO:     128
  14 SPORADIC: 64->64
  15 FIFO:     128
  15 SPORADIC: 64->64
  15 SPORADIC: 64->192
  16 SPORADIC: 192->192
  17 SPORADIC: 192->192
  17 SPORADIC: 192->64
  18 SPORADIC: 64->64
  19 SPORADIC: 64->64
  20 SPORADIC: 64->64
  20 SPORADIC: 64->192
  21 SPORADIC: 192->192
  22 SPORADIC: 192->192
  22 SPORADIC: 192->64
  23 SPORADIC: 64->64
  24 SPORADIC: 64->64
  25 SPORADIC: 64->64
  25 SPORADIC: 64->192
  26 SPORADIC: 192->192
  27 SPORADIC: 192->192
  27 SPORADIC: 192->64
  28 SPORADIC: 64->64
  29 SPORADIC: 64->64
  30 SPORADIC: 64->64
  30 SPORADIC: 64->192
  31 SPORADIC: 192->192
  32 SPORADIC: 192->192
  32 SPORADIC: 192->64
  33 SPORADIC: 64->64
  34 SPORADIC: 64->64
  35 SPORADIC: 64->64
sporadic_test: Done

End of test memory usage:
VARIABLE  BEFORE   AFTER
======== ======== ========
arena     7b8e000  7b8e000
ordblks         9        6
mxordblk  7b67878  7b73900
uordblks    1e720    12278
fordblks  7b6f8e0  7b7bd88

user_main: Dual sporadic thread test
Sporadic 1: prio high 180, low 20, repl 100000000 ns
Sporadic 2: prio high 170, low 30, repl 100000000 ns

        THREAD    BUDGET  HI MS  LO MS
sporadic_test: CONFIG_SCHED_SPORADIC_MAXREPL is small: 3
  -- There will some errors in the replenishment interval
  1 Sporadic 1 000000000      0  50000
    Sporadic 2 030000000  14898  35102
sporadic_test: CONFIG_SCHED_SPORADIC_MAXREPL is small: 3
  -- There will some errors in the replenishment interval
  2 Sporadic 1 010000000   5885  44115
    Sporadic 2 030000000  14715  35285
sporadic_test: CONFIG_SCHED_SPORADIC_MAXREPL is small: 3
  -- There will some errors in the replenishment interval
  3 Sporadic 1 020000000   9856  40143
    Sporadic 2 030000000  14715  35285
sporadic_test: CONFIG_SCHED_SPORADIC_MAXREPL is small: 3
  -- There will some errors in the replenishment interval
  4 Sporadic 1 030000000  14715  35285
    Sporadic 2 030000000  15695  34305
sporadic_test: CONFIG_SCHED_SPORADIC_MAXREPL is small: 3
  -- There will some errors in the replenishment interval
  5 Sporadic 1 040000000  19803  30196
    Sporadic 2 030000000  14715  35285
sporadic_test: CONFIG_SCHED_SPORADIC_MAXREPL is small: 3
  -- There will some errors in the replenishment interval
  6 Sporadic 1 050000000  25500  24500
    Sporadic 2 030000000  14716  35284

End of test memory usage:
VARIABLE  BEFORE   AFTER
======== ======== ========
arena     7b8e000  7b8e000
ordblks         6        4
mxordblk  7b73900  7b73900
uordblks    12278    12360
fordblks  7b7bd88  7b7bca0

user_main: barrier test
barrier_test: Initializing barrier
barrier_test: Thread 0 created
barrier_func: Thread 0 started
barrier_test: Thread 1 created
barrier_func: Thread 1 started
barrier_test: Thread 2 created
barrier_func: Thread 2 started
barrier_test: Thread 3 created
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 0, back with status=0 (I am not special)
barrier_func: Thread 7, back with status=PTHREAD_BARRIER_SERIAL_THREAD (I AM 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 0 done
barrier_func: Thread 7 done
barrier_test: Thread 0 completed with result=0
barrier_func: Thread 1 done
barrier_func: Thread 2 done
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_func: Thread 5 done
barrier_func: Thread 6 done
barrier_test: Thread 4 completed with result=0
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     7b8e000  7b8e000
ordblks         4        7
mxordblk  7b73900  7b5b7b0
uordblks    12360    1a678
fordblks  7b7bca0  7b73988

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     7b8e000  7b8e000
ordblks         7        6
mxordblk  7b5b7b0  7b5b7b0
uordblks    1a678    1a678
fordblks  7b73988  7b73988

user_main: vfork() test
vfork_test: Child 122 ran successfully

user_main: smp call test
smp_call_test: Test start
smp_call_test: Call cpu 0, nowait
smp_call_test: Call cpu 0, wait
smp_call_test: Call cpu 1, nowait
smp_call_test: Call cpu 1, wait
smp_call_test: Call multi cpu, nowait
smp_call_test: Call in interrupt, wait
smp_call_test: Call multi cpu, wait
smp_call_test: Test success

Final memory usage:
VARIABLE  BEFORE   AFTER
======== ======== ========
arena     7b8e000  7b8e000
ordblks         2        7
mxordblk  7b7be30  7b5b7b0
uordblks    12198    1a670
fordblks  7b7be68  7b73990
user_main: Exiting
ostest_main: Exiting with status 0

In an effort to avoid unexpected behaviour from users not calibrating
BOARD_LOOPSPERMSEC, a compilation error occurs when it is undefined. On
some systems, this is allowed (those that use timer implementations
instead of busy-looping for delays). In these cases, we should busy-loop
using the clock time instead of relying on a possibly
undefined/uncalibrated macro.

Signed-off-by: Matteo Golin <matteo.golin@gmail.com>
Copy link
Contributor

@cederom cederom left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you @linguini1 :-)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

[FEATURE] Remove CONFIG_BOARD_LOOPSPERMSEC references in applications

2 participants