1.8 Product design flow and documentation

You must complete several processes to use the CCI-500. To obtain the best performance from the CCI-500, ARM recommends that you perform some of the implementation stages, including RAM integration, before integrating it into your wider SoC.

The processes you must perform are as follows:
Implementation
The implementer configures and synthesizes the RTL.
Integration
The integrator connects the implemented design into a SoC. This includes connecting it to a memory system, processors, and peripherals.
Final SoC implementation
The process of implementing the final, fully integrated SoC in silicon. ARM can provide only guidance relevant to its own products for this process. If ARM provides guidance on this process for your product, then a separate document is included in the implementation bundle for that product.
Programming
This is the last process. The system programmer develops the software required to configure and initialize the CCI-500, and tests the required application software.
For information on the CCI-500 documents that provide information on these processes, see 1.8.1 Documentation.
Each process:
  • Is separate, and a different person can complete it.
  • Can include implementation and integration choices that affect the behavior and features of the CCI-500, and therefore the other tasks in the flow.
The operation of the final device depends on:
Build configuration
The implementer chooses the options that affect the preprocessing of the RTL source files. These options usually include or exclude the logic that affects one or more of the features, the area, or the maximum frequency and performance of the resulting macrocell. For example, the number of outstanding transactions that each master and slave interface supports.
Configuration inputs
The integrator configures some features of the CCI-500 by tying inputs to specific values. These configurations affect the start-up behavior before you specify the software configuration. They can also limit the options available to the software. For example, the ACCHANNELENSx signal inputs prevent AC coherency requests from being emitted from an unconnected slave interface.
Software configuration
The programmer configures the CCI-500 by programming particular values into registers. This affects the behavior of the CCI-500, for example, by enabling QoS features.
Non-ConfidentialPDF file icon PDF versionARM 100023_0001_00_en
Copyright © 2014, 2015 ARM. All rights reserved.