OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [rtems/] [c/] [src/] [tests/] [sptests/] [spsize/] [size.c] - Blame information for rev 587

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 30 unneback
/*  main
2
 *
3
 *  This program is run to determine the data space and work space
4
 *  requirements of the current version of RTEMS.
5
 *
6
 *  COPYRIGHT (c) 1989-1999.
7
 *  On-Line Applications Research Corporation (OAR).
8
 *
9
 *  The license and distribution terms for this file may be
10
 *  found in the file LICENSE in this distribution or at
11
 *  http://www.OARcorp.com/rtems/license.html.
12
 *
13
 *  $Id: size.c,v 1.2 2001-09-27 12:02:38 chris Exp $
14
 */
15
 
16
#include <rtems/system.h>
17
#include <rtems/config.h>
18
#include <rtems/directives.h>
19
#include <rtems/score/apiext.h>
20
#include <rtems/score/copyrt.h>
21
#include <rtems/rtems/clock.h>
22
#include <rtems/rtems/tasks.h>
23
#include <rtems/rtems/dpmem.h>
24
#include <rtems/rtems/event.h>
25
#include <rtems/extension.h>
26
#include <rtems/fatal.h>
27
#include <rtems/init.h>
28
#include <rtems/score/isr.h>
29
#include <rtems/rtems/intr.h>
30
#include <rtems/io.h>
31
#include <rtems/rtems/message.h>
32
#if defined(RTEMS_MULTIPROCESSING)
33
#include <rtems/rtems/mp.h>
34
#include <rtems/score/mpci.h>
35
#endif
36
#include <rtems/rtems/part.h>
37
#include <rtems/score/priority.h>
38
#include <rtems/rtems/ratemon.h>
39
#include <rtems/rtems/region.h>
40
#include <rtems/rtems/sem.h>
41
#include <rtems/rtems/signal.h>
42
#include <rtems/score/sysstate.h>
43
#include <rtems/score/thread.h>
44
#include <rtems/rtems/timer.h>
45
#include <rtems/score/tod.h>
46
#include <rtems/score/userext.h>
47
#include <rtems/score/wkspace.h>
48
 
49
#include <stdlib.h>
50
 
51
/* These are always defined by the executive.
52
 *
53
 * #include <rtems/copyrt.h>
54
 * #include <rtems/tables.h>
55
 * #include <rtems/sptables.h>
56
 */
57
#define  HEAP_OVHD        16    /* wasted heap space per task stack */
58
#define  NAME_PTR_SIZE     8    /* size of name and pointer table entries */
59
#define  READYCHAINS_SIZE  \
60
    ((RTEMS_MAXIMUM_PRIORITY + 1) * sizeof(Chain_Control ))
61
 
62
#define PER_TASK      \
63
     (long) (sizeof (Thread_Control) + \
64
      NAME_PTR_SIZE + HEAP_OVHD + sizeof( RTEMS_API_Control ))
65
#define PER_SEMAPHORE \
66
     (long) (sizeof (Semaphore_Control) + NAME_PTR_SIZE)
67
#define PER_TIMER     \
68
     (long) (sizeof (Timer_Control) + NAME_PTR_SIZE)
69
#define PER_MSGQ      \
70
     (long) (sizeof (Message_queue_Control) + NAME_PTR_SIZE)
71
#define PER_REGN      \
72
     (long) (sizeof (Region_Control) + NAME_PTR_SIZE)
73
#define PER_PART      \
74
     (long) (sizeof (Partition_Control) + NAME_PTR_SIZE)
75
#define PER_PERIOD      \
76
     (long) (sizeof (Rate_monotonic_Control) + NAME_PTR_SIZE)
77
#define PER_PORT      \
78
     (long) (sizeof (Dual_ported_memory_Control) + NAME_PTR_SIZE)
79
#define PER_EXTENSION     \
80
     (long) (sizeof (Extension_Control) + NAME_PTR_SIZE)
81
 
82
#define PER_DRV       (long) (0)
83
#define PER_FPTASK    (long) (CONTEXT_FP_SIZE)
84
#define PER_GOBTBL    (long) (sizeof (Chain_Control)*4)
85
#define PER_NODE      (long) PER_GOBTBL
86
#if defined(RTEMS_MULTIPROCESSING)
87
#define PER_GOBJECT   (long) (sizeof (Objects_MP_Control))
88
#else
89
#define PER_GOBJECT   (long) 0
90
#endif
91
#define PER_PROXY     (long) (sizeof (Thread_Proxy_control))
92
 
93
#if !defined(RTEMS_MULTIPROCESSING) || (CPU_ALL_TASKS_ARE_FP != TRUE)
94
#define MPCI_RECEIVE_SERVER_FP (long) 0
95
#else
96
#define MPCI_RECEIVE_SERVER_FP (long) (sizeof( Context_Control_fp ))
97
#endif
98
 
99
#if (CPU_IDLE_TASK_IS_FP == TRUE)
100
#define SYSTEM_IDLE_FP (long) (sizeof( Context_Control_fp ))
101
#else
102
#define SYSTEM_IDLE_FP (long) 0
103
#endif
104
 
105
#if !defined(RTEMS_MULTIPROCESSING)
106
#define MPCI_RECEIVE_SERVER_STACK_SIZE 0
107
#endif
108
 
109
#if defined(RTEMS_MULTIPROCESSING)
110
#define MP_SYSTEM_TASKS \
111
   (MPCI_RECEIVE_SERVER_STACK_SIZE + \
112
    sizeof(Thread_Control) + \
113
    MPCI_RECEIVE_SERVER_FP)
114
#else
115
#define MP_SYSTEM_TASKS 0
116
#endif
117
 
118
/*
119
 *  Idle and the MPCI Receive Server Threads
120
 */
121
 
122
#define SYSTEM_TASKS  \
123
    (STACK_MINIMUM_SIZE + sizeof(Thread_Control) + SYSTEM_IDLE_FP + \
124
     MP_SYSTEM_TASKS)
125
 
126
#define rtems_unsigned32 unsigned32
127
 
128
rtems_unsigned32 sys_req;
129
 
130
/* to avoid warnings */
131
int puts();
132
int printf();
133
int getint();
134
#undef getchar
135
int getchar();
136
void help_size();
137
void print_formula();
138
 
139
void size_rtems(
140
  int mode
141
)
142
{
143
int uninitialized = 0;
144
int initialized = 0;
145
 
146
/*
147
 *  The following data is allocated for each Manager:
148
 *
149
 *    + Per Manager Object Information
150
 *      - local pointer table
151
 *      - local name table
152
 *      - the object's control blocks
153
 *      - global name chains
154
 *
155
 *  The following is the data allocate from the RTEMS Workspace Area.
156
 *  The order indicates the order in which RTEMS allocates it.
157
 *
158
 *    + Object MP
159
 *      - Global Object CB's
160
 *    + Thread
161
 *      - Ready Chain
162
 *    + Thread MP
163
 *      - Proxies Chain
164
 *    + Interrupt Manager
165
 *      - Interrupt Stack
166
 *    + Timer Manager
167
 *      - per Manager Object Data
168
 *    + Extension Manager
169
 *      - per Manager Object Data
170
 *    + Message Queue Manager
171
 *      - per Manager Object Data
172
 *      - Message Buffers
173
 *    + Semaphore Manager
174
 *      - per Manager Object Data
175
 *    + Partition Manager
176
 *      - per Manager Object Data
177
 *    + Region Manager
178
 *      - per Manager Object Data
179
 *    + Dual Ported Memory Manager
180
 *      - per Manager Object Data
181
 *    + Rate Monotonic Manager
182
 *      - per Manager Object Data
183
 *    + Internal Threads Handler
184
 *      - MPCI Receive Server Thread TCB
185
 *      - IDLE Thread TCB
186
 *      - MPCI Receive Server Thread stack
187
 *      - MPCI Receive Server Thread FP area (if CPU requires this)
188
 *      - IDLE Thread stack
189
 *      - IDLE Thread FP area (if CPU requires this)
190
 *
191
 *  This does not take into account any CPU dependent alignment requirements.
192
 *
193
 *  The following calculates the overhead needed by RTEMS from the
194
 *  Workspace Area.
195
 */
196
sys_req = SYSTEM_TASKS     +     /* MPCI Receive Server and IDLE */
197
          NAME_PTR_SIZE    +     /* Task Overhead */
198
          READYCHAINS_SIZE +     /* Ready Chains */
199
          NAME_PTR_SIZE    +     /* Timer Overhead */
200
          NAME_PTR_SIZE    +     /* Semaphore Overhead */
201
          NAME_PTR_SIZE    +     /* Message Queue Overhead */
202
          NAME_PTR_SIZE    +     /* Region Overhead */
203
          NAME_PTR_SIZE    +     /* Partition Overhead */
204
          NAME_PTR_SIZE    +     /* Dual-Ported Memory Overhead */
205
          NAME_PTR_SIZE    +     /* Rate Monotonic Overhead */
206
          NAME_PTR_SIZE    +     /* Extension Overhead */
207
          PER_NODE;              /* Extra Gobject Table */
208
 
209
uninitialized =
210
/*address.h*/   0                                         +
211
 
212
/*apiext.h*/    (sizeof _API_extensions_List)             +
213
 
214
/*asr.h*/       0                                         +
215
 
216
/*attr.h*/      0                                         +
217
 
218
/*bitfield.h*/  0                                         +
219
 
220
/*chain.h*/     0                                         +
221
 
222
/*clock.h*/     0                                         +
223
 
224
/*config.h*/    (sizeof _Configuration_Table)             +
225
                (sizeof _Configuration_MP_table)          +
226
 
227
/*context.h*/   (sizeof _Context_Switch_necessary)        +
228
 
229
/*copyrt.h*/    0                                         +
230
 
231
/*debug.h*/     (sizeof _Debug_Level)                     +
232
 
233
/*dpmem.h*/     (sizeof _Dual_ported_memory_Information)  +
234
 
235
/*event.h*/     (sizeof _Event_Sync_state)                +
236
 
237
#if defined(RTEMS_MULTIPROCESSING)
238
/*eventmp.h*/   0                                         +
239
#endif
240
 
241
/*eventset.h*/  0                                         +
242
 
243
/*extension.h*/ (sizeof _Extension_Information)           +
244
 
245
/*fatal.h*/     0                                         +
246
 
247
/*heap.h*/      0                                         +
248
 
249
/*init.h*/      0                                         +
250
 
251
/*interr.h*/    (sizeof Internal_errors_What_happened)    +
252
 
253
/*intr.h*/      0                                         +
254
 
255
/*io.h*/        (sizeof _IO_Number_of_drivers)            +
256
                (sizeof _IO_Driver_address_table)         +
257
                (sizeof _IO_Number_of_devices)            +
258
                (sizeof _IO_Driver_name_table)            +
259
 
260
/*isr.h*/       (sizeof _ISR_Nest_level)                  +
261
                (sizeof _ISR_Vector_table)                +
262
                (sizeof _ISR_Signals_to_thread_executing) +
263
 
264
/*message.h*/   (sizeof _Message_queue_Information)       +
265
 
266
/*modes.h*/     0                                         +
267
 
268
#if defined(RTEMS_MULTIPROCESSING)
269
/*mp.h*/        0                                         +
270
#endif
271
 
272
#if defined(RTEMS_MULTIPROCESSING)
273
/*mpci.h*/      (sizeof _MPCI_Remote_blocked_threads)     +
274
                (sizeof _MPCI_Semaphore)                  +
275
                (sizeof _MPCI_table)                      +
276
                (sizeof _MPCI_Receive_server_tcb)         +
277
                (sizeof _MPCI_Packet_processors)          +
278
#endif
279
 
280
#if defined(RTEMS_MULTIPROCESSING)
281
/*mppkt.h*/     0                                         +
282
#endif
283
 
284
#if defined(RTEMS_MULTIPROCESSING)
285
/*mptables.h*/  0                                         +
286
#endif
287
 
288
#if defined(RTEMS_MULTIPROCESSING)
289
/*msgmp.h*/     0                                         +
290
#endif
291
 
292
/*object.h*/    (sizeof _Objects_Local_node)              +
293
                (sizeof _Objects_Maximum_nodes)           +
294
                (sizeof _Objects_Information_table)       +
295
 
296
#if defined(RTEMS_MULTIPROCESSING)
297
/*objectmp.h*/  (sizeof _Objects_MP_Maximum_global_objects) +
298
                (sizeof _Objects_MP_Inactive_global_objects) +
299
#endif
300
 
301
/*options.h*/   0                                         +
302
 
303
/*part.h*/      (sizeof _Partition_Information)           +
304
 
305
#if defined(RTEMS_MULTIPROCESSING)
306
/*partmp.h*/    0                                         +
307
#endif
308
 
309
/*priority.h*/  (sizeof _Priority_Major_bit_map)          +
310
                (sizeof _Priority_Bit_map)                +
311
 
312
/*ratemon.h*/   (sizeof _Rate_monotonic_Information)      +
313
 
314
/*region.h*/    (sizeof _Region_Information)              +
315
 
316
#if defined(RTEMS_MULTIPROCESSING)
317
/*regionmp.h*/  0                                         +
318
#endif
319
 
320
/*rtems.h*/     /* Not applicable */
321
 
322
/*sem.h*/       (sizeof _Semaphore_Information)           +
323
 
324
#if defined(RTEMS_MULTIPROCESSING)
325
/*semmp.h*/     0                                         +
326
#endif
327
 
328
/*signal.h*/    0                                         +
329
 
330
/*signalmp.h*/  0                                         +
331
 
332
/*stack.h*/     0                                         +
333
 
334
/*states.h*/    0                                         +
335
 
336
/*status.h*/    0                                         +
337
 
338
/*sysstate.h*/  (sizeof _System_state_Is_multiprocessing) +
339
                (sizeof _System_state_Current)            +
340
 
341
/*system.h*/    (sizeof _CPU_Table)                       +
342
 
343
#if defined(RTEMS_MULTIPROCESSING)
344
/*taskmp.h*/    0                                         +
345
#endif
346
 
347
/*tasks.h*/     (sizeof _RTEMS_tasks_Information)         +
348
                (sizeof _RTEMS_tasks_User_initialization_tasks) +
349
                (sizeof _RTEMS_tasks_Number_of_initialization_tasks) +
350
 
351
/*thread.h*/    (sizeof _Thread_BSP_context)              +
352
                (sizeof _Thread_Dispatch_disable_level)   +
353
                (sizeof _Thread_Do_post_task_switch_extension) +
354
                (sizeof _Thread_Maximum_extensions)       +
355
                (sizeof _Thread_Ticks_per_timeslice)      +
356
                (sizeof _Thread_Ready_chain)              +
357
                (sizeof _Thread_Executing)                +
358
                (sizeof _Thread_Heir)                     +
359
                (sizeof _Thread_Allocated_fp)             +
360
                (sizeof _Thread_Internal_information)     +
361
                (sizeof _Thread_Idle)                     +
362
 
363
#if defined(RTEMS_MULTIPROCESSING)
364
/*threadmp.h*/  (sizeof _Thread_MP_Receive)               +
365
                (sizeof _Thread_MP_Active_proxies)        +
366
                (sizeof _Thread_MP_Inactive_proxies)      +
367
#endif
368
 
369
/*threadq.h*/   (sizeof _Thread_queue_Extract_table)      +
370
 
371
/*timer.h*/     (sizeof _Timer_Information)               +
372
 
373
/*tod.h*/       (sizeof _TOD_Current)                     +
374
                (sizeof _TOD_Seconds_since_epoch)         +
375
                (sizeof _TOD_Microseconds_per_tick)       +
376
                (sizeof _TOD_Ticks_per_second)            +
377
                (sizeof _TOD_Seconds_watchdog)            +
378
 
379
/*tqdata.h*/    0                                         +
380
 
381
/*types.h*/     0                                         +
382
 
383
/*userext.h*/   (sizeof _User_extensions_List)            +
384
 
385
/*watchdog.h*/  (sizeof _Watchdog_Sync_level)             +
386
                (sizeof _Watchdog_Sync_count)             +
387
                (sizeof _Watchdog_Ticks_since_boot)       +
388
                (sizeof _Watchdog_Ticks_chain)            +
389
                (sizeof _Watchdog_Seconds_chain)          +
390
 
391
/*wkspace.h*/   (sizeof _Workspace_Area);
392
 
393
uninitialized = 0;
394
 
395
#ifndef unix  /* make sure this is not a native compile */
396
 
397
#ifdef __i386__
398
 
399
/* cpu.h */
400
uninitialized += (sizeof _CPU_Null_fp_context) +
401
                 (sizeof _CPU_Interrupt_stack_low) +
402
                 (sizeof _CPU_Interrupt_stack_high);
403
 
404
#endif
405
 
406
#ifdef __i960__
407
 
408
/* cpu.h */
409
uninitialized += (sizeof _CPU_Interrupt_stack_low) +
410
                 (sizeof _CPU_Interrupt_stack_high);
411
 
412
#endif
413
 
414
#ifdef __hppa__
415
 
416
/* cpu.h */
417
uninitialized += (sizeof _CPU_Null_fp_context) +
418
#ifndef RTEMS_UNIX
419
                 (sizeof _CPU_Default_gr27) +
420
#endif
421
                 (sizeof _CPU_Interrupt_stack_low) +
422
                 (sizeof _CPU_Interrupt_stack_high);
423
#endif
424
 
425
#ifdef __mc68000__
426
 
427
/* cpu.h */
428
uninitialized += (sizeof _CPU_Interrupt_stack_low) +
429
                 (sizeof _CPU_Interrupt_stack_high);
430
 
431
#endif
432
 
433
#ifdef __sparc__
434
 
435
/* cpu.h */
436
uninitialized += (sizeof _CPU_Interrupt_stack_low) +
437
                 (sizeof _CPU_Interrupt_stack_high) +
438
                 (sizeof _CPU_Null_fp_context);
439
 
440
#ifndef NO_TABLE_MOVE
441
uninitialized += (sizeof _CPU_Trap_Table_area);
442
#endif
443
 
444
#ifdef erc32
445
uninitialized += (sizeof _ERC32_MEC_Timer_Control_Mirror);
446
#endif
447
 
448
 
449
#endif
450
 
451
 
452
#ifdef no_cpu
453
 
454
/* cpu.h */
455
uninitialized += (sizeof _CPU_Null_fp_context) +
456
                 (sizeof _CPU_Interrupt_stack_low) +
457
                 (sizeof _CPU_Interrupt_stack_high) +
458
                 (sizeof _CPU_Thread_dispatch_pointer);
459
 
460
#endif
461
 
462
#ifdef __PPC__
463
 
464
/* cpu.h */
465
uninitialized += (sizeof _CPU_Interrupt_stack_low) +
466
                 (sizeof _CPU_Interrupt_stack_high) +
467
                 (sizeof _CPU_IRQ_info);
468
 
469
#endif
470
#endif /* !unix */
471
 
472
initialized +=
473
/*copyrt.h*/    (strlen(_Copyright_Notice)+1)             +
474
 
475
/*sptables.h*/  (sizeof _Initialization_Default_multiprocessing_table)  +
476
                (strlen(_RTEMS_version)+1)      +
477
                (sizeof _Entry_points)          +
478
 
479
 
480
/*tod.h*/       (sizeof _TOD_Days_per_month)    +
481
                (sizeof _TOD_Days_to_date)      +
482
                (sizeof _TOD_Days_since_last_leap_year);
483
 
484
#ifndef unix /* make sure this is not native */
485
#ifdef __sparc__
486
 
487
initialized +=  (sizeof _CPU_Trap_slot_template);
488
 
489
#endif
490
#endif /* !unix */
491
 
492
puts( "" );
493
 
494
  if ( mode == 0 ) help_size();
495
  else             print_formula();
496
 
497
printf( "\n" );
498
printf( "RTEMS uninitialized data consumes %d bytes\n", uninitialized );
499
printf( "RTEMS intialized data consumes %d bytes\n", initialized );
500
 
501
}
502
 
503
void help_size()
504
{
505
int c = '\0';
506
int break_loop;
507
int total_size;
508
int task_stacks;
509
int interrupt_stack;
510
int maximum_tasks, size_tasks;
511
int maximum_sems, size_sems;
512
int maximum_timers, size_timers;
513
int maximum_msgqs, size_msgqs;
514
int maximum_msgs, size_msgs_overhead;
515
int maximum_regns, size_regns;
516
int maximum_parts, size_parts;
517
int maximum_ports, size_ports;
518
int maximum_periods, size_periods;
519
int maximum_extensions, size_extensions;
520
int maximum_drvs, size_drvs;
521
int maximum_fps, size_fps;
522
int maximum_nodes, size_nodes;
523
int maximum_gobjs, size_gobjs;
524
int maximum_proxies, size_proxies;
525
 
526
total_size = sys_req;    /* Fixed Overhead */
527
printf( "What is maximum_tasks? " );
528
maximum_tasks = getint();
529
size_tasks = PER_TASK * maximum_tasks;
530
total_size += size_tasks;
531
 
532
printf( "What is maximum_semaphores? " );
533
maximum_sems = getint();
534
size_sems = PER_SEMAPHORE * maximum_sems;
535
total_size += size_sems;
536
 
537
printf( "What is maximum_timers? " );
538
maximum_timers = getint();
539
size_timers = PER_TIMER * maximum_timers;
540
total_size += size_timers;
541
 
542
printf( "What is maximum_message_queues? " );
543
maximum_msgqs = getint();
544
size_msgqs = PER_MSGQ * maximum_msgqs;
545
total_size += size_msgqs;
546
 
547
printf( "What is maximum_messages?  XXXX " );
548
maximum_msgs = getint();
549
size_msgs_overhead = 0;
550
total_size += size_msgs_overhead;
551
 
552
printf( "What is maximum_regions? " );
553
maximum_regns = getint();
554
size_regns = PER_REGN * maximum_regns;
555
total_size += size_regns;
556
 
557
printf( "What is maximum_partitions? " );
558
maximum_parts = getint();
559
size_parts = PER_PART * maximum_parts;
560
total_size += size_parts;
561
 
562
printf( "What is maximum_ports? " );
563
maximum_ports = getint();
564
size_ports = PER_PORT * maximum_ports;
565
total_size += size_ports;
566
 
567
printf( "What is maximum_periods? " );
568
maximum_periods = getint();
569
size_periods = PER_PORT * maximum_periods;
570
total_size += size_periods;
571
 
572
printf( "What is maximum_extensions? " );
573
maximum_extensions = getint();
574
size_extensions = PER_EXTENSION * maximum_extensions;
575
total_size += size_extensions;
576
 
577
printf( "What is number_of_device_drivers? " );
578
maximum_drvs = getint();
579
size_drvs = PER_DRV  * maximum_drvs;
580
total_size += size_drvs;
581
 
582
printf( "What will be total stack requirement for all tasks? " );
583
task_stacks = getint();
584
total_size += task_stacks;
585
 
586
printf( "What is the size of the interrupt stack? " );
587
interrupt_stack = getint();
588
total_size += interrupt_stack;
589
 
590
printf( "How many tasks will be created with the FP flag? " );
591
maximum_fps = getint();
592
size_fps = PER_FPTASK  * maximum_fps;
593
total_size += size_fps;
594
 
595
printf( "Is this a single processor system? " );
596
for ( break_loop=0 ; !break_loop; c = getchar() ) {
597
  switch ( c ) {
598
    case 'Y':  case 'y':
599
    case 'N':  case 'n':
600
      break_loop = 1;
601
      break;
602
  }
603
}
604
printf( "%c\n", c );
605
if ( c == 'n' || c == 'N' ) {
606
  printf( "What is maximum_nodes? " );
607
  maximum_nodes = getint();
608
  size_nodes = PER_NODE * maximum_nodes;
609
  total_size += size_nodes;
610
  printf( "What is maximum_global_objects? " );
611
  maximum_gobjs = getint();
612
  size_gobjs = PER_GOBJECT * maximum_gobjs;
613
  total_size += size_gobjs;
614
  printf( "What is maximum_proxies? " );
615
  maximum_proxies = getint();
616
  size_proxies = PER_PROXY * maximum_proxies;
617
  total_size += size_proxies;
618
} else {
619
  maximum_nodes = 0;
620
  size_nodes = PER_NODE * 0;
621
  maximum_gobjs = 0;
622
  size_gobjs = PER_GOBJECT * 0;
623
  maximum_proxies = 0;
624
  size_proxies = PER_PROXY * 0;
625
}
626
 
627
printf( "\n\n" );
628
printf( " ************** EXECUTIVE WORK SPACE REQUIRED **************\n" );
629
printf( " Tasks                - %03d * %03ld            =  %ld\n",
630
          maximum_tasks, PER_TASK, (long) size_tasks );
631
printf( " Semaphores           - %03d * %03ld            =  %ld\n",
632
          maximum_sems, PER_SEMAPHORE, (long) size_sems );
633
printf( " Timers               - %03d * %03ld            =  %ld\n",
634
          maximum_timers, PER_TIMER, (long) size_timers );
635
printf( " Msg Queues           - %03d * %03ld            =  %ld\n",
636
          maximum_msgqs, PER_MSGQ, (long) size_msgqs );
637
printf( " Messages Overhead    - %03d * %03d            =  %ld\n",
638
          maximum_msgs, 0 /* PER_MSG_OVERHEAD */, (long) size_msgs_overhead );
639
printf( " Regions              - %03d * %03ld            =  %ld\n",
640
          maximum_regns, PER_REGN, (long) size_regns);
641
printf( " Partitions           - %03d * %03ld            =  %ld\n",
642
          maximum_parts, PER_PART, (long) size_parts );
643
printf( " Periods              - %03d * %03ld            =  %ld\n",
644
          maximum_periods, PER_PERIOD, (long) size_periods );
645
printf( " Extensions           - %03d * %03ld            =  %ld\n",
646
          maximum_extensions, PER_EXTENSION, (long) size_extensions );
647
printf( " Device Drivers       - %03d * %03ld            =  %ld\n",
648
          maximum_drvs, PER_DRV, (long) size_drvs );
649
 
650
printf( " System Requirements  - %04d                 =  %d\n",
651
          sys_req, sys_req );
652
 
653
printf( " Floating Point Tasks - %03d * %03ld            =  %ld\n",
654
          maximum_fps, PER_FPTASK, (long) size_fps );
655
printf( " Application Task Stacks -                     =  %d\n",
656
          task_stacks );
657
printf( " Interrupt Stacks -                            =  %d\n",
658
          task_stacks );
659
printf( " \n" );
660
printf( " Global object tables - %03d * %03ld            =  %ld\n",
661
          maximum_nodes, PER_NODE, (long) size_nodes );
662
printf( " Global objects       - %03d * %03ld            =  %ld\n",
663
          maximum_gobjs, PER_GOBJECT, (long) size_gobjs );
664
printf( " Proxies              - %03d * %03ld            =  %ld\n",
665
          maximum_proxies, PER_PROXY, (long) size_proxies );
666
printf( "\n\n" );
667
printf( " TOTAL                                       = %d bytes\n",
668
      total_size );
669
}
670
 
671
void print_formula()
672
{
673
printf( " ************** EXECUTIVE WORK SPACE FORMULA **************\n" );
674
printf( " Tasks                - maximum_tasks * %ld\n",      PER_TASK );
675
printf( " Timers               - maximum_timers * %ld\n",     PER_TIMER );
676
printf( " Semaphores           - maximum_semaphores * %ld\n", PER_SEMAPHORE);
677
printf( " Message Queues       - maximum_message_queues * %ld\n", PER_MSGQ );
678
printf( " Messages             -\n");
679
printf( " Regions              - maximum_regions * %ld\n",    PER_REGN );
680
printf( " Partitions           - maximum_partitions * %ld\n", PER_PART );
681
printf( " Ports                - maximum_ports * %ld\n",      PER_PORT );
682
printf( " Periods              - maximum_periods * %ld\n",    PER_PORT );
683
printf( " Extensions           - maximum_extensions * %ld\n", PER_EXTENSION );
684
printf( " Device Drivers       - number_of_device_drivers * %ld\n", PER_DRV);
685
printf( " System Requirements  - %d\n",                       sys_req );
686
printf( " Floating Point Tasks - FPMASK Tasks * %ld\n",       PER_FPTASK );
687
printf( " User's Tasks' Stacks -\n" );
688
printf( " Interrupt Stack      -\n" );
689
printf( " \n" );
690
printf( " Global object tables - maximum_nodes * %ld\n",          PER_NODE );
691
printf( " Global objects       - maximum_global_objects * %ld\n", PER_GOBJECT );
692
printf( " Proxies              - maximum_proxies * %ld\n",        PER_PROXY );
693
}

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.