Remove some carriage returns
This commit is contained in:
parent
95ee8a4ef9
commit
9ed20f79dc
@ -1,404 +1,404 @@
|
|||||||
examples/ostest output as of November 4, 2010
|
examples/ostest output as of November 4, 2010
|
||||||
=============================================
|
=============================================
|
||||||
|
|
||||||
stdio_test: write fd=1
|
stdio_test: write fd=1
|
||||||
stdio_test: write fd=2
|
stdio_test: write fd=2
|
||||||
stdio_test: Standard I/O Check: printf
|
stdio_test: Standard I/O Check: printf
|
||||||
user_start: Started user_main at PID=2
|
user_start: Started user_main at PID=2
|
||||||
user_start: Exitting
|
user_start: Exitting
|
||||||
stdio_test: Standard I/O Check: fprintf to stderr
|
stdio_test: Standard I/O Check: fprintf to stderr
|
||||||
|
|
||||||
user_main: Begin argument test
|
user_main: Begin argument test
|
||||||
user_main: Started with argc=5
|
user_main: Started with argc=5
|
||||||
user_main: argv[0]="<noname>"
|
user_main: argv[0]="<noname>"
|
||||||
user_main: argv[1]="Arg1"
|
user_main: argv[1]="Arg1"
|
||||||
user_main: argv[2]="Arg2"
|
user_main: argv[2]="Arg2"
|
||||||
user_main: argv[3]="Arg3"
|
user_main: argv[3]="Arg3"
|
||||||
user_main: argv[4]="Arg4"
|
user_main: argv[4]="Arg4"
|
||||||
|
|
||||||
End of test memory usage:
|
End of test memory usage:
|
||||||
VARIABLE BEFORE AFTER
|
VARIABLE BEFORE AFTER
|
||||||
======== ======== ========
|
======== ======== ========
|
||||||
arena 71a0 71a0
|
arena 71a0 71a0
|
||||||
ordblks 2 2
|
ordblks 2 2
|
||||||
mxordblk 4a80 4a80
|
mxordblk 4a80 4a80
|
||||||
uordblks 1900 1900
|
uordblks 1900 1900
|
||||||
fordblks 58a0 58a0
|
fordblks 58a0 58a0
|
||||||
|
|
||||||
user_main: /dev/null test
|
user_main: /dev/null test
|
||||||
dev_null: Read 0 bytes from /dev/null
|
dev_null: Read 0 bytes from /dev/null
|
||||||
dev_null: Wrote 1024 bytes to /dev/null
|
dev_null: Wrote 1024 bytes to /dev/null
|
||||||
|
|
||||||
End of test memory usage:
|
End of test memory usage:
|
||||||
VARIABLE BEFORE AFTER
|
VARIABLE BEFORE AFTER
|
||||||
======== ======== ========
|
======== ======== ========
|
||||||
arena 71a0 71a0
|
arena 71a0 71a0
|
||||||
ordblks 2 2
|
ordblks 2 2
|
||||||
mxordblk 4a80 4a80
|
mxordblk 4a80 4a80
|
||||||
uordblks 1900 1900
|
uordblks 1900 1900
|
||||||
fordblks 58a0 58a0
|
fordblks 58a0 58a0
|
||||||
|
|
||||||
user_main: mutex test
|
user_main: mutex test
|
||||||
Initializing mutex
|
Initializing mutex
|
||||||
Starting thread 1
|
Starting thread 1
|
||||||
Starting thread 2
|
Starting thread 2
|
||||||
Thread1 Thread2
|
Thread1 Thread2
|
||||||
Loops 32 32
|
Loops 32 32
|
||||||
Errors 0 0
|
Errors 0 0
|
||||||
|
|
||||||
End of test memory usage:
|
End of test memory usage:
|
||||||
VARIABLE BEFORE AFTER
|
VARIABLE BEFORE AFTER
|
||||||
======== ======== ========
|
======== ======== ========
|
||||||
arena 71a0 71a0
|
arena 71a0 71a0
|
||||||
ordblks 2 2
|
ordblks 2 2
|
||||||
mxordblk 4a80 4a80
|
mxordblk 4a80 4a80
|
||||||
uordblks 1900 1900
|
uordblks 1900 1900
|
||||||
fordblks 58a0 58a0
|
fordblks 58a0 58a0
|
||||||
|
|
||||||
user_main: cancel test
|
user_main: cancel test
|
||||||
cancel_test: Test 1: Normal Cancelation
|
cancel_test: Test 1: Normal Cancelation
|
||||||
cancel_test: Starting thread
|
cancel_test: Starting thread
|
||||||
start_thread: Initializing mutex
|
start_thread: Initializing mutex
|
||||||
start_thread: Initializing cond
|
start_thread: Initializing cond
|
||||||
start_thread: Starting thread
|
start_thread: Starting thread
|
||||||
thread_waiter: Taking mutex
|
thread_waiter: Taking mutex
|
||||||
thread_waiter: Starting wait for condition
|
thread_waiter: Starting wait for condition
|
||||||
start_thread: Yielding
|
start_thread: Yielding
|
||||||
cancel_test: Canceling thread
|
cancel_test: Canceling thread
|
||||||
cancel_test: Joining
|
cancel_test: Joining
|
||||||
cancel_test: waiter exited with result=ffffffff
|
cancel_test: waiter exited with result=ffffffff
|
||||||
cancel_test: PASS thread terminated with PTHREAD_CANCELED
|
cancel_test: PASS thread terminated with PTHREAD_CANCELED
|
||||||
cancel_test: Test 2: Cancelation of detached thread
|
cancel_test: Test 2: Cancelation of detached thread
|
||||||
cancel_test: Re-starting thread
|
cancel_test: Re-starting thread
|
||||||
restart_thread: Destroying cond
|
restart_thread: Destroying cond
|
||||||
restart_thread: Destroying mutex
|
restart_thread: Destroying mutex
|
||||||
restart_thread: Re-starting thread
|
restart_thread: Re-starting thread
|
||||||
start_thread: Initializing mutex
|
start_thread: Initializing mutex
|
||||||
start_thread: Initializing cond
|
start_thread: Initializing cond
|
||||||
start_thread: Starting thread
|
start_thread: Starting thread
|
||||||
thread_waiter: Taking mutex
|
thread_waiter: Taking mutex
|
||||||
thread_waiter: Starting wait for condition
|
thread_waiter: Starting wait for condition
|
||||||
start_thread: Yielding
|
start_thread: Yielding
|
||||||
cancel_test: Canceling thread
|
cancel_test: Canceling thread
|
||||||
cancel_test: Joining
|
cancel_test: Joining
|
||||||
cancel_test: PASS pthread_join failed with status=ESRCH
|
cancel_test: PASS pthread_join failed with status=ESRCH
|
||||||
cancel_test: Test 3: Non-cancelable threads
|
cancel_test: Test 3: Non-cancelable threads
|
||||||
cancel_test: Re-starting thread (non-cancelable)
|
cancel_test: Re-starting thread (non-cancelable)
|
||||||
restart_thread: Destroying cond
|
restart_thread: Destroying cond
|
||||||
restart_thread: Destroying mutex
|
restart_thread: Destroying mutex
|
||||||
restart_thread: Re-starting thread
|
restart_thread: Re-starting thread
|
||||||
start_thread: Initializing mutex
|
start_thread: Initializing mutex
|
||||||
start_thread: Initializing cond
|
start_thread: Initializing cond
|
||||||
start_thread: Starting thread
|
start_thread: Starting thread
|
||||||
thread_waiter: Taking mutex
|
thread_waiter: Taking mutex
|
||||||
thread_waiter: Starting wait for condition
|
thread_waiter: Starting wait for condition
|
||||||
thread_waiter: Setting non-cancelable
|
thread_waiter: Setting non-cancelable
|
||||||
start_thread: Yielding
|
start_thread: Yielding
|
||||||
cancel_test: Canceling thread
|
cancel_test: Canceling thread
|
||||||
cancel_test: Joining
|
cancel_test: Joining
|
||||||
thread_waiter: Releasing mutex
|
thread_waiter: Releasing mutex
|
||||||
thread_waiter: Setting cancelable
|
thread_waiter: Setting cancelable
|
||||||
cancel_test: waiter exited with result=ffffffff
|
cancel_test: waiter exited with result=ffffffff
|
||||||
cancel_test: PASS thread terminated with PTHREAD_CANCELED
|
cancel_test: PASS thread terminated with PTHREAD_CANCELED
|
||||||
|
|
||||||
End of test memory usage:
|
End of test memory usage:
|
||||||
VARIABLE BEFORE AFTER
|
VARIABLE BEFORE AFTER
|
||||||
======== ======== ========
|
======== ======== ========
|
||||||
arena 71a0 71a0
|
arena 71a0 71a0
|
||||||
ordblks 2 2
|
ordblks 2 2
|
||||||
mxordblk 4a80 4a80
|
mxordblk 4a80 4a80
|
||||||
uordblks 1900 1900
|
uordblks 1900 1900
|
||||||
fordblks 58a0 58a0
|
fordblks 58a0 58a0
|
||||||
|
|
||||||
user_main: semaphore test
|
user_main: semaphore test
|
||||||
sem_test: Initializing semaphore to 0
|
sem_test: Initializing semaphore to 0
|
||||||
sem_test: Starting waiter thread 1
|
sem_test: Starting waiter thread 1
|
||||||
sem_test: Set thread 1 priority to 191
|
sem_test: Set thread 1 priority to 191
|
||||||
waiter_func: Thread 1 Started
|
waiter_func: Thread 1 Started
|
||||||
waiter_func: Thread 1 initial semaphore value = 0
|
waiter_func: Thread 1 initial semaphore value = 0
|
||||||
waiter_func: Thread 1 waiting on semaphore
|
waiter_func: Thread 1 waiting on semaphore
|
||||||
sem_test: Starting waiter thread 2
|
sem_test: Starting waiter thread 2
|
||||||
sem_test: Set thread 2 priority to 128
|
sem_test: Set thread 2 priority to 128
|
||||||
waiter_func: Thread 2 Started
|
waiter_func: Thread 2 Started
|
||||||
waiter_func: Thread 2 initial semaphore value = -1
|
waiter_func: Thread 2 initial semaphore value = -1
|
||||||
waiter_func: Thread 2 waiting on semaphore
|
waiter_func: Thread 2 waiting on semaphore
|
||||||
sem_test: Starting poster thread 3
|
sem_test: Starting poster thread 3
|
||||||
sem_test: Set thread 3 priority to 64
|
sem_test: Set thread 3 priority to 64
|
||||||
poster_func: Thread 3 started
|
poster_func: Thread 3 started
|
||||||
poster_func: Thread 3 semaphore value = -2
|
poster_func: Thread 3 semaphore value = -2
|
||||||
poster_func: Thread 3 posting semaphore
|
poster_func: Thread 3 posting semaphore
|
||||||
waiter_func: Thread 1 awakened
|
waiter_func: Thread 1 awakened
|
||||||
waiter_func: Thread 1 new semaphore value = -1
|
waiter_func: Thread 1 new semaphore value = -1
|
||||||
waiter_func: Thread 1 done
|
waiter_func: Thread 1 done
|
||||||
poster_func: Thread 3 new semaphore value = -1
|
poster_func: Thread 3 new semaphore value = -1
|
||||||
poster_func: Thread 3 semaphore value = -1
|
poster_func: Thread 3 semaphore value = -1
|
||||||
poster_func: Thread 3 posting semaphore
|
poster_func: Thread 3 posting semaphore
|
||||||
waiter_func: Thread 2 awakened
|
waiter_func: Thread 2 awakened
|
||||||
waiter_func: Thread 2 new semaphore value = 0
|
waiter_func: Thread 2 new semaphore value = 0
|
||||||
waiter_func: Thread 2 done
|
waiter_func: Thread 2 done
|
||||||
poster_func: Thread 3 new semaphore value = 0
|
poster_func: Thread 3 new semaphore value = 0
|
||||||
poster_func: Thread 3 done
|
poster_func: Thread 3 done
|
||||||
|
|
||||||
End of test memory usage:
|
End of test memory usage:
|
||||||
VARIABLE BEFORE AFTER
|
VARIABLE BEFORE AFTER
|
||||||
======== ======== ========
|
======== ======== ========
|
||||||
arena 71a0 71a0
|
arena 71a0 71a0
|
||||||
ordblks 2 2
|
ordblks 2 2
|
||||||
mxordblk 4a80 4a80
|
mxordblk 4a80 4a80
|
||||||
uordblks 1900 1900
|
uordblks 1900 1900
|
||||||
fordblks 58a0 58a0
|
fordblks 58a0 58a0
|
||||||
|
|
||||||
user_main: condition variable test
|
user_main: condition variable test
|
||||||
cond_test: Initializing mutex
|
cond_test: Initializing mutex
|
||||||
cond_test: Initializing cond
|
cond_test: Initializing cond
|
||||||
cond_test: Starting waiter
|
cond_test: Starting waiter
|
||||||
cond_test: Set thread 1 priority to 128
|
cond_test: Set thread 1 priority to 128
|
||||||
waiter_thread: Started
|
waiter_thread: Started
|
||||||
cond_test: Starting signaler
|
cond_test: Starting signaler
|
||||||
cond_test: Set thread 2 priority to 64
|
cond_test: Set thread 2 priority to 64
|
||||||
thread_signaler: Started
|
thread_signaler: Started
|
||||||
thread_signaler: Terminating
|
thread_signaler: Terminating
|
||||||
cond_test: signaler terminated, now cancel the waiter
|
cond_test: signaler terminated, now cancel the waiter
|
||||||
cond_test: Waiter Signaler
|
cond_test: Waiter Signaler
|
||||||
cond_test: Loops 32 32
|
cond_test: Loops 32 32
|
||||||
cond_test: Errors 0 0
|
cond_test: Errors 0 0
|
||||||
cond_test:
|
cond_test:
|
||||||
cond_test: 0 times, waiter did not have to wait for data
|
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, data was already available when the signaler run
|
||||||
cond_test: 0 times, the waiter was in an unexpected state when the signaler ran
|
cond_test: 0 times, the waiter was in an unexpected state when the signaler ran
|
||||||
|
|
||||||
End of test memory usage:
|
End of test memory usage:
|
||||||
VARIABLE BEFORE AFTER
|
VARIABLE BEFORE AFTER
|
||||||
======== ======== ========
|
======== ======== ========
|
||||||
arena 71a0 71a0
|
arena 71a0 71a0
|
||||||
ordblks 2 2
|
ordblks 2 2
|
||||||
mxordblk 4a80 4a80
|
mxordblk 4a80 4a80
|
||||||
uordblks 1900 1900
|
uordblks 1900 1900
|
||||||
fordblks 58a0 58a0
|
fordblks 58a0 58a0
|
||||||
|
|
||||||
user_main: timed wait test
|
user_main: timed wait test
|
||||||
thread_waiter: Initializing mutex
|
thread_waiter: Initializing mutex
|
||||||
timedwait_test: Initializing cond
|
timedwait_test: Initializing cond
|
||||||
timedwait_test: Starting waiter
|
timedwait_test: Starting waiter
|
||||||
timedwait_test: Set thread 2 priority to 177
|
timedwait_test: Set thread 2 priority to 177
|
||||||
thread_waiter: Taking mutex
|
thread_waiter: Taking mutex
|
||||||
thread_waiter: Starting 5 second wait for condition
|
thread_waiter: Starting 5 second wait for condition
|
||||||
timedwait_test: Joining
|
timedwait_test: Joining
|
||||||
thread_waiter: pthread_cond_timedwait timed out
|
thread_waiter: pthread_cond_timedwait timed out
|
||||||
thread_waiter: Releasing mutex
|
thread_waiter: Releasing mutex
|
||||||
thread_waiter: Exit with status 0x12345678
|
thread_waiter: Exit with status 0x12345678
|
||||||
timedwait_test: waiter exited with result=12345678
|
timedwait_test: waiter exited with result=12345678
|
||||||
|
|
||||||
End of test memory usage:
|
End of test memory usage:
|
||||||
VARIABLE BEFORE AFTER
|
VARIABLE BEFORE AFTER
|
||||||
======== ======== ========
|
======== ======== ========
|
||||||
arena 71a0 71a0
|
arena 71a0 71a0
|
||||||
ordblks 2 2
|
ordblks 2 2
|
||||||
mxordblk 4a80 4a80
|
mxordblk 4a80 4a80
|
||||||
uordblks 1900 1900
|
uordblks 1900 1900
|
||||||
fordblks 58a0 58a0
|
fordblks 58a0 58a0
|
||||||
|
|
||||||
user_main: message queue test
|
user_main: message queue test
|
||||||
mqueue_test: Starting receiver
|
mqueue_test: Starting receiver
|
||||||
mqueue_test: Set receiver priority to 128
|
mqueue_test: Set receiver priority to 128
|
||||||
receiver_thread: Starting
|
receiver_thread: Starting
|
||||||
mqueue_test: Starting sender
|
mqueue_test: Starting sender
|
||||||
mqueue_test: Set sender thread priority to 64
|
mqueue_test: Set sender thread priority to 64
|
||||||
mqueue_test: Waiting for sender to complete
|
mqueue_test: Waiting for sender to complete
|
||||||
sender_thread: Starting
|
sender_thread: Starting
|
||||||
receiver_thread: mq_receive succeeded on msg 0
|
receiver_thread: mq_receive succeeded on msg 0
|
||||||
sender_thread: mq_send succeeded on msg 0
|
sender_thread: mq_send succeeded on msg 0
|
||||||
receiver_thread: mq_receive succeeded on msg 1
|
receiver_thread: mq_receive succeeded on msg 1
|
||||||
sender_thread: mq_send succeeded on msg 1
|
sender_thread: mq_send succeeded on msg 1
|
||||||
receiver_thread: mq_receive succeeded on msg 2
|
receiver_thread: mq_receive succeeded on msg 2
|
||||||
sender_thread: mq_send succeeded on msg 2
|
sender_thread: mq_send succeeded on msg 2
|
||||||
receiver_thread: mq_receive succeeded on msg 3
|
receiver_thread: mq_receive succeeded on msg 3
|
||||||
sender_thread: mq_send succeeded on msg 3
|
sender_thread: mq_send succeeded on msg 3
|
||||||
receiver_thread: mq_receive succeeded on msg 4
|
receiver_thread: mq_receive succeeded on msg 4
|
||||||
sender_thread: mq_send succeeded on msg 4
|
sender_thread: mq_send succeeded on msg 4
|
||||||
receiver_thread: mq_receive succeeded on msg 5
|
receiver_thread: mq_receive succeeded on msg 5
|
||||||
sender_thread: mq_send succeeded on msg 5
|
sender_thread: mq_send succeeded on msg 5
|
||||||
receiver_thread: mq_receive succeeded on msg 6
|
receiver_thread: mq_receive succeeded on msg 6
|
||||||
sender_thread: mq_send succeeded on msg 6
|
sender_thread: mq_send succeeded on msg 6
|
||||||
receiver_thread: mq_receive succeeded on msg 7
|
receiver_thread: mq_receive succeeded on msg 7
|
||||||
sender_thread: mq_send succeeded on msg 7
|
sender_thread: mq_send succeeded on msg 7
|
||||||
receiver_thread: mq_receive succeeded on msg 8
|
receiver_thread: mq_receive succeeded on msg 8
|
||||||
sender_thread: mq_send succeeded on msg 8
|
sender_thread: mq_send succeeded on msg 8
|
||||||
receiver_thread: mq_receive succeeded on msg 9
|
receiver_thread: mq_receive succeeded on msg 9
|
||||||
sender_thread: mq_send succeeded on msg 9
|
sender_thread: mq_send succeeded on msg 9
|
||||||
sender_thread: returning nerrors=0
|
sender_thread: returning nerrors=0
|
||||||
mqueue_test: Killing receiver
|
mqueue_test: Killing receiver
|
||||||
receiver_thread: mq_receive interrupted!
|
receiver_thread: mq_receive interrupted!
|
||||||
receiver_thread: returning nerrors=0
|
receiver_thread: returning nerrors=0
|
||||||
mqueue_test: Canceling receiver
|
mqueue_test: Canceling receiver
|
||||||
mqueue_test: receiver has already terminated
|
mqueue_test: receiver has already terminated
|
||||||
|
|
||||||
End of test memory usage:
|
End of test memory usage:
|
||||||
VARIABLE BEFORE AFTER
|
VARIABLE BEFORE AFTER
|
||||||
======== ======== ========
|
======== ======== ========
|
||||||
arena 71a0 71a0
|
arena 71a0 71a0
|
||||||
ordblks 2 2
|
ordblks 2 2
|
||||||
mxordblk 4a80 4a80
|
mxordblk 4a80 4a80
|
||||||
uordblks 1900 1900
|
uordblks 1900 1900
|
||||||
fordblks 58a0 58a0
|
fordblks 58a0 58a0
|
||||||
|
|
||||||
user_main: timed message queue test
|
user_main: timed message queue test
|
||||||
timedmqueue_test: Starting sender
|
timedmqueue_test: Starting sender
|
||||||
sender_thread: Starting
|
sender_thread: Starting
|
||||||
sender_thread: mq_timedsend succeeded on msg 0
|
sender_thread: mq_timedsend succeeded on msg 0
|
||||||
sender_thread: mq_timedsend succeeded on msg 1
|
sender_thread: mq_timedsend succeeded on msg 1
|
||||||
sender_thread: mq_timedsend succeeded on msg 2
|
sender_thread: mq_timedsend succeeded on msg 2
|
||||||
sender_thread: mq_timedsend succeeded on msg 3
|
sender_thread: mq_timedsend succeeded on msg 3
|
||||||
sender_thread: mq_timedsend succeeded on msg 4
|
sender_thread: mq_timedsend succeeded on msg 4
|
||||||
sender_thread: mq_timedsend succeeded on msg 5
|
sender_thread: mq_timedsend succeeded on msg 5
|
||||||
sender_thread: mq_timedsend succeeded on msg 6
|
sender_thread: mq_timedsend succeeded on msg 6
|
||||||
sender_thread: mq_timedsend succeeded on msg 7
|
sender_thread: mq_timedsend succeeded on msg 7
|
||||||
sender_thread: mq_timedsend succeeded on msg 8
|
sender_thread: mq_timedsend succeeded on msg 8
|
||||||
timedmqueue_test: Waiting for sender to complete
|
timedmqueue_test: Waiting for sender to complete
|
||||||
sender_thread: mq_timedsend 9 timed out as expected
|
sender_thread: mq_timedsend 9 timed out as expected
|
||||||
sender_thread: returning nerrors=0
|
sender_thread: returning nerrors=0
|
||||||
timedmqueue_test: Starting receiver
|
timedmqueue_test: Starting receiver
|
||||||
receiver_thread: Starting
|
receiver_thread: Starting
|
||||||
receiver_thread: mq_timedreceive succeeded on msg 0
|
receiver_thread: mq_timedreceive succeeded on msg 0
|
||||||
receiver_thread: mq_timedreceive succeeded on msg 1
|
receiver_thread: mq_timedreceive succeeded on msg 1
|
||||||
receiver_thread: mq_timedreceive succeeded on msg 2
|
receiver_thread: mq_timedreceive succeeded on msg 2
|
||||||
receiver_thread: mq_timedreceive succeeded on msg 3
|
receiver_thread: mq_timedreceive succeeded on msg 3
|
||||||
receiver_thread: mq_timedreceive succeeded on msg 4
|
receiver_thread: mq_timedreceive succeeded on msg 4
|
||||||
receiver_thread: mq_timedreceive succeeded on msg 5
|
receiver_thread: mq_timedreceive succeeded on msg 5
|
||||||
receiver_thread: mq_timedreceive succeeded on msg 6
|
receiver_thread: mq_timedreceive succeeded on msg 6
|
||||||
receiver_thread: mq_timedreceive succeeded on msg 7
|
receiver_thread: mq_timedreceive succeeded on msg 7
|
||||||
receiver_thread: mq_timedreceive succeeded on msg 8
|
receiver_thread: mq_timedreceive succeeded on msg 8
|
||||||
timedmqueue_test: Waiting for receiver to complete
|
timedmqueue_test: Waiting for receiver to complete
|
||||||
receiver_thread: Receive 9 timed out as expected
|
receiver_thread: Receive 9 timed out as expected
|
||||||
receiver_thread: returning nerrors=0
|
receiver_thread: returning nerrors=0
|
||||||
timedmqueue_test: Test complete
|
timedmqueue_test: Test complete
|
||||||
|
|
||||||
End of test memory usage:
|
End of test memory usage:
|
||||||
VARIABLE BEFORE AFTER
|
VARIABLE BEFORE AFTER
|
||||||
======== ======== ========
|
======== ======== ========
|
||||||
arena 71a0 71a0
|
arena 71a0 71a0
|
||||||
ordblks 2 2
|
ordblks 2 2
|
||||||
mxordblk 4a80 4a80
|
mxordblk 4a80 4a80
|
||||||
uordblks 1900 1900
|
uordblks 1900 1900
|
||||||
fordblks 58a0 58a0
|
fordblks 58a0 58a0
|
||||||
|
|
||||||
user_main: signal handler test
|
user_main: signal handler test
|
||||||
sighand_test: Initializing semaphore to 0
|
sighand_test: Initializing semaphore to 0
|
||||||
sighand_test: Starting waiter task
|
sighand_test: Starting waiter task
|
||||||
sighand_test: Started waiter_main pid=20
|
sighand_test: Started waiter_main pid=20
|
||||||
waiter_main: Waiter started
|
waiter_main: Waiter started
|
||||||
waiter_main: Unmasking signal 17
|
waiter_main: Unmasking signal 17
|
||||||
waiter_main: Registering signal handler
|
waiter_main: Registering signal handler
|
||||||
waiter_main: oact.sigaction=0 oact.sa_flags=0 oact.sa_mask=0
|
waiter_main: oact.sigaction=0 oact.sa_flags=0 oact.sa_mask=0
|
||||||
waiter_main: Waiting on semaphore
|
waiter_main: Waiting on semaphore
|
||||||
sighand_test: Signaling pid=20 with signo=17 sigvalue=42
|
sighand_test: Signaling pid=20 with signo=17 sigvalue=42
|
||||||
wakeup_action: Received signal 17
|
wakeup_action: Received signal 17
|
||||||
wakeup_action: sival_int=42
|
wakeup_action: sival_int=42
|
||||||
wakeup_action: si_code=1
|
wakeup_action: si_code=1
|
||||||
wakeup_action: ucontext=0
|
wakeup_action: ucontext=0
|
||||||
waiter_main: sem_wait() successfully interrupted by signal
|
waiter_main: sem_wait() successfully interrupted by signal
|
||||||
waiter_main: done
|
waiter_main: done
|
||||||
sighand_test: done
|
sighand_test: done
|
||||||
|
|
||||||
End of test memory usage:
|
End of test memory usage:
|
||||||
VARIABLE BEFORE AFTER
|
VARIABLE BEFORE AFTER
|
||||||
======== ======== ========
|
======== ======== ========
|
||||||
arena 71a0 71a0
|
arena 71a0 71a0
|
||||||
ordblks 2 2
|
ordblks 2 2
|
||||||
mxordblk 4a80 4a80
|
mxordblk 4a80 4a80
|
||||||
uordblks 1900 1900
|
uordblks 1900 1900
|
||||||
fordblks 58a0 58a0
|
fordblks 58a0 58a0
|
||||||
|
|
||||||
user_main: POSIX timer test
|
user_main: POSIX timer test
|
||||||
timer_test: Initializing semaphore to 0
|
timer_test: Initializing semaphore to 0
|
||||||
timer_test: Unmasking signal 17
|
timer_test: Unmasking signal 17
|
||||||
timer_test: Registering signal handler
|
timer_test: Registering signal handler
|
||||||
timer_test: oact.sigaction=0 oact.sa_flags=0 oact.sa_mask=0
|
timer_test: oact.sigaction=0 oact.sa_flags=0 oact.sa_mask=0
|
||||||
timer_test: Creating timer
|
timer_test: Creating timer
|
||||||
timer_test: Starting timer
|
timer_test: Starting timer
|
||||||
timer_test: Waiting on semaphore
|
timer_test: Waiting on semaphore
|
||||||
timer_expiration: Received signal 17
|
timer_expiration: Received signal 17
|
||||||
timer_expiration: sival_int=42
|
timer_expiration: sival_int=42
|
||||||
timer_expiration: si_code=2 (SI_TIMER)
|
timer_expiration: si_code=2 (SI_TIMER)
|
||||||
timer_expiration: ucontext=0
|
timer_expiration: ucontext=0
|
||||||
timer_test: sem_wait() successfully interrupted by signal
|
timer_test: sem_wait() successfully interrupted by signal
|
||||||
timer_test: g_nsigreceived=1
|
timer_test: g_nsigreceived=1
|
||||||
timer_test: Waiting on semaphore
|
timer_test: Waiting on semaphore
|
||||||
timer_expiration: Received signal 17
|
timer_expiration: Received signal 17
|
||||||
timer_expiration: sival_int=42
|
timer_expiration: sival_int=42
|
||||||
timer_expiration: si_code=2 (SI_TIMER)
|
timer_expiration: si_code=2 (SI_TIMER)
|
||||||
timer_expiration: ucontext=0
|
timer_expiration: ucontext=0
|
||||||
timer_test: sem_wait() successfully interrupted by signal
|
timer_test: sem_wait() successfully interrupted by signal
|
||||||
timer_test: g_nsigreceived=2
|
timer_test: g_nsigreceived=2
|
||||||
timer_test: Waiting on semaphore
|
timer_test: Waiting on semaphore
|
||||||
timer_expiration: Received signal 17
|
timer_expiration: Received signal 17
|
||||||
timer_expiration: sival_int=42
|
timer_expiration: sival_int=42
|
||||||
timer_expiration: si_code=2 (SI_TIMER)
|
timer_expiration: si_code=2 (SI_TIMER)
|
||||||
timer_expiration: ucontext=0
|
timer_expiration: ucontext=0
|
||||||
timer_test: sem_wait() successfully interrupted by signal
|
timer_test: sem_wait() successfully interrupted by signal
|
||||||
timer_test: g_nsigreceived=3
|
timer_test: g_nsigreceived=3
|
||||||
timer_test: Waiting on semaphore
|
timer_test: Waiting on semaphore
|
||||||
timer_expiration: Received signal 17
|
timer_expiration: Received signal 17
|
||||||
timer_expiration: sival_int=42
|
timer_expiration: sival_int=42
|
||||||
timer_expiration: si_code=2 (SI_TIMER)
|
timer_expiration: si_code=2 (SI_TIMER)
|
||||||
timer_expiration: ucontext=0
|
timer_expiration: ucontext=0
|
||||||
timer_test: sem_wait() successfully interrupted by signal
|
timer_test: sem_wait() successfully interrupted by signal
|
||||||
timer_test: g_nsigreceived=4
|
timer_test: g_nsigreceived=4
|
||||||
timer_test: Waiting on semaphore
|
timer_test: Waiting on semaphore
|
||||||
timer_expiration: Received signal 17
|
timer_expiration: Received signal 17
|
||||||
timer_expiration: sival_int=42
|
timer_expiration: sival_int=42
|
||||||
timer_expiration: si_code=2 (SI_TIMER)
|
timer_expiration: si_code=2 (SI_TIMER)
|
||||||
timer_expiration: ucontext=0
|
timer_expiration: ucontext=0
|
||||||
timer_test: sem_wait() successfully interrupted by signal
|
timer_test: sem_wait() successfully interrupted by signal
|
||||||
timer_test: g_nsigreceived=5
|
timer_test: g_nsigreceived=5
|
||||||
timer_test: Deleting timer
|
timer_test: Deleting timer
|
||||||
timer_test: done
|
timer_test: done
|
||||||
|
|
||||||
End of test memory usage:
|
End of test memory usage:
|
||||||
VARIABLE BEFORE AFTER
|
VARIABLE BEFORE AFTER
|
||||||
======== ======== ========
|
======== ======== ========
|
||||||
arena 71a0 71a0
|
arena 71a0 71a0
|
||||||
ordblks 2 2
|
ordblks 2 2
|
||||||
mxordblk 4a80 4a80
|
mxordblk 4a80 4a80
|
||||||
uordblks 1900 1900
|
uordblks 1900 1900
|
||||||
fordblks 58a0 58a0
|
fordblks 58a0 58a0
|
||||||
|
|
||||||
user_main: barrier test
|
user_main: barrier test
|
||||||
barrier_test: Initializing barrier
|
barrier_test: Initializing barrier
|
||||||
barrier_func: Thread 0 started
|
barrier_func: Thread 0 started
|
||||||
barrier_test: Thread 0 created
|
barrier_test: Thread 0 created
|
||||||
barrier_func: Thread 1 started
|
barrier_func: Thread 1 started
|
||||||
barrier_test: Thread 1 created
|
barrier_test: Thread 1 created
|
||||||
barrier_func: Thread 2 started
|
barrier_func: Thread 2 started
|
||||||
barrier_test: Thread 2 created
|
barrier_test: Thread 2 created
|
||||||
barrier_func: Thread 0 calling pthread_barrier_wait()
|
barrier_func: Thread 0 calling pthread_barrier_wait()
|
||||||
barrier_func: Thread 1 calling pthread_barrier_wait()
|
barrier_func: Thread 1 calling pthread_barrier_wait()
|
||||||
barrier_func: Thread 2 calling pthread_barrier_wait()
|
barrier_func: Thread 2 calling pthread_barrier_wait()
|
||||||
barrier_func: Thread 2, back with status=PTHREAD_BARRIER_SERIAL_THREAD (I AM SPECIAL)
|
barrier_func: Thread 2, 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 0, back with status=0 (I am not special)
|
||||||
barrier_func: Thread 1, back with status=0 (I am not special)
|
barrier_func: Thread 1, back with status=0 (I am not special)
|
||||||
barrier_func: Thread 2 done
|
barrier_func: Thread 2 done
|
||||||
barrier_func: Thread 0 done
|
barrier_func: Thread 0 done
|
||||||
barrier_func: Thread 1 done
|
barrier_func: Thread 1 done
|
||||||
barrier_test: Thread 0 completed with result=0
|
barrier_test: Thread 0 completed with result=0
|
||||||
barrier_test: Thread 1 completed with result=0
|
barrier_test: Thread 1 completed with result=0
|
||||||
barrier_test: Thread 2 completed with result=0
|
barrier_test: Thread 2 completed with result=0
|
||||||
|
|
||||||
End of test memory usage:
|
End of test memory usage:
|
||||||
VARIABLE BEFORE AFTER
|
VARIABLE BEFORE AFTER
|
||||||
======== ======== ========
|
======== ======== ========
|
||||||
arena 71a0 71a0
|
arena 71a0 71a0
|
||||||
ordblks 2 2
|
ordblks 2 2
|
||||||
mxordblk 4a80 4a80
|
mxordblk 4a80 4a80
|
||||||
uordblks 1900 1900
|
uordblks 1900 1900
|
||||||
fordblks 58a0 58a0
|
fordblks 58a0 58a0
|
||||||
|
|
||||||
Final memory usage:
|
Final memory usage:
|
||||||
VARIABLE BEFORE AFTER
|
VARIABLE BEFORE AFTER
|
||||||
======== ======== ========
|
======== ======== ========
|
||||||
arena 71a0 71a0
|
arena 71a0 71a0
|
||||||
ordblks 2 2
|
ordblks 2 2
|
||||||
mxordblk 4a80 4a80
|
mxordblk 4a80 4a80
|
||||||
uordblks 1900 1900
|
uordblks 1900 1900
|
||||||
fordblks 58a0 58a0
|
fordblks 58a0 58a0
|
||||||
user_main: Exitting
|
user_main: Exitting
|
||||||
|
@ -1,123 +1,123 @@
|
|||||||
README
|
README
|
||||||
======
|
======
|
||||||
|
|
||||||
This is the README file for the port of NuttX to the TI CC3200 Launchpad.
|
This is the README file for the port of NuttX to the TI CC3200 Launchpad.
|
||||||
|
|
||||||
OpenOCD for Windows
|
OpenOCD for Windows
|
||||||
===================
|
===================
|
||||||
|
|
||||||
Get the CC3200 SDK
|
Get the CC3200 SDK
|
||||||
------------------
|
------------------
|
||||||
Get this from the TI web site. Also get "CC3200 SimpleLink™ Wi-Fi® and
|
Get this from the TI web site. Also get "CC3200 SimpleLink™ Wi-Fi® and
|
||||||
IoT Solution With MCU LaunchPad™ Getting Started Guide" (SWRU376A)
|
IoT Solution With MCU LaunchPad™ Getting Started Guide" (SWRU376A)
|
||||||
|
|
||||||
Get OpenOCD
|
Get OpenOCD
|
||||||
------------
|
------------
|
||||||
The OpenOCD project is here: http://openocd.sourceforge.net/
|
The OpenOCD project is here: http://openocd.sourceforge.net/
|
||||||
|
|
||||||
I use the pre-built binaries provided by Freddie Chopin that can b
|
I use the pre-built binaries provided by Freddie Chopin that can b
|
||||||
downloaded here: http://www.freddiechopin.info/
|
downloaded here: http://www.freddiechopin.info/
|
||||||
|
|
||||||
I used version 0.8.0 which available here:
|
I used version 0.8.0 which available here:
|
||||||
http://www.freddiechopin.info/en/articles/34-news/92-openocd-w-wersji-080
|
http://www.freddiechopin.info/en/articles/34-news/92-openocd-w-wersji-080
|
||||||
|
|
||||||
Other versions are available here:
|
Other versions are available here:
|
||||||
http://www.freddiechopin.info/en/download/category/4-openocd
|
http://www.freddiechopin.info/en/download/category/4-openocd
|
||||||
|
|
||||||
Get Zadig
|
Get Zadig
|
||||||
---------
|
---------
|
||||||
Unless you are very clever with Windows drivers, then I also recommend
|
Unless you are very clever with Windows drivers, then I also recommend
|
||||||
that you download and install Zadig: http://zadig.akeo.ie/
|
that you download and install Zadig: http://zadig.akeo.ie/
|
||||||
|
|
||||||
Other Stuff
|
Other Stuff
|
||||||
-----------
|
-----------
|
||||||
USB Cable, your favorite serial terminal program, NuttX build with
|
USB Cable, your favorite serial terminal program, NuttX build with
|
||||||
one of the CC3200 configurations in this diretory.
|
one of the CC3200 configurations in this diretory.
|
||||||
|
|
||||||
Installing
|
Installing
|
||||||
----------
|
----------
|
||||||
Install the TI CC3200 SDK and OpenOCD. Zadig is just an binary so there
|
Install the TI CC3200 SDK and OpenOCD. Zadig is just an binary so there
|
||||||
is no installation. Plug in the CC3200 via the USB cable. You should see
|
is no installation. Plug in the CC3200 via the USB cable. You should see
|
||||||
two new devices in the Windows Device Manager, both called:
|
two new devices in the Windows Device Manager, both called:
|
||||||
|
|
||||||
USB <-> JTAG/SWD
|
USB <-> JTAG/SWD
|
||||||
|
|
||||||
There will be indications on the driver icon that no driver is installed.
|
There will be indications on the driver icon that no driver is installed.
|
||||||
|
|
||||||
Follow the instructions in the paragraph "Install USB Driver" to install
|
Follow the instructions in the paragraph "Install USB Driver" to install
|
||||||
the TI USB drivers. You need to do this twice, once for each device. Now
|
the TI USB drivers. You need to do this twice, once for each device. Now
|
||||||
you will have two devices with different names:
|
you will have two devices with different names:
|
||||||
|
|
||||||
CC3200CP JTAG Port A, and
|
CC3200CP JTAG Port A, and
|
||||||
CC3200CP UART Port B
|
CC3200CP UART Port B
|
||||||
|
|
||||||
OpenOCD cannot use the TI JTAG drivers. So we need to replace that port
|
OpenOCD cannot use the TI JTAG drivers. So we need to replace that port
|
||||||
(ONLY) with the libusb driver. Use Zadig to install the libusb driver
|
(ONLY) with the libusb driver. Use Zadig to install the libusb driver
|
||||||
replacing the TI driver for "CC3200CP JTAG Port A". Now you should have
|
replacing the TI driver for "CC3200CP JTAG Port A". Now you should have
|
||||||
the following under "Ports (COM & LPT)":
|
the following under "Ports (COM & LPT)":
|
||||||
|
|
||||||
CC3200 UART Port B
|
CC3200 UART Port B
|
||||||
|
|
||||||
And under "Universal Serial Bus Devices", again:
|
And under "Universal Serial Bus Devices", again:
|
||||||
|
|
||||||
USB <-> JTAG/SWD
|
USB <-> JTAG/SWD
|
||||||
|
|
||||||
But this time without the indication that a driver is needed.
|
But this time without the indication that a driver is needed.
|
||||||
|
|
||||||
Starting OpenOCD
|
Starting OpenOCD
|
||||||
----------------
|
----------------
|
||||||
These instructions assume that (1) you are using a terminal with a Bash
|
These instructions assume that (1) you are using a terminal with a Bash
|
||||||
shell under Cygwin, (2) that you installed OpenOCD at C:\openocd-0.8.0,
|
shell under Cygwin, (2) that you installed OpenOCD at C:\openocd-0.8.0,
|
||||||
and (3) you are using a 64-bit windows version. You will need to make
|
and (3) you are using a 64-bit windows version. You will need to make
|
||||||
minor changes if any of these are not true.
|
minor changes if any of these are not true.
|
||||||
|
|
||||||
The script to use with OpenOCD 0.8.0 is provided in
|
The script to use with OpenOCD 0.8.0 is provided in
|
||||||
nuttx/configs/cc3200-launchpad/tools. Go there and start OpenOCd as
|
nuttx/configs/cc3200-launchpad/tools. Go there and start OpenOCd as
|
||||||
follow:
|
follow:
|
||||||
|
|
||||||
$ cd configs/cc3200-launchpad/tools
|
$ cd configs/cc3200-launchpad/tools
|
||||||
$ /cygdrive/c/openocd-0.8.0/bin-x64/openocd-x64-0.8.0.exe --file cc3200.cfg
|
$ /cygdrive/c/openocd-0.8.0/bin-x64/openocd-x64-0.8.0.exe --file cc3200.cfg
|
||||||
|
|
||||||
And you should see something like:
|
And you should see something like:
|
||||||
|
|
||||||
Open On-Chip Debugger 0.8.0 (2014-04-28-08:42)
|
Open On-Chip Debugger 0.8.0 (2014-04-28-08:42)
|
||||||
Licensed under GNU GPL v2
|
Licensed under GNU GPL v2
|
||||||
For bug reports, read
|
For bug reports, read
|
||||||
http://openocd.sourceforge.net/doc/doxygen/bugs.html
|
http://openocd.sourceforge.net/doc/doxygen/bugs.html
|
||||||
Info : only one transport option; autoselect 'jtag'
|
Info : only one transport option; autoselect 'jtag'
|
||||||
adapter speed: 1000 kHz
|
adapter speed: 1000 kHz
|
||||||
Info : clock speed 1000 kHz
|
Info : clock speed 1000 kHz
|
||||||
Info : JTAG tap: cc3200.jrc tap/device found: 0x0b97c02f (mfg: 0x017, part: 0xb97c, ver: 0x0)
|
Info : JTAG tap: cc3200.jrc tap/device found: 0x0b97c02f (mfg: 0x017, part: 0xb97c, ver: 0x0)
|
||||||
Info : JTAG tap: cc3200.dap enabled
|
Info : JTAG tap: cc3200.dap enabled
|
||||||
Info : cc3200.cpu: hardware has 6 breakpoints, 4 watchpoints
|
Info : cc3200.cpu: hardware has 6 breakpoints, 4 watchpoints
|
||||||
|
|
||||||
Open the Serial Terminal
|
Open the Serial Terminal
|
||||||
------------------------
|
------------------------
|
||||||
Connect the CC3200 board via the USB cabale. Open the serial terminal
|
Connect the CC3200 board via the USB cabale. Open the serial terminal
|
||||||
program using the libusb COM device. For me this is usually COM6 but
|
program using the libusb COM device. For me this is usually COM6 but
|
||||||
could be anything. If you are unsure, remove the CC3200 and see which
|
could be anything. If you are unsure, remove the CC3200 and see which
|
||||||
one goes away.
|
one goes away.
|
||||||
|
|
||||||
The serial interface should be configured 115200 8N1.
|
The serial interface should be configured 115200 8N1.
|
||||||
|
|
||||||
Using GDB
|
Using GDB
|
||||||
---------
|
---------
|
||||||
Start GDB and connect to OpenOCD:
|
Start GDB and connect to OpenOCD:
|
||||||
|
|
||||||
$ arm-none-eabi-gdb
|
$ arm-none-eabi-gdb
|
||||||
(gdb) target remote localhost:3333
|
(gdb) target remote localhost:3333
|
||||||
|
|
||||||
Load and start the NuttX ELF file (nuttx):
|
Load and start the NuttX ELF file (nuttx):
|
||||||
|
|
||||||
(gdb) mon reset halt
|
(gdb) mon reset halt
|
||||||
(gdb) load nuttx
|
(gdb) load nuttx
|
||||||
(gdb) cont
|
(gdb) cont
|
||||||
(gdb)
|
(gdb)
|
||||||
|
|
||||||
After entering cont(inue), you should see the NSH prompt in the serial
|
After entering cont(inue), you should see the NSH prompt in the serial
|
||||||
terminal window:
|
terminal window:
|
||||||
|
|
||||||
C3200 init
|
C3200 init
|
||||||
|
|
||||||
NuttShell (NSH)
|
NuttShell (NSH)
|
||||||
nsh>
|
nsh>
|
||||||
|
@ -2,82 +2,82 @@ diff -rub lpc21isp-1.60/lpc21isp.c lpc21isp-Linux//lpc21isp.c
|
|||||||
--- lpc21isp-1.60/lpc21isp.c 2008-07-21 15:17:06.000000000 -0600
|
--- lpc21isp-1.60/lpc21isp.c 2008-07-21 15:17:06.000000000 -0600
|
||||||
+++ lpc21isp-Linux//lpc21isp.c 2008-09-16 09:21:20.000000000 -0600
|
+++ lpc21isp-Linux//lpc21isp.c 2008-09-16 09:21:20.000000000 -0600
|
||||||
@@ -22,6 +22,7 @@
|
@@ -22,6 +22,7 @@
|
||||||
#include "adprog.h"
|
#include "adprog.h"
|
||||||
#include "lpcprog.h"
|
#include "lpcprog.h"
|
||||||
#include "lpcterm.h"
|
#include "lpcterm.h"
|
||||||
+#include "errno.h"
|
+#include "errno.h"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
Change-History:
|
Change-History:
|
||||||
@@ -319,10 +320,7 @@
|
@@ -319,10 +320,7 @@
|
||||||
|
|
||||||
if (IspEnvironment->fdCom < 0)
|
if (IspEnvironment->fdCom < 0)
|
||||||
{
|
{
|
||||||
- int* p_err = __error();
|
- int* p_err = __error();
|
||||||
- int err;
|
- int err;
|
||||||
- if (p_err) { err = *p_err; }
|
- if (p_err) { err = *p_err; }
|
||||||
- DebugPrintf(1, "Can't open COM-Port %s ! (Error: %dd (0x%X))\n", IspEnvironment->serial_port, err, err);
|
- DebugPrintf(1, "Can't open COM-Port %s ! (Error: %dd (0x%X))\n", IspEnvironment->serial_port, err, err);
|
||||||
+ DebugPrintf(1, "Can't open COM-Port %s ! (Error: %dd (0x%X))\n", IspEnvironment->serial_port, errno, errno);
|
+ DebugPrintf(1, "Can't open COM-Port %s ! (Error: %dd (0x%X))\n", IspEnvironment->serial_port, errno, errno);
|
||||||
exit(2);
|
exit(2);
|
||||||
}
|
}
|
||||||
|
|
||||||
diff -rub lpc21isp-1.60/lpc21isp.h lpc21isp-Linux//lpc21isp.h
|
diff -rub lpc21isp-1.60/lpc21isp.h lpc21isp-Linux//lpc21isp.h
|
||||||
--- lpc21isp-1.60/lpc21isp.h 2008-05-10 17:35:00.000000000 -0600
|
--- lpc21isp-1.60/lpc21isp.h 2008-05-10 17:35:00.000000000 -0600
|
||||||
+++ lpc21isp-Linux//lpc21isp.h 2008-09-16 09:18:42.000000000 -0600
|
+++ lpc21isp-Linux//lpc21isp.h 2008-09-16 09:18:42.000000000 -0600
|
||||||
@@ -165,6 +165,7 @@
|
@@ -165,6 +165,7 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
unsigned serial_timeout_count; /**< Local used to track timeouts on serial port read. */
|
unsigned serial_timeout_count; /**< Local used to track timeouts on serial port read. */
|
||||||
+ unsigned char DoNotStart; /* Do not start Code if this is set*/
|
+ unsigned char DoNotStart; /* Do not start Code if this is set*/
|
||||||
|
|
||||||
} ISP_ENVIRONMENT;
|
} ISP_ENVIRONMENT;
|
||||||
|
|
||||||
@@ -173,7 +174,6 @@
|
@@ -173,7 +174,6 @@
|
||||||
#define DebugPrintf(in, ...)
|
#define DebugPrintf(in, ...)
|
||||||
|
|
||||||
#else
|
#else
|
||||||
-extern int debug_level;
|
-extern int debug_level;
|
||||||
|
|
||||||
#if defined INTEGRATED_IN_WIN_APP
|
#if defined INTEGRATED_IN_WIN_APP
|
||||||
|
|
||||||
@@ -191,7 +191,6 @@
|
@@ -191,7 +191,6 @@
|
||||||
|
|
||||||
#else
|
#else
|
||||||
void DebugPrintf(int level, const char *fmt, ...);
|
void DebugPrintf(int level, const char *fmt, ...);
|
||||||
-//#define DebugPrintf(level, ...) if (level <= debug_level) { TRACE( __VA_ARGS__ ); }
|
-//#define DebugPrintf(level, ...) if (level <= debug_level) { TRACE( __VA_ARGS__ ); }
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void ClearSerialPortBuffers(ISP_ENVIRONMENT *IspEnvironment);
|
void ClearSerialPortBuffers(ISP_ENVIRONMENT *IspEnvironment);
|
||||||
diff -rub lpc21isp-1.60/lpcprog.c lpc21isp-Linux//lpcprog.c
|
diff -rub lpc21isp-1.60/lpcprog.c lpc21isp-Linux//lpcprog.c
|
||||||
--- lpc21isp-1.60/lpcprog.c 2008-07-21 14:39:50.000000000 -0600
|
--- lpc21isp-1.60/lpcprog.c 2008-07-21 14:39:50.000000000 -0600
|
||||||
+++ lpc21isp-Linux//lpcprog.c 2008-09-16 08:52:46.000000000 -0600
|
+++ lpc21isp-Linux//lpcprog.c 2008-09-16 08:52:46.000000000 -0600
|
||||||
@@ -1062,15 +1062,16 @@
|
@@ -1062,15 +1062,16 @@
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
+ if (IspEnvironment->DoNotStart == 0)
|
+ if (IspEnvironment->DoNotStart == 0)
|
||||||
+ {
|
+ {
|
||||||
DebugPrintf(2, "Now launching the brand new code\n");
|
DebugPrintf(2, "Now launching the brand new code\n");
|
||||||
fflush(stdout);
|
fflush(stdout);
|
||||||
-
|
-
|
||||||
if (IspEnvironment->HalfDuplex == 0)
|
if (IspEnvironment->HalfDuplex == 0)
|
||||||
sprintf(tmpString, "G %ld A\r\n", IspEnvironment->StartAddress);
|
sprintf(tmpString, "G %ld A\r\n", IspEnvironment->StartAddress);
|
||||||
else
|
else
|
||||||
sprintf(tmpString, "G %ld A\n", IspEnvironment->StartAddress);
|
sprintf(tmpString, "G %ld A\n", IspEnvironment->StartAddress);
|
||||||
-
|
-
|
||||||
SendComPort(IspEnvironment, tmpString); //goto 0 : run this fresh new downloaded code code
|
SendComPort(IspEnvironment, tmpString); //goto 0 : run this fresh new downloaded code code
|
||||||
+
|
+
|
||||||
if (IspEnvironment->BinaryOffset < LPC_RAMSTART)
|
if (IspEnvironment->BinaryOffset < LPC_RAMSTART)
|
||||||
{ // Skip response on G command - show response on Terminal instead
|
{ // Skip response on G command - show response on Terminal instead
|
||||||
ReceiveComPort(IspEnvironment, Answer, sizeof(Answer)-1, &realsize, 2, 5000);
|
ReceiveComPort(IspEnvironment, Answer, sizeof(Answer)-1, &realsize, 2, 5000);
|
||||||
@@ -1099,6 +1100,7 @@
|
@@ -1099,6 +1100,7 @@
|
||||||
return (FAILED_RUN + GetAndReportErrorNumber(Answer));
|
return (FAILED_RUN + GetAndReportErrorNumber(Answer));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
+ }
|
+ }
|
||||||
|
|
||||||
fflush(stdout);
|
fflush(stdout);
|
||||||
}
|
}
|
||||||
Only in lpc21isp-Linux/: lpcprog.c.orig
|
Only in lpc21isp-Linux/: lpcprog.c.orig
|
||||||
diff -rub lpc21isp-1.60/Makefile lpc21isp-Linux//Makefile
|
diff -rub lpc21isp-1.60/Makefile lpc21isp-Linux//Makefile
|
||||||
--- lpc21isp-1.60/Makefile 2008-04-07 00:23:00.000000000 -0600
|
--- lpc21isp-1.60/Makefile 2008-04-07 00:23:00.000000000 -0600
|
||||||
|
@ -1,37 +1,37 @@
|
|||||||
#daemon configuration
|
#daemon configuration
|
||||||
telnet_port 4444
|
telnet_port 4444
|
||||||
gdb_port 3333
|
gdb_port 3333
|
||||||
|
|
||||||
#interface
|
#interface
|
||||||
interface ft2232
|
interface ft2232
|
||||||
ft2232_device_desc "Olimex OpenOCD JTAG A"
|
ft2232_device_desc "Olimex OpenOCD JTAG A"
|
||||||
ft2232_layout "olimex-jtag"
|
ft2232_layout "olimex-jtag"
|
||||||
ft2232_vid_pid 0x15BA 0x0003
|
ft2232_vid_pid 0x15BA 0x0003
|
||||||
jtag_speed 0
|
jtag_speed 0
|
||||||
|
|
||||||
#use combined on interfaces or targets that can't set TRST/SRST separately
|
#use combined on interfaces or targets that can't set TRST/SRST separately
|
||||||
reset_config trst_and_srst srst_pulls_trst
|
reset_config trst_and_srst srst_pulls_trst
|
||||||
|
|
||||||
#jtag scan chain
|
#jtag scan chain
|
||||||
#format L IRC IRCM IDCODE (Length, IR Capture, IR Capture Mask, IDCODE)
|
#format L IRC IRCM IDCODE (Length, IR Capture, IR Capture Mask, IDCODE)
|
||||||
jtag_device 4 0x1 0xf 0xe
|
jtag_device 4 0x1 0xf 0xe
|
||||||
|
|
||||||
#target configuration
|
#target configuration
|
||||||
daemon_startup reset
|
daemon_startup reset
|
||||||
|
|
||||||
#target <type> <startup mode>
|
#target <type> <startup mode>
|
||||||
#target arm7tdmi <reset mode> <chainpos> <endianness> <variant>
|
#target arm7tdmi <reset mode> <chainpos> <endianness> <variant>
|
||||||
target arm7tdmi little run_and_halt 0 arm7tdmi
|
target arm7tdmi little run_and_halt 0 arm7tdmi
|
||||||
run_and_halt_time 0 30
|
run_and_halt_time 0 30
|
||||||
|
|
||||||
working_area 0 0x2000C000 0x4000 nobackup
|
working_area 0 0x2000C000 0x4000 nobackup
|
||||||
|
|
||||||
#flash bank <driver> <base> <size> <chip_width> <bus_width>
|
#flash bank <driver> <base> <size> <chip_width> <bus_width>
|
||||||
flash bank str7x 0x40000000 0x00040000 0 0 0 STR71x
|
flash bank str7x 0x40000000 0x00040000 0 0 0 STR71x
|
||||||
#flash bank cfi 0x60000000 0x00400000 2 2 0
|
#flash bank cfi 0x60000000 0x00400000 2 2 0
|
||||||
|
|
||||||
#Script used for FLASH programming
|
#Script used for FLASH programming
|
||||||
#target_script 0 reset str71x_flashprogram.ocd
|
#target_script 0 reset str71x_flashprogram.ocd
|
||||||
|
|
||||||
# For more information about the configuration files, take a look at:
|
# For more information about the configuration files, take a look at:
|
||||||
# http://openfacts.berlios.de/index-en.phtml?title=Open+On-Chip+Debugger
|
# http://openfacts.berlios.de/index-en.phtml?title=Open+On-Chip+Debugger
|
||||||
|
@ -1,43 +1,43 @@
|
|||||||
Using the Binaries:
|
Using the Binaries:
|
||||||
==================
|
==================
|
||||||
|
|
||||||
Prequisites:
|
Prequisites:
|
||||||
===========
|
===========
|
||||||
|
|
||||||
1. SAMA5D3x-EK board and power supply
|
1. SAMA5D3x-EK board and power supply
|
||||||
2. RS-232 NUL modem cable
|
2. RS-232 NUL modem cable
|
||||||
3. A full size SD card. This should be older style SD or SDHC cards. Some
|
3. A full size SD card. This should be older style SD or SDHC cards. Some
|
||||||
of the newest very high capacity cards will not work.
|
of the newest very high capacity cards will not work.
|
||||||
4. The WAV file jsbach16.wav
|
4. The WAV file jsbach16.wav
|
||||||
5. The NuttX HEX binary, nuttx.hex, .bin or .elf.
|
5. The NuttX HEX binary, nuttx.hex, .bin or .elf.
|
||||||
|
|
||||||
Procedure:
|
Procedure:
|
||||||
|
|
||||||
1. Put the WAV file jsbach16.wav on the SD card
|
1. Put the WAV file jsbach16.wav on the SD card
|
||||||
|
|
||||||
2. Place the SD card in the full size SD slot on the motherboard.
|
2. Place the SD card in the full size SD slot on the motherboard.
|
||||||
|
|
||||||
3. Use SAM-BA to copy the NuttX binary to NOR flash
|
3. Use SAM-BA to copy the NuttX binary to NOR flash
|
||||||
|
|
||||||
4. Set the boot jumper to boot from NOR FLASH
|
4. Set the boot jumper to boot from NOR FLASH
|
||||||
|
|
||||||
5. NSH shouls start
|
5. NSH shouls start
|
||||||
|
|
||||||
NuttShell (NSH) NuttX-7.3
|
NuttShell (NSH) NuttX-7.3
|
||||||
nsh>
|
nsh>
|
||||||
|
|
||||||
6. Mount the SD card at /music
|
6. Mount the SD card at /music
|
||||||
|
|
||||||
nsh> mount -t vfat /dev/mmcsd0 /music
|
nsh> mount -t vfat /dev/mmcsd0 /music
|
||||||
|
|
||||||
7. Star the NxPlayer and select the pcm0 device
|
7. Star the NxPlayer and select the pcm0 device
|
||||||
|
|
||||||
nsh> nxplayer
|
nsh> nxplayer
|
||||||
NxPlayer version 1.04
|
NxPlayer version 1.04
|
||||||
h for commands, q to exit
|
h for commands, q to exit
|
||||||
|
|
||||||
nxplayer> device pcm0
|
nxplayer> device pcm0
|
||||||
|
|
||||||
8. And play the WAV file
|
8. And play the WAV file
|
||||||
|
|
||||||
nxplayer> play jsbach16.wav
|
nxplayer> play jsbach16.wav
|
||||||
|
Loading…
Reference in New Issue
Block a user