## RTA-OSEK ### Freescale S12X with the Metrowerks Compiler #### Features at a Glance - OSEK/VDX OS version 2.2 certified OS - RTOS overhead: 12 bytes RAM, 93 bytes ROM - Category 2 interrupt latency: 21 cycles - Applications include: HEVAC, Engine Management, Security, Integrated Starter Alternators #### **RTA-OSEK** RTA-OSEK provides an application design environment that combines the smallest and fastest OSEK RTOS with an unique timing analysis tool. This port data sheet discusses the Freescale S12X port of the RTA-OSEK kernel alone and should be read in conjunction with the Technical Product Overview "Developing Embedded Real-Time Applications with RTA-OSEK" available from LiveDevices. The kernel element of RTA-OSEK is a fixed priority, pre-emptive real-time operating system that is compliant to the OSEK/VDX OS standard version 2.2 for all four conformance classes (BCC1, BCC2, ECC1 and ECC2) and intra processor communication using OSEK COM Conformance Classes A and B (CCCA and CCCB). All CPU overheads of the kernel have low worst case bounds and little variability in execution time. The kernel is particularly suited to systems with very tight constraints on hardware costs and where run-time performance must be guaranteed. The kernel is configured using an offline tool provided with RTA-OSEK. Determining in advance which features are used allows memory requirements to be minimized and API calls to be optimized for greatest efficiency. All tasks and ISRs in RTA-OSEK run on a single stack – even extended tasks. This allows dramatic reductions in application stack space requirements. The RTA-OSEK kernel is designed to be scalable. When a task uses queued activation or waits on events, the additional RTOS overhead required to support these features is paid by the task rather than by the system. This means that a basic single activation task uses the same resources in a BCC1 system as it does in an ECC2 system. #### Compiler/Assembler/Linker The libraries containing the code for the RTA-OSEK kernel have been built using the following tools: - Metrowerks compiler CHC12 v5.0.28 Build 5051 - Metrowerks assembler AHC12 v5.0.28 Build 5051 - Metrowerks linker v5.0.26 Build 5051 #### Memory Model RTA-OSEK for the HC12X with the Metrowerks compiler supports the banked memory model. Kernel API calls use the *far* calling convention and the OS does not restrict their placement at link time. For runtime efficiency, and because the interrupt vector table only allows near function pointers, kernel interrupt wrappers and other internal kernel calls are *near* and must be placed in unbanked memory. The functions are located in the linker section os\_text\_unbanked, which should appear in the PLACEMENT section of the linker file mapped to the fixed flash areas 0x4000-0x7FFF or 0xC000 to 0xFF0F. All API declarations and ISR calls are far and can be located in paged or unpaged memory. The CPU and compiler maintain the paging state implicitly. In the banked memory model, it is not necessary to preserve the PPAGE, EPAGE, GPAGE and DPAGE registers during an ISR. The kernel code expects to find its internal variables in near space. These variables are put in the os\_pir, os\_pur, os\_pid, os\_pird, os\_data\_unbanked and os\_constdata\_unbanked sections, which the user must locate in unbanked memory. #### **ORTI Debugger Support** ORTI is the OSEK Run-Time Interface. Currently there are no ORTI compatible debuggers supported by RTA for this target. Further information about ORTI for RTA-OSEK can be found in the ORTI Guide. #### **Hardware Environment** RTA-OSEK supports all variants of the Freescale S12X family. This port has been tested on the MC9S12XDP512 device. #### **Interrupt Model** The RTA-OSEK port for the Freescale S12X with Metrowerks compiler supports the multilevel interrupt model through the 3-bit CCRH register and the legacy I bit in CCR. There are 7 regular interrupt priority levels above user level plus IPL 8, signified by the I bit being set. This is the level at which the non-maskable interrupts run. #### Floating Point Support This port of RTA-OSEK is designed to work with fully re-entrant software floating-point libraries supplied by Metrowerks. This allows floating-point to be used in RTA-OSEK tasks and ISRs without the need to save and restore any additional context. #### **Evaluation Board Support** This port of RTA-OSEK can be used with any Freescale S12X evaluation board. An example application is provided to run on the Freescale BEAPP075(A) MCS12XDP256 QFP112 EVB evaluation board. This application can be adapted for other target boards by adjusting the linker command file (eg, to alter the allocation of program sections) and one source file (if alternative output pins are required). #### **Functionality** The table below outlines the restrictions on the maximum number of operating system objects allowed by RTA-OSEK. | | BCC1 | BCC2 | ECC1 | ECC2 | |-------------------------|-------------------------|-----------|---------|------| | Max. no of tasks | 16 plus an idle task | | | k | | Max. tasks per priority | 1 | 16 | 1 | 16 | | Max. queued activations | 1 | 255 | 1 | 255 | | Max. events per task | n/a | n/a | 16 | 16 | | Max. nested resources | 255 | | | | | Max. alarms | not | limited b | y RTA-O | SEK | | Max. standard resources | 255 | 255 | 255 | 255 | | Max. internal resources | not limited by RTA-OSEK | | | | | Max. application modes | | 2! | 55 | | Note that OSEK specifies that queued activations in an ECC2 system are only possible for basic tasks. Where tasks share a priority level, the maximum number of queued activations per priority level is 255. The number of alarms, tasksets, schedules and schedule arrivalpoints is only limited by available hardware resources. #### **Memory Usage** The memory overhead of RTA-OSEK is: | Memory type | Overhead (bytes) | |-------------|------------------| | RAM | 12 | | ROM/Flash | 93 | In addition to the RTOS overhead, each object used by an application has the following memory requirements: | Object | RAM Bytes | ROM Bytes | |-------------------|-----------|-----------| | BCC1 task | 0 | 20 | | BCC2 task | 5 | 27 | | ECC1 task | 11 | 32 | | ECC2 task | 13 | 36 | | Category 1 ISR | 0 | 0 | | Category 2 ISR | 0 | 30 | | Resource | 0 | 20 | | Internal Resource | 0 | 0 | | Event | 0 | 2 | | Alarm | 5 | 36 | | Counter | 2 | 4 | | Taskset (RW) | 2 | 2 | | Taskset (RO) | 0 | 2 | | Schedule | 7 | 20 | | Arrivalpoint (RW) | 6 | 6 | | Arrivalpoint (RO) | 0 | 6 | In addition to these static memory requirements each task priority and Category 2 interrupt has a stack overhead (in addition to application stack usage). The single stack model means that this overhead applies to each priority level rather than to each task. Similarly, for Category 2 interrupts this overhead applies for each unique interrupt priority. The table below shows stack usage for these objects. | Object | Stack Bytes | |----------------------|-------------| | Task priority level | 21 | | Category 2 interrupt | 14 | RTA-OSEK provides an optimization for task termination if the user can guarantee that tasks only terminate from their entry function. Tasks that terminate from elsewhere are not eligible for this optimization and duly require 8 more stack bytes per priority level than indicated in the table above. #### **Performance** The following table gives the key kernel timings for operating system behavior in CPU cycles. | Task Type | Basic | Extended | Ref | |--------------------------------|-------|----------|-----| | Category 1 ISR Latency | 28 | 28 | K | | Category 2 ISR Latency | 21 | 21 | А | | Normal Termination | 89 | 192 | D | | ChainTask | 190 | 404 | J | | Pre-emption | 171 | 273 | C | | Triggered by alarm | 304 | 405 | F | | Schedule | 150 | 248 | Q | | ReleaseResource | 160 | 256 | М | | SetEvent | n/a | 419 | S | | Category 2 exit switch latency | 129 | 228 | Е | All performance figures are for the non-optimized interface to RTA-OSEK. Using the optimized interface will result in shorter execution times for some operations. All tasks use lightweight termination and no pre or post task hooks were specified. The execution time for every kernel API call is available on request from LiveDevices. Figure 1 - Category 1 interrupt with return to interrupted task Figure 2 - Category 2 interrupt with return to interrupted task Figure 3 - Category 2 interrupt activates a higher priority task Figure 4 - Task activates a higher priority task Figure 5 - Alarm activates task Figure 6 - Task chaining Figure 7 - Schedule() call Figure 8 - Activation by SetEvent() Figure 9 - ReleaseResource() ## BCC2 #### **Benchmarks** The following sections shows benchmarks for RTA-OSEK memory usage for BCC1, BCC2, ECC1 and ECC2 conformant applications. The applications have the following framework: - 8 tasks plus the idle task - All basic tasks are lightweight tasks - 1 Category 2 ISR with a 10ms minimum inter-arrival time - 1 Counter - 7 or 8 alarms, all attached to the same counter - No resources or internal resources - No hooks - No schedules - No tasksets - Built using standard status The following table shows the task priority configuration for each benchmark application: | Task/ISR | Stack (bytes) | Period (ms) | BCC1 | BCC2 | ECC1 | ECC2 | |----------|---------------|-------------|------|------|------|------| | ISR1 | 10 | 10 | IPL1 | IPL1 | IPL1 | IPL1 | | А | 10 | 10 | 8 | 8 | 8 | 8 | | В | 20 | 20 | 7 | 7 | 7 | 7 | | С | 30 | 20 | 6 | 6 | 6 | 6 | | D | 40 | 30 | 5 | 5 | 5 | 5 | | E | 50 | 50 | 4 | 4 | 4 | 4 | | F | 60 | 80 | 3 | 3 | 3 | 3 | | G | 70 | 100 | 2 | 2 | 2 | 2 | | Н | 80 | 150 | 1 | 1 | 1 | 2 | | Idle | 10 | - | idle | idle | idle | idle | The overhead figures give the ROM and RAM required for RTA-OSEK in addition to that required by the application. The RAM figure is shown split into RAM data and RAM stack. #### BCC<sub>1</sub> The BCC1 application uses 8 basic tasks with unique priorities. This application has the following overheads: | | Memory usage | Bytes | |--------|----------------------|-------| | OS ROM | | 1075 | | OS RAM | | 243 | | | comprising RAM data | 54 | | | comprising RAM stack | 189 | The BCC2 application uses 8 basic tasks with unique priorities. Tasks A-G are attached to 7 alarms. Task H is activated multiple times from Task A and has maximum queued activation count of 255. This application has the following overheads: | | Memory usage | Bytes | |--------|----------------------|-------| | OS ROM | | 1278 | | OS RAM | | 244 | | | comprising RAM data | 52 | | | comprising RAM stack | 192 | #### ECC1 The ECC1 application uses 7 basic tasks and 1 extended task with unique priorities. Task H is the extended task and it waits on a single event that is set by basic tasks A-G. This application has the following overheads: | Memory usage | | Bytes | |--------------|----------------------|-------| | OS ROM | | 1612 | | OS RAM | | 272 | | | comprising RAM data | 65 | | | comprising RAM stack | 207 | #### ECC2 The ECC2 application uses 6 basic tasks and 2 extended tasks. Tasks G and H are the extended tasks and share a priority. The extended tasks wait on a single event that is set by tasks A-F. This application has the following overheads: | M | emory usage | Bytes | |--------|----------------------|-------| | OS ROM | | 2100 | | OS RAM | | 341 | | | comprising RAM data | 84 | | | comprising RAM stack | 257 | #### **Stack Optimization** Using stack optimization with the benchmark example identifies that the following tasks can share internal resources: "Tasks A, B and C "Tasks D, E and F "Tasks G and H The benefit of this optimization is shown in the following table: | Total Stack Space<br>(bytes) | BCC1 | BCC2 | ECC1 | ECC2 | |------------------------------|------|------|------|------| | Non-optimized | 569 | 572 | 587 | 637 | | OS Overhead | 189 | 192 | 207 | 257 | | Application Overhead | 380 | 380 | 380 | 380 | | Optimized | 264 | 264 | 282 | 282 | | OS Overhead | 84 | 84 | 102 | 102 | | Application Overhead | 180 | 180 | 180 | 180 | #### **Contact addresses:** LiveDevices Ltd. Atlas House Link Business Park Osbaldwick Link Road Osbaldwick York YO10 3JB, Great Britain Phone +44 (1904) 56 25 80 Fax +44 (1904) 56 25 81 info@livedevices.com www.livedevices.com ETAS GmbH Borsigstraße 14 70469 Stuttgart, Germany Phone +49 (711) 8 96 61-102 Fax +49 (711) 8 96 61-106 sales@etas.de www.etas.de ETAS Inc. 3021 Miller Road Ann Arbor, MI 48103, USA Phone +1 (888) ETAS INC Fax +1 (734) 997-9449 sales@etas.us ETAS K.K. Queen's Tower C-17F 2-3-5, Minatomirai Nishi-ku Yokohama 220-6217, Japan Phone +81 (45) 222-0900 Fax +81 (45) 222-0956 sales@etas.co.jp www.etas.co.jp # ETAS S.A.S. 1, place des Etats-Unis SILIC 307 94588 Rungis Cedex, France Phone +33 (1) 56 70 00 50 Fax +33 (1) 56 70 00 51 sales@etas.fr www.etas.fr ETAS Korea Co., Ltd. 4F, 705 Bldg. 70-5 Yangjae-dong, Seocho-gu Seoul 137-889, Korea Phone +82 (2) 57 47-016 Fax +82 (2) 57 47-120 sales@etas.co.kr www.etas.co.kr www.etasgroup.com Subject to changes (02/06)