

September 2, 2014, Revision -

## **General Description**

The MicroBlaze<sup>®</sup> DO-254 Certifiable Data Package is made up of the artifacts produced by applying the DO-254 lifecycle to the Xilinx<sup>™</sup> MicroBlaze<sup>®</sup> IP and an encrypted version of the source code. This includes the following completed documents:

- Plan for Hardware Aspects of Certification
- Hardware Validation and Verification
   Plan
- Hardware Configuration Management Plan
- Hardware Design Plan
- Hardware Process Assurance Plan
- Hardware Validation and Verification Standard
- Hardware Requirements Standard
- Hardware Design Standard
- Hardware Requirements Document
- Hardware Design Document
- Hardware Configuration Index (includes Hardware Lifecycle Environment Configuration Index)
- Verification Configuration Index
- Hardware Test Procedures
- Hardware Verification Results
- Hardware Elemental Analysis Results
- Hardware Requirements Traceability
   Matrix
- Hardware Accomplishment Summary

The above documents are available for certification efforts, however not all documents are included in the delivery package.

The DO-254 MicroBlaze<sup>®</sup> IP Core created and designed by Xilinx<sup>™</sup>, is a 32-bit reduced instruction set computer (RISC) embedded soft core processor optimized for implementation in Xilinx<sup>™</sup> Field Programmable Gate Arrays (FPGAs).

### **Safety Features**

This version of the Xilinx<sup>®</sup> MicroBlaze<sup>®</sup> IP has the following safety features:

- Error Detection and Correction

   LMB BRAM Memory
- Parity protection
  - Internal BRAMs and Caches
- OpCode Monitoring and Exceptions
  - Instruction Bus Exception
  - Illegal OpCode Exception
  - Stack Protection Violation Exception
  - Unaligned Access Exception
  - o Data Bus Exception
  - o Divide Exception
  - Floating Point Exception
  - Stream Exception
- Lockstep
- Optional exclusion of SRLs and LUTRAM

#### Features

This version of the Xilinx<sup>®</sup> MicroBlaze<sup>®</sup> IP does not incorporate the following subset of features:

- MMU (Memory Management Unit)
- PLBv46 Bus
- Debug Module
- Hardware breaks
- XCL (CacheLink bus)
- AXI exclusive access



## **Block Diagram**



# **Supported FPGA Families**

Xilinx<sup>®</sup>-7 Series and Spartan<sup>®</sup>-6

# **Development Tools**

Xilinx<sup>®</sup> ISE/EDK<sup>®</sup> 13.4 or later ModelSim<sup>®</sup> v10.1c or later Xilinx<sup>®</sup> ISIM 13.4 or later Xilinx<sup>®</sup> XST 13.4 or later

# Configuration

The DO-254 MicroBlaze<sup>®</sup> version 1.00a is configurable as shown below:

| Settable Parameter | Label in EDK                                                                        |  |
|--------------------|-------------------------------------------------------------------------------------|--|
| C_AREA_OPTIMIZED   | Select implementation<br>to optimize area (with<br>lower instruction<br>throughput) |  |
| C_USE_BARREL       | Enable Barrel Shifter                                                               |  |
| C_USE_FPU          | Enable Floating Point<br>Unit                                                       |  |
| C_USE_HW_MUL       | Enable Integer Multiplier                                                           |  |
| C_USE_DIV          | Enable Integer Divider                                                              |  |
| C_USE_MSR_INSTR    | Enable Additional<br>Machine Status Register<br>Instructions                        |  |
| C_USE_PCMP_INSTR   | Enable Pattern<br>Comparator                                                        |  |

| Settable Parameter             | Label in EDK                                                      |  |
|--------------------------------|-------------------------------------------------------------------|--|
| C_USE_EXTENDED_FS<br>L_INSTR   | Enable Additional<br>Stream Instructions                          |  |
| C_USE_BRANCH_TAR<br>GET_CACHE  | Enable Branch Target<br>Cache                                     |  |
| C_BRANCH_TARGET_<br>CACHE_SIZE | Branch Target Cache Size                                          |  |
| C_FAULT_TOLERANT               | Enable Fault Tolerance<br>Support                                 |  |
| C_FPU_EXCEPTION                | Enable Floating Point<br>Unit Exceptions                          |  |
| C_DIV_ZERO_EXCEPTI<br>ON       | Enable Integer Divide<br>Exception                                |  |
| C_M_AXI_I_BUS_EXC<br>EPTION    | Enable Instruction-side<br>AXI Exception                          |  |
| C_M_AXI_D_BUS_EX<br>CEPTION    | Enable Data-side AXI<br>Exception                                 |  |
| C_ILL_OPCODE_EXCE<br>PTION     | Enable Illegal Instruction<br>Exception                           |  |
| C_OPCODE_0X0_ILLE<br>GAL       | Generate Illegal<br>Instruction Exception for<br>NULL Instruction |  |
| C_USE_STACK_PROTE<br>CTION     | Enable stack protection                                           |  |
| C_UNALIGNED_EXCEP<br>TIONS     | Enable Unaligned Data<br>Exception                                |  |
| C_FSL_EXCEPTION                | Enable Stream Exception                                           |  |
| C_USE_ICACHE                   | Enable Instruction Cache                                          |  |
| C_CACHE_BYTE_SIZE              | Size in Bytes (Instruction<br>Cache Feature)                      |  |
| C_ICACHE_LINE_LEN              | Line Length (Instruction<br>Cache Feature)                        |  |
| C_ICACHE_BASEADDR              | Base Address<br>(Instruction Cache<br>Feature)                    |  |
| C_ICACHE_HIGHADD<br>R          | High Address<br>(Instruction Cache<br>Feature)                    |  |
| C_ALLOW_ICACHE_W<br>R          | Enable Writes<br>(Instruction Cache<br>Feature)                   |  |



| Settable Parameter            | Label in EDK                                                                 |  |
|-------------------------------|------------------------------------------------------------------------------|--|
| C_ICACHE_ALWAYS_<br>USED      | Use Cache Links for All<br>Memory Accesses<br>(Instruction Cache<br>Feature) |  |
| C_ICACHE_FORCE_TA<br>G_LUTRAM | Use Distributed RAM for<br>Tags (Instruction Cache<br>Feature)               |  |
| C_ICACHE_STREAMS              | Number of Streams<br>(Instruction Cache<br>Feature)                          |  |
| C_ICACHE_VICTIMS              | Number of Victims<br>(Instruction Cache<br>Feature)                          |  |
| C_ICACHE_DATA_WI<br>DTH       | Data Width (Instruction<br>Cache Feature)                                    |  |
| C_USE_DCACHE                  | Enable Data Cache                                                            |  |
| C_DCACHE_BYTE_SIZ<br>E        | Size in Bytes (Data Cache<br>Feature)                                        |  |
| C_DCACHE_LINE_LEN             | Line Length (Data Cache<br>Feature)                                          |  |
| C_DCACHE_BASZEAD<br>DR        | Base Address (Data<br>Cache Feature)                                         |  |
| C_DCACHE_HIGHADD<br>DR        | High Address (Data<br>Cache Feature)                                         |  |
| C_ALLOW_DCACHE_<br>WR         | Enable Writes (Data<br>Cache Feature)                                        |  |
| C_DCACHE_ALWAYS_<br>USED      | Use Cache Links for All<br>Memory Accesses (Data<br>Cache Feature)           |  |
| C_DCACHE_FORCE_T<br>AG_LUTRAM | Use Distributed RAM for<br>Tags (Data Cache<br>Feature)                      |  |
| C_DCACHE_USE_WRI<br>TEBACK    | Enable Write-back<br>Storage Policy (Data<br>Cache Feature)                  |  |
| C_DCACHE_VICTIMS              | Number of Victims (Data<br>Cache Feature)                                    |  |
| C_DCACHE_DATA_WI<br>DTH       | Data Width (Data Cache<br>Feature)                                           |  |
| C_INTERRUPT_IS_ED<br>GE       | Sense Interrupt on Edge<br>vs. Level                                         |  |

| Settable Parameter | Label in EDK                                  |
|--------------------|-----------------------------------------------|
| C_EDGE_IS_POSITIVE | Sense Interrupt on Rising<br>vs. Falling Edge |
| C_RESET_MSR        | Reset Value for Select<br>MSR Bits            |
| C_PVR              | Specifies Processor<br>Version Register       |
| C_PVR_USER1        | USER1 Bits in Processor<br>Version Register   |
| C_PVR_USER2        | USER2 Bits in Processor<br>Version Registers  |

## Assumptions

Assumption 1: The integrator will develop a full set of DO-254 artifacts to reflect the objectives, activities, and lifecycle data related to the system/safety, implementation, target test, acceptance test, production transition aspects, related validation and verification, configuration management, process assurance, and certification liaison aspects of the system/LRU.

Assumption 2: The objectives, activities and lifecycle data related specifically to the DO-254 MicroBlaze<sup>®</sup> IP Core will be provided to the Integrator for inclusion into their overall certification package.

**Assumption 3**: Place and route, clock frequency, and parameter selection decisions related to the IP core will have an impact on critical areas such as timing. These decisions and the verification of these implementation decisions will be the responsibility of the integrator.

**Assumption 4**: All objectives related to the building, integration and Production (including Production Testing - ATP) of the system/LRU will be the responsibility of the integrator.



Assumption 5: Objectives related to hardware components other than the DO-254 MicroBlaze<sup>®</sup> IP Core are the responsibility of the integrator.

Assumption 6: The integrator will develop all DO-254 artifacts that are related to the integration and testing of the DO-254 MicroBlaze<sup>®</sup> IP Core in their system.

**Assumption 7**: The integrator will perform implementation objectives related to the target hardware, including the integral process objectives, to verify the timing and other critical parameters of the DO-254 MicroBlaze® IP Core.

Assumption 8: The applicant is responsible for communicating with their Certification Authority relative to the implementation of the DO-254 MicroBlaze<sup>®</sup> IP Core into their system.

Assumption 9: Compliance with the objectives related to system (and safety-related) requirements allocated to the hardware will be the responsibility of the integrator. The requirement to feed all IP derived requirements to the System/Safety Process will be the responsibility of the integrator. The integrator will be required to generate hardware requirements allocated from the system requirements that exercise the DO-254 MicroBlaze<sup>®</sup> IP Core at the system level.

Assumption 10: The integrator is required to include a clock timing constraint for this DO-254 MicroBlaze® IP Core. This clock timing constraint will define the clock rate at which the IP core will operate. It is recommended that the integrator define this constraint in the UCF file. The integrator typically would also include (at a minimum, but not limited to) pinout constraints, I/O electrical standards, etc. An example UCF file will be provided in 10100-UG, but it is for reference only.

**Assumption 11:** The integrator is not required to rerun any elemental analysis (code coverage). Code coverage results will indicate that all configurations required to attain 100% coverage are tested.

Assumption 12: Simulation validation for the DO-254 MicroBlaze® IP Core is being done on a test board. The integrator is responsible for black box testing in his system. In order to accomplish this black box testing, the integrator is recommended to design his PCB to have access to at least XX (number defined in 10100-UG) spare FPGA pins that can be connected to a logic analyzer. If the integrator chooses to do post place and route simulation on their system as an additional validation, Logicircuit will provide the necessary files for the DO-254 MicroBlaze® IP Core.



September 2, 2014, Revision -

# **Revision History**

|          |                    |          | Subversion |
|----------|--------------------|----------|------------|
|          |                    |          | repository |
| Revision | Reason/Description | Date     | revision   |
| -        | Initial Release    | 9/2/2014 | 175        |