⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 size.c

📁 RTEMS (Real-Time Executive for Multiprocessor Systems) is a free open source real-time operating sys
💻 C
📖 第 1 页 / 共 2 页
字号:
/*tasks.h*/     (sizeof _RTEMS_tasks_Information)         +                (sizeof _RTEMS_tasks_User_initialization_tasks) +                (sizeof _RTEMS_tasks_Number_of_initialization_tasks) +/*thread.h*/    (sizeof _Thread_BSP_context)              +                (sizeof _Thread_Dispatch_disable_level)   +                (sizeof _Thread_Do_post_task_switch_extension) +                (sizeof _Thread_Maximum_extensions)       +                (sizeof _Thread_Ticks_per_timeslice)      +                (sizeof _Thread_Ready_chain)              +                (sizeof _Thread_Executing)                +                (sizeof _Thread_Heir)                     +#if (CPU_HARDWARE_FP == 1) || (CPU_SOFTWARE_FP == 1)                (sizeof _Thread_Allocated_fp)             +#endif                (sizeof _Thread_Internal_information)     +                (sizeof _Thread_Idle)                     +#if defined(RTEMS_MULTIPROCESSING)/*threadmp.h*/  (sizeof _Thread_MP_Receive)               +                (sizeof _Thread_MP_Active_proxies)        +                (sizeof _Thread_MP_Inactive_proxies)      +#endif/*threadq.h*//*timer.h*/     (sizeof _Timer_Information)               +/*tod.h*/       (sizeof _TOD_Current)                     +                (sizeof _TOD_Seconds_since_epoch)         +                (sizeof _TOD_Microseconds_per_tick)       +                (sizeof _TOD_Ticks_per_second)            +                (sizeof _TOD_Seconds_watchdog)            +/*tqdata.h*/    0                                         +/*types.h*/     0                                         +/*userext.h*/   (sizeof _User_extensions_List)            +/*watchdog.h*/  (sizeof _Watchdog_Sync_level)             +                (sizeof _Watchdog_Sync_count)             +                (sizeof _Watchdog_Ticks_since_boot)       +                (sizeof _Watchdog_Ticks_chain)            +                (sizeof _Watchdog_Seconds_chain)          +/*wkspace.h*/   (sizeof _Workspace_Area);uninitialized = 0;#ifndef unix  /* make sure this is not a native compile */#ifdef __i386__/* cpu.h */uninitialized += (sizeof _CPU_Null_fp_context);#if (CPU_ALLOCATE_INTERRUPT_STACK == TRUE)uninitialized += (sizeof _CPU_Interrupt_stack_low) +                 (sizeof _CPU_Interrupt_stack_high);#endif#endif#ifdef __i960__/* cpu.h */uninitialized += (sizeof _CPU_Interrupt_stack_low) +                 (sizeof _CPU_Interrupt_stack_high);#endif#ifdef __hppa__/* cpu.h */uninitialized += (sizeof _CPU_Null_fp_context) +#if !defined(RTEMS_UNIX)                 (sizeof _CPU_Default_gr27) +#endif                 (sizeof _CPU_Interrupt_stack_low) +                 (sizeof _CPU_Interrupt_stack_high);#endif#ifdef __mc68000__/* cpu.h */uninitialized += (sizeof _CPU_Interrupt_stack_low) +                 (sizeof _CPU_Interrupt_stack_high);#endif#ifdef __sparc__ /* cpu.h */uninitialized += (sizeof _CPU_Interrupt_stack_low) +                 (sizeof _CPU_Interrupt_stack_high) +                 (sizeof _CPU_Null_fp_context);#endif#ifdef no_cpu/* cpu.h */uninitialized += (sizeof _CPU_Null_fp_context) +                 (sizeof _CPU_Interrupt_stack_low) +                 (sizeof _CPU_Interrupt_stack_high) +                 (sizeof _CPU_Thread_dispatch_pointer);#endif#ifdef __PPC__/* cpu.h */uninitialized += (sizeof _CPU_Interrupt_stack_low) +                 (sizeof _CPU_Interrupt_stack_high) +                 (sizeof _CPU_IRQ_info);#endif#endif /* !unix */initialized +=/*copyrt.h*/    (strlen(_Copyright_Notice)+1)             +/*sptables.h*/  (sizeof _Initialization_Default_multiprocessing_table)  +                (strlen(_RTEMS_version)+1)      +/*tod.h*/       (sizeof _TOD_Days_per_month)    +                (sizeof _TOD_Days_to_date)      +                (sizeof _TOD_Days_since_last_leap_year);#ifndef unix /* make sure this is not native */#ifdef __sparc__initialized +=  (sizeof _CPU_Trap_slot_template);#endif#endif /* !unix */puts( "" );  if ( mode == 0 ) help_size();  else             print_formula();printf( "\n" );printf( "RTEMS uninitialized data consumes %d bytes\n", uninitialized );printf( "RTEMS intialized data consumes %d bytes\n", initialized );}void help_size(){int c = '\0';int break_loop;int total_size;int task_stacks;int interrupt_stack;int maximum_tasks, size_tasks;int maximum_sems, size_sems;int maximum_timers, size_timers;int maximum_msgqs, size_msgqs;int maximum_msgs, size_msgs_overhead;int maximum_regns, size_regns;int maximum_parts, size_parts;int maximum_ports, size_ports;int maximum_periods, size_periods;int maximum_extensions, size_extensions;int maximum_drvs, size_drvs;int maximum_fps, size_fps;int maximum_nodes, size_nodes;int maximum_gobjs, size_gobjs;int maximum_proxies, size_proxies;total_size = sys_req;    /* Fixed Overhead */printf( "What is maximum_tasks? " );maximum_tasks = getint();size_tasks = PER_TASK * maximum_tasks;total_size += size_tasks;printf( "What is maximum_semaphores? " );maximum_sems = getint();size_sems = PER_SEMAPHORE * maximum_sems;total_size += size_sems;printf( "What is maximum_timers? " );maximum_timers = getint();size_timers = PER_TIMER * maximum_timers;total_size += size_timers;printf( "What is maximum_message_queues? " );maximum_msgqs = getint();size_msgqs = PER_MSGQ * maximum_msgqs;total_size += size_msgqs;printf( "What is maximum_messages?  XXXX " );maximum_msgs = getint();size_msgs_overhead = 0;total_size += size_msgs_overhead;printf( "What is maximum_regions? " );maximum_regns = getint();size_regns = PER_REGN * maximum_regns;total_size += size_regns;printf( "What is maximum_partitions? " );maximum_parts = getint();size_parts = PER_PART * maximum_parts;total_size += size_parts;printf( "What is maximum_ports? " );maximum_ports = getint();size_ports = PER_PORT * maximum_ports;total_size += size_ports;printf( "What is maximum_periods? " );maximum_periods = getint();size_periods = PER_PORT * maximum_periods;total_size += size_periods;printf( "What is maximum_extensions? " );maximum_extensions = getint();size_extensions = PER_EXTENSION * maximum_extensions;total_size += size_extensions;printf( "What is number_of_device_drivers? " );maximum_drvs = getint();size_drvs = PER_DRV  * maximum_drvs;total_size += size_drvs;printf( "What will be total stack requirement for all tasks? " );task_stacks = getint();total_size += task_stacks;printf( "What is the size of the interrupt stack? " );interrupt_stack = getint();total_size += interrupt_stack;printf( "How many tasks will be created with the FP flag? " );maximum_fps = getint();size_fps = PER_FPTASK  * maximum_fps;total_size += size_fps;printf( "Is this a single processor system? " );for ( break_loop=0 ; !break_loop; c = getchar() ) {  switch ( c ) {    case 'Y':  case 'y':    case 'N':  case 'n':      break_loop = 1;      break;  }}printf( "%c\n", c );if ( c == 'n' || c == 'N' ) {  printf( "What is maximum_nodes? " );  maximum_nodes = getint();  size_nodes = PER_NODE * maximum_nodes;  total_size += size_nodes;  printf( "What is maximum_global_objects? " );  maximum_gobjs = getint();  size_gobjs = PER_GOBJECT * maximum_gobjs;  total_size += size_gobjs;  printf( "What is maximum_proxies? " );  maximum_proxies = getint();  size_proxies = PER_PROXY * maximum_proxies;  total_size += size_proxies;} else {  maximum_nodes = 0;  size_nodes = PER_NODE * 0;  maximum_gobjs = 0;  size_gobjs = PER_GOBJECT * 0;  maximum_proxies = 0;  size_proxies = PER_PROXY * 0;}printf( "\n\n" );printf( " ************** EXECUTIVE WORK SPACE REQUIRED **************\n" );printf( " Tasks                - %03d * %03ld            =  %ld\n",          maximum_tasks, PER_TASK, (long) size_tasks );printf( " Semaphores           - %03d * %03ld            =  %ld\n",          maximum_sems, PER_SEMAPHORE, (long) size_sems );printf( " Timers               - %03d * %03ld            =  %ld\n",          maximum_timers, PER_TIMER, (long) size_timers );printf( " Msg Queues           - %03d * %03ld            =  %ld\n",          maximum_msgqs, PER_MSGQ, (long) size_msgqs );printf( " Messages Overhead    - %03d * %03d            =  %ld\n",          maximum_msgs, 0 /* PER_MSG_OVERHEAD */, (long) size_msgs_overhead );printf( " Regions              - %03d * %03ld            =  %ld\n",          maximum_regns, PER_REGN, (long) size_regns);printf( " Partitions           - %03d * %03ld            =  %ld\n",          maximum_parts, PER_PART, (long) size_parts );printf( " Periods              - %03d * %03ld            =  %ld\n",          maximum_periods, PER_PERIOD, (long) size_periods );printf( " Extensions           - %03d * %03ld            =  %ld\n",          maximum_extensions, PER_EXTENSION, (long) size_extensions );printf( " Device Drivers       - %03d * %03ld            =  %ld\n",          maximum_drvs, PER_DRV, (long) size_drvs );printf( " System Requirements  - %04d                 =  %d\n",          sys_req, sys_req );printf( " Floating Point Tasks - %03d * %03ld            =  %ld\n",          maximum_fps, PER_FPTASK, (long) size_fps );printf( " Application Task Stacks -                     =  %d\n",          task_stacks );printf( " Interrupt Stacks -                            =  %d\n",          task_stacks );printf( " \n" );printf( " Global object tables - %03d * %03ld            =  %ld\n",          maximum_nodes, PER_NODE, (long) size_nodes );printf( " Global objects       - %03d * %03ld            =  %ld\n",          maximum_gobjs, PER_GOBJECT, (long) size_gobjs );printf( " Proxies              - %03d * %03ld            =  %ld\n",          maximum_proxies, PER_PROXY, (long) size_proxies );printf( "\n\n" );printf( " TOTAL                                       = %d bytes\n",      total_size );}void print_formula(){printf( " ************** EXECUTIVE WORK SPACE FORMULA **************\n" );printf( " Tasks                - maximum_tasks * %ld\n",      PER_TASK );printf( " Timers               - maximum_timers * %ld\n",     PER_TIMER );printf( " Semaphores           - maximum_semaphores * %ld\n", PER_SEMAPHORE);printf( " Message Queues       - maximum_message_queues * %ld\n", PER_MSGQ );printf( " Messages             -\n");printf( " Regions              - maximum_regions * %ld\n",    PER_REGN );printf( " Partitions           - maximum_partitions * %ld\n", PER_PART );printf( " Ports                - maximum_ports * %ld\n",      PER_PORT );printf( " Periods              - maximum_periods * %ld\n",    PER_PORT );printf( " Extensions           - maximum_extensions * %ld\n", PER_EXTENSION );printf( " Device Drivers       - number_of_device_drivers * %ld\n", PER_DRV);printf( " System Requirements  - %d\n",                       sys_req );printf( " Floating Point Tasks - FPMASK Tasks * %ld\n",       PER_FPTASK );printf( " User's Tasks' Stacks -\n" );printf( " Interrupt Stack      -\n" );printf( " \n" );printf( " Global object tables - maximum_nodes * %ld\n",          PER_NODE );printf( " Global objects       - maximum_global_objects * %ld\n", PER_GOBJECT );printf( " Proxies              - maximum_proxies * %ld\n",        PER_PROXY );}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -