source: rtems/c/src/lib/libbsp/powerpc/mpc8260ads/times @ 2d0bc83

Last change on this file since 2d0bc83 was d5154d0f, checked in by Aun-Ali Zaidi <admin@…>, on Dec 23, 2015 at 8:44:02 PM

api: Remove deprecated Notepads

Notepads where a feature of RTEMS' tasks that simply functioned in
the same way as POSIX keys or threaded local storage (TLS). They were
introduced well before per task variables, which are also deprecated,
and were barely used in favor of their POSIX alternatives.

In addition to their scarce usage, Notepads took up unnecessary memory.
For each task:

  • 16 32-bit integers were allocated.
  • A total of 64 bytes per task per thread.

This is especially critical in low memory and safety-critical applications.

They are also defined as uint32_t, and therefore are not guaranteed to
hold a pointer.

Lastly, they are not portable solutions for SMP and uniprocessor systems,
like POSIX keys and TLS.

updates #2493.

  • Property mode set to 100644
File size: 11.0 KB
Line 
1#
2#  Timing Test Suite Results for the mpc8260ads BSP
3#
4
5# Testing not complete. 
6# DO NOT BELIEVE THESE RESULTS
7
8Board:          mpc8260ads
9CPU:            Motorola MPC8260
10Clock Speed:    40 Mhz
11Memory Configuration: SDRAM, no caches
12Wait States:
13
14Times Reported in: cycles, microseconds, etc
15Timer Source: Time Base register
16
17Column X:
18Column Y:
19
20#                          DESCRIPTION                                 A    B
21== =================================================================  ==== ====
221  rtems_semaphore_create                                               56
23   rtems_semaphore_delete                                               35
24   rtems_semaphore_obtain: available                                    13
25   rtems_semaphore_obtain: not available -- NO_WAIT                     13
26   rtems_semaphore_release: no waiting tasks                            16
27
282  rtems_semaphore_obtain: not available -- caller blocks               48
29
303  rtems_semaphore_release: task readied -- preempts caller             36
31
324  rtems_task_restart: blocked task -- preempts caller                 117
33   rtems_task_restart: ready task -- preempts caller                    94   
34   rtems_semaphore_release: task readied -- returns to caller           22
35   rtems_task_create                                                    83
36   rtems_task_start                                                     30
37   rtems_task_restart: suspended task -- returns to caller              36
38   rtems_task_delete: suspended task                                    74   
39   rtems_task_restart: ready task -- returns to caller                  35
40   rtems_task_restart: blocked task -- returns to caller                47
41   rtems_task_delete: blocked task                                      76 
42
435  rtems_task_suspend: calling task                                     37 
44   rtems_task_resume: task readied -- preempts caller                   31
45
466  rtems_task_restart: calling task                                     48
47   rtems_task_suspend: returns to caller                                14   
48   rtems_task_resume: task readied -- returns to caller                 16 
49   rtems_task_delete: ready task                                        80
50
517  rtems_task_restart: suspended task -- preempts caller                56   
52
538 rtems_task_set_priority: obtain current priority                      12
54  rtems_task_set_priority: returns to caller                            23 
55  rtems_task_mode: obtain current mode                                   5
56  rtems_task_mode: no reschedule                                         7 
57  rtems_task_mode: reschedule -- returns to caller                      14
58  rtems_task_mode: reschedule -- preempts caller                        43
59  rtems_clock_set                                                       28
60  rtems_clock_get                                                        0
61
629 rtems_message_queue_create                                           110
63  rtems_message_queue_send: no waiting tasks                            28
64  rtems_message_queue_urgent: no waiting tasks                          28
65  rtems_message_queue_receive: available                                26
66  rtems_message_queue_flush: no messages flushed                        13
67  rtems_message_queue_flush: messages flushed                           14
68  rtems_message_queue_delete                                            45
69
7010  rtems_message_queue_receive: not available -- NO_WAIT               15
71    rtems_message_queue_receive: not available -- caller blocks         48
72
7311  rtems_message_queue_send: task readied -- preempts caller           46
74
7512  rtems_message_queue_send: task readied -- returns to caller         31
76
7713  rtems_message_queue_urgent: task readied -- preempts caller         46
78
7914  rtems_message_queue_urgent: task readied -- returns to caller       31
80
8115  rtems_event_receive: obtain current events                           1   
82    rtems_event_receive: not available -- NO_WAIT                       11
83    rtems_event_receive: not available -- caller blocks                 36
84    rtems_event_send: no task readied                                   12
85    rtems_event_receive: available                                      19
86    rtems_event_send: task readied -- returns to caller                 21
87
8816  rtems_event_send: task readied -- preempts caller                   38
89
9017  rtems_task_set_priority: preempts caller                            51
91
9218  rtems_task_delete: calling task                                    102
93
9419  rtems_signal_catch                                                  31
95    rtems_signal_send: returns to caller                                21
96    rtems_signal_send: signal to self                                   39
97    exit ASR overhead: returns to calling task                          30
98    exit ASR overhead: returns to preempting task                       33
99
10020  rtems_partition_create                                              59
101    rtems_region_create                                                 37     
102    rtems_partition_get_buffer: available                               19     
103    rtems_partition_get_buffer: not available                           12 
104    rtems_partition_return_buffer                                       21
105    rtems_partition_delete                                              20
106    rtems_region_get_segment: available                                 20
107    rtems_region_get_segment: not available -- NO_WAIT                  24
108    rtems_region_return_segment: no waiting tasks                       21
109    rtems_region_get_segment: not available -- caller blocks            76
110    rtems_region_return_segment: task readied -- preempts caller        82
111    rtems_region_return_segment: task readied -- returns to caller      55
112    rtems_region_delete                                                 20   
113    rtems_io_initialize                                                  1   
114    rtems_io_open                                                        1
115    rtems_io_close                                                       1
116    rtems_io_read                                                        1
117    rtems_io_write                                                       1
118    rtems_io_control                                                     1
119
12021  rtems_task_ident                                                    84   
121    rtems_message_queue_ident                                           82
122    rtems_semaphore_ident                                               94   
123    rtems_partition_ident                                               82   
124    rtems_region_ident                                                  84
125    rtems_port_ident                                                    82
126    rtems_timer_ident                                                   82
127    rtems_rate_monotonic_ident                                          82
128
12922 rtems_message_queue_broadcast: task readied -- returns to caller     81
130   rtems_message_queue_broadcast: no waiting tasks                      22   
131   rtems_message_queue_broadcast: task readied -- preempts caller       76   
132
13323  rtems_timer_create                                                  11
134    rtems_timer_fire_after: inactive                                    20 
135    rtems_timer_fire_after: active                                      22   
136    rtems_timer_cancel: active                                          12
137    rtems_timer_cancel: inactive                                        11
138    rtems_timer_reset: inactive                                         18
139    rtems_timer_reset: active                                           21
140    rtems_timer_fire_when: inactive                                     24   
141    rtems_timer_fire_when: active                                       24     
142    rtems_timer_delete: active                                          16
143    rtems_timer_delete: inactive                                        14
144    rtems_task_wake_when                                                49
145
14624  rtems_task_wake_after: yield -- returns to caller                    8
147    rtems_task_wake_after: yields -- preempts caller                    30   
148
14925  rtems_clock_tick                                                    35 
150
15126  _ISR_Disable                                                        24
152    _ISR_Flash                                                           0
153    _ISR_Enable                                                          1
154    _Thread_Disable_dispatch                                             1
155    _Thread_Enable_dispatch                                              7 
156    _Thread_Set_state                                                    7
157    _Thread_Disptach (NO FP)                                            31
158    context switch: no floating point contexts                          22
159    context switch: self                                                 9
160    context switch: to another task                                     10
161    fp context switch: restore 1st FP task                              24
162    fp context switch: save idle, restore initialized                   10
163    fp context switch: save idle, restore idle                          23   
164    fp context switch: save initialized, restore initialized            10
165    _Thread_Resume                                                      11
166    _Thread_Unblock                                                      6
167    _Thread_Ready                                                       10 
168    _Thread_Get                                                          3     
169    _Semaphore_Get                                                       2 
170    _Thread_Get: invalid id                                              0
171
172
17327  interrupt entry overhead: returns to interrupted task               14
174    interrupt exit overhead: returns to interrupted task                26   
175    interrupt entry overhead: returns to nested interrupt                7   
176    interrupt exit overhead: returns to nested interrupt                10   
177    interrupt entry overhead: returns to preempting task                14
178    interrupt exit overhead: returns to preempting task                 45
179
18028  rtems_port_create                                                   23
181    rtems_port_external_to_internal                                     10
182    rtems_port_internal_to_external                                     10
183    rtems_port_delete                                                   21
184
18529  rtems_rate_monotonic_create                                         43
186    rtems_rate_monotonic_period: initiate period -- returns to caller   32
187    rtems_rate_monotonic_period: obtain status                          17 
188    rtems_rate_monotonic_cancel                                         22   
189    rtems_rate_monotonic_delete: inactive                               25
190    rtems_rate_monotonic_delete: active                                 28   
191    rtems_rate_monotonic_period: conclude periods -- caller blocks      30
Note: See TracBrowser for help on using the repository browser.