



## Fast Models

Version 11.20

# Fixed Virtual Platforms (FVP) Reference Guide

**Non-Confidential**

Copyright © 2017–2022 Arm Limited (or its affiliates).  
All rights reserved.

**Issue 00**

100966\_1120\_00\_en

# Fast Models

## Fixed Virtual Platforms (FVP) Reference Guide

Copyright © 2017–2022 Arm Limited (or its affiliates). All rights reserved.

### Release Information

#### Document history

| Issue   | Date             | Confidentiality  | Change                                                   |
|---------|------------------|------------------|----------------------------------------------------------|
| 1100-00 | 31 May 2017      | Non-Confidential | Update for v11.0. Document numbering scheme has changed. |
| 1101-00 | 31 August 2017   | Non-Confidential | Update for v11.1.                                        |
| 1102-00 | 17 November 2017 | Non-Confidential | Update for v11.2.                                        |
| 1103-00 | 23 February 2018 | Non-Confidential | Update for v11.3.                                        |
| 1104-00 | 22 June 2018     | Non-Confidential | Update for v11.4.                                        |
| 1104-01 | 17 August 2018   | Non-Confidential | Update for v11.4.2.                                      |
| 1105-00 | 23 November 2018 | Non-Confidential | Update for v11.5.                                        |
| 1106-00 | 26 February 2019 | Non-Confidential | Update for v11.6.                                        |
| 1107-00 | 17 May 2019      | Non-Confidential | Update for v11.7.                                        |
| 1108-00 | 5 September 2019 | Non-Confidential | Update for v11.8.                                        |
| 1108-01 | 3 October 2019   | Non-Confidential | Update for v11.8.1.                                      |
| 1109-00 | 28 November 2019 | Non-Confidential | Update for v11.9.                                        |
| 1110-00 | 12 March 2020    | Non-Confidential | Update for v11.10.                                       |

| Issue   | Date              | Confidentiality  | Change                               |
|---------|-------------------|------------------|--------------------------------------|
| 1111-00 | 9 June 2020       | Non-Confidential | Update for v11.11.                   |
| 1112-00 | 22 September 2020 | Non-Confidential | Update for v11.12.                   |
| 1113-00 | 9 December 2020   | Non-Confidential | Update for v11.13.                   |
| 1114-00 | 17 March 2021     | Non-Confidential | Update for v11.14.                   |
| 1114-01 | 14 April 2021     | Non-Confidential | Update for FVP_Base_AEMv8R.          |
| 1115-00 | 29 June 2021      | Non-Confidential | Update for v11.15.                   |
| 1116-00 | 6 October 2021    | Non-Confidential | Update for v11.16.                   |
| 1117-00 | 16 February 2022  | Non-Confidential | Update for v11.17.                   |
| 1118-00 | 15 June 2022      | Non-Confidential | Update for v11.18.                   |
| 1118-01 | 26 August 2022    | Non-Confidential | Update for Arm Corstone SSE-310 FVP. |
| 1119-00 | 14 September 2022 | Non-Confidential | Update for v11.19.                   |
| 1120-00 | 7 December 2022   | Non-Confidential | Update for v11.20.                   |

## Proprietary Notice

This document is protected by copyright and other related rights and the practice or implementation of the information contained in this document may be protected by one or more patents or pending patent applications. No part of this document may be reproduced in any form by any means without the express prior written permission of Arm. No license, express or implied, by estoppel or otherwise to any intellectual property rights is granted by this document unless specifically stated.

Your access to the information in this document is conditional upon your acceptance that you will not use or permit others to use the information for the purposes of determining whether implementations infringe any third party patents.

THIS DOCUMENT IS PROVIDED "AS IS". ARM PROVIDES NO REPRESENTATIONS AND NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF MERCHANTABILITY, SATISFACTORY QUALITY, NON-INFRINGEMENT OR FITNESS FOR A PARTICULAR PURPOSE WITH RESPECT TO THE DOCUMENT. For the avoidance of doubt, Arm makes no representation with respect to, and has undertaken no analysis to identify or understand the scope and content of, patents, copyrights, trade secrets, or other rights.

This document may include technical inaccuracies or typographical errors.

TO THE EXTENT NOT PROHIBITED BY LAW, IN NO EVENT WILL ARM BE LIABLE FOR ANY DAMAGES, INCLUDING WITHOUT LIMITATION ANY DIRECT, INDIRECT, SPECIAL, INCIDENTAL, PUNITIVE, OR CONSEQUENTIAL DAMAGES, HOWEVER CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY, ARISING OUT OF ANY USE OF THIS DOCUMENT, EVEN IF ARM HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

This document consists solely of commercial items. You shall be responsible for ensuring that any use, duplication or disclosure of this document complies fully with any relevant export laws and regulations to assure that this document or any portion thereof is not exported, directly or indirectly, in violation of such export laws. Use of the word "partner" in reference to Arm's customers is not intended to create or refer to any partnership relationship with any other company. Arm may make changes to this document at any time and without notice.

This document may be translated into other languages for convenience, and you agree that if there is any conflict between the English version of this document and any translation, the terms of the English version of the Agreement shall prevail.

The Arm corporate logo and words marked with ® or ™ are registered trademarks or trademarks of Arm Limited (or its affiliates) in the US and/or elsewhere. All rights reserved. Other brands and names mentioned in this document may be the trademarks of their respective owners. Please follow Arm's trademark usage guidelines at <https://www.arm.com/company/policies/trademarks>.

Copyright © 2017–2022 Arm Limited (or its affiliates). All rights reserved.

Arm Limited. Company 02557590 registered in England.

110 Fulbourn Road, Cambridge, England CB1 9NJ.

(LES-PRE-20349|version 21.0)

## Confidentiality Status

This document is Non-Confidential. The right to use, copy and disclose this document may be subject to license restrictions in accordance with the terms of the agreement entered into by Arm and the party that Arm delivered this document to.

Unrestricted Access is an Arm internal classification.

## Product Status

The information in this document is Final, that is for a developed product.

## Feedback

Arm welcomes feedback on this product and its documentation. To provide feedback on the product, create a ticket on <https://support.developer.arm.com>.

To provide feedback on the document, fill the following survey: <https://developer.arm.com/documentation-feedback-survey>.

## Inclusive language commitment

Arm values inclusive communities. Arm recognizes that we and our industry have used language that can be offensive. Arm strives to lead the industry and create change.

This document includes language that can be offensive. We will replace this language in a future issue of this document.

To report offensive language in this document, email [terms@arm.com](mailto:terms@arm.com).

# Contents

|                                                                           |           |
|---------------------------------------------------------------------------|-----------|
| <b>1. Introduction.....</b>                                               | <b>12</b> |
| 1.1 Conventions.....                                                      | 12        |
| 1.2 Other information.....                                                | 12        |
| 1.3 Useful resources.....                                                 | 13        |
| <b>2. Introduction to FVPs.....</b>                                       | <b>14</b> |
| 2.1 Types of FVP.....                                                     | 14        |
| <b>3. Getting Started with Fixed Virtual Platforms.....</b>               | <b>16</b> |
| 3.1 Contents of the FVP Standard Library package.....                     | 16        |
| 3.2 FVP command-line options.....                                         | 17        |
| 3.3 Loading and running an application on an FVP.....                     | 22        |
| 3.4 Configuring the model.....                                            | 23        |
| 3.5 FVP debug.....                                                        | 23        |
| 3.6 Using the CLCD window.....                                            | 24        |
| 3.7 Ethernet with VE FVPs.....                                            | 27        |
| 3.8 Using a terminal with a system model.....                             | 30        |
| 3.9 Virtio P9 device component.....                                       | 33        |
| <b>4. Arm® CoreLink™ SGI-575 reference design FVP.....</b>                | <b>35</b> |
| 4.1 About the SGI-575 FVP.....                                            | 35        |
| 4.2 SGI-575 FVP peripherals.....                                          | 35        |
| 4.2.1 Memory map for SGI-575 FVP SoC peripherals.....                     | 36        |
| 4.2.2 Memory map for SGI-575 FVP board peripherals.....                   | 37        |
| 4.2.3 Interrupt maps for SGI-575 FVP.....                                 | 37        |
| <b>5. Arm® Corstone™ SSE-300 FVP.....</b>                                 | <b>39</b> |
| 5.1 Memory map overview for Corstone™ SSE-300.....                        | 39        |
| 5.2 Corstone™ SSE-300 FVP peripherals.....                                | 41        |
| 5.2.1 Corstone™ SSE-300 non-secure expansion peripherals memory map.....  | 42        |
| 5.2.2 Corstone™ SSE-300 secure expansion peripherals memory map.....      | 43        |
| 5.2.3 Corstone™ SSE-300 expansion peripheral interrupt map.....           | 45        |
| 5.3 Corstone™ SSE-300 peripheral protection controller expansion map..... | 47        |

|                                                                                   |           |
|-----------------------------------------------------------------------------------|-----------|
| 5.4 Corstone™ SSE-300 memory components.....                                      | 47        |
| <b>6. Arm® Corstone™ SSE-310 FVP.....</b>                                         | <b>49</b> |
| 6.1 Corstone™ SSE-310 FVP memory map overview.....                                | 49        |
| 6.2 Corstone™ SSE-310 FVP peripherals.....                                        | 51        |
| 6.2.1 Corstone™ SSE-310 FVP subsystem peripherals non-secure memory map.....      | 52        |
| 6.2.2 Corstone™ SSE-310 FVP subsystem peripherals secure memory map.....          | 53        |
| 6.2.3 Corstone™ SSE-310 FVP non-secure expansion peripherals memory map.....      | 54        |
| 6.2.4 Corstone™ SSE-310 FVP secure expansion peripherals memory map.....          | 56        |
| 6.2.5 Corstone™ SSE-310 FVP expansion peripheral interrupt map.....               | 57        |
| 6.3 Corstone™ SSE-310 FVP peripheral protection controller expansion map.....     | 59        |
| 6.4 Corstone™ SSE-310 FVP memory components.....                                  | 59        |
| <b>7. Arm® Corstone™-1000 FVP.....</b>                                            | <b>61</b> |
| 7.1 Corstone™-1000 FVP modeled components.....                                    | 61        |
| 7.2 Run the Corstone™-1000 FVP with the software package.....                     | 62        |
| 7.3 Corstone™-1000 board peripherals memory and interrupt map.....                | 63        |
| 7.4 Networking on Corstone™-1000 FVP.....                                         | 63        |
| <b>8. Juno FVP3 model.....</b>                                                    | <b>64</b> |
| 8.1 Unimplemented features and model limitations.....                             | 64        |
| 8.2 Running the Juno FVP3 model.....                                              | 65        |
| 8.2.1 Run the Juno FVP3 model in Arm DS.....                                      | 65        |
| 8.2.2 Run the Juno FVP3 model standalone.....                                     | 65        |
| 8.2.3 Run the create_afs_image.py script.....                                     | 66        |
| 8.3 Jump-start the application clusters on bare metal.....                        | 67        |
| 8.4 Basic setup for the TZC-400 model on bare metal.....                          | 67        |
| <b>9. Arm® Neoverse™ N1 edge and Neoverse™ E1 edge reference design FVPs.....</b> | <b>69</b> |
| 9.1 About the RD-N1-E1 FVPs.....                                                  | 69        |
| 9.2 Block diagrams for RD-N1-E1-edge.....                                         | 70        |
| 9.3 RD-N1-E1 FVP peripherals.....                                                 | 71        |
| 9.3.1 Memory map for RD-N1-E1-edge FVP SoC peripherals.....                       | 72        |
| 9.3.2 Memory map for RD-N1-E1-edge FVP board peripherals.....                     | 73        |
| 9.3.3 Interrupt maps for RD-N1-E1-edge FVP.....                                   | 74        |
| <b>10. Arm® Neoverse™ N2 reference design FVP.....</b>                            | <b>75</b> |

|                                                             |           |
|-------------------------------------------------------------|-----------|
| 10.1 About the RD-N2 FVP.....                               | 75        |
| 10.2 RD-N2 FVP peripherals.....                             | 76        |
| 10.2.1 Memory map for RD-N2 FVP SoC peripherals.....        | 76        |
| 10.2.2 Memory map for RD-N2 FVP board peripherals.....      | 77        |
| 10.2.3 Interrupt maps for RD-N2 FVP.....                    | 78        |
| <b>11. Arm® Neoverse™ V1 reference design FVP.....</b>      | <b>80</b> |
| 11.1 About the RD-V1 FVP.....                               | 80        |
| 11.2 RD-V1 FVP peripherals.....                             | 81        |
| 11.2.1 Memory map for RD-V1 FVP SoC peripherals.....        | 81        |
| 11.2.2 Memory map for RD-V1 FVP board peripherals.....      | 82        |
| 11.2.3 Interrupt maps for RD-V1 FVP.....                    | 83        |
| <b>12. Configurable PCIe hierarchy.....</b>                 | <b>85</b> |
| 12.1 JSON format for the hierarchy.....                     | 85        |
| 12.2 Common PCIe endpoint parameters.....                   | 86        |
| 12.3 AHCI controller parameters.....                        | 87        |
| 12.4 Host bridge parameters.....                            | 89        |
| 12.5 SMMU test engine parameters.....                       | 91        |
| 12.6 Root port parameters.....                              | 93        |
| 12.7 Switch parameters.....                                 | 93        |
| 12.8 Root bridge parameters.....                            | 94        |
| 12.9 Example hierarchy for a single ECAM configuration..... | 95        |
| 12.10 Example hierarchy for two ECAM configuration.....     | 96        |
| <b>13. Base Platform FVPs.....</b>                          | <b>98</b> |
| 13.1 FVP_Base_AEMvA-AEMvA.....                              | 98        |
| 13.2 FVP_Base_Cortex-A32x1.....                             | 112       |
| 13.3 FVP_Base_Cortex-A32x2.....                             | 124       |
| 13.4 FVP_Base_Cortex-A32x4.....                             | 136       |
| 13.5 FVP_Base_Cortex-A35x1.....                             | 149       |
| 13.6 FVP_Base_Cortex-A35x2.....                             | 161       |
| 13.7 FVP_Base_Cortex-A35x4.....                             | 173       |
| 13.8 FVP_Base_Cortex-A510.....                              | 186       |
| 13.9 FVP_Base_Cortex-A510x4+Cortex-A710x4.....              | 201       |
| 13.10 FVP_Base_Cortex-A53x1.....                            | 213       |
| 13.11 FVP_Base_Cortex-A53x2.....                            | 225       |

|                                                   |     |
|---------------------------------------------------|-----|
| 13.12 FVP_Base_Cortex-A53x4.....                  | 237 |
| 13.13 FVP_Base_Cortex-A55.....                    | 250 |
| 13.14 FVP_Base_Cortex-A55+Cortex-A76.....         | 265 |
| 13.15 FVP_Base_Cortex-A55x1+Cortex-A75x1.....     | 276 |
| 13.16 FVP_Base_Cortex-A55x2+Cortex-A75x2.....     | 288 |
| 13.17 FVP_Base_Cortex-A55x4+Cortex-A75x1.....     | 300 |
| 13.18 FVP_Base_Cortex-A55x4+Cortex-A75x2.....     | 312 |
| 13.19 FVP_Base_Cortex-A55x4+Cortex-A75x4.....     | 324 |
| 13.20 FVP_Base_Cortex-A55x4+Cortex-A76x2.....     | 337 |
| 13.21 FVP_Base_Cortex-A55x4+Cortex-A78x4.....     | 349 |
| 13.22 FVP_Base_Cortex-A57x1.....                  | 361 |
| 13.23 FVP_Base_Cortex-A57x1-A35x1.....            | 373 |
| 13.24 FVP_Base_Cortex-A57x1-A53x1.....            | 386 |
| 13.25 FVP_Base_Cortex-A57x2.....                  | 398 |
| 13.26 FVP_Base_Cortex-A57x2-A35x4.....            | 410 |
| 13.27 FVP_Base_Cortex-A57x2-A53x4.....            | 424 |
| 13.28 FVP_Base_Cortex-A57x4.....                  | 438 |
| 13.29 FVP_Base_Cortex-A57x4-A35x4.....            | 451 |
| 13.30 FVP_Base_Cortex-A57x4-A53x4.....            | 465 |
| 13.31 FVP_Base_Cortex-A65.....                    | 479 |
| 13.32 FVP_Base_Cortex-A65AE.....                  | 494 |
| 13.33 FVP_Base_Cortex-A65AEx2+Cortex-A76AEx2..... | 510 |
| 13.34 FVP_Base_Cortex-A65AEx4+Cortex-A76AEx4..... | 522 |
| 13.35 FVP_Base_Cortex-A710.....                   | 534 |
| 13.36 FVP_Base_Cortex-A715.....                   | 549 |
| 13.37 FVP_Base_Cortex-A72x1.....                  | 564 |
| 13.38 FVP_Base_Cortex-A72x1-A53x1.....            | 576 |
| 13.39 FVP_Base_Cortex-A72x2.....                  | 588 |
| 13.40 FVP_Base_Cortex-A72x2-A53x4.....            | 600 |
| 13.41 FVP_Base_Cortex-A72x4.....                  | 614 |
| 13.42 FVP_Base_Cortex-A72x4-A53x4.....            | 627 |
| 13.43 FVP_Base_Cortex-A73x1.....                  | 641 |
| 13.44 FVP_Base_Cortex-A73x1-A53x1.....            | 653 |
| 13.45 FVP_Base_Cortex-A73x2.....                  | 666 |
| 13.46 FVP_Base_Cortex-A73x2-A53x4.....            | 678 |
| 13.47 FVP_Base_Cortex-A73x4.....                  | 692 |

|                                                 |             |
|-------------------------------------------------|-------------|
| 13.48 FVP_Base_Cortex-A73x4-A53x4.....          | 705         |
| 13.49 FVP_Base_Cortex-A75.....                  | 719         |
| 13.50 FVP_Base_Cortex-A76.....                  | 732         |
| 13.51 FVP_Base_Cortex-A76AE.....                | 745         |
| 13.52 FVP_Base_Cortex-A77.....                  | 758         |
| 13.53 FVP_Base_Cortex-A78.....                  | 771         |
| 13.54 FVP_Base_Cortex-A78AE.....                | 784         |
| 13.55 FVP_Base_Cortex-A78C.....                 | 797         |
| 13.56 FVP_Base_Cortex-X1.....                   | 810         |
| 13.57 FVP_Base_Cortex-X1C.....                  | 823         |
| 13.58 FVP_Base_Cortex-X2.....                   | 836         |
| 13.59 FVP_Base_Cortex-X3.....                   | 851         |
| 13.60 FVP_Base_Neoverse-E1.....                 | 865         |
| 13.61 FVP_Base_Neoverse-N1.....                 | 880         |
| 13.62 FVP_Base_Neoverse-N2.....                 | 893         |
| 13.63 FVP_Base_Neoverse-N2x1-Neoverse-N2x1..... | 905         |
| 13.64 FVP_Base_Neoverse-V1.....                 | 918         |
| 13.65 FVP_Base_Neoverse-V2.....                 | 931         |
| 13.66 FVP_Base_Neoverse-V2x1-Neoverse-V2x1..... | 943         |
| <b>14. BaseR Platform FVPs.....</b>             | <b>956</b>  |
| 14.1 FVP_BaseR_Cortex-R52Plus.....              | 956         |
| 14.2 FVP_BaseR_Cortex-R52x1.....                | 969         |
| 14.3 FVP_BaseR_Cortex-R52x2.....                | 981         |
| 14.4 FVP_BaseR_Cortex-R52x4.....                | 993         |
| 14.5 FVP_BaseR_Cortex-R82x1.....                | 1006        |
| 14.6 FVP_BaseR_Cortex-R82x2.....                | 1018        |
| 14.7 FVP_BaseR_Cortex-R82x4.....                | 1030        |
| <b>15. VE Platform FVPs.....</b>                | <b>1044</b> |
| 15.1 FVP_VE_Cortex-A15x1.....                   | 1044        |
| 15.2 FVP_VE_Cortex-A15x1-A7x1.....              | 1054        |
| 15.3 FVP_VE_Cortex-A15x2.....                   | 1065        |
| 15.4 FVP_VE_Cortex-A15x2-A7x2.....              | 1075        |
| 15.5 FVP_VE_Cortex-A15x4.....                   | 1086        |
| 15.6 FVP_VE_Cortex-A15x4-A7x4.....              | 1097        |
| 15.7 FVP_VE_Cortex-A17x1.....                   | 1111        |

|                                        |             |
|----------------------------------------|-------------|
| 15.8 FVP_VE_Cortex-A17x1-A7x1.....     | 1121        |
| 15.9 FVP_VE_Cortex-A17x2.....          | 1132        |
| 15.10 FVP_VE_Cortex-A17x4.....         | 1142        |
| 15.11 FVP_VE_Cortex-A17x4-A7x4.....    | 1153        |
| 15.12 FVP_VE_Cortex-A5x1.....          | 1166        |
| 15.13 FVP_VE_Cortex-A5x2.....          | 1176        |
| 15.14 FVP_VE_Cortex-A5x4.....          | 1186        |
| 15.15 FVP_VE_Cortex-A7x1.....          | 1197        |
| 15.16 FVP_VE_Cortex-A7x2.....          | 1206        |
| 15.17 FVP_VE_Cortex-A7x4.....          | 1217        |
| 15.18 FVP_VE_Cortex-A9x1.....          | 1228        |
| 15.19 FVP_VE_Cortex-A9x2.....          | 1237        |
| 15.20 FVP_VE_Cortex-A9x4.....          | 1247        |
| 15.21 FVP_VE_Cortex-R4.....            | 1258        |
| 15.22 FVP_VE_Cortex-R5x1.....          | 1267        |
| 15.23 FVP_VE_Cortex-R5x2.....          | 1276        |
| 15.24 FVP_VE_Cortex-R7x1.....          | 1284        |
| 15.25 FVP_VE_Cortex-R7x2.....          | 1292        |
| 15.26 FVP_VE_Cortex-R8x1.....          | 1301        |
| 15.27 FVP_VE_Cortex-R8x2.....          | 1309        |
| 15.28 FVP_VE_Cortex-R8x4.....          | 1317        |
| <b>16. MPS2 Platform FVPs.....</b>     | <b>1327</b> |
| 16.1 FVP_MPS2_AEMv8M.....              | 1327        |
| 16.2 FVP_MPS2_Cortex-M0.....           | 1346        |
| 16.3 FVP_MPS2_Cortex-M0plus.....       | 1365        |
| 16.4 FVP_MPS2_Cortex-M23.....          | 1384        |
| 16.5 FVP_MPS2_Cortex-M3.....           | 1403        |
| 16.6 FVP_MPS2_Cortex-M33.....          | 1422        |
| 16.7 FVP_MPS2_Cortex-M35P.....         | 1441        |
| 16.8 FVP_MPS2_Cortex-M4.....           | 1460        |
| 16.9 FVP_MPS2_Cortex-M55.....          | 1479        |
| 16.10 FVP_MPS2_Cortex-M7.....          | 1499        |
| 16.11 FVP_MPS2_Cortex-M85.....         | 1518        |
| 16.12 FVP_MPS2_SSE-200_Cortex-M33..... | 1537        |
| 16.13 FVP_MPS2_SSE-200_Cortex-M55..... | 1556        |

# 1. Introduction

This document describes how to get started with Fixed Virtual Platforms (FVPs). It also provides a reference for FVPs for Reference Designs, Arm Architecture FVPs, and FVPs that are included in the FVP library.

## 1.1 Conventions

The following subsections describe conventions used in Arm documents.

### Glossary

The Arm® Glossary is a list of terms used in Arm documentation, together with definitions for those terms. The Arm Glossary does not contain terms that are industry standard unless the Arm meaning differs from the generally accepted meaning.

See the Arm Glossary for more information: [developer.arm.com/glossary](https://developer.arm.com/glossary).

### Typographic conventions

| Convention                    | Use                                                                                                                                                                                                                                       |
|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <i>italic</i>                 | Citations.                                                                                                                                                                                                                                |
| <b>bold</b>                   | Highlights interface elements, such as menu names.<br><br>Also used for terms in descriptive lists, where appropriate.                                                                                                                    |
| <code>monospace</code>        | Denotes text that you can enter at the keyboard, such as commands, file and program names, and source code.                                                                                                                               |
| <u>monospace</u>              | Denotes a permitted abbreviation for a command or option. You can enter the underlined text instead of the full command or option name.                                                                                                   |
| <code>monospace italic</code> | Denotes arguments to monospace text where the argument is to be replaced by a specific value.                                                                                                                                             |
| <code>&lt;and&gt;</code>      | Encloses replaceable terms for assembler syntax where they appear in code or code fragments. For example:<br><br><code>MRC p15, 0, &lt;Rd&gt;, &lt;CRn&gt;, &lt;CRm&gt;, &lt;Opcode_2&gt;</code>                                          |
| <b>SMALL CAPITALS</b>         | Used in body text for a few terms that have specific technical meanings, that are defined in the Arm® Glossary. For example, <b>IMPLEMENTATION DEFINED</b> , <b>IMPLEMENTATION SPECIFIC</b> , <b>UNKNOWN</b> , and <b>UNPREDICTABLE</b> . |

## 1.2 Other information

See the Arm® website for other relevant information.

- [Arm® Developer](#).
- [Arm® Documentation](#).

- [Technical Support](#).
- [Arm® Glossary](#).

## 1.3 Useful resources

This document contains information that is specific to this product. See the following resources for other useful information.

Access to Arm documents depends on their confidentiality:

- Non-Confidential documents are available at [developer.arm.com/documentation](https://developer.arm.com/documentation). Each document link in the following tables goes to the online version of the document.
- Confidential documents are available to licensees only through the product package.

| Arm® product resources                                                              | Document ID            | Confidentiality  |
|-------------------------------------------------------------------------------------|------------------------|------------------|
| <a href="#">Arm® Architecture Models</a>                                            | -                      | Non-Confidential |
| <a href="#">Arm® Corstone™ SSE-300 Example Subsystem Technical Reference Manual</a> | 101773                 | Non-Confidential |
| <a href="#">Arm® Corstone™-1000 Technical Overview</a>                              | 102360                 | Non-Confidential |
| <a href="#">Arm® Development Platforms wiki</a>                                     | -                      | Non-Confidential |
| <a href="#">Arm® Development Studio Getting Started Guide</a>                       | 101469                 | Non-Confidential |
| <a href="#">Arm® Development Studio User Guide</a>                                  | 101470                 | Non-Confidential |
| <a href="#">Arm® MPS3 FPGA Prototyping Board Technical Reference Manual</a>         | 100765                 | Non-Confidential |
| <a href="#">Arm® Neoverse™ v1 reference design Software Developer Guide</a>         | PJDOC-1779577084-33214 | Non-Confidential |
| <a href="#">Corstone™-300</a>                                                       | -                      | Non-Confidential |
| <a href="#">Fast Models Reference Guide</a>                                         | 100964                 | Non-Confidential |
| <a href="#">Fast Models User Guide</a>                                              | 100965                 | Non-Confidential |
| <a href="#">Getting started with your FVP</a>                                       | -                      | Non-Confidential |
| <a href="#">Iris Python Debug Scripting User Guide</a>                              | 101421                 | Non-Confidential |
| <a href="#">Iris User Guide</a>                                                     | 101196                 | Non-Confidential |
| <a href="#">Juno r2 Arm® Development Platform SoC Technical Reference Manual</a>    | DDI 0515               | Non-Confidential |
| <a href="#">Model Debugger for Fast Models User Guide</a>                           | 100968                 | Non-Confidential |
| <a href="#">Neoverse™ Reference Design</a>                                          | -                      | Non-Confidential |

| Arm® architecture and specifications                                          | Document ID | Confidentiality  |
|-------------------------------------------------------------------------------|-------------|------------------|
| <a href="#">Arm® Architecture Reference Manual for A-profile architecture</a> | DDI 0487    | Non-Confidential |
| <a href="#">Semihosting for AArch32 and AArch64 specification</a>             | -           | Non-Confidential |



Arm tests its PDFs only in Adobe Acrobat and Acrobat Reader. Arm cannot guarantee the quality of its documents when used with any other PDF reader.

Note

Adobe PDF reader products can be downloaded at <http://www.adobe.com>

## 2. Introduction to FVPs

Fixed Virtual Platforms (FVPs) enable software development without the need for real hardware.

They are available for Linux and Windows hosts, either:

- As pre-built executables. Their composition is fixed, but you can configure their behavior using parameters.
- As source code examples in the Fast Models product, with the tools required to customize and build them.

FVPs are available for all Cortex®-A, Cortex®-R, and Cortex®-M processors, and most of them support the CADI, MTI, and Iris interfaces, so can be used for debugging and for trace output.

Arm provides validated Linux and Android deliverables for various platforms, including FVPs. For details, see the [Arm Development Platforms wiki](#) on Arm Community. To get started with Linux on FVPs, see [FVPs](#) on Arm Community.

### 2.1 Types of FVP

Most Fast Models FVPs are provided in a single license-managed library. In addition, some Architecture Envelope Model (AEM) FVPs are available for download without requiring a license.

Fast Models FVPs are based on the following platforms:

- Base Platform.
- BaseR Platform.
- Arm® Versatile™ Express development boards.
- Arm® MPS2 or Arm® MPS2+ platforms, for Cortex®-M series processors.

FVPs can be obtained in the following ways:

- License-managed FVPs, including some plug-ins and utilities, are provided in the FVP Standard Library. It is available for Windows or Linux hosts. For information on how to download it, see [Fixed Virtual Platforms](#) on Arm Developer.
- Free-of-charge AEM FVPs can be downloaded from [Arm Architecture Models](#) on Arm Developer without a license. They are available for Linux hosts only. The following FVPs are available:
  - Foundation Platform. This is a basic FVP with a minimal peripheral set. It includes a single cluster which can be configured with 1-4 AEMvA cores. It is suitable for running bare-metal applications and for booting Linux. It supports the CADI debug interface, but does not support MTI or Iris interfaces. It is documented in the [Foundation Platform User Guide](#).
  - Armv-A Base Platform RevC FVP. This is a platform model with a more extended peripheral set than the Foundation Platform. It has two clusters, each of which can be configured with

1-4 AEMvA cores. It supports Arm®v8-A architecture versions up to v8.7 and Armv9-A. It also supports CADI, MTI, and Iris debug and trace interfaces.

- Arm®v8-R AEM FVP. This FVP includes a single cluster of 1-4 AEMv8-R cores. It allows you to target AArch32 or AArch64, RAS, VFP, EL2, and other Arm®v8-R features.
- Armv-A Compliance FVP. This FVP is optimized for validating CPU implementations and can be used with the A-profile Architecture Compliance Kit (ACK) to demonstrate compliance with the Arm® architecture specification.
- Free-of-charge Arm Ecosystem FVPs, including Reference Design FVPs and the Morello Platform FVP can be downloaded from [Arm Ecosystem FVPs](#) on Arm Developer.

## Related information

[Contents of the FVP Standard Library package](#) on page 16

[Base Platform](#)

[Microcontroller Prototyping System 2](#)

[Versatile Express Model](#)

# 3. Getting Started with Fixed Virtual Platforms

This chapter describes how to use FVPs.

## 3.1 Contents of the FVP Standard Library package

The FVP Standard Library consolidates commonly used FVPs into a single package which also contains some useful plug-ins and utilities.



The package does not include unlicensed FVPs. These are available for download separately, from [Arm Architecture Models](#) on Arm Developer.

The package installs the FVPs under the `models` directory. It also installs:

### Plug-ins

Plug-ins are DLLs or shared objects that provide extra functionality to FVPs, for instance different types of trace output. To load a plug-in, pass the name of the plug-in to the FVP at startup using the `--plugin` command-line option or using the `FM_TRACE_PLUGINS` environment variable. For more information about plug-ins, see [Plug-ins for Fast Models](#) in the *Fast Models Reference Guide*.

### Model Shell and Model Debugger

Model Shell is a command-line tool for launching FVPs. For more information about Model Shell, see [Model Shell for Fast Models Reference Guide](#). Model Debugger is an easy to use symbolic debugger with a GUI that allows you to debug software running on the FVP. For more information about Model Debugger, see [Model Debugger for Fast Models User Guide](#). They are installed in the `bin` directory.

### iris.debug Python module

`iris.debug` is a Python scripting interface to Fast Models. It allows you to interact with FVPs, including connecting to and configuring them, performing execution control, and accessing registers and memory. It is installed under the `iris` directory. For more information about `iris.debug`, see [Iris Python Debug Scripting User Guide](#).

## 3.2 FVP command-line options

Specify these options when you launch an FVP from the command line. You can specify these options in any order.

**Table 3-1: CADI or Iris-related options**

| Short form | Long form                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | --iris-connect<br><i>conspec</i> | <p>Start the Iris server according to the connection specification <i>conspec</i>. <i>conspec</i> is a structured string argument which can contain flags and parameters.</p> <p>Use <code>--iris-connect help</code> to print a list and description of all available Iris connection types.</p> <p>The following options are ignored when using <code>--iris-connect</code>:</p> <ul style="list-style-type: none"> <li>• <code>--iris-server</code></li> <li>• <code>--iris-allow-remote</code></li> <li>• <code>--iris-port</code></li> <li>• <code>--iris-port-range</code></li> </ul> <p>To set these connection parameters, use:</p> <pre>--iris-connect tcpserver[,port=PORT][,endport=ENDPORT][,allowRemote]</pre> <p>This command starts the TCP server on the first free port in the range <i>PORT-ENDPORT</i>, where the default for <i>PORT</i> is 7100 and the default for <i>ENDPORT</i> is <i>PORT</i> + 63. Only local connections are allowed, unless <i>allowRemote</i> is specified.</p> <p>The other supported connection type is <code>socketfd=FD</code> which uses the socket file descriptor <i>FD</i> as an established UNIX domain socket connection.</p> <p>Use <code>--iris-connect verbose=n</code> to set the logging level of the IrisTcpServer, where <i>n</i> is 0-3.</p> |
| -S         | --cadi-server                    | Start a CADI server. This option allows a CADI-enabled debugger to connect to targets in the simulation. To shut down the server, return to the command window that you used to start the model and press <b>Ctrl+C</b> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| -I         | --iris-server                    | <p>Start an Iris server. This option allows an Iris-enabled debugger to connect to targets in the simulation.</p> <p><b>Note:</b><br/>This option is deprecated. Use <code>--iris-connect</code> instead.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| -R         | --run                            | <p>Run the simulation immediately after the CADI or Iris server is started.</p> <p>Use this option with <code>--cadi-server</code> or <code>--iris-server</code>.</p> <p>The default is to wait until the debugger has connected before running.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| -L         | --cadi-log                       | <p>Log all CADI function calls made during the simulation into XML files.</p> <p>One log file is created for each CADI target. The log files are created in the current working directory.</p> <p>The filename format is:</p> <p><code>CADIlog-&lt;TargetInstanceName&gt;-&lt;ProcessID&gt;.xml</code></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Short form | Long form               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -i         | --iris-log              | <p>Log to stdout all Iris function calls that were made during the simulation.</p> <p>There are 5 possible log levels. To set a level greater than 1, specify the option multiple times, for example <code>--ii</code> for level 2.</p> <p>The log levels have the following meanings:</p> <ul style="list-style-type: none"> <li><b>0</b><br/>Logging is disabled. This value is the default.</li> <li><b>1</b><br/>Log messages use a compact single-line format.</li> <li><b>2</b><br/>Log messages use a single-line pseudo-JSON format.</li> <li><b>3</b><br/>Log messages use a more readable, multi-line pseudo-JSON format.</li> <li><b>4</b><br/>As 3 but also prints the U64JSON hex value of the message.</li> </ul> <p><b>Note:</b><br/>To set the Iris log level for all FVP invocations, use the <code>IRIS_GLOBAL_INSTANCE_LOG_MESSAGES</code> environment variable.</p> |
| -A         | --iris-allow-remote     | <p>Start an Iris server and allow connections to it from a remote workstation.</p> <p>The default is disallowed.</p> <p><b>Note:</b><br/>This option is deprecated. Use <code>--iris-connect</code> instead.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| -p         | --print-port-number     | <p>Print the port number on which the Iris or CADI server is listening.</p> <p>Use this option with <code>--iris-server</code> or <code>--cadi-server</code>.</p> <p><b>Tip:</b><br/>This option can be useful if you need to specify the port number when you connect a client to the debug server.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|            | --iris-port<br><i>n</i> | <p>Set a port to use for the Iris server.</p> <p>Use this option with <code>--iris-server</code>.</p> <p>The default is 7100.</p> <p><b>Note:</b><br/>This option is deprecated. Use <code>--iris-connect</code> instead.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Short form | Long form                           | Description                                                                                                                                                                                                                                                                    |
|------------|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | --iris-port-range<br><i>min:max</i> | <p>Set the range of ports to scan when starting an Iris server. The server uses the first available port in the range.</p> <p>Use this option with <code>--iris-server</code>.</p> <p><b>Note:</b><br/>This option is deprecated. Use <code>--iris-connect</code> instead.</p> |

**Table 3-2: Output-related options**

| Short form | Long form                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | --list-instances         | <p>Print a list of model instances to standard output, then exit the simulation.</p> <p>Use this option to help identify the correct syntax for configuration files, and to find out what instances the target supplies.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| -l         | --list-params            | <p>Print a list of model parameters to standard output, then exit the simulation.</p> <p><b>Tip:</b><br/>If you are loading a plug-in, this option also lists the plug-in parameters.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|            | --dump-params            | Dump the list of model parameters into a JSON file called <code>parameter_list.json</code> , then exit the simulation. The file is created in the current working directory.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|            | --list-reg               | Print model register information to standard output, then exit the simulation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|            | --check-reg              | Same as <code>--list-reg</code> but with extra consistency checks on the CADI register API.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| -o         | --output <i>filename</i> | <p>Redirect output from the <code>--list-instances</code>, <code>--list-memory</code>, <code>--list-params</code>, and <code>--list-reg</code> commands to a file.</p> <p>If this option is used with <code>--list-params</code>, the contents of the output file are formatted correctly for use as input by the <code>--config-file</code> option.</p>                                                                                                                                                                                                                                                                                                        |
|            | --log <i>filename</i>    | Log all SystemC reports into <i>filename</i> .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|            | --stat                   | <p>Print the following performance statistics on simulation exit:</p> <p><b>Simulated time</b><br/>An estimate of the time that the workload would have taken on the modeled hardware.</p> <p><b>User time</b><br/>Time in wall clock seconds that the host CPU spent running in user mode.</p> <p><b>System time</b><br/>Time in wall clock seconds that the host CPU spent running in system mode.</p> <p><b>Wall time</b><br/>Time in wall clock seconds between the simulation starting and stopping.</p> <p><b>Performance index</b><br/>An estimate of the accuracy of the simulation performance. This value is Simulated time divided by Wall time.</p> |
| -P         | --prefix                 | Prefix each line of semihosting output with the name of the target instance.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| -h         | --help                   | Print the help message and exit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|            | --version                | Print version information for the FVP.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| Short form | Long form                | Description                                                                                                       |
|------------|--------------------------|-------------------------------------------------------------------------------------------------------------------|
| -q         | --quiet                  | Suppress informational output.                                                                                    |
| -K         | --keep-console           | Keep the console window open after completion. This option applies to Windows only.                               |
|            | --disable-model-exitcode | Disable the simulation from retrieving the exit code returned by a model or a plug-in. By default, it is enabled. |

**Table 3-3: Run control options**

| Short form | Long form                                   | Description                                                                                                                                                                                                                                                  |
|------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | --cpulimit <i>n</i>                         | Maximum number of wall-clock seconds for the simulation process to be active. This value excludes simulation startup and shutdown.<br><br>This option is ignored if a debug server is started.<br><br>The default is unlimited.                              |
|            | --cyclelimit <i>n</i>                       | Maximum number of cycles to run.<br><br>This option is ignored if a debug server is started.<br><br>The default is unlimited.                                                                                                                                |
| -T         | --timelimit <i>n</i>                        | Maximum number of wall-clock seconds for the simulation to run, excluding startup and shutdown. To terminate the model immediately after initialization, specify --timelimit 0.                                                                              |
|            | --simlimit <i>n</i>                         | Maximum number of seconds to simulate.<br><br>This option is ignored if a debug server is started.<br>The default is unlimited.<br><br>Like the Simulated time value output by --stat, this value is measured in simulation seconds, not wall-clock seconds. |
| -b         | --break [ <i>instance=</i> ] <i>address</i> | Set a program breakpoint on the address of an instruction.<br><br>This option can be specified multiple times.<br><br>If the FVP has multiple cores you must specify an instance, for example:<br><br>-b FVP_Base_AEMvA.cluster0.cpu0=0x800010eC             |

**Table 3-4: Timing and performance options**

| Short form | Long form                   | Description                                                                                                                                        |
|------------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
|            | --cpi-file <i>filename</i>  | Use <i>filename</i> to set the Cycles Per Instruction (CPI) class.<br><br>For information about CPI files, see <a href="#">Timing Annotation</a> . |
| -Q         | --quantum <i>n</i>          | Number of ticks to simulate for each quantum. The default is 10000.                                                                                |
| -M         | --min-sync-latency <i>n</i> | Number of ticks to simulate before synchronizing. Events that occur at a higher frequency than this value are missed. The default is 100.          |
|            | --fast-ram <i>filename</i>  | Enable FastRAM and load the configuration from <i>filename</i> . For more information about FastRAM, see <a href="#">FastRAM</a> .                 |

**Table 3-5: Memory-related options**

| Short form | Long form                          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            | --dump <i>file@address, size</i>   | <p>Dump a section of memory to a file at model shutdown. This option can be specified multiple times. The full syntax is:</p> <pre>.--dump [instance=] <i>file@[memspace:]address, size</i></pre> <p><b>Tip:</b><br/>To see the list of instances and memory spaces, use the <code>--list-memory</code> option.</p>                                                                                                                                                                   |
|            | --data <i>file@address</i>         | <p>Write raw data contained in <i>file</i> to the specified address. This option can be specified multiple times. The full syntax is:</p> <pre>--data [instance=] <i>file@[memspace:]address</i></pre>                                                                                                                                                                                                                                                                                |
|            | --list-memory                      | Print model memory information to standard output, then exit the simulation.                                                                                                                                                                                                                                                                                                                                                                                                          |
|            | --start [instance=] <i>address</i> | <p>Set the initial PC value to this address, overriding the <code>.axf</code> start address.</p> <p><b>Note:</b></p> <ul style="list-style-type: none"> <li>• Use this option if you do not want the CPU to start executing at the default reset address. You do not normally need to do this if you are loading an ELF file using <code>--application</code>.</li> <li>• This option can be used with <code>--data</code> to load binary data that is not in an ELF file.</li> </ul> |

**Table 3-6: Configuration options**

| Short form | Long form                                   | Description                                                                                                                                                                          |
|------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -C         | --parameter <i>instance.parameter=value</i> | <p>Set a parameter. This option can be specified multiple times. Specify the full hierarchical name of the parameter.</p> <p>This option is also used to set plug-in parameters.</p> |
| -f         | --config-file <i>filename</i>               | Load the parameters from a configuration file.                                                                                                                                       |

**Table 3-7: Options for loading a plug-in or application**

| Short form | Long form                                 | Description                                                                                                                                                                                                                                             |
|------------|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| -a         | --application [instance=] <i>filename</i> | <p>Load an application.</p> <p>On a multi-core system, specify the instance, or use * to load the application image into all the cores in a cluster:</p> <pre>-a cluster0.cpu*=file</pre>                                                               |
|            | --plugin <i>filename</i>                  | Load the plug-in <i>filename</i> . This option can be specified multiple times. You can also load plug-ins using the <code>FM_TRACE_PLUGINS</code> environment variable. For information about plug-ins, see <a href="#">Plug-ins for Fast Models</a> . |

| Short form | Long form                         | Description                                                                                           |
|------------|-----------------------------------|-------------------------------------------------------------------------------------------------------|
|            | --trace-plugin<br><i>filename</i> | <p>Load a trace plug-in.</p> <p><b>Note:</b><br/>This option is deprecated. Use --plugin instead.</p> |

### 3.3 Loading and running an application on an FVP

There are different ways to launch an FVP, for example from the command prompt, or from Model Debugger or Arm® Development Studio.

To run an FVP from the command prompt, enter the model name followed by the model options. To see all available options, use the --help option. This is a list of some of the commonly used options for FVPs:

#### **-a [instance=]*filename.axf***

Specifies an application to load, and optionally, the instance or instances to load it on. The file can be in one of the following formats, or in a gzip-compressed version:

- ELF.
- Motorola S-Record.

If the FVP contains multiple core instances, you can specify the instance to load the image on. The instance name can include a wildcard (\*) to load the same application image into multiple cores, for example:

```
./FVP_Base_AEMvA -a cluster0.cpu*=__image.axf
```

Omitting the instance name loads the application on all cores in the first cluster. If the FVP has multiple cores but no clusters, you must specify the instance name.

#### **--data *filename.bin@address***

Loads binary data into memory at the address specified.

#### **-C *instance.parameter=value***

Sets a single model parameter. Parameters are specified using a path that separates the instance names and the parameter using dots. For example, -c *bp.flashloader0.fname=fip.bin*. Here, *bp* and *flashloader0* are instance names and *fname* is the parameter. To set multiple parameters using a configuration file, use the -f option instead. To list all the available parameters, with their type, default value, and description, run the model with the --list-params, or -l option.

#### **-f *config\_file.txt***

Specifies the name of a plain text configuration file. Configuration files simplify managing multiple model parameters. You can set the same parameters using this option as with the -c option.

**-S**

Starts a CADI debug server. This option allows a CADI-enabled debugger, such as Model Debugger or Arm® Development Studio Debugger, to connect to the running model. By default, the model waits for the debugger to connect before starting.

### Related information

[Arm Development Studio Getting Started Guide](#)

[Using Model Debugger](#)

## 3.4 Configuring the model

When you start the model from the command line, you can configure it using either:

- One or more -c command-line arguments.
- A configuration file and the -f command-line argument.

Each -c command-line argument or line in the configuration file must contain:

- The name of the component instance.
- The parameter to modify.
- Its value.

Use the following format:

*instance.parameter=value*

The `instance` can be a hierarchical path, with each level separated by a dot . character.



- Comment lines in the configuration file begin with a # character.
- You can set Boolean values using either `true` or `false`, or 1 or 0.

You can generate a configuration file with all parameters set to default values by using the -o option to redirect the output from the --list-params option, for example:

```
FVP_Base_AEMvA.exe --list-params -o params.txt
```

## 3.5 FVP debug

This section describes how to debug an FVP.

### FVP debug options

To debug an FVP, you can either:

- Run the FVP from within a CADI-enabled debugger.
- Start the FVP with the `-s` command-line argument and then connect a CADI-enabled debugger to it.

For information about using your debugger in these ways, see your debugger documentation.

## Semihosting support

Semihosting enables code running on a platform model to directly access the I/O facilities on a host computer. Examples of these facilities include console I/O and file I/O.

The simulator handles semihosting by intercepting `HLT 0xF000`, `svc 0x123456`, or `svc 0xAB`, depending on whether the processor is in A64, A32 or T32 state. It handles all other `HLTs` and `svcs` as normal.

If the operating system does not use `HLT 0xF000`, `svc 0x123456`, or `svc 0xAB` for its own purposes, it is not necessary to disable semihosting support to boot an operating system.

To temporarily or permanently disable semihosting support for a current debug connection, see your debugger documentation.

## Related information

[Semihosting for AArch32 and AArch64](#)

[Using semihosting to access resources on the host computer](#)

## 3.6 Using the CLCD window

When an FVP starts, the CLCD window opens, representing the contents of the simulated color LCD frame buffer. It automatically resizes to match the horizontal and vertical resolution that is set in the CLCD peripheral registers.

### MPS2 FVPs

The LEDs and MCC switches in the CLCD window for MPS2-based FVPs correspond to the LEDs and switches on the physical board. They are controlled by the software that you load onto the FVP. For information on how to use them, see [User switches and user LEDs](#) in the Arm® MPS2 and MPS2+ FPGA Prototyping Boards TRM on Arm Developer.

### Base Platform and VE FVPs

The top section of the CLCD window for Base Platform and VE FVPs displays the status information:

**Figure 3-1: Base Platform CLCD window in its default state at startup**

## USERSW

Eight white boxes show the state of the User DIP switches.

These represent switch S6 on the VE hardware, USERSW[8:1], which is mapped to bits [7:0] of the SYS\_SW register at address 0x1C010004.

The switches are in the off position by default. To change its state, click in the area above or below a white box.

## BOOTSW

Eight white boxes show the state of the VE Boot DIP switches.

These represent switch S8 on the VE hardware, BOOTSEL[8:1], which is mapped to bits [15:8] of the SYS\_SW register at address 0x1C010004.

The switches are in the off position by default.



**Note** Changing Boot DIP switch positions while the model is running can result in unpredictable behavior.

## S6LED

Eight colored boxes indicate the state of the VE User LEDs.

These represent the red/yellow/green LEDs on the VE hardware, which are mapped to bits [7:0] of the SYS\_LED register at address 0x1C010008.

## Daughter

Eight white boxes show the state of the daughterboard DIP switches and eight colored boxes show the state of the daughterboard LEDs.

## Total Instr

A counter showing the total number of instructions executed.

Because the FVP models provide a *Programmer's View* (PV) of the system, the CLCD displays total instructions rather than total processor cycles. Timing might differ substantially from the hardware because:

- Bus fabric is simplified.

- Memory latencies are minimized.
- Cycle approximate processor and peripheral models are used.

In general, bus transaction timing is consistent with the hardware, but the timing of operations within the model is not accurate.

### Total Time

A counter showing the total elapsed time, in seconds.

This time is wall clock time, not simulated time.

### Rate Limit

A feature that disables or enables fast simulation.

Because the system model is highly optimized, your code might run faster than it would on real hardware. This effect might cause timing issues.

Rate Limit is enabled by default. Simulation time is restricted so that it more closely matches real time.

To disable or enable Rate Limit, click the square button. You can configure this option when instantiating the model with the `rate_limit-enable` visualization component parameter.

When you click the **Total Instr** item in the CLCD, the display toggles to show the following:

#### Instr/sec

The number of instructions that execute per second of wall clock time.

#### Perf Index

The ratio of real time to simulation time. The larger the ratio, the faster the simulation runs. If you enable the Rate Limit feature, the Perf Index approaches unity.

You can reset the simulation counters by resetting the model.

The FVP CLCD displays the core run state for each core on each cluster using a colored icon. The icons are to the left of the **Total Instr** (or **Inst/sec**) item.

**Figure 3-2: Core run state icons for a dual-cluster, quad-core model**



**Table 3-8: Core run state icon descriptions**

| Icon | State label | Description                                                          |
|------|-------------|----------------------------------------------------------------------|
|      | UNKNOWN     | Run status unknown, that is, simulation has not started.             |
|      | RUNNING     | Core running, is not idle, and is executing instructions.            |
|      | HALTED      | External halt signal asserted.                                       |
|      | STANDBY_WFE | Last instruction executed was WFE and standby mode has been entered. |
|      | STANDBY_WFI | Last instruction executed was WFI and standby mode has been entered. |
|      | IN_RESET    | External reset signal asserted.                                      |
|      | DORMANT     | Partial core power down.                                             |
|      | SHUTDOWN    | Complete core power down.                                            |

If the CLCD window has focus:

- Any keyboard input is translated to PS/2 keyboard data.
- Any mouse activity over the window is translated into PS/2 relative mouse motion data. The data is then streamed to the KMI peripheral model FIFOs.



The simulator only sends relative mouse motion events to the model. As a result, the host mouse pointer does not necessarily align with the target OS mouse pointer.

---

You can hide the host mouse pointer by pressing the **left Ctrl+left Alt** keys. Press the keys again to redisplay the host mouse pointer. Only the **left Ctrl** key is operational. The **right Ctrl** key does not have the same effect.

If you prefer to use a different key, configure it with the `trap_key` visualization component parameter.

## Related information

[VEVisualisation component](#)

## 3.7 Ethernet with VE FVPs

This section describes how to use Ethernet with VE FVPs.

### Using Ethernet with VE FVPs

The VE FVPs have a virtual Ethernet component. This component is a model of the SMSC 91C111 Ethernet controller, and uses a TAP device to communicate with the network. By default, the Ethernet component is disabled.

## Host requirements

Before you can use the Ethernet capability of VE FVPs, set up your host computer.

## Target requirements

This section describes the target requirements.

### Target requirements - about

The VE FVPs include a software implementation of the SMSC 91C111 Ethernet controller. Your target OS must therefore include a driver for this specific device. To use the SMSC chip, configure the kernel. Linux supports the SMSC 91C111.

The configurable SMSC 91C111 component parameters are:

- `enabled`.
- `mac_address`.
- `promiscuous`.

#### enabled

When the device is disabled, the kernel cannot detect the device.

**Figure 3-3: Model networking structure block diagram**

To perform read and write operations on the TAP device, configure a HostBridge component. The HostBridge component is a virtual *Programmer's View* (PV) model. It acts as a networking

gateway to exchange Ethernet packets with the TAP device on the host, and to forward packets to NIC models.

#### **mac\_address**

There are two options for the `mac_address` parameter.

If a MAC address is not specified, when the simulator is run it takes the default MAC address, which is randomly generated. This random generation provides some degree of MAC address uniqueness when running models on multiple hosts on a local network.

#### **promiscuous**

The Ethernet component starts in promiscuous mode by default. In this mode, it receives all network traffic, even any not addressed to the device. Use this mode if you are using a single network device for multiple MAC addresses. Use this mode if, for example, you share the network card between your host OS and the VE FVP Ethernet component.

By default, the Ethernet device on the VE FVP has a randomly generated MAC address and starts in promiscuous mode.

## **3.8 Using a terminal with a system model**

The TelnetTerminal component is a virtual component that enables UART data to be transferred between a TCP/IP socket on the host and a serial port on the target.

#### **Using TelnetTerminal**

The following figure shows a block diagram of one possible relationship between the target and host through the TelnetTerminal component. The TelnetTerminal block is what you configure when you define Terminal component parameters. The Virtual Machine is an FVP.

**Figure 3-4: Terminal block diagram**

On the target side, the console process that is invoked by your target OS relies on a suitable driver being present. Such drivers are normally part of the OS kernel. The driver passes serial data through a UART. The data is forwarded to the TelnetTerminal component. When the simulation is started and the TelnetTerminal component is enabled, the component opens a server (listening) socket on a TCP/IP port. This is port 5000 by default. This port can be connected to by, for example, a Telnet process on the host.

When data becomes available on the network socket, the TelnetTerminal component buffers the data, which can then be read from SerialData.

If there is no connection to the network socket when the first data access is made, and the `start_telnet` parameter is true, a host Telnet session is started automatically. Prior to this first access, you can connect a client of your choice to the network socket.

If the connection between the TelnetTerminal component and the client is broken at any time, for example by closing a client Telnet session, the port is re-opened on the host, permitting you to make another client connection. This could have a different port number if the original one is no longer available.

The port number of a particular TelnetTerminal instance can be defined when your model system starts. The actual value of the port used by each TelnetTerminal is declared when it starts or restarts, and might not be the value that you specified if the port is already in use. If you are using Model Shell, the port numbers are displayed in the host window in which you started the model.

---

Microsoft Windows 10 disables the Telnet client by default. Follow these steps to enable it:



1. Select **Start > Settings**.
  2. In the search box, type **Turn Windows features on or off**. The **Windows Features** dialog opens.
  3. Select the **Telnet Client** check box and click **OK**. The installation might take several minutes to complete.
- 

## TelnetTerminal parameters

To set the parameters, the syntax to use in a configuration file or on the command line is:

```
motherboard.terminal_x.parameter=value
```

where `x` is the terminal identifier and can be 0, 1, 2, or 3.

You can start the TelnetTerminal component in either of the following modes, depending on the `mode` parameter:

### **telnet**

In Telnet mode, the terminal component supports a subset of the RFC 854 protocol. This means that the terminal participates in negotiations between the host and client concerning what is and is not supported, but there is no flow control.

### **raw**

In raw mode the byte stream passes unmodified between the host and the target. The terminal does not participate in initial capability negotiations between the host and client. Instead it acts as a TCP/IP port. You can use this feature to directly connect to your target through the TelnetTerminal component. This permits a debugger connection, for example, to connect a gdb client to a gdbserver running on the target operating system.

The `terminal_command` parameter specifies the command line used to launch a terminal application and connect to the opened TCP port. The `TelnetTerminal` component replaces the keywords `%port` and `%title`, if specified, with the opened port number and component name, respectively. After replacing `%port` and `%title`, the command line is executed verbatim.

An empty string, which is the default, launches `xterm` on Linux or `telnet.exe` on Windows.



Note

If you specify a non-empty string, it must include `%port`, but `%title` is optional.

For example:

```
fvp_mps2.telnetterminal0.terminal_command="putty.exe -telnet localhost %port"
```

## 3.9 Virtio P9 device component

The `VirtioP9Device` component is included in Base, BaseR, and A-profile VE platforms. It implements a subset of the Plan 9 file protocol over a virtio transport. It enables accessing a directory on the host's filesystem within Linux, or another operating system that implements the protocol, running on a platform model.

Take the following steps to set up this component:

- Use a version of Linux that supports v9fs over virtio and virtio-mmio devices.
- Update the device tree to include the `VirtioP9Device` component, or specify it on the kernel command-line, as shown below. The address range for both VE and Base platforms is `0x1c140000-0x1c14FFFF`.  
The interrupt number is 43, or IRQ 75, for both VE and Base platforms.
- Set the following parameter to the directory on the host that you want to mount in the model:

**VE:**

```
motherboard.virtiop9device.root_path
```

**Base:**

```
bp.virtiop9device.root_path
```

- On Linux, mount the host directory by using the following command in the model:

```
$ mount -t 9p -o trans=virtio,version=9p2000.L FM <mount point>
```

Example kernel command-line argument:

```
virtio_mmio.device=0x10000@0x1c140000:75
```

Example entry for DTS files, to add next to the corresponding `virtio_block` entry:

```
virtio_p9@0140000 {  
    compatible = "virtio,mmio";  
    reg = <0x0 0x1c140000 0x0 0x1000>;  
    interrupts = <0x0 0x2b 0x4>;  
};
```

# 4. Arm® CoreLink™ SGI-575 reference design FVP

The SGI-575 FVP provides a software model of the Arm® CoreLink™ SGI-575 System Guidance for Infrastructure reference subsystem. It drives system architecture and software standardization and provides software and binaries of proprietary firmware that reduce the amount of work that is required for SoC development.

The FVP is used with the SGI-575 software package.

See the Arm® CoreLink™ SGI-575 System Guidance for Infrastructure Software Bundle Readme for instructions on how to set up and run the FVP.

## 4.1 About the SGI-575 FVP

The SGI-575 Fixed Virtual Platform (FVP) models multiple IP components.



Note

It does not model every component that SGI-575 describes. For example, it does not model the Arm® CoreSight™ technology components.

The FVP models the following IP components:

- 2 × MP4 Cortex®-A75 clusters
- SCP
- MCP
- CMN-600
- Multiple NIC-400 interconnects
- Memory access path towards DRAM

## 4.2 SGI-575 FVP peripherals

The SGI-575 FVP includes peripherals that the software payload requires to run.

These peripherals are organized in two layers:

### SoC

The SoC peripherals represent peripherals that are added to a compute subsystem in a SoC design.

## Board

The board peripherals represent peripherals that are present on the board onto which the SoC is mounted.

### 4.2.1 Memory map for SGI-575 FVP SoC peripherals

This table shows the memory map for the SoC peripherals in the SGI-575 FVP.

**Table 4-1: SoC peripherals**

| Name                          | Base address   | Size  | Description     |
|-------------------------------|----------------|-------|-----------------|
| SMC interface                 | 0x00_0800_0000 | 368MB | Routed to Board |
| DMA MMU-400                   | 0x00_7FB0_0000 | 64KB  | -               |
| HDLCD1 MMU-400                | 0x00_7FB1_0000 | 64KB  | -               |
| HDLCD0 MMU-400                | 0x00_7FB2_0000 | 64KB  | -               |
| SoC Interconnect NIC400 GPV   | 0x00_7FD0_0000 | 1MB   | -               |
| Surge detector                | 0x00_7FE5_0000 | 4KB   | Dummy APB       |
| TRNG                          | 0x00_7FE6_0000 | 4KB   | -               |
| Trusted Non-volatile counters | 0x00_7FE7_0000 | 4KB   | -               |
| Trusted Root-Key storage      | 0x00_7FE8_0000 | 4KB   | -               |
| Secure I2C                    | 0x00_7FE9_0000 | 256B  | PL061 GPIO      |
| DDR4 PHY 1                    | 0x00_7FB7_0000 | 64KB  | Dummy APB       |
| DDR4 PHY 0                    | 0x00_7FB6_0000 | 64KB  | Dummy APB       |
| DMA Non-secure                | 0x00_7FF0_0000 | 4KB   | -               |
| DMA Secure                    | 0x00_7FF1_0000 | 4KB   | -               |
| HDCLD1                        | 0x00_7FF5_0000 | 4KB   | -               |
| HDCLD1                        | 0x00_7FF6_0000 | 4KB   | -               |
| UART 1                        | 0x00_7FF7_0000 | 4KB   | -               |
| UART 0                        | 0x00_7FF8_0000 | 4KB   | -               |
| I2S                           | 0x00_7FF9_0000 | 1KB   | PL061 GPIO      |
| I2C                           | 0x00_7FFA_0000 | 256B  | PL061 GPIO      |
| PL352                         | 0x00_7FFD_0000 | 4KB   | PL354           |
| System override Registers     | 0x00_7FFF_0000 | 4KB   | -               |
| AP configuration              | 0x00_7FFE_0000 | 4KB   | GPR             |

## 4.2.2 Memory map for SGI-575 FVP board peripherals

This table shows the memory map for the board peripherals in the SGI-575 FVP.

**Table 4-2: Board peripherals**

| Name                | Base address   | Size | Description |
|---------------------|----------------|------|-------------|
| NOR Flash 0         | 0x00_0800_0000 | 64MB | -           |
| NOR Flash 1         | 0x00_0C00_0000 | 64MB | -           |
| NOR Flash 2         | 0x00_1000_0000 | 64MB | -           |
| Ethernet            | 0x00_1800_0000 | 64MB | SMSC 91C111 |
| System Registers    | 0x00_1C01_0000 | 64KB | -           |
| MCI                 | 0x00_1C05_0000 | 64KB | PL180       |
| KMI 0               | 0x00_1C06_0000 | 64KB | PL050       |
| KMI 1               | 0x00_1C07_0000 | 64KB | PL050       |
| UART 0              | 0x00_1C09_0000 | 64KB | PL011       |
| UART 1              | 0x00_1C0A_0000 | 64KB | PL011       |
| VFS2                | 0x00_1C0D_0000 | 64KB | -           |
| Watchdog            | 0x00_1C0F_0000 | 64KB | SP805       |
| Dual Timer          | 0x00_1C11_0000 | 64KB | SP084       |
| Virtio Block Device | 0x00_1C13_0000 | 64KB | -           |
| RTC                 | 0x00_1C17_0000 | 64KB | PL031       |
| GPIO 0              | 0x00_1C1D_0000 | 64KB | -           |
| GPIO 1              | 0x00_1C1E_0000 | 64KB | -           |
| DRAM                | 0x00_8000_0000 | 2GB  | -           |
| DRAM                | 0x80_8000_0000 | 6GB  | -           |

## 4.2.3 Interrupt maps for SGI-575 FVP

These tables show the interrupt IDs and sources for the FVP peripherals.

**Table 4-3: Interrupt map at the SoC layer**

| Interrupt ID | Source | Description |
|--------------|--------|-------------|
| 147          | UART 0 | -           |
| 148          | UART 1 | -           |
| 171          | TRNG   | -           |

**Table 4-4: Interrupt map at the board layer**

| Interrupt ID | Source   | Description |
|--------------|----------|-------------|
| 111          | Ethernet | -           |
| 132          | RTC      | -           |
| 133          | UART 0   | -           |

| Interrupt ID | Source                        | Description        |
|--------------|-------------------------------|--------------------|
| 134          | UART 1                        | -                  |
| 140          | VFS2                          | -                  |
| 202          | Virtio                        | -                  |
| 228          | Watchdog                      | -                  |
| 229          | KMI 0                         | -                  |
| 230          | Dual Timer                    | Interrupts 0 and 1 |
| 231          | System Registers Ethernet IRQ | -                  |

## 5. Arm® Corstone™ SSE-300 FVP

To develop ahead of hardware availability and to explore the design from a software perspective, the Corstone™ SSE-300 Fixed Virtual Platform (FVP) models much of the Arm® IP in the Corstone™ SSE-300 subsystem version r0p1.

The Corstone™ SSE-300 FVP drives system architecture and software standardization. It is used with the Corstone™ SSE-300 software package which provides software and binaries of proprietary firmware that reduce the amount of work that is required for SoC development. See the Corstone™ SSE-300 software bundle readme for instructions on how to set up and run the FVP.

The FVP models the following IP components:

- A single Arm® Cortex®-M55 processor with the MVE extension.
- A single Arm® Ethos™-U55 or Ethos™-U65 processor.
- Memory Protection Controller (MPC).
- Peripheral Protection Controller (PPC).
- Implementation Defined Attribution Unit (IDAU).

The full description of components that are internal to the SSE-300 subsystem can be found in the [Arm Corstone SSE-300 Example Subsystem Technical Reference Manual](#).

The FVP has the following limitations:

- It does not model every component that Corstone™ SSE-300 describes. For example, it does not model the CoreSight™ technology components.
- QSPI is not modeled. It has QSPI SRAM instead.
- Some components are dummy stubs with a minimal implementation. Models with dummy APB have memory access.
- Some components are partially modeled.

Refer to the following documents for more information:

- [Arm Corstone SSE-300 Example Subsystem Technical Reference Manual](#)
- [Arm MPS3 FPGA Prototyping Board Technical Reference Manual](#)
- [Corstone-300 on Arm Developer](#)

### 5.1 Memory map overview for Corstone™ SSE-300

This table outlines the main FVP memories and their positions within the memory map.

This memory map includes IDAU security information for memory regions.

**Table 5-1: Memory map overview**

| Row ID | Address range |             | Size   | Description                                                | Alias with Row ID | IDAU region values |        |          |
|--------|---------------|-------------|--------|------------------------------------------------------------|-------------------|--------------------|--------|----------|
|        | From          | To          |        |                                                            |                   | Security           | IDAUID | NSC      |
| 1      | 0x0000_0000   | 0x0007_FFFF | 512KB  | ITCM <sup>3</sup>                                          | 5                 | NS                 | 0      | 0        |
| 2      | 0x0008_0000   | 0x00FF_FFFF | 15.5MB | Reserved                                                   | -                 |                    |        |          |
| 3      | 0x0100_0000   | 0x010F_FFFF | 1MB    | SRAM (only 1MB) <sup>1</sup>                               | 7                 |                    |        |          |
| 4      | 0x0110_0000   | 0x0FFF_FFFF | 239MB  | Reserved                                                   | -                 |                    |        |          |
| 5      | 0x1000_0000   | 0x1007_FFFF | 512KB  | ITCM <sup>3</sup>                                          | 1                 | S                  | 1      | CODE NSC |
| 6      | 0x1008_0000   | 0x10FF_FFFF | 15.5MB | Reserved                                                   | -                 |                    |        |          |
| 7      | 0x1100_0000   | 0x110F_FFFF | 1MB    | SRAM (only 1MB) <sup>1</sup>                               | 3                 |                    |        |          |
| 8      | 0x1110_0000   | 0x1FFF_FFFF | 239MB  | Reserved                                                   | -                 |                    |        |          |
| 9      | 0x2000_0000   | 0x2007_FFFF | 512KB  | DTCM (4 x banks of 128KB) <sup>3</sup>                     | 15                | NS                 | 2      | 0        |
| 10     | 0x2008_0000   | 0x20FF_FFFF | 15.5MB | Reserved                                                   | -                 | -                  | -      | -        |
| 11     | 0x2100_0000   | 0x211F_FFFF | 2MB    | Internal SRAM area (SSE-300 implements 2x1MB) <sup>3</sup> | 17                | -                  | -      | -        |
| 12     | 0x2120_0000   | 0x27FF_FFFF | 110MB  | Reserved                                                   | -                 | -                  | -      | -        |
| 13     | 0x2800_0000   | 0x287F_FFFF | 8MB    | QSPI (only 8MB) <sup>1</sup>                               | 19                | -                  | -      | -        |
| 14     | 0x2880_0000   | 0x2FFF_FFFF | 120MB  | Reserved                                                   | -                 | -                  | -      | -        |
| 15     | 0x3000_0000   | 0x3007_FFFF | 512KB  | DTCM (4 x banks of 128KB) <sup>3</sup>                     | 9                 | S                  | 3      | RAM NSC  |
| 16     | 0x3008_0000   | 0x30FF_FFFF | 15.5MB | Reserved                                                   | -                 | -                  | -      | -        |
| 17     | 0x3100_0000   | 0x311F_FFFF | 2MB    | Internal SRAM area (SSE-300 implements 2x1MB) <sup>3</sup> | 11                | -                  | -      | -        |
| 18     | 0x3120_0000   | 0x37FF_FFFF | 110MB  | Reserved                                                   | -                 | -                  | -      | -        |
| 19     | 0x3800_0000   | 0x387F_FFFF | 8MB    | QSPI (only 8MB) <sup>1</sup>                               | 13                | -                  | -      | -        |
| 20     | 0x3880_0000   | 0x3FFF_FFFF | 120MB  | Reserved                                                   | -                 | -                  | -      | -        |
| 21     | 0x4000_0000   | 0x47FF_FFFF | 128MB  | Non-Secure Low Latency Peripheral Region.                  | 23                | NS                 | 4      | 0        |
| 22     | 0x4800_0000   | 0x4FFF_FFFF | 128MB  | Non-Secure High Latency Peripheral Region.                 | 24                | NS                 | 4      | 0        |
| 23     | 0x5000_0000   | 0x57FF_FFFF | 128MB  | Secure Low Latency Peripheral Region.                      | 21                | S                  | 5      | 0        |
| 24     | 0x5800_0000   | 0x5FFF_FFFF | 128MB  | Secure High Latency Peripheral Region.                     | 22                | S                  | 5      | 0        |
| 25     | 0x6000_0000   | 0x6FFF_FFFF | 256MB  | DDR4 <sup>1</sup>                                          | -                 | NS                 | 6      | 0        |
| 26     | 0x7000_0000   | 0x7FFF_FFFF | 256MB  | DDR4 <sup>1</sup>                                          | -                 | S                  | 7      | 0        |
| 27     | 0x8000_0000   | 0x8FFF_FFFF | 256MB  | DDR4 <sup>1</sup>                                          | -                 | NS                 | 8      | 0        |
| 28     | 0x9000_0000   | 0x9FFF_FFFF | 256MB  | DDR4 <sup>1</sup>                                          | -                 | S                  | 9      | 0        |
| 29     | 0xA000_0000   | 0xAF00_FFFF | 256MB  | DDR4 <sup>1</sup>                                          | -                 | NS                 | A      | 0        |
| 30     | 0xB000_0000   | 0xBFFF_FFFF | 256MB  | DDR4 <sup>1</sup>                                          | -                 | S                  | B      | 0        |
| 31     | 0xC000_0000   | 0xCFFF_FFFF | 256MB  | DDR4 <sup>1</sup>                                          | -                 | NS                 | C      | 0        |

| Row ID | Address range |             | Size  | Description                                          | Alias with Row ID | IDAU region values |        |     |
|--------|---------------|-------------|-------|------------------------------------------------------|-------------------|--------------------|--------|-----|
|        | From          | To          |       |                                                      |                   | Security           | IDAUID | NSC |
| 32     | 0xD000_0000   | 0xDFFF_FFFF | 256MB | DDR4 <sup>1</sup>                                    | -                 | S                  | D      | 0   |
| 33     | 0xE000_0000   | 0xE00F_FFFF | 1MB   | External Private Peripheral Bus                      | -                 | -                  | Exempt | -   |
| 34     | 0xE010_0000   | 0xE01F_FFFF | 1MB   | Reserved                                             | -                 | NS                 | E      | 0   |
| 35     | 0xE020_0000   | 0xEFFF_FFFF | 254MB | Maps to HMSTEXPPILL expansion interface <sup>2</sup> | -                 | NS                 | E      | 0   |
| 36     | 0xF000_0000   | 0xF00F_FFFF | 1MB   | Reserved                                             | -                 | -                  | Exempt | -   |
| 37     | 0xF010_0000   | 0xF01F_FFFF | 1MB   | Reserved                                             | -                 | S                  | F      | 0   |
| 38     | 0xF020_0000   | 0xFFFF_FFFF | 254MB | Maps to HMSTEXPPILL expansion interface <sup>2</sup> | -                 | S                  | F      | 0   |

## 5.2 Corstone™ SSE-300 FVP peripherals

The Corstone™ SSE-300 FVP includes peripherals that the software payload requires to run.

Board peripherals are peripherals that might be present on the board onto which the SoC is mounted. The Corstone™ SSE-300 board model is based on the Arm® MPS3 board.



Some of the MPS3 Fast Models have minimal implementations. For more information, refer to the documents in the FVP package.

All peripherals that are extensions to the Corstone™ SSE-300 subsystem are mapped into two key areas of the memory map:

### **0x4000\_0000 to 0x47FF\_FFFF and 0x4800\_0000 to 0x4FFF\_FFFF**

Non-secure region that maps to AHB Master Expansion 1 interface.

### **0x5000\_0000 to 0x57FF\_FFFF and 0x5800\_0000 to 0x5FFF\_FFFF**

Secure region that maps to AHB Master Expansion 1 interface.

<sup>1</sup> Security access is controlled by MPC.

<sup>2</sup> Accesses to these addresses result in an AHB5 error response.

<sup>3</sup> For security settings, control, and features, refer to the Arm® Corstone™ SSE-300 documentation.

## 5.2.1 Corstone™ SSE-300 non-secure expansion peripherals memory map

Memory map for non-secure board peripherals.

**Table 5-2: Non-secure board peripherals**

| Row ID | Address range in non-secure region |             | Size  | Description              | Modeled in FVP                 |
|--------|------------------------------------|-------------|-------|--------------------------|--------------------------------|
|        | From                               | To          |       |                          |                                |
| 1      | 0x4110_0000                        | 0x4110_0FFF | 4KB   | GPIO 0                   | CMSDK GPIO                     |
| 2      | 0x4110_1000                        | 0x4110_1FFF | 4KB   | GPIO 1                   | CMSDK GPIO                     |
| 3      | 0x4110_2000                        | 0x4110_2FFF | 4KB   | GPIO 2                   | CMSDK GPIO                     |
| 4      | 0x4110_3000                        | 0x4110_3FFF | 4KB   | GPIO 3                   | CMSDK GPIO                     |
| 5      | 0x4110_4000                        | 0x4110_4FFF | 4KB   | FMC GPIO 0               | CMSDK GPIO                     |
| 6      | 0x4110_5000                        | 0x4110_5FFF | 4KB   | FMC GPIO 1               | CMSDK GPIO                     |
| 7      | 0x4110_6000                        | 0x4110_6FFF | 4KB   | FMC GPIO 2               | CMSDK GPIO                     |
| 8      | 0x4110_7000                        | 0x4110_7FFF | 4KB   | FMC USER AHB             | Not modeled                    |
| -      | 0x4110_8000                        | 0x411F_FFFF | -     | Reserved                 | -                              |
| 9      | 0x4120_0000                        | 0x4120_0FFF | 4KB   | USER AHB 0               | Not modeled                    |
| 10     | 0x4120_1000                        | 0x4120_1FFF | 4KB   | USER AHB 1               | Not modeled                    |
| 11     | 0x4120_2000                        | 0x4120_2FFF | 4KB   | USER AHB 2               | Not modeled                    |
| 12     | 0x4120_3000                        | 0x4120_3FFF | 4KB   | USER AHB 3               | Not modeled                    |
| -      | 0x4120_4000                        | 0x413F_FFFF | -     | Reserved                 | -                              |
| 13     | 0x4140_0000                        | 0x414F_FFFF | 1MB   | Ethernet                 | SMSC91C111 Ethernet controller |
| 14     | 0x4150_0000                        | 0x415F_FFFF | 1MB   | USB                      | Dummy stub                     |
| -      | 0x4160_0000                        | 0x416F_FFFF | -     | Reserved                 | -                              |
| 15     | 0x4170_0000                        | 0x4170_0FFF | 4KB   | User APB0                | Not modeled                    |
| 16     | 0x4170_1000                        | 0x4170_1FFF | 4KB   | User APB1                | Not modeled                    |
| 17     | 0x4170_2000                        | 0x4170_2FFF | 4KB   | User APB2                | Not modeled                    |
| 18     | 0x4170_3000                        | 0x4170_3FFF | 4KB   | User APB3                | Not modeled                    |
| -      | 0x4170_4000                        | 0x417F_FFFF | -     | Reserved                 | -                              |
| 19     | 0x4180_0000                        | 0x4180_0FFF | 4KB   | QSPI Config              | Not modeled                    |
| 20     | 0x4180_1000                        | 0x4180_1FFF | 4KB   | QSPI Write               | Not modeled                    |
| -      | 0x4180_2000                        | 0x47FF_FFFF | -     | Reserved                 | -                              |
| -      | 0x4800_0000                        | 0x480F_FFFF | -     | Subsystem peripherals    | -                              |
| 21     | 0x4810_2000                        | 0x4810_2FFF | 4KB   | Ethos-U55 APB            | Modeled                        |
| 22     | 0x4810_3000                        | 0x4810_31FF | 0.5KB | U55 timing adapter 0 APB | Modeled                        |
| 23     | 0x4810_3200                        | 0x4810_33FF | 0.5KB | U55 timing adapter 1 APB | Modeled                        |
| -      | 0x4810_3400                        | 0x491F_FFFF | -     | Reserved                 | -                              |

| Row ID | Address range in non-secure region |             | Size | Description                    | Modeled in FVP    |
|--------|------------------------------------|-------------|------|--------------------------------|-------------------|
|        | From                               | To          |      |                                |                   |
| 24     | 0x4920_0000                        | 0x4920_0FFF | 4KB  | FPGA - SBCon I2C (Touch)       | Partially modeled |
| 25     | 0x4920_1000                        | 0x4920_1FFF | 4KB  | FPGA - SBCon I2C (Audio Conf)  | Dummy stub        |
| 26     | 0x4920_2000                        | 0x4920_2FFF | 4KB  | FPGA - PL022 (SPI ADC)         | Dummy stub        |
| 27     | 0x4920_3000                        | 0x4920_3FFF | 4KB  | FPGA - PL022 (SPI Shield0)     | Dummy stub        |
| 28     | 0x4920_4000                        | 0x4920_4FFF | 4KB  | FPGA - PL022 (SPI Shield1)     | Dummy stub        |
| 29     | 0x4920_5000                        | 0x4920_5FFF | 4KB  | SBCon (I2C - Shield0)          | Dummy stub        |
| 30     | 0x4920_6000                        | 0x4920_6FFF | 4KB  | SBCon (I2C - Shield1)          | Dummy stub        |
| 31     | 0x4920_7000                        | 0x4920_7FFF | 4KB  | USER APB                       | Dummy stub        |
| 32     | 0x4920_8000                        | 0x4920_8FFF | 4KB  | FPGA - SBCon I2C (DDR4 EEPROM) | Dummy stub        |
| -      | 0x4920_9000                        | 0x492F_FFFF | -    | Reserved                       | -                 |
| 33     | 0x4930_0000                        | 0x4930_0FFF | 4KB  | FPGA - SCC registers           | Modeled           |
| 34     | 0x4930_1000                        | 0x4930_1FFF | 4KB  | FPGA - I2S (Audio)             | Partially modeled |
| 35     | 0x4930_2000                        | 0x4930_2FFF | 4KB  | FPGA - IO (System Ctrl + I/O)  | Modeled           |
| 36     | 0x4930_3000                        | 0x4930_3FFF | 4KB  | UART0 - UART_F [0]             | CMSDK UART        |
| 37     | 0x4930_4000                        | 0x4930_4FFF | 4KB  | UART1 - UART_F [1]             | CMSDK UART        |
| 38     | 0x4930_5000                        | 0x4930_5FFF | 4KB  | UART2 - UART_F [2]             | CMSDK UART        |
| 39     | 0x4930_6000                        | 0x4930_6FFF | 4KB  | UART3 - UART Shield 0          | Dummy stub        |
| 40     | 0x4930_7000                        | 0x4930_7FFF | 4KB  | UART4 - UART Shield 1          | Dummy stub        |
| 41     | 0x4930_8000                        | 0x4930_8FFF | 4KB  | UART5 - UART_F [3]             | CMSDK UART        |
| 42     | 0x4930_9000                        | 0x4930_9FFF | 4KB  | Reserved                       |                   |
| 43     | 0x4930_A000                        | 0x4930_AFFF | 4KB  | CLCD Config Reg                | Partially modeled |
| 44     | 0x4930_B000                        | 0x4930_BFFF | 4KB  | RTC                            | PL031_RTC         |

## 5.2.2 Corstone™ SSE-300 secure expansion peripherals memory map

Memory map for secure board peripherals.

**Table 5-3: Secure board peripherals**

| Row ID | Address range in secure region |             | Size | Description | Modeled in FVP |
|--------|--------------------------------|-------------|------|-------------|----------------|
|        | From                           | To          |      |             |                |
| 1      | 0x5110_0000                    | 0x5110_0FFF | 4KB  | GPIO 0      | CMSDK GPIO     |

| Row ID | Address range in secure region |             | Size  | Description                             | Modeled in FVP                 |
|--------|--------------------------------|-------------|-------|-----------------------------------------|--------------------------------|
|        | From                           | To          |       |                                         |                                |
| 2      | 0x5110_1000                    | 0x5110_1FFF | 4KB   | GPIO 1                                  | CMSDK GPIO                     |
| 3      | 0x5110_2000                    | 0x5110_2FFF | 4KB   | GPIO 2                                  | CMSDK GPIO                     |
| 4      | 0x5110_3000                    | 0x5110_3FFF | 4KB   | GPIO 3                                  | CMSDK GPIO                     |
| 5      | 0x5110_4000                    | 0x5110_4FFF | 4KB   | FMC GPIO 0                              | CMSDK GPIO                     |
| 6      | 0x5110_5000                    | 0x5110_5FFF | 4KB   | FMC GPIO 1                              | CMSDK GPIO                     |
| 7      | 0x5110_6000                    | 0x5110_6FFF | 4KB   | FMC GPIO 2                              | CMSDK GPIO                     |
| 8      | 0x5110_7000                    | 0x5110_7FFF | 4KB   | FMC USER AHB                            | Not modeled                    |
|        | 0x5110_8000                    | 0x511F_FFFF |       | Reserved                                |                                |
| 9      | 0x5120_0000                    | 0x5120_0FFF | 4KB   | USER AHB 0                              | Not modeled                    |
| 10     | 0x5120_1000                    | 0x5120_1FFF | 4KB   | USER AHB 1                              | Not modeled                    |
| 11     | 0x5120_2000                    | 0x5120_2FFF | 4KB   | USER AHB 2                              | Not modeled                    |
| 12     | 0x5120_3000                    | 0x5120_3FFF | 4KB   | USER AHB 3                              | Not modeled                    |
|        | 0x5120_4000                    | 0x513F_FFFF |       | Reserved                                |                                |
| 13     | 0x5140_0000                    | 0x514F_FFFF | 1MB   | Ethernet                                | SMSC91C111 Ethernet controller |
| 14     | 0x5150_0000                    | 0x515F_FFFF | 1MB   | USB                                     | Dummy stub                     |
|        | 0x5160_0000                    | 0x516F_FFFF |       | Reserved                                |                                |
| 15     | 0x5170_0000                    | 0x5170_0FFF | 4KB   | User APB0                               | Not modeled                    |
| 16     | 0x5170_1000                    | 0x5170_1FFF | 4KB   | User APB1                               | Not modeled                    |
| 17     | 0x5170_2000                    | 0x5170_2FFF | 4KB   | User APB2                               | Not modeled                    |
| 18     | 0x5170_3000                    | 0x5170_3FFF | 4KB   | User APB3                               | Not modeled                    |
|        | 0x5170_4000                    | 0x517F_FFFF |       | Reserved                                |                                |
| 19     | 0x5180_0000                    | 0x5180_0FFF | 4KB   | QSPI Config                             | Not modeled                    |
| 20     | 0x5180_1000                    | 0x5180_1FFF | 4KB   | QSPI Write                              | Not modeled                    |
|        | 0x5180_2000                    | 0x56FF_FFFF |       | Reserved                                |                                |
| 21     | 0x5700_0000                    | 0x5700_0FFF | 4KB   | SRAM Memory Protection Controller (MPC) | Modeled                        |
| 22     | 0x5700_1000                    | 0x5700_1FFF | 4KB   | QSPI Memory Protection Controller (MPC) | Modeled                        |
| 23     | 0x5700_2000                    | 0x5700_2FFF | 4KB   | DDR4 Memory Protection Controller (MPC) | Modeled                        |
|        | 0x5700_3000                    | 0x57FF_FFFF |       | Reserved                                |                                |
|        | 0x5800_0000                    | 0x580F_FFFF |       | Subsystem peripherals                   |                                |
| 24     | 0x5810_2000                    | 0x5810_2FFF | 4KB   | Ethos-U55 APB                           | Modeled                        |
| 25     | 0x5810_3000                    | 0x5810_31FF | 0.5KB | U55 timing adapter 0 APB                | Modeled                        |

| Row ID | Address range in secure region |             | Size  | Description                   | Modeled in FVP    |
|--------|--------------------------------|-------------|-------|-------------------------------|-------------------|
|        | From                           | To          |       |                               |                   |
| 26     | 0x5810_3200                    | 0x5810_33FF | 0.5KB | U55 timing adapter 1 APB      | Modeled           |
|        | 0x5810_3400                    | 0x591F_FFFF |       | Reserved                      |                   |
| 27     | 0x5920_4000                    | 0x5920_4FFF | 4KB   | FPGA - PL022 (SPI Shield1)    | Dummy stub        |
| 28     | 0x5920_5000                    | 0x5920_5FFF | 4KB   | SBCOn (I2C - Shield0)         | Dummy stub        |
| 29     | 0x5920_6000                    | 0x5920_6FFF | 4KB   | SBCOn (I2C – Shield1)         | Dummy stub        |
| 30     | 0x5920_7000                    | 0x5920_7FFF | 4KB   | USER APB                      | Dummy stub        |
| 31     | 0x5920_8000                    | 0x5920_8FFF | 4KB   | DDR4 EEPROM                   | Dummy stub        |
|        | 0x5920_9000                    | 0x592F_FFFF |       | Reserved                      |                   |
| 32     | 0x5930_0000                    | 0x5930_0FFF | 4KB   | FPGA - SCC registers          | Modeled           |
| 33     | 0x5930_1000                    | 0x5930_1FFF | 4KB   | FPGA - I2S (Audio)            | Partially modeled |
| 34     | 0x5930_2000                    | 0x5930_2FFF | 4KB   | FPGA - IO (System Ctrl + I/O) | Modeled           |
| 35     | 0x5930_3000                    | 0x5930_3FFF | 4KB   | UART0 - UART_F [0]            | CMSDK UART        |
| 36     | 0x5930_4000                    | 0x5930_4FFF | 4KB   | UART1 - UART_F [1]            | CMSDK UART        |
| 37     | 0x5930_5000                    | 0x5930_5FFF | 4KB   | UART2 - UART_F [2]            | CMSDK UART        |
| 38     | 0x5930_6000                    | 0x5930_6FFF | 4KB   | UART3 - UART Shield 0         | Dummy stub        |
| 39     | 0x5930_7000                    | 0x5930_7FFF | 4KB   | UART4 - UART Shield 1         | Dummy stub        |
| 40     | 0x5930_8000                    | 0x5930_8FFF | 4KB   | UART5 - UART_F [3]            | CMSDK UART        |
|        | 0x5930_9000                    | 0x5930_9FFF | 4KB   | Reserved                      |                   |
| 41     | 0x5930_A000                    | 0x5930_AFFF | 4KB   | CLCD Config Reg               | Partially modeled |
| 42     | 0x5930_B000                    | 0x5930_BFFF | 4KB   | RTC                           | PL031_RTC         |

### 5.2.3 Corstone™ SSE-300 expansion peripheral interrupt map

Interrupt map at the board layer.

**Table 5-4: Interrupt map at the board layer**

| Interrupt input | Interrupt source                                     |
|-----------------|------------------------------------------------------|
| IRQ [32]        | System timestamp counter interrupt. Not implemented. |
| IRQ [33]        | UART 0 receive interrupt.                            |
| IRQ [34]        | UART 0 transmit Interrupt.                           |
| IRQ [35]        | UART 1 receive interrupt.                            |
| IRQ [36]        | UART 1 transmit interrupt.                           |
| IRQ [37]        | UART 2 receive interrupt.                            |
| IRQ [38]        | UART 2 transmit interrupt.                           |

| Interrupt input | Interrupt source                      |
|-----------------|---------------------------------------|
| IRQ [39]        | UART 3 receive interrupt.             |
| IRQ [40]        | UART 3 transmit interrupt.            |
| IRQ [41]        | UART 4 receive interrupt.             |
| IRQ [42]        | UART 4 transmit interrupt.            |
| IRQ [43]        | UART 0 combined interrupt.            |
| IRQ [44]        | UART 1 combined interrupt.            |
| IRQ [45]        | UART 2 combined interrupt.            |
| IRQ [46]        | UART 3 combined interrupt.            |
| IRQ [47]        | UART 4 combined interrupt.            |
| IRQ [48]        | UART overflow (0, 1, 2, 3, 4, and 5). |
| IRQ [49]        | Ethernet.                             |
| IRQ [50]        | Audio I2S.                            |
| IRQ [51]        | Touch screen.                         |
| IRQ [52]        | USB.                                  |
| IRQ [53]        | SPI ADC.                              |
| IRQ [54]        | SPI (shield 0).                       |
| IRQ [55]        | SPI (shield 1).                       |
| IRQ [56]        | Ethos-U interrupt.                    |
| IRQ [68:57]     | Reserved.                             |
| IRQ [69]        | GPIO 0 combined interrupt.            |
| IRQ [70]        | GPIO 1 combined interrupt.            |
| IRQ [71]        | GPIO 2 combined interrupt.            |
| IRQ [72]        | GPIO 3 combined interrupt.            |
| IRQ [88:73]     | GPIO 0 individual interrupts.         |
| IRQ [104:89]    | GPIO 1 individual interrupts.         |
| IRQ [120:105]   | GPIO 2 individual interrupts.         |
| IRQ [124:121]   | GPIO 3 individual interrupts.         |
| IRQ [125]       | UART 5 receive interrupt.             |
| IRQ [126]       | UART 5 transmit interrupt.            |
| IRQ [127]       | UART 5 combined interrupt.            |
| IRQ [130:128]   | Reserved.                             |

## 5.3 Corstone™ SSE-300 peripheral protection controller expansion map

The Corstone™ SSE-300 FVP implements secure access configuration registers which control security and privileged accesses to peripherals connected to PPC.

**Table 5-5: Secure access configuration registers - PPC bits**

| Bit         | MAIN_PPCEXP0 (AHB0) | MAIN_PPCEXP1 (AHB1) | PERIPH_PPCEXP0 (APB0) | PERIPH_PPCEXP1 (APB1)         | PERIPH_PPCEXP2 (APB2)           |
|-------------|---------------------|---------------------|-----------------------|-------------------------------|---------------------------------|
| 0           | GPIO-0              | User AHB 0          | -                     | SBCOn I2C (touch screen)      | FPGA - SCC registers            |
| 1           | GPIO-1              | User AHB 1          | -                     | SBCOn I2C (audio conf)        | FPGA - I2S (audio)              |
| 2           | GPIO-2              | User AHB 2          | -                     | FPGA PL022 (SPI2 for ADC)     | FPGA - GPIO (System Ctrl + I/O) |
| 3           | GPIO-3              | User AHB 3          | -                     | FPGA PL022 (SPI Shield0)      | UART0                           |
| 4           | FMC GPIO-0          | -                   | NPU APB0              | FPGA PL022 (SPI Shield1)      | UART1                           |
| 5           | FMC GPIO-1          | -                   | NPU APB1              | FPGA SBCOn (I2C - Shield0)    | UART2                           |
| 6           | FMC GPIO-2          | -                   | -                     | FPGA SBCOn (I2C - Shield1)    | UART3 STUB                      |
| 7           | FMC User AHB        | -                   | -                     | Reserved                      | UART4 STUB                      |
| 8           | USB and Ethernet    | -                   | -                     | FPGA – SBCOn I2C (DDR4 EPROM) | UART5                           |
| 9           | -                   | -                   | -                     | -                             | Reserved                        |
| 10          | -                   | -                   | -                     | -                             | CLCD config reg                 |
| 11          | -                   | -                   | -                     | -                             | RTC                             |
| 12          | -                   | -                   | -                     | -                             | -                               |
| 13          | -                   | -                   | SRAM MPC              | -                             | -                               |
| 14          | -                   | -                   | QSPI MPC              | -                             | -                               |
| 15          | -                   | -                   | DDR MPC               | -                             | -                               |
| PPC IRQ no. | 5                   | 6                   | 2                     | 3                             | 4                               |

## 5.4 Corstone™ SSE-300 memory components

The Corstone™ SSE-300 FVP includes the following memory components and their security access is controlled by the MPC.

**Table 5-6: Memory components**

| Name      | Non-secure address range  | Secure alias              | Size  |
|-----------|---------------------------|---------------------------|-------|
| SRAM      | 0x0100_0000 - 0x010F_FFFF | 0x1100_0000 - 0x110F_FFFF | 1MB   |
| QSPI SRAM | 0x2800_0000 - 0x287F_FFFF | 0x3800_0000 - 0x387F_FFFF | 8MB   |
| DDR0      | 0x6000_0000 - 0x6FFF_FFFF | 0x7000_0000 - 0x7FFF_FFFF | 256MB |
| DDR1      | 0x8000_0000 - 0x8FFF_FFFF | 0x9000_0000 - 0x9FFF_FFFF | 256MB |

| Name | Non-secure address range  | Secure alias              | Size  |
|------|---------------------------|---------------------------|-------|
| DDR2 | 0xA000_0000 - 0xAFFF_FFFF | 0xB000_0000 - 0xBFFF_FFFF | 256MB |
| DDR3 | 0xC000_0000 - 0xCFFF_FFFF | 0xD000_0000 - 0xDFFF_FFFF | 256MB |

## 6. Arm® Corstone™ SSE-310 FVP

To develop ahead of hardware availability and explore the design from a software perspective, the Corstone™ SSE-310 Fixed Virtual Platform (FVP) models much of the Arm® IP in the Corstone™ SSE-310 design. It models version rOp0 of the Corstone™ SSE-310 subsystem.

The FVP drives system architecture and software standardization. It is used with the Corstone™ SSE-310 software package which provides software and binaries of proprietary firmware that reduce the amount of work that is required for SoC development. See the Corstone™ SSE-310 software bundle readme for instructions on how to set up and run the FVP.

The FVP models the following IP components:

- A single Arm® Cortex®-M85 processor with MVE extension.
- A single Arm® Ethos™-U55 processor.
- Memory Protection Controller (MPC).
- Peripheral Protection Controller (PPC).
- Implementation Defined Attribution Unit (IDAU).

The full description of components that are internal to the SSE-310 subsystem can be found in the SSE-310 Example Subsystem TRM.

The FVP has the following limitations:

- It does not model every component that Corstone™ SSE-310 describes. For example, it does not model the CoreSight™ technology components.
- QSPI is not modeled. It has QSPI SRAM instead.
- It has a single DMA-350 engine instead of four PL081 DMA peripherals.
- Some components are dummy stubs with a minimal implementation. Models with dummy APB have memory access.
- Some components are partially modeled.

Refer to the following documents for more information:

- [Arm Corstone SSE-310 Example Subsystem Technical Reference Manual](#)
- [Arm MPS3 FPGA Prototyping Board Technical Reference Manual](#)
- [Corstone-310 on Arm Developer](#)

### 6.1 Corstone™ SSE-310 FVP memory map overview

This table outlines the main FVP memories and their positions within the memory map.

This memory map includes IDAU security information for memory regions:

**Table 6-1: Memory map overview**

| Row ID | Address range |             | Size   | Description                                                | Alias with Row ID | IDAU region values |        |          |
|--------|---------------|-------------|--------|------------------------------------------------------------|-------------------|--------------------|--------|----------|
|        | From          | To          |        |                                                            |                   | Security           | IDAUID | NSC      |
| 1      | 0x0000_0000   | 0x0000_7FFF | 32KB   | ITCM <sup>6</sup>                                          | 5                 | NS                 | 0      | 0        |
| 2      | 0x0000_8000   | 0x00FF_FFFF | 15.9MB | Reserved                                                   | -                 |                    |        |          |
| 3      | 0x0100_0000   | 0x011F_FFFF | 2MB    | SRAM (2MB) <sup>4</sup>                                    | 7                 |                    |        |          |
| 4      | 0x0120_0000   | 0x0FFF_FFFF | 238MB  | Reserved                                                   | -                 |                    |        |          |
| 5      | 0x1000_0000   | 0x1000_7FFF | 32KB   | ITCM <sup>6</sup>                                          | 1                 | S                  | 1      | CODE NSC |
| 6      | 0x1000_8000   | 0x10FF_FFFF | 15.9MB | Reserved                                                   | -                 |                    |        |          |
| 7      | 0x1100_0000   | 0x111F_FFFF | 2MB    | SRAM (2MB) <sup>4</sup>                                    | 3                 |                    |        |          |
| 8      | 0x1120_0000   | 0x1FFF_FFFF | 238MB  | Reserved                                                   | -                 |                    |        |          |
| 9      | 0x2000_0000   | 0x2000_7FFF | 32KB   | DTCM (4 x banks of 8KB) <sup>6</sup>                       | 15                | NS                 | 2      | 0        |
| 10     | 0x2000_8000   | 0x20FF_FFFF | 15.9MB | Reserved                                                   | -                 | -                  | -      | -        |
| 11     | 0x2100_0000   | 0x213F_FFFF | 4MB    | Internal SRAM area (SSE-310 implements 2x2MB) <sup>6</sup> | 17                | -                  | -      | -        |
| 12     | 0x2140_0000   | 0x27FF_FFFF | 108MB  | Reserved                                                   | -                 | -                  | -      | -        |
| 13     | 0x2800_0000   | 0x287F_FFFF | 8MB    | QSPI (only 8MB) <sup>4</sup>                               | 19                | -                  | -      | -        |
| 14     | 0x2880_0000   | 0x2FFF_FFFF | 120MB  | Reserved                                                   | -                 | -                  | -      | -        |
| 15     | 0x3000_0000   | 0x3000_7FFF | 32KB   | DTCM (4 x banks of 8KB) <sup>6</sup>                       | 9                 | S                  | 3      | RAM NSC  |
| 16     | 0x3000_8000   | 0x30FF_FFFF | 15.9MB | Reserved                                                   | -                 | -                  | -      | -        |
| 17     | 0x3100_0000   | 0x313F_FFFF | 4MB    | Internal SRAM area (SSE-310 implements 2x2MB) <sup>6</sup> | 11                | -                  | -      | -        |
| 18     | 0x3140_0000   | 0x37FF_FFFF | 108MB  | Reserved                                                   | -                 | -                  | -      | -        |
| 19     | 0x3800_0000   | 0x387F_FFFF | 8MB    | QSPI (only 8MB) <sup>4</sup>                               | 13                | -                  | -      | -        |
| 20     | 0x3880_0000   | 0x3FFF_FFFF | 120MB  | Reserved                                                   | -                 | -                  | -      | -        |
| 21     | 0x4000_0000   | 0x47FF_FFFF | 128MB  | Non-Secure Low Latency Peripheral Region.                  | 23                | NS                 | 4      | 0        |
| 22     | 0x4800_0000   | 0x4FFF_FFFF | 128MB  | Non-Secure High Latency Peripheral Region.                 | 24                | NS                 | 4      | 0        |
| 23     | 0x5000_0000   | 0x57FF_FFFF | 128MB  | Secure Low Latency Peripheral Region.                      | 21                | S                  | 5      | 0        |
| 24     | 0x5800_0000   | 0x5FFF_FFFF | 128MB  | Secure High Latency Peripheral Region.                     | 22                | S                  | 5      | 0        |
| 25     | 0x6000_0000   | 0x6FFF_FFFF | 256MB  | DDR4 <sup>4</sup>                                          | -                 | NS                 | 6      | 0        |
| 26     | 0x7000_0000   | 0x7FFF_FFFF | 256MB  | DDR4 <sup>4</sup>                                          | -                 | S                  | 7      | 0        |
| 27     | 0x8000_0000   | 0x8FFF_FFFF | 256MB  | DDR4 <sup>4</sup>                                          | -                 | NS                 | 8      | 0        |
| 28     | 0x9000_0000   | 0x9FFF_FFFF | 256MB  | DDR4 <sup>4</sup>                                          | -                 | S                  | 9      | 0        |
| 29     | 0xA000_0000   | 0xAF00_FFFF | 256MB  | DDR4 <sup>4</sup>                                          | -                 | NS                 | A      | 0        |
| 30     | 0xB000_0000   | 0xBFFF_FFFF | 256MB  | DDR4 <sup>4</sup>                                          | -                 | S                  | B      | 0        |
| 31     | 0xC000_0000   | 0xCFFF_FFFF | 256MB  | DDR4 <sup>4</sup>                                          | -                 | NS                 | C      | 0        |

| Row ID | Address range |             | Size  | Description                                          | Alias with Row ID | IDAU region values |        |     |
|--------|---------------|-------------|-------|------------------------------------------------------|-------------------|--------------------|--------|-----|
|        | From          | To          |       |                                                      |                   | Security           | IDAUID | NSC |
| 32     | 0xD000_0000   | 0xDFFF_FFFF | 256MB | DDR4 <sup>4</sup>                                    | -                 | S                  | D      | 0   |
| 33     | 0xE000_0000   | 0xE00F_FFFF | 1MB   | External Private Peripheral Bus                      | -                 | -                  | Exempt | -   |
| 34     | 0xE010_0000   | 0xE01F_FFFF | 1MB   | Reserved                                             | -                 | NS                 | E      | 0   |
| 35     | 0xE020_0000   | 0xEFFF_FFFF | 254MB | Maps to HMSTEXPPILL expansion interface <sup>5</sup> | -                 | NS                 | E      | 0   |
| 36     | 0xF000_0000   | 0xF00F_FFFF | 1MB   | Reserved                                             | -                 | -                  | Exempt | -   |
| 37     | 0xF010_0000   | 0xF01F_FFFF | 1MB   | Reserved                                             | -                 | S                  | F      | 0   |
| 38     | 0xF020_0000   | 0xFFFF_FFFF | 254MB | Maps to HMSTEXPPILL expansion interface <sup>5</sup> | -                 | S                  | F      | 0   |

## 6.2 Corstone™ SSE-310 FVP peripherals

The Corstone™ SSE-310 FVP includes peripherals that the software payload requires to run.

These peripherals are organized in the following layers:

### Subsystem

The subsystem peripherals represent peripherals that are present on the SoC.

### Board

The board peripherals represent peripherals that may be present on the board onto which the SoC is mounted. The Corstone™ SSE-310 board model is based on the Arm® MPS3 board.

All peripherals that are extensions to the Corstone™ SSE-310 subsystem are mapped into two key areas of the memory map:

#### **0x4000\_0000 to 0x47FF\_FFFF and 0x4800\_0000 to 0x4FFF\_FFFF**

Non-Secure region that maps to the AHB Master Expansion 1 interface.

#### **0x5000\_0000 to 0x57FF\_FFFF and 0x5800\_0000 to 0x5FFF\_FFFF**

Secure region that maps to the AHB Master Expansion 1 interface.



Some of the MPS3 Fast Models have minimal implementations. For more information, refer to the documents in the FVP package.

<sup>4</sup> Security access is controlled by MPC.

<sup>5</sup> Accesses to these addresses result in an AHB5 error response.

<sup>6</sup> For security settings, control, and features, refer to the Arm® Corstone™ SSE-310 documentation.

## 6.2.1 Corstone™ SSE-310 FVP subsystem peripherals non-secure memory map

Non-secure memory map for subsystem peripherals.

**Table 6-2: Non-secure subsystem peripherals**

| Row ID | Address range in non-secure region |             | Size | Description                               | Modeled in FVP |
|--------|------------------------------------|-------------|------|-------------------------------------------|----------------|
|        | From                               | To          |      |                                           |                |
| 1      | 0x4000_0000                        | 0x4000_0FFF | 4KB  | MHU 0                                     | Not modeled    |
| 2      | 0x4000_1000                        | 0x4000_1FFF | 4KB  | MHU 1                                     | Not modeled    |
| 3      | 0x4000_2000                        | 0x4000_3FFF | 8KB  | DMA                                       | DMA-350        |
| 4      | 0x4000_4000                        | 0x4000_4FFF | 4KB  | NPU APB                                   | Modeled        |
| -      | 0x4000_5000                        | 0x4001_EFFF | -    | Reserved                                  | -              |
| 5      | 0x4001_F000                        | 0x4001_FFFF | 4KB  | CPUID                                     | Modeled        |
| -      | 0x4002_0000                        | 0x4007_0000 | -    | Reserved                                  | -              |
| 6      | 0x4008_0000                        | 0x4008_0FFF | 4KB  | Non-secure Access Configuration Registers | Modeled        |
| -      | 0x4008_1000                        | 0x4008_FFFF | -    | Reserved                                  | -              |
| 7      | 0x4009_0000                        | 0x4009_3FFF | 16KB | CryptoCell312                             | Not modeled    |
| -      | 0x4009_4000                        | 0x400F_FFFF | -    | Reserved                                  | -              |
| -      | 0x4010_0000                        | 0x47FF_FFFF | -    | Board peripherals                         | -              |
| 8      | 0x4800_0000                        | 0x4800_0FFF | 4KB  | Timer 0                                   | Modeled        |
| 9      | 0x4800_1000                        | 0x4800_1FFF | 4KB  | Timer 1                                   | Modeled        |
| 10     | 0x4800_2000                        | 0x4800_2FFF | 4KB  | Timer 2                                   | Modeled        |
| 11     | 0x4800_3000                        | 0x4800_3FFF | 4KB  | Timer 3                                   | Modeled        |
| -      | 0x4800_4000                        | 0x4801_FFFF | -    | Reserved                                  | -              |
| 12     | 0x4802_0000                        | 0x4802_0FFF | 4KB  | SYSINFO                                   | Modeled        |
| -      | 0x4802_1FFF                        | 0x4802_EFFF | -    | Reserved                                  | -              |
| 13     | 0x4802_F000                        | 0x4802_FFFF | 4KB  | SLOWCLK Timer                             | Modeled        |
| -      | 0x4803_0000                        | 0x4803_FFFF | -    | Reserved                                  | -              |
| 14     | 0x4804_0000                        | 0x4804_0FFF | 4KB  | Non-Secure Watchdog Control Frame         | Modeled        |
| 15     | 0x4804_1000                        | 0x4804_1FFF | 4KB  | Non-Secure Watchdog Refresh Frame         | Modeled        |
| -      | 0x4804_2000                        | 0x480F_FFFF | -    | Reserved                                  | -              |

## 6.2.2 Corstone™ SSE-310 FVP subsystem peripherals secure memory map

Secure memory map for subsystem peripherals.

**Table 6-3: Secure subsystem peripherals**

| Row ID | Address range in non-secure region |             | Size | Description                           | Modeled in FVP |
|--------|------------------------------------|-------------|------|---------------------------------------|----------------|
|        | From                               | To          |      |                                       |                |
| 1      | 0x5000_0000                        | 0x5000_0FFF | 4KB  | MHU 0                                 | Not modeled    |
| 2      | 0x5000_1000                        | 0x5000_1FFF | 4KB  | MHU 1                                 | Not modeled    |
| 3      | 0x5000_2000                        | 0x5000_3FFF | 8KB  | DMA                                   | DMA-350        |
| 4      | 0x5000_4000                        | 0x5000_4FFF | 4KB  | NPU APB                               | Modeled        |
| -      | 0x5000_5000                        | 0x5001_EFFF | -    | Reserved                              | -              |
| 5      | 0x5001_F000                        | 0x5001_FFFF | 4KB  | CPUID                                 | Modeled        |
| -      | 0x5002_0000                        | 0x5007_0000 | -    | Reserved                              | -              |
| 6      | 0x5008_0000                        | 0x5008_0FFF | 4KB  | Secure Access Configuration Registers | Modeled        |
| -      | 0x5008_1000                        | 0x5008_2FFF | -    | Reserved                              | -              |
| 7      | 0x5008_3000                        | 0x5008_3FFF | 4KB  | Internal SRAM MPC 0                   | Modeled        |
| 8      | 0x5008_4000                        | 0x5008_4FFF | 4KB  | Internal SRAM MPC 1                   | Modeled        |
| -      | 0x5008_5000                        | 0x5008_FFFF | -    | Reserved                              | -              |
| 9      | 0x5009_0000                        | 0x5009_3FFF | 16KB | CryptoCell312                         | Not modeled    |
| -      | 0x5009_4000                        | 0x500F_FFFF | -    | Reserved                              | -              |
| -      | 0x5010_0000                        | 0x57FF_FFFF | -    | Board peripherals                     | -              |
| 10     | 0x5800_0000                        | 0x5800_0FFF | 4KB  | Timer 0                               | Modeled        |
| 11     | 0x5800_1000                        | 0x5800_1FFF | 4KB  | Timer 1                               | Modeled        |
| 12     | 0x5800_2000                        | 0x5800_2FFF | 4KB  | Timer 2                               | Modeled        |
| 13     | 0x5800_3000                        | 0x5800_3FFF | 4KB  | Timer 3                               | Modeled        |
| -      | 0x5800_4000                        | 0x5801_FFFF | -    | Reserved                              | -              |
| 14     | 0x5802_0000                        | 0x5802_0FFF | 4KB  | SYSINFO                               | Modeled        |
| 15     | 0x5802_1000                        | 0x5802_1FFF | 4KB  | SYSCONTROL                            | Modeled        |
| 16     | 0x5802_2000                        | 0x5802_2FFF | 4KB  | SYS_PPU                               | Modeled        |
| 17     | 0x5802_3000                        | 0x5802_3FFF | 4KB  | CPU0_PPU                              | Modeled        |
| -      | 0x5802_4000                        | 0x5802_6FFF | -    | Reserved                              | -              |
| 18     | 0x5802_7000                        | 0x5802_7FFF | 4KB  | CRYPTO_PPU                            | Not modeled    |
| 19     | 0x5802_8000                        | 0x5802_8FFF | 4KB  | MGMT_PPU                              | Modeled        |
| 20     | 0x5802_9000                        | 0x5802_9FFF | 4KB  | DBG_PPU                               | Modeled        |
| 21     | 0x5802_A000                        | 0x5802_AFFF | 4KB  | NPU_PPU                               | Modeled        |
| -      | 0x5802_B000                        | 0x5802_DFFF | -    | Reserved                              | -              |
| 22     | 0x5802_E000                        | 0x5802_EFFF | 4KB  | SLOWCLK Watchdog                      | Modeled        |

| Row ID | Address range in non-secure region |             | Size | Description                   | Modeled in FVP |
|--------|------------------------------------|-------------|------|-------------------------------|----------------|
|        | From                               | To          |      |                               |                |
| 23     | 0x5802_F000                        | 0x5802_FFFF | 4KB  | SLOWCLK Timer                 | Modeled        |
| -      | 0x5803_0000                        | 0x5803_FFFF | -    | Reserved                      | -              |
| 24     | 0x5804_0000                        | 0x5804_0FFF | 4KB  | Secure Watchdog Control Frame | Modeled        |
| 25     | 0x5804_1000                        | 0x5804_1FFF | 4KB  | Secure Watchdog Refresh Frame | Modeled        |
| -      | 0x5804_2000                        | 0x580F_FFFF | -    | Reserved                      | -              |

### 6.2.3 Corstone™ SSE-310 FVP non-secure expansion peripherals memory map

Non-secure memory map for board peripherals.

**Table 6-4: Non-secure board peripherals**

| Row ID | Address range in non-secure region |             | Size | Description                     | Modeled in FVP                 |
|--------|------------------------------------|-------------|------|---------------------------------|--------------------------------|
|        | From                               | To          |      |                                 |                                |
| 1      | 0x4110_0000                        | 0x4110_0FFF | 4KB  | GPIO 0                          | CMSDK GPIO                     |
| 2      | 0x4110_1000                        | 0x4110_1FFF | 4KB  | GPIO 1                          | CMSDK GPIO                     |
| 3      | 0x4110_2000                        | 0x4110_2FFF | 4KB  | GPIO 2                          | CMSDK GPIO                     |
| 4      | 0x4110_3000                        | 0x4110_3FFF | 4KB  | GPIO 3                          | CMSDK GPIO                     |
| 5      | 0x4110_4000                        | 0x4110_4FFF | 4KB  | USER AHB 0                      | Not modeled                    |
| 6      | 0x4110_5000                        | 0x4110_5FFF | 4KB  | USER AHB 1                      | Not modeled                    |
| 7      | 0x4110_6000                        | 0x4110_6FFF | 4KB  | USER AHB 2                      | Not modeled                    |
| 8      | 0x4110_7000                        | 0x4110_7FFF | 4KB  | USER AHB 3                      | Not modeled                    |
| -      | 0x4110_8000                        | 0x413F_FFFF | -    | Reserved                        | -                              |
| 9      | 0x4140_0000                        | 0x414F_FFFF | 1MB  | Ethernet                        | SMSC91C111 Ethernet controller |
| 10     | 0x4150_0000                        | 0x415F_FFFF | 1MB  | USB                             | Dummy stub                     |
| -      | 0x4160_0000                        | 0x416F_FFFF | -    | Reserved                        | -                              |
| 11     | 0x4170_0000                        | 0x4170_0FFF | 4KB  | Timing adapter APB0 - FPGA SRAM | Dummy stub                     |
| 12     | 0x4170_1000                        | 0x4170_1FFF | 4KB  | Timing adapter APB1 - QSPI      | Dummy stub                     |
| 13     | 0x4170_2000                        | 0x4170_2FFF | 4KB  | Timing adapter APB2 - DDR4      | Dummy stub                     |
| 14     | 0x4170_3000                        | 0x4170_3FFF | 4KB  | User APB3                       | Not modeled                    |
| -      | 0x4170_4000                        | 0x417F_FFFF | -    | Reserved                        | -                              |
| 15     | 0x4180_0000                        | 0x4180_0FFF | 4KB  | QSPI Config                     | Not modeled                    |
| 16     | 0x4180_1000                        | 0x4180_1FFF | 4KB  | QSPI Write                      | Not modeled                    |
| -      | 0x4180_2000                        | 0x47FF_FFFF | -    | Reserved                        | -                              |

| Row ID | Address range in non-secure region |             | Size | Description                    | Modeled in FVP    |
|--------|------------------------------------|-------------|------|--------------------------------|-------------------|
|        | From                               | To          |      |                                |                   |
| -      | 0x4800_0000                        | 0x480F_FFFF | -    | Subsystem peripherals          | -                 |
| -      | 0x4810_0000                        | 0x491F_FFFF | -    | Reserved                       | -                 |
| 17     | 0x4920_0000                        | 0x4920_0FFF | 4KB  | FPGA - SBCon I2C (Touch)       | Partially modeled |
| 18     | 0x4920_1000                        | 0x4920_1FFF | 4KB  | FPGA - SBCon I2C (Audio Conf)  | Dummy stub        |
| 19     | 0x4920_2000                        | 0x4920_2FFF | 4KB  | FPGA - PL022 (SPI ADC)         | Dummy stub        |
| 20     | 0x4920_3000                        | 0x4920_3FFF | 4KB  | FPGA - PL022 (SPI Shield0)     | Dummy stub        |
| 21     | 0x4920_4000                        | 0x4920_4FFF | 4KB  | FPGA - PL022 (SPI Shield1)     | Dummy stub        |
| 22     | 0x4920_5000                        | 0x4920_5FFF | 4KB  | SBCon (I2C - Shield0)          | Dummy stub        |
| 23     | 0x4920_6000                        | 0x4920_6FFF | 4KB  | SBCon (I2C - Shield1)          | Dummy stub        |
| 24     | 0x4920_7000                        | 0x4920_7FFF | 4KB  | USER APB                       | Dummy stub        |
| 25     | 0x4920_8000                        | 0x4920_8FFF | 4KB  | FPGA - SBCon I2C (DDR4 EEPROM) | Dummy stub        |
| -      | 0x4920_9000                        | 0x492F_FFFF | -    | Reserved                       | -                 |
| 26     | 0x4930_0000                        | 0x4930_0FFF | 4KB  | FPGA - SCC registers           | Modeled           |
| 27     | 0x4930_1000                        | 0x4930_1FFF | 4KB  | FPGA - I2S (Audio)             | Partially modeled |
| 28     | 0x4930_2000                        | 0x4930_2FFF | 4KB  | FPGA - IO (System Ctrl + I/O)  | Modeled           |
| 29     | 0x4930_3000                        | 0x4930_3FFF | 4KB  | UART0 - UART_F [0]             | CMSDK UART        |
| 30     | 0x4930_4000                        | 0x4930_4FFF | 4KB  | UART1 - UART_F [1]             | CMSDK UART        |
| 31     | 0x4930_5000                        | 0x4930_5FFF | 4KB  | UART2 - UART_F [2]             | CMSDK UART        |
| 32     | 0x4930_6000                        | 0x4930_6FFF | 4KB  | UART3 - UART Shield 0          | Dummy stub        |
| 33     | 0x4930_7000                        | 0x4930_7FFF | 4KB  | UART4 - UART Shield 1          | Dummy stub        |
| 34     | 0x4930_8000                        | 0x4930_8FFF | 4KB  | UART5 - UART_F [3]             | CMSDK UART        |
| -      | 0x4930_9000                        | 0x4930_9FFF | 4KB  | Reserved                       | -                 |
| 35     | 0x4930_A000                        | 0x4930_AFFF | 4KB  | CLCD Config Reg                | Partially modeled |
| 36     | 0x4930_B000                        | 0x4930_BFFF | 4KB  | RTC                            | PL031_RTC         |

## 6.2.4 Corstone™ SSE-310 FVP secure expansion peripherals memory map

Secure memory map for board peripherals.

**Table 6-5: Secure board peripherals**

| Row ID | Address range in secure region |             | Size | Description                             | Modeled in FVP                 |
|--------|--------------------------------|-------------|------|-----------------------------------------|--------------------------------|
|        | From                           | To          |      |                                         |                                |
| 1      | 0x5110_0000                    | 0x5110_0FFF | 4KB  | GPIO 0                                  | CMSDK GPIO                     |
| 2      | 0x5110_1000                    | 0x5110_1FFF | 4KB  | GPIO 1                                  | CMSDK GPIO                     |
| 3      | 0x5110_2000                    | 0x5110_2FFF | 4KB  | GPIO 2                                  | CMSDK GPIO                     |
| 4      | 0x5110_3000                    | 0x5110_3FFF | 4KB  | GPIO 3                                  | CMSDK GPIO                     |
| 5      | 0x5110_4000                    | 0x5110_4FFF | 4KB  | USER AHB 0                              | Not modeled                    |
| 6      | 0x5110_5000                    | 0x5110_5FFF | 4KB  | USER AHB 1                              | Not modeled                    |
| 7      | 0x5110_6000                    | 0x5110_6FFF | 4KB  | USER AHB 2                              | Not modeled                    |
| 8      | 0x5110_7000                    | 0x5110_7FFF | 4KB  | USER AHB 3                              | Not modeled                    |
| -      | 0x5110_8000                    | 0x513F_FFFF | -    | Reserved                                | -                              |
| 9      | 0x5140_0000                    | 0x514F_FFFF | 1MB  | Ethernet                                | SMSC91C111 Ethernet controller |
| 10     | 0x5150_0000                    | 0x515F_FFFF | 1MB  | USB                                     | Dummy stub                     |
| -      | 0x5160_0000                    | 0x516F_FFFF | -    | Reserved                                | -                              |
| 11     | 0x5170_0000                    | 0x5170_0FFF | 4KB  | Timing Adapter APB0 - FPGA SRAM         | Dummy stub                     |
| 12     | 0x5170_1000                    | 0x5170_1FFF | 4KB  | Timing Adapter APB1 - QSPI              | Dummy stub                     |
| 13     | 0x5170_2000                    | 0x5170_2FFF | 4KB  | Timing Adapter APB2 - DDR4              | Dummy stub                     |
| 14     | 0x5170_3000                    | 0x5170_3FFF | 4KB  | User APB3                               | Not modeled                    |
| -      | 0x5170_4000                    | 0x517F_FFFF | -    | Reserved                                | -                              |
| 15     | 0x5180_0000                    | 0x5180_0FFF | 4KB  | QSPI Config                             | Not modeled                    |
| 16     | 0x5180_1000                    | 0x5180_1FFF | 4KB  | QSPI Write                              | Not modeled                    |
| -      | 0x5180_2000                    | 0x56FF_FFFF | -    | Reserved                                | -                              |
| 17     | 0x5700_0000                    | 0x5700_0FFF | 4KB  | SRAM Memory Protection Controller (MPC) | Modeled                        |
| 18     | 0x5700_1000                    | 0x5700_1FFF | 4KB  | QSPI Memory Protection Controller (MPC) | Modeled                        |
| 19     | 0x5700_2000                    | 0x5700_2FFF | 4KB  | DDR4 Memory Protection Controller (MPC) | Modeled                        |
| -      | 0x5700_3000                    | 0x57FF_FFFF | -    | Reserved                                | -                              |
| -      | 0x5800_0000                    | 0x5810_1FFF | -    | Subsystem peripherals                   | -                              |
| -      | 0x5810_2000                    | 0x591F_FFFF | -    | Reserved                                | -                              |

| Row ID | Address range in secure region |             | Size | Description                   | Modeled in FVP    |
|--------|--------------------------------|-------------|------|-------------------------------|-------------------|
|        | From                           | To          |      |                               |                   |
| 20     | 0x5920_0000                    | 0x5920_0FFF | 4KB  | FPGA - SBCon I2C (Touch)      | Partially modeled |
| 21     | 0x5920_1000                    | 0x5920_1FFF | 4KB  | FPGA - SBCon I2C (Audio Conf) | Dummy stub        |
| 22     | 0x5920_2000                    | 0x5920_2FFF | 4KB  | FPGA - PL022 (SPI ADC)        | Dummy stub        |
| 23     | 0x5920_3000                    | 0x5920_3FFF | 4KB  | FPGA - PL022 (SPI Shield0)    | Dummy stub        |
| 24     | 0x5920_4000                    | 0x5920_4FFF | 4KB  | FPGA - PL022 (SPI Shield1)    | Dummy stub        |
| 25     | 0x5920_5000                    | 0x5920_5FFF | 4KB  | SBCon (I2C - Shield0)         | Dummy stub        |
| 26     | 0x5920_6000                    | 0x5920_6FFF | 4KB  | SBCon (I2C - Shield1)         | Dummy stub        |
| 27     | 0x5920_7000                    | 0x5920_7FFF | 4KB  | USER APB                      | Dummy stub        |
| 28     | 0x5920_8000                    | 0x5920_8FFF | 4KB  | DDR4 EEPROM                   | Dummy stub        |
| -      | 0x5920_9000                    | 0x592F_FFFF | -    | Reserved                      | -                 |
| 29     | 0x5930_0000                    | 0x5930_0FFF | 4KB  | FPGA - SCC registers          | Modeled           |
| 30     | 0x5930_1000                    | 0x5930_1FFF | 4KB  | FPGA - I2S (Audio)            | Partially modeled |
| 31     | 0x5930_2000                    | 0x5930_2FFF | 4KB  | FPGA - IO (System Ctrl + I/O) | Modeled           |
| 32     | 0x5930_3000                    | 0x5930_3FFF | 4KB  | UART0 - UART_F [0]            | CMSDK UART        |
| 33     | 0x5930_4000                    | 0x5930_4FFF | 4KB  | UART1 - UART_F [1]            | CMSDK UART        |
| 34     | 0x5930_5000                    | 0x5930_5FFF | 4KB  | UART2 - UART_F [2]            | CMSDK UART        |
| 35     | 0x5930_6000                    | 0x5930_6FFF | 4KB  | UART3 - UART Shield 0         | Dummy stub        |
| 36     | 0x5930_7000                    | 0x5930_7FFF | 4KB  | UART4 - UART Shield 1         | Dummy stub        |
| 37     | 0x5930_8000                    | 0x5930_8FFF | 4KB  | UART5 - UART_F [3]            | CMSDK UART        |
| -      | 0x5930_9000                    | 0x5930_9FFF | 4KB  | Reserved                      | -                 |
| 38     | 0x5930_A000                    | 0x5930_AFFF | 4KB  | CLCD Config Reg               | Partially modeled |
| 39     | 0x5930_B000                    | 0x5930_BFFF | 4KB  | RTC                           | PL031_RTC         |

## 6.2.5 Corstone SSE-310 FVP expansion peripheral interrupt map

Interrupt map at the board layer.

**Table 6-6: Interrupt map at the board layer**

| Interrupt input | Interrupt source                                     |
|-----------------|------------------------------------------------------|
| IRQ [32]        | System timestamp counter interrupt. Not implemented. |
| IRQ [33]        | UART 0 receive interrupt.                            |
| IRQ [34]        | UART 0 transmit interrupt.                           |

| Interrupt input | Interrupt source                      |
|-----------------|---------------------------------------|
| IRQ [35]        | UART 1 receive interrupt.             |
| IRQ [36]        | UART 1 transmit interrupt.            |
| IRQ [37]        | UART 2 receive interrupt.             |
| IRQ [38]        | UART 2 transmit interrupt.            |
| IRQ [39]        | UART 3 receive interrupt.             |
| IRQ [40]        | UART 3 transmit interrupt.            |
| IRQ [41]        | UART 4 receive interrupt.             |
| IRQ [42]        | UART 4 transmit interrupt.            |
| IRQ [43]        | UART 0 combined interrupt.            |
| IRQ [44]        | UART 1 combined interrupt.            |
| IRQ [45]        | UART 2 combined interrupt.            |
| IRQ [46]        | UART 3 combined interrupt.            |
| IRQ [47]        | UART 4 combined interrupt.            |
| IRQ [48]        | UART overflow (0, 1, 2, 3, 4, and 5). |
| IRQ [49]        | Ethernet.                             |
| IRQ [50]        | Audio I2S.                            |
| IRQ [51]        | Touch screen.                         |
| IRQ [52]        | USB.                                  |
| IRQ [53]        | SPI ADC.                              |
| IRQ [54]        | SPI (shield 0).                       |
| IRQ [55]        | SPI (shield 1).                       |
| IRQ [56]        | Reserved.                             |
| IRQ [57]        | DMA channel 0 interrupt.              |
| IRQ [58]        | DMA channel 1 interrupt.              |
| IRQ [68:59]     | Reserved.                             |
| IRQ [69]        | GPIO 0 combined interrupt.            |
| IRQ [70]        | GPIO 1 combined interrupt.            |
| IRQ [71]        | GPIO 2 combined interrupt.            |
| IRQ [72]        | GPIO 3 combined interrupt.            |
| IRQ [88:73]     | GPIO 0 individual interrupts.         |
| IRQ [104:89]    | GPIO 1 individual interrupts.         |
| IRQ [120:105]   | GPIO 2 individual interrupts.         |
| IRQ [124:121]   | GPIO 3 individual interrupts.         |
| IRQ [125]       | UART 5 receive interrupt.             |
| IRQ [126]       | UART 5 transmit interrupt.            |
| IRQ [127]       | UART 5 combined interrupt.            |
| IRQ [130:128]   | Reserved.                             |

## 6.3 Corstone™ SSE-310 FVP peripheral protection controller expansion map

The Corstone™ SSE-310 FVP implements secure access configuration registers which control security and privileged accesses to peripherals connected to PPC.

**Table 6-7: Secure access configuration registers - PPC bits**

| Bit         | MAIN_PPCEXP0 (AHB0) | MAIN_PPCEXP1 (AHB1) | PERIPH_PPCEXP0 (APB0) | PERIPH_PPCEXP1 (APB1)          | PERIPH_PPCEXP2 (APB2)           |
|-------------|---------------------|---------------------|-----------------------|--------------------------------|---------------------------------|
| 0           | GPIO-0              | -                   | Timing adapter APB 0  | SBCCon I2C (touch screen)      | FPGA - SCC registers            |
| 1           | GPIO-1              | -                   | Timing adapter APB 1  | SBCCon I2C (audio conf)        | FPGA - I2S (audio)              |
| 2           | GPIO-2              | -                   | Timing adapter APB 2  | FPGA PL022 (SPI2 for ADC)      | FPGA - GPIO (System Ctrl + I/O) |
| 3           | GPIO-3              | -                   | -                     | FPGA PL022 (SPI Shield0)       | UART0                           |
| 4           | User AHB 0          | -                   | -                     | FPGA PL022 (SPI Shield1)       | UART1                           |
| 5           | User AHB 1          | -                   | -                     | FPGA SBCCon (I2C - Shield0)    | UART2                           |
| 6           | User AHB 2          | -                   | -                     | FPGA SBCCon (I2C - Shield1)    | UART3 STUB                      |
| 7           | User AHB 3          | -                   | -                     | Reserved                       | UART4 STUB                      |
| 8           | USB and ethernet    | -                   | -                     | FPGA – SBCCon I2C (DDR4 EPROM) | UART5                           |
| 9           | -                   | -                   | -                     | -                              | Reserved                        |
| 10          | -                   | -                   | -                     | -                              | CLCD config reg                 |
| 11          | -                   | -                   | -                     | -                              | RTC                             |
| 12          | -                   | -                   | -                     | -                              | -                               |
| 13          | -                   | -                   | -                     | -                              | -                               |
| 14          | -                   | -                   | -                     | -                              | -                               |
| 15          | -                   | -                   | -                     | -                              | -                               |
| PPC IRQ no. | 5                   | 6                   | 2                     | 3                              | 4                               |

## 6.4 Corstone™ SSE-310 FVP memory components

The Corstone™ SSE-310 FVP includes the following memory components and their security access is controlled by the MPC.

**Table 6-8: Memory components**

| Name      | Non-secure address range  | Secure alias              | Size |
|-----------|---------------------------|---------------------------|------|
| SRAM      | 0x0100_0000 - 0x011F_FFFF | 0x1100_0000 - 0x111F_FFFF | 2MB  |
| QSPI SRAM | 0x2800_0000 - 0x287F_FFFF | 0x3800_0000 - 0x387F_FFFF | 8MB  |

**Table 6-9: DDR regions**

| Name | Address range             | IDAU region security | Size  |
|------|---------------------------|----------------------|-------|
| DDR0 | 0x6000_0000 - 0x6FFF_FFFF | NS                   | 256MB |
| DDR1 | 0x7000_0000 - 0x7FFF_FFFF | S                    | 256MB |
| DDR2 | 0x8000_0000 - 0x8FFF_FFFF | NS                   | 256MB |
| DDR3 | 0x9000_0000 - 0x9FFF_FFFF | S                    | 256MB |
| DDR4 | 0xA000_0000 - 0xAF00_FFFF | NS                   | 256MB |
| DDR5 | 0xB000_0000 - 0xBFFF_FFFF | S                    | 256MB |
| DDR6 | 0xC000_0000 - 0xCF00_FFFF | NS                   | 256MB |
| DDR7 | 0xD000_0000 - 0xDF00_FFFF | S                    | 256MB |

# 7. Arm® Corstone™-1000 FVP

This is an example FVP system as specified by the Corstone™-1000 architecture and system specifications.

Refer to the [Arm Corstone-1000 Technical Overview](#) for more information.



Note

You must have installed the MMEncrypt add-on package to use this FVP. It can be downloaded from [Product Download Hub](#).

## 7.1 Corstone™-1000 FVP modeled components

The following components are present in the Corstone™-1000 FVP.

- Host controller:
  - [Cortex-A35 64-bit 4x Cluster CPU](#)
  - [GIC400](#)
  - [Firewall](#)
- MPS3 board:
  - [SMSC 91C111 ethernet controller](#)
  - [PrimeCell RTC \(PL031\) module](#)
  - Audio I2S and SBCon I2C as dummy stub modules
  - [Two SD cards](#)
  - [DRAM 2GB](#)
  - [SRAM 32MB](#)
  - [PL050 KMI](#)
  - [PS2 keyboard](#)
  - [SP805 watchdog](#)
- Secure enclave:
  - [M0+ CPU](#)
  - [CryptoCell312](#)
  - SE Flash (64KB up to 8MB)
  - NVM OTP memory for CC312
  - [Firewall](#)



The FVP does not model Arm® CoreSight™ components.

Note

## 7.2 Run the Corstone™-1000 FVP with the software package

This FVP is intended to be used with the Arm reference design software package.

### About this task

The User Guide for the software package can be found at [User Guide](#).

### Procedure

1. To see a list of available configuration parameters, run the FVP with the `--list-params` option. Many of these parameters help to bring up bare-metal software on the FVP and are not required if the model is run with the Arm® firmware supplied.
2. This example command line launches the model with the Arm software package:

```
./FVP_Corstone-1000 \
-C diagnostics=4 \
-C se.trustedBootROMloader.fname="bl1.bin" \
-C se.trustedSRAM_config=6 \
-C se.BootROM_config="3" \
-C se.nvm.raw_image="cc312_otp.bin" \
--data board.flash0=corstone1000-aarch64-image-mps3.wic.nopt@0x68050000 \
-C board.xnvm_size=64 \
-C board.smsc_91c111.enabled=1 \
-C board.hostbridge.userNetworking=true \
-C board.se_flash_size=8192 \
-C board.msd_mmc.p_mmc_file=mmc1.dat \
-C board.msd_mmc.card_type="SD" \
-C board.msd_mmc.p_fast_access=0 \
-C board.msd_mmc_2.p_mmc_file=mmc2.dat \
-C board.msd_mmc_2.card_type="SD" \
-C board.msd_mmc_2.p_fast_access=0 \
-C board.msd_mmc.p_max_block_count="0xFFFF" \
-C board.msd_mmc_2.p_max_block_count="0xFFFF" \
-C board.flashloader0.fname="flash0" \
-C board.flashloader0.fnameWrite="flash0"
```

## 7.3 Corstone™-1000 board peripherals memory and interrupt map

The subsystem model is complemented by a range of peripherals. The board peripherals are representative of peripherals present on the board onto which the SoC is mounted.

**Table 7-1: Corstone™-1000 board peripherals memory and interrupt map**

| Component     | Base address   | Size | IRQ |
|---------------|----------------|------|-----|
| Ethernet      | 0x00_4010_0000 | 1M   | 116 |
| SCC registers | 0x00_4000_0000 | 4KB  | -   |
| IO registers  | 0x00_4001_0000 | 4KB  | -   |
| SD card 0     | 0x00_4030_0000 | 64KB | 149 |
| SD card 1     | 0x00_5000_0000 | 64KB | 147 |
| SE flash      | 0x00_6001_0000 | 8MB  | -   |

## 7.4 Networking on Corstone™-1000 FVP

Steps to bring up the network on the FVP.

### Procedure

1. Set up the TAP interface on the host machine. For information, see [TAP/TUN networking](#) in the *Fast Models Reference Guide*.
2. Append the following parameters to the model:
  - `-C board.smsc_91c111.enabled=true`
  - `-C board.hostbridge.interfaceName=<TAP Interface Name>"`

# 8. Juno FVP3 model

This model implements an updated version of the third release of the Juno Arm®v8 platform.

The Juno SoC is described in the [Juno Arm Development Platform TRM](#).

The version number of the model, including the build number, can be obtained by running the model with the --version parameter.

For information about the changes in this release, see the Fast Models Portfolio release notes.

To provide feedback on the product, create a ticket on <https://support.developer.arm.com>.

## 8.1 Unimplemented features and model limitations

Some peripherals are unimplemented in the model, and others are implemented with limitations.

The model does not implement the following peripherals that are described in the Juno SoC ADP TRM:

- CoreSight™ and device discovery ROMs.
- CoreSight™ devices. The memory area is mapped as a dummy APB region.
- SoC Master signals.
- DFI phy config. It is mapped as a dummy APB region.
- PVT sensors are mapped as DummyAPB peripherals.
- PCIe and the associated SMMU, and the associated MSI mechanism.
- USB and the associated SMMU.
- I2C controllers and their associated peripherals.

The following peripherals are implemented but with limitations:

- The Mali™-T624 GPU is present in a form that permits a driver to load and make forward progress, but it does not render any output to the target surface or buffer.
- 2 x HDLCD controllers are present but the downstream physical ports and logic that would normally be part of selecting a suitable display format are not modeled. An additional Linux driver is available instead.

## 8.2 Running the Juno FVP3 model

The model can be run through the Arm DS debug IDE or standalone.



**Note** When running the model on a Linux host machine, ensure that it has at least 16GB of RAM, in addition to the normal Fast Models requirements. The Juno platform and model incorporate 8GB of DRAM.

### 8.2.1 Run the Juno FVP3 model in Arm DS

Arm DS can auto-detect and connect to the Juno FVP and offers access to the big.LITTLE™ cores individually or collectively. It is also possible to connect to the Cortex®-M3 core in the SCP.

Start the model with the `--iris-server` option, or the older `--cadi-server` option, then use **New > Model connection** to begin the process of auto-detection.

### 8.2.2 Run the Juno FVP3 model standalone

The Juno FVP can boot standard software stacks, for example Linux, with minimal modification.

Example command line:

```
$BUILD/Platforms/LISA/CSS/Build Juno_FVP3/Linux64-Release-GCC-7.3/isim_system \
--plugin $BUILD/PVLIB_HOME/plugins/Linux64_GCC-7.3/Crypto.so \
-C css.aon.scp.ROMloader.fname=juno-scp-rom.bin \
-C board.flashloader0.fname=juno-nor-image.bin \
-C board.base_clk_frequency=0x17D7840 \
-C soc.p1011_uart0.unbuffered_output=1 \
-C soc.p1011_uart1.unbuffered_output=1 \
-C board.p1011_uart1.unbuffered_output=1 \
-C soc.scc.gpr0=0x03000000 \
-C soc.scc.apps_alt_boot=0xBEC0000 \
-C soc.scc.scp_alt_boot=0xABE40000 \
-C board mmc_p_mmc_file=optional-mmc-card.img \
-C board.virtioblockdevice.image_path=optional-virtio-disk.img \
-C board.smsc_91c111.enabled=1 \
-C board.hostbridge.userNetworking=<0|1> \
-C board.hostbridge.interfaceName=<tap>
```



- `juno-scp-rom.bin` is included with the model in this release.
- `juno-nor-image.bin` represents the contents of the NOR flash memory.

In hardware, there is a complex mechanism to present the NOR flash as a USB disk to allow replacement firmware, for example arm-trusted-firmware, boot loader, or Linux kernel, to be pushed to the board. Instead of modeling this, a script, `images/create_afs_image.py` is included to create the same memory image directly from the firmware components. Any optional MMC image should be less than 2GB.

See [User mode networking](#) for more information about networking in Fast Models.

### 8.2.3 Run the `create_afs_image.py` script

This topic shows an example command line that boots Linux using U-Boot.

```
python3 create_afs_image.py juno-nor-image.bin
${FW_SW_DIR}/fip-uboot.bin,-,0 \
${KERNEL_OUT_DIR}/arch/arm64/boot/Image,Image \
${KERNEL_OUT_DIR}/arch/arm64/boot/dts/arm/juno-fvp.dtb,board.dtb \
${FW_SW_DIR}/scp_b11.bin,-,0x3e40000 \
${FW_SW_DIR}/b11.bin,-,0x3ec0000 \
uboot-script.img,BOOTSCR \
./u-boot-saveenv.bin,-,0x3fc0000
```

The entry for each component of the NOR image consists of:

- The file on the host machine to add to the image.
- An optional alternative name to use for that file when the NOR metadata is generated. Use a '-' to not have an entry in the metadata at all, or leave blank to use the leaf name of the host file.
- An optional address at which to position the file in the NOR image. Those components shown with an address must use that address to place code and data at expected locations. Other components can be referenced by name so their address does not need to be fixed. Components with no fixed address are allocated sequentially after the previous component. There is no intelligent allocation of components to make best use of the available space. A warning occurs if the image exceeds the size of the NOR area.

In this command line:

- `FW_SW_DIR` points to the `SOFTWARE` directory of a standard Juno firmware bundle, for example those from <http://releases.linaro.org/members/arm/platforms/20.01/> and `KERNEL_OUT_DIR` is the build output of a Linux kernel.
- `juno-fvp.dtb` is a modified version of the normal `juno.dts` that removes the unsupported hardware, for example PCIe, USB, and I2C audio, and adds some additional sections, for example the virtio disk and a helper mechanism for the HDLCD output.

`juno-fvp.dts` is included alongside the model in this release and should be used to patch a standard Linux kernel to create the DTB.

- `BOOTSCR/uboot-script.img` allows you to make permanent changes to the boot sequence programmatically. One required change is typically to tell the kernel to boot from the virtio device `/dev/vda` instead of a regular disk at `/dev/sda`. With bigger kernels, it is also necessary to move the device tree up in memory, for example:

```
echo "setenv fdt_addr 83000000" > uboot_script.txt
echo "setenv bootargs '\$bootargs root=/dev/vda'" >> uboot_script.txt
mkimage -T script -C none -n 'BOOTSCR' -d uboot-script.txt uboot_script.img
```

If your disk image has no partition table, then `root=/dev/vda` is correct.

If your disk image has a partition table then you need something like `root=/dev/vda2` to point at the correct partition to find the root fs. You can check this with:

```
fdisk -l optional-virtio-disk.img
```

- `u-boot-saveenv.bin` is an optional example of an alternative way to modify U-Boot settings by replacing the region of flash containing the saved U-Boot environment. This is not supplied, but can be created by using the U-Boot commands to modify the environment and save it to another part of memory to be dumped to disk.

## 8.3 Jump-start the application clusters on bare metal

It is possible to bring the application clusters out of reset without running firmware on the SCP. This is supported using parameters that allow the user to override the default configuration for the SCP control over Cortex®-A53 and Cortex®-A57 cluster reset.

Add the following lines as appropriate to the Juno configuration file:

```
-C css.aon.scp.scp_sc.a53_power_on=15  
-C css.aon.scp.scp_sc.a57_power_on=3
```

The parameter is a bitfield describing which of the CPUs to turn on.



If you are using a separate parameter file, the `-c` is not required. Specify each parameter on a new line in the file.

To supply an image at the same time, add the following:

```
-a css.cluster0.*=<your-image>
```

You can also target cluster1, and optionally any supported cpu in a cluster, for example `css.cluster0.cpu0`. Because the two clusters and the CPUs within a cluster share a memory interface, this rarely makes a difference.

## 8.4 Basic setup for the TZC-400 model on bare metal

The default state out of reset for the TZC-400 is to block all accesses to DRAM.

You can configure the TZC-400 through the programmer's view or by using command-line parameters. For many applications, you can ignore TrustZone® security for DRAM. In this case,

you must enable read/write access to DRAM from Secure and Non-Secure world in the application clusters. This can be achieved with the following parameters:

```
-C css.tzc400.rst_gate_keeper=0x0f  
-C css.tzc400.rst_region_attributes_0=0xc000000f  
-C css.tzc400.rst_region_id_access_0=0xffffffff
```

# 9. Arm® Neoverse™ N1 edge and Neoverse™ E1 edge reference design FVPs

This chapter describes the Arm® Neoverse™ N1 edge and Arm® Neoverse™ E1 edge reference design FVPs. These FVPs are collectively referred to as RD-N1-E1-edge FVPs.

A reference design is a collection of resources, including documentation, a software stack, and FVPs, that describe and model the design choices and performance for recommended configurations of a typical Arm®-based subsystem.

The RD-N1-E1-edge FVPs drive system architecture and software standardization. They provide software and binaries of proprietary firmware that reduce the amount of work that is required for SoC development.



**Note** Arm is working to make more content available for these FVPs. To find out more about reference designs, or to contact Arm about them, see [Neoverse Reference Design](#).

## 9.1 About the RD-N1-E1 FVPs

The RD-N1-E1-edge FVPs model many of the Arm® IP components in the RD-N1-E1-edge design.

The RD-N1-E1-edge FVPs model the following RD-N1-E1-edge configurations:

### Config1

N1 2xMP4, 512KB L2 cache per core, 4x2 mesh, 2xDMC.

### Config2

E1 2xMP8, 256KB L2 cache per core, 4x2 mesh, 2xDMC.

### Config3

Dual-chip. Two Config1 subsystems linked by CMN-600 CML.

The diagrams in [9.2 Block diagrams for RD-N1-E1-edge](#) on page 70 show the IP components that RD-N1-E1-edge describes. Not all of these components are modeled by these FVPs. The following components are modeled:

- N1 2xMP4 or E1 2xMP8 cores.
- System Control Processor (SCP).
- Management Control Processor (MCP).
- CMN-600.

- Multiple NIC-450 interconnects, although NIC-450 is replaced with a simple bus model.
- Memory access path towards DRAM, including DMC-620 memory controllers.

The following components are not modeled:

- CoreSight™ SoC.
- ELA-500.
- USB.

## 9.2 Block diagrams for RD-N1-E1-edge

The following diagrams show the composition of RD-N1-E1-edge systems.

**Figure 9-1: Block diagram for Neoverse N1 edge reference design**



**Figure 9-2: Block diagram for Neoverse E1 edge reference design**

## 9.3 RD-N1-E1 FVP peripherals

The RD-N1-E1-edge FVPs include peripherals that the software payload requires to run.

These peripherals are organized in two layers:

### SoC

The SoC peripherals represent peripherals that may be added to a compute subsystem in a SoC design.

### Board

The board peripherals represent peripherals that may be present on the board onto which the SoC is mounted.

The RD-N1-E1-edge SoC model and board model are based on the Juno Arm® Development Platform (ADP).

In Config3, each compute subsystem has its own SoC and board layers. In this two-chip configuration, each chip is assigned the following memory regions:

**Chip 0**`0x000_0000_0000-0x3FF_FFFF_FFFF`**Chip 1**`0x400_0000_0000-0x7FF_FFFF_FFFF`

A sideband communication channel is required to coordinate multi-chiplet software boot over CMN-600. The FVP implements this using the MHU device, but Arm recommends using a solution such as I2C in hardware.

### 9.3.1 Memory map for RD-N1-E1-edge FVP SoC peripherals

This table shows the memory map for the SoC peripherals in the RD-N1-E1-edge FVPs.



**Note** The SoC peripherals area in the RD\_N1\_E1\_edge memory map is mapped to an Expansion AXI region. Therefore, these mappings are not defined in the reference design.

**Table 9-1: SoC peripherals memory map**

| Name                          | Base address   | Size  | Description                                                                                                                             |
|-------------------------------|----------------|-------|-----------------------------------------------------------------------------------------------------------------------------------------|
| SMC interface                 | 0x00_0800_0000 | 368MB | Routed to board                                                                                                                         |
| SMMUv3                        | 0x00_2B40_0000 | 1MB   | -                                                                                                                                       |
| PCIe config                   | 0x00_6000_0000 | 16MB  | -                                                                                                                                       |
| PCIe memory                   | 0x00_7000_0000 | 132MB | -                                                                                                                                       |
| DMA MMU-400                   | 0x00_7FB0_0000 | 64KB  | -                                                                                                                                       |
| HDLCD1 MMU-400                | 0x00_7FB1_0000 | 64KB  | -                                                                                                                                       |
| HDLCD0 MMU-400                | 0x00_7FB2_0000 | 64KB  | -                                                                                                                                       |
| DDR3 PHY 0                    | 0x00_7FB6_0000 | 64KB  | Dummy APB                                                                                                                               |
| DDR3 PHY 1                    | 0x00_7FB7_0000 | 64KB  | Dummy APB                                                                                                                               |
| DDR3 PHY 2                    | 0x00_7FB8_0000 | 64KB  | Dummy APB                                                                                                                               |
| DDR3 PHY 3                    | 0x00_7FB9_0000 | 64KB  | Dummy APB                                                                                                                               |
| SoC interconnect NIC-400 GPV  | 0x00_7FD0_0000 | 1MB   | -                                                                                                                                       |
| Surge detector                | 0x00_7FE5_0000 | 4KB   | Dummy APB                                                                                                                               |
| TRNG                          | 0x00_7FE6_0000 | 4KB   | -                                                                                                                                       |
| Trusted non-volatile counters | 0x00_7FE7_0000 | 4KB   | -                                                                                                                                       |
| Trusted Root-Key storage      | 0x00_7FE8_0000 | 4KB   | -                                                                                                                                       |
| Secure I2C                    | 0x00_7FE9_0000 | 256B  | A Secure I2C component does not exist in the FVP. Instead, a PL061_GPIO is mapped as a dummy component. It is not functional as a GPIO. |
| DMA non-secure                | 0x00_7FF0_0000 | 4KB   | -                                                                                                                                       |

| Name                      | Base address   | Size   | Description                                                                                                                       |
|---------------------------|----------------|--------|-----------------------------------------------------------------------------------------------------------------------------------|
| DMA secure                | 0x00_7FF1_0000 | 4KB    | -                                                                                                                                 |
| HDLCD1                    | 0x00_7FF5_0000 | 4KB    | -                                                                                                                                 |
| HDLCD0                    | 0x00_7FF6_0000 | 4KB    | -                                                                                                                                 |
| UART 1                    | 0x00_7FF7_0000 | 4KB    | -                                                                                                                                 |
| UART 0                    | 0x00_7FF8_0000 | 4KB    | -                                                                                                                                 |
| I2S                       | 0x00_7FF9_0000 | 1KB    | An I2S component does not exist in the FVP. Instead, a PL061_GPIO is mapped as a dummy component. It is not functional as a GPIO. |
| I2C                       | 0x00_7FFA_0000 | 0x256B | An I2C component does not exist in the FVP. Instead, a PL061_GPIO is mapped as a dummy component. It is not functional as a GPIO. |
| PL352                     | 0x00_7FFD_0000 | 4KB    | PL354                                                                                                                             |
| AP configuration          | 0x00_7FFE_0000 | 4KB    | GPR                                                                                                                               |
| System override registers | 0x00_7FFF_0000 | 4KB    | -                                                                                                                                 |
| PCIe memory               | 0x05_0000_0000 | 12GB   | -                                                                                                                                 |



The following devices are discoverable on the PCIe bus:

- Virtio block device x 2.
- AHCI controller with attached SATA disk.

### 9.3.2 Memory map for RD-N1-E1-edge FVP board peripherals

This table shows the memory map for the board peripherals in the RD-N1-E1-edge FVPs.



The board peripherals area in the RD\_N1\_E1\_edge memory map is mapped to an Expansion AXI region. Therefore, these mappings are not defined in the reference design.

**Table 9-2: Board peripherals memory map**

| Name             | Base address   | Size | Description |
|------------------|----------------|------|-------------|
| NOR Flash 0      | 0x00_0800_0000 | 64MB | -           |
| NOR Flash 1      | 0x00_0C00_0000 | 64MB | -           |
| NOR Flash 2      | 0x00_1000_0000 | 64MB | -           |
| Ethernet         | 0x00_1800_0000 | 64MB | SMSC 91C111 |
| System registers | 0x00_1C01_0000 | 64KB | -           |
| MCI              | 0x00_1C05_0000 | 64KB | PL180       |
| KMI 0            | 0x00_1C06_0000 | 64KB | PL050       |
| KMI 1            | 0x00_1C07_0000 | 64KB | PL050       |
| UART 0           | 0x00_1C09_0000 | 64KB | PL011       |

| Name                | Base address   | Size | Description                                                                           |
|---------------------|----------------|------|---------------------------------------------------------------------------------------|
| UART 1              | 0x00_1C0A_0000 | 64KB | PL011                                                                                 |
| Watchdog            | 0x00_1C0F_0000 | 64KB | SP805                                                                                 |
| Dual timer          | 0x00_1C11_0000 | 64KB | SP804                                                                                 |
| Virtio block device | 0x00_1C13_0000 | 64KB | -                                                                                     |
| Virtio net device   | 0x00_1C15_0000 | 64KB | -                                                                                     |
| RTC                 | 0x00_1C17_0000 | 64KB | PL031                                                                                 |
| GPIO 0              | 0x00_1C1D_0000 | 64KB | PL061_GPIO is mapped as a dummy component in the FVP. It is not functional as a GPIO. |
| GPIO 1              | 0x00_1C1E_0000 | 64KB | PL061_GPIO is mapped as a dummy component in the FVP. It is not functional as a GPIO. |
| DRAM                | 0x00_8000_0000 | 2GB  | -                                                                                     |
| DRAM                | 0x80_8000_0000 | 6GB  | -                                                                                     |

### 9.3.3 Interrupt maps for RD-N1-E1-edge FVP

These tables show the interrupt IDs and sources for the FVP peripherals.

**Table 9-3: Interrupt map at the SoC layer**

| Interrupt ID | Source | Description |
|--------------|--------|-------------|
| 147          | UART 0 | -           |
| 148          | UART 1 | -           |
| 171          | TRNG   | -           |

**Table 9-4: Interrupt map at the board layer**

| Interrupt ID | Source                        | Description        |
|--------------|-------------------------------|--------------------|
| 111          | Ethernet                      | -                  |
| 132          | RTC                           | -                  |
| 133          | UART 0                        | -                  |
| 134          | UART 1                        | -                  |
| 140          | VFS2                          | -                  |
| 202          | Virtio                        | -                  |
| 204          | Virtio net device             | -                  |
| 228          | Watchdog                      | -                  |
| 229          | KMI 0                         | -                  |
| 230          | Dual timer                    | Interrupts 0 and 1 |
| 231          | System registers ethernet IRQ | -                  |

# 10. Arm® Neoverse™ N2 reference design FVP

The Arm® Neoverse™ N2 reference design (RD-N2) Fixed Virtual Platform (FVP) models much of the Arm® IP in RD-N2. The FVP enables partners to develop ahead of hardware availability and to explore the design from a software perspective.

The FVP is used with the RD-N2 software package. For instructions on setting up and running the FVP, see the RD-N2 Software Bundle Readme.

## 10.1 About the RD-N2 FVP

The RD-N2 FVP models CFG32C4M, which is a single-chiplet system with the number of Arm® Neoverse™ N2 cores reduced to 16.

The FVP models the following IP components:

- Arm® Neoverse™ N2 MP1 cores.
- CMN-700.



**Note** The CMN-700 model supports RAS, which when enabled can impact system performance. To avoid this, the model disables RAS by default. To enable it, set the CMN700 model parameter `enable_ras` to true.

- Multiple NIC-450 interconnects.
- GIC-700.
- MMU-700.
- Arm® Cortex®-M7 SCP and MCP cores.



**Note** The FVP does not model every component that RD-N2 describes. For example, the FVP does not model the CoreSight™ technology components.

The RD-N2 FVP drives system architecture and software standardization. The models provide software and binaries of proprietary firmware that reduce the amount of work that is required for SoC development.

## 10.2 RD-N2 FVP peripherals

The RD-N2 FVP includes peripherals that the software payload requires to run.

The SoC peripherals area and board peripherals area in the RD-N2 memory map are mapped to an expansion AMBA® AXI region. Therefore, these mappings are not defined in the reference design.

The peripherals are organized into two layers:

### SoC

The SoC peripherals represent peripherals that might be added to a compute subsystem in an SoC design. The RD-N2 SoC model is based on the Juno Arm® Development Platform (ADP).

### Board

The board peripherals represent peripherals that might be present on the board onto which the SoC is mounted. The RD-N2 board model is based on the Juno ADP.

### 10.2.1 Memory map for RD-N2 FVP SoC peripherals

This table shows the memory map for the SoC peripherals in the RD-N2 FVP.

**Table 10-1: RD-N2 FVP SoC peripherals**

| Name                             | Base address   | Size         | Description                                                                                        |
|----------------------------------|----------------|--------------|----------------------------------------------------------------------------------------------------|
| SMC0 interface                   | 0x00_0800_0000 | 64MB         | Routed to the board.                                                                               |
| SMC1 interface                   | 0x10_5000_0000 | 256MB        | Routed to the board.                                                                               |
| PCIe config                      | 0x10_1000_0000 | 256MB        | -                                                                                                  |
| PCIe memory                      | 0x00_6000_0000 | 512MB        | -                                                                                                  |
| DMA MMU-500                      | 0x00_E00_0000  | 64KB         | -                                                                                                  |
| HDLCD1 MMU-500                   | 0x00_E01_0000  | 64KB         | -                                                                                                  |
| HDLCD0 MMU-500                   | 0x00_E02_0000  | 64KB         | -                                                                                                  |
| SoC interconnect<br>NIC-400 GPV  | 0x00_ED0_0000  | 1MB          | -                                                                                                  |
| Surge detector                   | 0x00_EE5_0000  | 4KB          | Dummy APB.                                                                                         |
| TRNG                             | 0x00_EE6_0000  | 4KB          | -                                                                                                  |
| Trusted non-volatile<br>counters | 0x00_EE7_0000  | 4KB          | -                                                                                                  |
| Trusted root-key storage         | 0x00_EE8_0000  | 4KB          | -                                                                                                  |
| Secure I2C                       | 0x00_EE9_0000  | 512<br>bytes | There is no Secure I2C component in the FVP. Instead, a PL061 GPIO is mapped as a dummy component. |
| DDR PHY 0-31                     | 0x00_EB0_0000  | 2MB          | Dummy APB.                                                                                         |
| DMA secure                       | 0x00_EF0_0000  | 64KB         | -                                                                                                  |
| DMA non-secure                   | 0x00_EF1_0000  | 64KB         | -                                                                                                  |
| PCIE macro                       | 0x00_EF2_0000  | 64KB         | -                                                                                                  |
| PCIE root port                   | 0x00_EF3_0000  | 64KB         | -                                                                                                  |

| Name                      | Base address  | Size      | Description                                                                                 |
|---------------------------|---------------|-----------|---------------------------------------------------------------------------------------------|
| HDLCD1                    | 0x00_EF5_0000 | 4KB       | -                                                                                           |
| HDLCD0                    | 0x00_EF6_0000 | 4KB       | -                                                                                           |
| UART 0                    | 0x00_EF7_0000 | 4KB       | -                                                                                           |
| UART 1                    | 0x00_EF8_0000 | 4KB       | -                                                                                           |
| I2S                       | 0x00_EF9_0000 | 1KB       | There is no I2S component in the FVP. Instead, a PL061 GPIO is mapped as a dummy component. |
| I2C                       | 0x00_EFA_0000 | 256 bytes | There is no I2C component in the FVP. Instead, a PL061 GPIO is mapped as a dummy component. |
| PL354                     | 0x00_EFD_0000 | 64KB      | Arm® PrimeCell SMC dual SRAM memory interface (PL354).                                      |
| System override registers | 0x00_EFF_0000 | 64KB      | -                                                                                           |
| AP configuration          | 0x00_EFE_0000 | 64KB      | Granular Power Requester (GPR).                                                             |

## 10.2.2 Memory map for RD-N2 FVP board peripherals

This table shows the memory map for the board peripherals in the RD-N2 FVP.

**Table 10-2: RD-N2 FVP board peripherals**

| Name                | Base address   | Size | Description                                         |
|---------------------|----------------|------|-----------------------------------------------------|
| NOR flash 0         | 0x00_0800_0000 | 64MB | -                                                   |
| NOR flash 1         | 0x10_5000_0000 | 64MB | -                                                   |
| NOR flash 2         | 0x10_5400_0000 | 64MB | -                                                   |
| Ethernet            | 0x10_5C00_0000 | 64MB | Non-PCI Ethernet controller (SMSC 91C111)           |
| System registers    | 0x00_0C01_0000 | 64KB | -                                                   |
| SP810 Sysctrl       | 0x00_0C02_0000 | 64KB | -                                                   |
| MCI                 | 0x00_0C05_0000 | 64KB | Arm® PrimeCell Multimedia Card Interface (PL180)    |
| KMI 0               | 0x00_0C06_0000 | 64KB | Arm® PrimeCell PS2 Keyboard/Mouse Interface (PL050) |
| KMI 1               | 0x00_0C07_0000 | 64KB | Arm® PrimeCell PS2 Keyboard/Mouse Interface (PL050) |
| UART 0              | 0x00_0C09_0000 | 64KB | Arm® PrimeCell UART (PL011)                         |
| UART 1              | 0x00_0C0A_0000 | 64KB | Arm® PrimeCell UART (PL011)                         |
| Watchdog            | 0x00_0C0F_0000 | 64KB | Arm® Watchdog Module (SP805)                        |
| Dual timer          | 0x00_0C11_0000 | 64KB | Arm® Dual-Timer Module (SP804)                      |
| Virtio block device | 0x00_0C13_0000 | 64KB | -                                                   |
| Virtio net device   | 0x00_0C15_0000 | 64KB | -                                                   |
| GPIO 2Wire (DVI)    | 0x00_0C16_0000 | 64KB | Arm® PrimeCell General Purpose Input/Output (PL061) |
| RTC0                | 0x00_0C17_0000 | 64KB | Arm® PrimeCell Real Time Clock (PL031)              |
| RTC1                | 0x00_0C18_0000 | 64KB | Arm® PrimeCell Real Time Clock (PL031)              |
| GPIO 0              | 0x00_0C1D_0000 | 64KB | Arm® PrimeCell General Purpose Input/Output (PL061) |
| GPIO 1              | 0x00_0C1E_0000 | 64KB | Arm® PrimeCell General Purpose Input/Output (PL061) |
| DRAM                | 0x00_8000_0000 | 2GB  | -                                                   |

| Name | Base address   | Size | Description |
|------|----------------|------|-------------|
| DRAM | 0x80_8000_0000 | 6GB  | -           |

### 10.2.3 Interrupt maps for RD-N2 FVP

These tables show the interrupt IDs and sources for the FVP peripherals.

**Table 10-3: Interrupt map at the SoC layer**

| Interrupt ID | Source |
|--------------|--------|
| 403          | UART 0 |
| 404          | UART 1 |
| 427          | TRNG   |

**Table 10-4: Interrupt map at the board layer**

| Interrupt ID | Source                             |
|--------------|------------------------------------|
| 387          | RTC1                               |
| 388          | RTC0                               |
| 389          | UART0 (board)                      |
| 390          | UART1 (board)                      |
| 391          | KMI1                               |
| 392          | GPIO0                              |
| 393          | GPIO1                              |
| 394          | I2C GPIO                           |
| 395          | MCIINTRO                           |
| 396          | MCIINTR1                           |
| 397          | SMSC 91C111                        |
| 405          | HDLCD controller 0                 |
| 406          | SMC PL354 interface 0              |
| 407          | SMC PL354 interface 1              |
| 413          | HDLCD controller 1                 |
| 414          | SMMU combined Secure interrupt     |
| 415          | SMMU combined Non-secure interrupt |
| 418-425      | DMA0 IRQ7-0                        |
| 426          | DMA0 IRQ abort                     |
| 428-435      | DMA1 IRQ7-0                        |
| 436          | DMA1 IRQ abort                     |
| 458          | Virtio block device                |
| 460          | Virtio net                         |
| 483          | RTCC                               |
| 484          | WDT                                |

| Interrupt ID | Source                        |
|--------------|-------------------------------|
| 485          | KMIO                          |
| 486          | Dual timer                    |
| 487          | System registers              |
| 488          | System register – USB         |
| 489          | System register – Tile        |
| 490          | System register – Push button |
| 491          | System register – Ethernet    |

# 11. Arm® Neoverse™ V1 reference design FVP

To develop ahead of hardware availability and to explore the design from a software perspective, the Fixed Virtual Platform (FVP) models many of the Arm® IP in the RD-V1 design.

## 11.1 About the RD-V1 FVP

Two configurations of RD-V1 are supported.

- RD-V1 FVP models Config-M, a single-chiplet system with 16 Arm® Neoverse™ V1 cores.
- RD-V1 quad-chiplet FVP models a reduced-size variant of Config-XL, consisting of four compute subsystems linked by CMN-650 CML. It provides a functional model of a quad-chiplet system. Each subsystem contains four Arm® Neoverse™ V1 cores, for a total of 16 cores in the FVP (at full size, Config-XL has 4 x 32 cores).

The FVP models the following IP components:

- Arm® Neoverse™ V1 MP1.
- GIC-700.
- MMU-600.
- SCP.
- MCP.
- CMN-650.
- Multiple NIC-450 interconnects.
- Memory access path towards DRAM which includes a TrustZone® controller.



The FVP does not model every component that RD-V1 describes. For example, it does not model the CoreSight™ technology components.

The RD-V1 FVP drives system architecture and software standardization. The models provide software and binaries of proprietary firmware that reduce the amount of work that is required for SoC development.

## 11.2 RD-V1 FVP peripherals

The RD-V1 FVP includes peripherals that the software payload requires to run.

These peripherals are organized in two layers:

### SoC

The SoC peripherals represent peripherals that can be added to a compute subsystem in a SoC design. The Arm® Neoverse™ V1 reference design SoC model is based on the Juno Arm Development Platform (ADP).

### Board

The board peripherals represent peripherals that can be present on the board onto which the SoC is mounted. The RD-V1 board model is based on the Juno Arm Development Platform (ADP).

In the quad-chiplet system, each compute subsystem has SoC and Board layers dedicated to that subsystem. Addressing for each chip is defined in chapter 7.1, AP memory map, in the Arm® Neoverse™ V1 reference design Software Developer Guide.

|               |                                  |
|---------------|----------------------------------|
| <b>Chip 0</b> | 0x000_0000_0000-0x3FF_FFFF_FFFF  |
| <b>Chip 1</b> | 0x400_0000_0000-0x7FF_FFFF_FFFF  |
| <b>Chip 2</b> | 0x800_0000_0000-0xBFF_FFFF_FFFF  |
| <b>Chip 3</b> | 0xC00_0000_0000-0xFFFF_FFFF_FFFF |

A sideband communication channel is required to coordinate multi-chiplet software boot over CMN-650. The FVP implements this using the MHU device, but Arm recommends using a solution such as I<sup>2</sup>C in hardware.

### Related information

[Arm Neoverse v1 reference design Software Developer Guide](#)

### 11.2.1 Memory map for RD-V1 FVP SoC peripherals

This table shows the memory map for the SoC peripherals in the RD-V1 FVP.



The following devices are discoverable on the PCIe bus:

- Virtio block device x 2.
- AHCI controller with attached SATA disk.

**Table 11-1: SoC peripherals**

| Name          | Base address   | Size  | Description     |
|---------------|----------------|-------|-----------------|
| SMC interface | 0x00_0800_0000 | 368MB | Routed to Board |
| SMMUv3        | 0x00_2B40_0000 | 1MB   | -               |
| PCIe Config   | 0x00_6000_0000 | 16MB  | -               |

| Name                          | Base address   | Size  | Description                                                                        |
|-------------------------------|----------------|-------|------------------------------------------------------------------------------------|
| PCIe Memory                   | 0x00_7000_0000 | 132MB | -                                                                                  |
| DMA MMU-400                   | 0x00_7FB0_0000 | 64KB  | -                                                                                  |
| HDLCD1 MMU-400                | 0x00_7FB1_0000 | 64KB  | -                                                                                  |
| HDLCD0 MMU-400                | 0x00_7FB2_0000 | 64KB  | -                                                                                  |
| DDR3 PHY 0                    | 0x00_7FB6_0000 | 64KB  | Dummy APB                                                                          |
| DDR3 PHY 1                    | 0x00_7FB7_0000 | 64KB  | Dummy APB                                                                          |
| DDR3 PHY 2                    | 0x00_7FB8_0000 | 64KB  | Dummy APB                                                                          |
| DDR3 PHY 3                    | 0x00_7FB9_0000 | 64KB  | Dummy APB                                                                          |
| SoC Interconnect NIC-400 GPV  | 0x00_7FD0_0000 | 1MB   | -                                                                                  |
| Surge detector                | 0x00_7FE5_0000 | 4KB   | Dummy APB                                                                          |
| TRNG                          | 0x00_7FE6_0000 | 4KB   | -                                                                                  |
| Trusted Non-volatile counters | 0x00_7FE7_0000 | 4KB   | -                                                                                  |
| Trusted Root-Key storage      | 0x00_7FE8_0000 | 4KB   | -                                                                                  |
| Secure I2C                    | 0x00_7FE9_0000 | 256B  | A Secure I2C component does not exist in the FVP. Instead, a PL061_GPIO is mapped. |
| DMA Non-secure                | 0x00_7FF0_0000 | 4KB   | -                                                                                  |
| DMA Secure                    | 0x00_7FF1_0000 | 4KB   | -                                                                                  |
| HDLCD1                        | 0x00_7FF5_0000 | 4KB   | -                                                                                  |
| HDLCD0                        | 0x00_7FF6_0000 | 4KB   | -                                                                                  |
| UART 1                        | 0x00_7FF7_0000 | 4KB   | -                                                                                  |
| UART 0                        | 0x00_7FF8_0000 | 4KB   | -                                                                                  |
| I2S                           | 0x00_7FF9_0000 | 1KB   | An I2S component does not exist in the FVP. Instead, a PL061_GPIO is mapped.       |
| I2C                           | 0x00_7FFA_0000 | 256B  | An I2C component does not exist in the FVP. Instead, a PL061_GPIO is mapped.       |
| PL352                         | 0x00_7FFD_0000 | 4KB   | PL354                                                                              |
| AP configuration              | 0x00_7FFE_0000 | 4KB   | GPR                                                                                |
| System override Registers     | 0x00_7FFF_0000 | 4KB   | -                                                                                  |
| PCIe Memory                   | 0x05_0000_0000 | 12GB  | -                                                                                  |

## 11.2.2 Memory map for RD-V1 FVP board peripherals

This table shows the memory map for the board peripherals in the RD-V1 FVP.



The SoC peripherals area and board peripherals area in the RD-V1 memory map are mapped to an Expansion AXI region. Therefore, these mappings are not defined in the reference design.

**Table 11-2: Board peripherals**

| Name                | Base address   | Size | Description |
|---------------------|----------------|------|-------------|
| NOR Flash 0         | 0x00_0800_0000 | 64MB | -           |
| NOR Flash 1         | 0x00_0C00_0000 | 64MB | -           |
| NOR Flash 2         | 0x00_1000_0000 | 64MB | -           |
| Ethernet            | 0x00_1800_0000 | 64MB | SMSC 91C111 |
| System registers    | 0x00_1C01_0000 | 64KB | -           |
| MCI                 | 0x00_1C05_0000 | 64KB | PL180       |
| KMI 0               | 0x00_1C06_0000 | 64KB | PL050       |
| KMI 1               | 0x00_1C07_0000 | 64KB | PL050       |
| UART 0              | 0x00_1C09_0000 | 64KB | PL011       |
| UART 1              | 0x00_1C0A_0000 | 64KB | PL011       |
| Watchdog            | 0x00_1C0F_0000 | 64KB | SP805       |
| Dual Timer          | 0x00_1C11_0000 | 64KB | SP804       |
| Virtio Block Device | 0x00_1C13_0000 | 64KB | -           |
| Virtio Net Device   | 0x00_1C15_0000 | 64KB | -           |
| RTC                 | 0x00_1C17_0000 | 64KB | PL031       |
| GPIO 0              | 0x00_1C1D_0000 | 64KB | PL061_GPIO  |
| GPIO 1              | 0x00_1C1E_0000 | 64KB | PL061_GPIO  |
| DRAM                | 0x00_8000_0000 | 2GB  | -           |
| DRAM                | 0x80_8000_0000 | 6GB  | -           |

### 11.2.3 Interrupt maps for RD-V1 FVP

These tables show the interrupt IDs and sources for the FVP peripherals.

**Table 11-3: Interrupt map at the SoC layer**

| Interrupt ID | Source | Description |
|--------------|--------|-------------|
| 147          | UART 0 | -           |
| 148          | UART 1 | -           |
| 171          | TRNG   | -           |

**Table 11-4: Interrupt map at the board layer**

| Interrupt ID | Source   | Description |
|--------------|----------|-------------|
| 111          | Ethernet | -           |
| 132          | RTC      | -           |
| 133          | UART 0   | -           |
| 134          | UART 1   | -           |
| 140          | VFS2     | -           |
| 202          | Virtio   | -           |

| Interrupt ID | Source                        | Description        |
|--------------|-------------------------------|--------------------|
| 204          | Virtio net device             | -                  |
| 228          | Watchdog                      | -                  |
| 229          | KMI 0                         | -                  |
| 230          | Dual Timer                    | Interrupts 0 and 1 |
| 231          | System registers Ethernet IRQ | -                  |

# 12. Configurable PCIe hierarchy

Configurable PCIe hierarchy allows you to create a customized PCIe hierarchy based on a JSON-formatted file.

To use it, add the following parameter to the command line before running the model, specifying the path to the PCIe hierarchy file:

```
-C pci.hierarchy_file_name=/path/to/hierarchy.json
```

## 12.1 JSON format for the hierarchy

To represent an endpoint device, a root port, or a switch, use the following JSON format.

An endpoint device is represented in the following format:

```
{
    "<device_type>/<device_name>": {
        "parameter1":<parameter_value>
        "parameter2":<parameter_value>
        "      ...      ":"<      ...      >
    }
}
```

A root port is represented in the following format, where a \_\_downstream\_\_ parameter denotes a device connected downstream of the port:

```
{
    "rootport/<rootport_name>": {
        "parameter1":<parameter value>
        "parameter2":<parameter value>
        "      ...      ":"<      ...      >
        "__downstream__":{
            "<device_type>/<device_name>":{
                "parameter3":<parameter value>
                "parameter4":<parameter value>
                "      ...      ":"<      ...      >
            }
        }
    }
}
```

A switch is represented in the following format, where a \_\_downstream\_\_ <device\_number> parameter denotes the device connected downstream of the switch, with the downstream port at device number <device\_number> on the switch's internal bus:

```
{
    "switch/<switch_name>": {
        "parameter1":<parameter value>
        "parameter2":<parameter value>
        "      ...      ":"<      ...      >
        "__downstream__<device_number1>": {
            "<device_type>/<device_name>": {

```

```
        "parameter3":<parameter value>
        "parameter4":<parameter value>
        "         ...          ":"<           ...           >
    }
},
"__downstream_<device_number2>":{
    "<device_type>/<device_name>":{
        "parameter5":<parameter value>
        "parameter6":<parameter value>
        "         ...          ":"<           ...           >
    }
}
}
```

## 12.2 Common PCIe endpoint parameters

A PCIe endpoint is the common PCIe frontend for all endpoint-type devices in the hierarchy, namely AHCI controller, host bridge, and SMMU test engine, which are described later in this chapter.

The following table describes the parameters for PCIe-related features of endpoints:

**Table 12-1: Common endpoint parameters**

| Parameter      | Description                                                                                                     | Type | Range    |
|----------------|-----------------------------------------------------------------------------------------------------------------|------|----------|
| device         | Device number of the endpoint.                                                                                  | int  | 0-31     |
| function       | Function number for the endpoint.                                                                               | int  | 0-7      |
| vendor_id      | PCI vendor ID.                                                                                                  | int  | 0-0xFFFF |
| device_id      | PCI device ID.                                                                                                  | int  | 0-0xFFFF |
| base_class     | PCI base class.                                                                                                 | int  | 0-255    |
| sub_class      | PCI sub class.                                                                                                  | int  | 0-255    |
| bar0_64bit     | If BAR 0 is 64 bits wide, if region size is nonzero.                                                            | bool | -        |
| bar1_64bit     | If BAR 1 is 64 bits wide, if region size is nonzero.                                                            | bool | -        |
| bar2_64bit     | If BAR 2 is 64 bits wide, if region size is nonzero.                                                            | bool | -        |
| bar3_64bit     | If BAR 3 is 64 bits wide, if region size is nonzero.                                                            | bool | -        |
| bar4_64bit     | If BAR 4 is 64 bits wide, if region size is nonzero.                                                            | bool | -        |
| bar0_log2_size | Log2 of the size of the region pointed to by BAR 0. Zero is reserved which means bar is not used <sup>7</sup> . | int  | 0-63     |
| bar1_log2_size | Log2 of the size of the region pointed to by BAR 1. Zero is reserved which means bar is not used.               | int  | 0-63     |
| bar2_log2_size | Log2 of the size of the region pointed to by BAR 2. Zero is reserved which means bar is not used.               | int  | 0-63     |
| bar3_log2_size | Log2 of the size of the region pointed to by BAR 3. Zero is reserved which means bar is not used.               | int  | 0-63     |
| bar4_log2_size | Log2 of the size of the region pointed to by BAR 4. Zero is reserved which means bar is not used.               | int  | 0-63     |

**7** Parameter value is fixed and cannot be overridden.

| Parameter                      | Description                                                                                               | Type | Range     |
|--------------------------------|-----------------------------------------------------------------------------------------------------------|------|-----------|
| bar5_log2_size                 | Log2 of the size of the region pointed to by BAR 5. Zero is reserved which means bar is not used.         | int  | 0-63      |
| uses_interrupt                 | Enable support for legacy interrupts.                                                                     | bool | -         |
| interrupt_pin_index            | Interrupt pin used by this function. 1 is INTA, 2 is INTB, 3 is INTC, 4 is INTD.                          | int  | 1-4       |
| multi_function                 | Set to true if this endpoint is part of a multi-function device.                                          | bool | -         |
| pcie_version                   | PCIe version, bits[3:0] in capabilities register. 1 is PCIe 3.0. 2 is PCIe 4.0.                           | int  | 1-15      |
| prog_iface                     | PCI programming interface.                                                                                | int  | 0-15      |
| rev_id                         | PCI revision ID.                                                                                          | int  | 0-15      |
| subsys_id                      | PCI subsystem ID.                                                                                         | int  | 0-0xFFFFE |
| subsys_vendor_id               | PCI subsystem vendor ID.                                                                                  | int  | 0-0xFFFFE |
| express_capability_device_type | PCI Express Capabilities Device Type, bits[7:4] in capabilities register. 0 is PCIe EndPoint, 9 is RCiEP. | int  | 0-15      |
| msix_support                   | Enable device support for MSI-X.                                                                          | bool | -         |
| msix_pba_bar                   | BAR used by MSI-X pending bit array.                                                                      | int  | 0-5       |
| msix_table_bar                 | BAR used by MSI-X table.                                                                                  | int  | 0-5       |
| msix_table_size                | Size of tables for MSI-X.                                                                                 | int  | 0-2048    |
| power_mgmt_capability          | Device supports power-management capabilities.                                                            | bool | -         |
| pasid_supported                | If set, then the PCIe device can emit PASID (SubstreamIDs).                                               | bool | -         |
| ext_fmt_field_supported        | Enable extended format field support.                                                                     | bool | -         |
| extended_tag_supported         | Extended tag field support.                                                                               | bool | -         |
| link_port_number               | Port number for PCIe link.                                                                                | int  | 0-255     |
| pri_supported                  | If set, then the PCIe function supports Page Request Interface (requires ATS).                            | bool | -         |
| rber_supported                 | Enable role-based error reporting.                                                                        | bool | -         |
| slot_and_root_status_msi_idx   | MSI index for reporting slot and root status changes.                                                     | int  | 0-2047    |
| tag_10bit_completer_supported  | Enable 10-bit tag completer support.                                                                      | bool | -         |
| tag_10bit_requester_supported  | Enable 10-bit tag requester support.                                                                      | bool | -         |
| aspm_optionality_compliant     | Enable ASPM optionality compliance.                                                                       | bool | -         |
| ats_supported                  | If set, then the PCIe function supports Address Translation Services (ATS).                               | bool | -         |

## 12.3 AHCI controller parameters

The Advanced Host Controller Interface (AHCI), is a technical standard for an interface that enables software to communicate with Serial ATA (SATA) devices.

Default values for endpoint parameters:

- device: 0

- function: 0
- vendor\_id: 0xABC\*
- device\_id: 0xACED\*
- base\_class: 0x1\* (device class for mass storage)
- sub\_class: 0x6\* (sub class for SATA)
- bar0\_64bit: false
- bar1\_64bit: false
- bar2\_64bit: false
- bar3\_64bit: false
- bar4\_64bit: false
- bar0\_log2\_size: 13
- bar1\_log2\_size: 13
- bar2\_log2\_size: 12
- bar3\_log2\_size: 13
- bar4\_log2\_size: 12
- bar5\_log2\_size: 13
- uses\_interrupt: false\*
- interrupt\_pin\_index: 1
- multi\_function: false
- pcie\_version: 2
- prog\_iface: 0x1\*
- rev\_id: 0x1\*
- subsys\_id: 0x2\*
- subsys\_vendor\_id: 0x13B5\*
- express\_capability\_device\_type: 0
- msix\_support: true\*
- msix\_pba\_bar: 4\*
- msix\_table\_bar: 2\*
- msix\_table\_size: 1\*
- power\_mgmt\_capability: true
- pasid\_supported: false
- ext\_fmt\_field\_supported: true
- extended\_tag\_supported: true
- link\_port\_number: 0

- pri\_supported: false
- rber\_supported: true
- slot\_and\_root\_status\_msi\_idx: 0
- tag\_10bit\_completer\_supported: true
- tag\_10bit\_requester\_supported: true
- aspm\_optionality\_compliant: true
- ats\_supported: false



\* indicates parameter values that are fixed and cannot be overridden.

Note

**Table 12-2: AHCI parameters and their default values**

| Parameter  | Description                                                                                                                                                                                                                                                                                    | Default value |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| force_mode | Force disk to report support for at most PIO/DMA/NCQ mode (only for testing/bring-up purposes). PIO mode is always supported. Use NCQ for maximum performance.                                                                                                                                 | "NCQ"         |
| image_path | Comma-separated list of 0-32 disk images. Each image represents one SATA disk which is connected to one port of the AHCI controller. Empty list elements are allowed and result in a SATA port that has no disk attached. An empty string (default) means one SATA port with no disk attached. | ""            |
| run_async  | Do host I/O in a background thread asynchronously. Enabling this parameter makes the simulation non-deterministic and may or may not improve performance.                                                                                                                                      | false         |

### Example

```
"ahci/ahci0": {
    "device": 10,
    "function": 0,
    "image_path": "/path/to/image",
    "express_capability_device_type": 9
}
```

## 12.4 Host bridge parameters

On real systems, the host bridge connects the tree of PCI buses, which are internally connected with PCI-to-PCI bridges, to the rest of the system. On FVPs, it is merely a placeholder representation, and does not provide any functionality.

Default values for endpoint parameters:

- device: 0
- function: 0
- vendor\_id: 0x13B5

- device\_id: 0
- base\_class: 0x6\*
- sub\_class: 0
- bar0\_64bit: false
- bar1\_64bit: false
- bar2\_64bit: false
- bar3\_64bit: false
- bar4\_64bit: false
- bar0\_log2\_size: 12
- bar1\_log2\_size: 0
- bar2\_log2\_size: 0
- bar3\_log2\_size: 0
- bar4\_log2\_size: 0
- bar5\_log2\_size: 0
- uses\_interrupt: false
- interrupt\_pin\_index: 1
- multi\_function: false
- pcie\_version: 2
- prog\_iface: 0xf
- rev\_id: 0xf
- subsys\_id: 0xf
- subsys\_vendor\_id: 0x13B5
- express\_capability\_device\_type: 9
- msix\_support: false
- msix\_pba\_bar: 6
- msix\_table\_bar: 6
- msix\_table\_size: 1
- power\_mgmt\_capability: true
- pasid\_supported: false
- ext\_fmt\_field\_supported: true
- extended\_tag\_supported: true
- link\_port\_number: 0
- pri\_supported: true
- rber\_supported: true

- slot\_and\_root\_status\_msi\_idx: 0
- tag\_10bit\_completer\_supported: true
- tag\_10bit\_requester\_supported: true
- aspm\_optionality\_compliant: true



\* indicates parameter values that are fixed and cannot be overridden.

## Example

```
"hostbridge/hb": {  
    "device": 0,  
    "function": 0,  
}
```

## 12.5 SMMU test engine parameters

SMMUV3TestEngine is a PCIe device used to generate various stimuli that can help test SMMU integration in the system.

Default values for endpoint parameters:

- device: 0
- function: 0
- vendor\_id: 0x13B5\*
- device\_id: 0xFF80
- base\_class: 0xFF\*
- sub\_class: 0
- bar0\_64bit: true
- bar1\_64bit: false
- bar2\_64bit: true
- bar3\_64bit: false
- bar4\_64bit: true
- bar0\_log2\_size: 18
- bar1\_log2\_size: 0
- bar2\_log2\_size: 15\*
- bar3\_log2\_size: 0
- bar4\_log2\_size: 12\*

- bar5\_log2\_size: 0
- uses\_interrupt: false
- multi\_function: false
- pcie\_version: 2
- prog\_iface: 0x0
- rev\_id: 0xf
- subsys\_id: 0x0
- subsys\_vendor\_id: 0x13B5\*
- express\_capability\_device\_type: 9
- msix\_support: true
- msix\_pba\_bar: 4
- msix\_table\_bar: 2
- msix\_table\_size: 2048
- power\_mgmt\_capability: true
- pasid\_supported: false
- ext\_fmt\_field\_supported: true
- extended\_tag\_supported: true
- link\_port\_number: 0
- pri\_supported: true
- rber\_supported: true
- slot\_and\_root\_status\_msi\_idx: 0
- tag\_10bit\_completer\_supported: true
- tag\_10bit\_requester\_supported: true
- aspm\_optionality\_compliant: true



\* indicates parameter values that are fixed and cannot be overridden.

## Example

```
"smmuv3testengine/smmute": {  
    "device": 0,  
    "function": 0,  
}
```

## 12.6 Root port parameters

The following root port parameters are available.

**Table 12-3: Root port parameters**

| Parameter                     | Description                                                                     | Type | Range    | Default value |
|-------------------------------|---------------------------------------------------------------------------------|------|----------|---------------|
| device_number                 | Device number on this bus.                                                      | int  | 0-31     | 0             |
| device_id                     | PCI device ID.                                                                  | int  | 0-0xFFFF | 0xdef         |
| vendor_id                     | PCI vendor ID.                                                                  | int  | 0-0xFFFF | 0x13B5        |
| acs_supported                 | Access control services supported.                                              | bool | -        | false         |
| aspm_optionality_compliant    | Enable ASPM optionality compliance.                                             | bool | -        | true          |
| ext_fmt_field_supported       | Enable extended format field support.                                           | bool | -        | true          |
| extended_tag_supported        | Extended tag field support.                                                     | bool | -        | true          |
| link_port_number              | Port number for PCIe link.                                                      | int  | 0-255    | 0             |
| pcie_version                  | PCIe version, bits[3:0] in capabilities register. 1 is PCIe 3.0. 2 is PCIe 4.0. | int  | 1-15     | 2             |
| rber_supported                | Enable role-based error reporting.                                              | bool | -        | true          |
| slot_and_root_status_msi_idx  | MSI index for reporting slot and root status changes.                           | int  | 0-2047   | 0             |
| tag_10bit_completer_supported | Enable 10-bit tag completer support.                                            | bool | -        | true          |
| tag_10bit_requester_supported | Enable 10-bit tag requester support.                                            | bool | -        | true          |

### Example

```
"rootport/rootport0": {
    "device_number": 5,
    "downstream": {
        "ahci/ahcil": {
            "device": 0,
            "function": 0,
            "image_path": "/path/to/image"
        }
    }
}
```

## 12.7 Switch parameters

This topic lists the switch parameters with their default values and gives an example.

**Table 12-4: Switch parameters**

| Parameter     | Description                        | Type | Range | Default value |
|---------------|------------------------------------|------|-------|---------------|
| device_number | Device number on this bus.         | int  | 0-31  | 0             |
| acs_supported | Access control services supported. | bool | -     | false         |

## Example

```
"switch/switch0": {
    "device_number": 0,
    "__downstream_10": {
        "ahci/ahci4": {...}
    },
    "__downstream_20": {
        "ahci/ahci2": {...}
    }
}
```

## 12.8 Root bridge parameters

The term *root bridge* is taken from the PCI Firmware Specification Revision 3.x. It refers to an abstraction for the platform's PCI config and memory I/O access mechanism. A root bridge can be used to create multiple ECAM and MMIO regions within the system's ECAM and MMIO limits.

**Table 12-5: Root bridge parameters**

| Parameter             | Description                        | Type | Range                                                                                                                                                                                                                                                                                   |
|-----------------------|------------------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ecam_start            | ECAM base address.                 | int  | Min: <System ECAM base><br>Max:<System ECAM end - 1MB>                                                                                                                                                                                                                                  |
| ecam_end_incl         | ECAM end address.                  | int  | Min:<System ECAM base + 1MB><br>Max:<System ECAM end>                                                                                                                                                                                                                                   |
| mem32_start           | 32-bit memory window base address. | int  | Min:<System MEM32 base><br>Max:<System MEM32 end>                                                                                                                                                                                                                                       |
| mem32_end_incl        | 32-bit memory window end address.  | int  | Min:<System MEM32 base><br>Max:<System MEM32 end>                                                                                                                                                                                                                                       |
| mem64_start           | 64-bit memory window base address. | int  | Min:<System MEM64 base><br>Max:<System MEM64 end>                                                                                                                                                                                                                                       |
| mem64_end_incl        | 64-bit memory window base address. | int  | Min:<System MEM64 base><br>Max:<System MEM64 end>                                                                                                                                                                                                                                       |
| ecam_start_bus_number | ECAM start bus number.             | int  | Min:<System start bus><br>Max:<System end bus><br><br><b>Note:</b><br>Each bus consumes 1MB of memory, so each ECAM should have enough space ( <code>ecam_start - ecam_end_incl</code> ) to accommodate the total number of buses ( <code>start_bus - end_bus</code> ) allocated to it. |

## Example

```
"rootbridge/rb0": {
```

```

    "ecam_start": 0x60000000,
    "ecam_end_incl": 0x67fffff,
    "mem32_start": 0x70000000,
    "mem32_end_incl": 0x73fffff,
    "mem64_start": 0x5000000000,
    "mem64_end_incl": 0x67fffff,
    "ecam_start_bus_number": 0x0,

    "__downstream__":
        "ahci/ahci0": {
            "device": 30,
            "function": 0,
            "image_path": "",
            "express_capability_device_type": 9
        },
        "ahci/ahci1": {
            "device": 31,
            "function": 0,
            "express_capability_device_type": 9,
            "image_path": ""
        }
    }
}

```

## 12.9 Example hierarchy for a single ECAM configuration

The absence of a root bridge before the beginning of the device hierarchy implies a single ECAM configuration.

```

{
    "ahci/ahci0": {
        "device": 30,
        "function": 0,
        "image_path": "",
        "express_capability_device_type": 9
    },
    "smmuv3testengine/smmuv3testengine3": {
        "device": 15,
        "function": 0,
        "express_capability_device_type": 9
    },
    "rootport/rootport0": {
        "device_number": 2,
        "__downstream__":
            "ahci/ahci1": {
                "device": 0,
                "function": 0,
                "image_path": "",
                "multi_function": true,
            },
            "ahci/ahci2": {
                "device": 0,
                "function": 1,
                "image_path": ""
            }
        }
    },
    "rootport/rootport1": {
        "device_number": 5,
        "__downstream__":
            "ahci/ahci3": {
                "device": 0,
                "function": 0,
                "image_path": ""
            }
    }
}

```

```

        }
    },
    "rootport/rootport2": {
        "device_number": 6,
        "__downstream__": {
            "switch/switch0": {
                "device_number": 0,
                "__downstream_10": {
                    "ahci/ahci4": {}
                },
                "__downstream_20": {
                    "ahci/ahci5": {}
                }
            }
        }
    }
}

```

## 12.10 Example hierarchy for two ECAM configuration

This example shows the JSON file for two ECAMs.

```

{
    "rootbridge/rb0": {
        "ecam_start": 0x60000000,
        "ecam_end_incl": 0x67ffffffff,
        "mem32_start": 0x70000000,
        "mem32_end_incl": 0x73ffffffff,
        "mem64_start": 0x5000000000,
        "mem64_end_incl": 0x67ffffffff,
        "ecam_start_bus_number": 0x0,

        "__downstream__": {
            "ahci/ahci0": {
                "device": 30,
                "function": 0,
                "image_path": "",
                "express_capability_device_type": 9
            },
            "ahci/ahci1": {
                "device": 31,
                "function": 0,
                "express_capability_device_type": 9,
                "image_path": ""
            }
        }
    },
    "rootbridge/rb1": {
        "ecam_start": 0x68000000,
        "ecam_end_incl": 0x6fffffff,
        "mem32_start": 0x74000000,
        "mem32_end_incl": 0x77ffffffff,
        "mem64_start": 0x6800000000,
        "mem64_end_incl": 0x7fffffffff,
        "ecam_start_bus_number": 0x1,

        "__downstream__": {
            "ahci/ahci0": {
                "device": 2,
                "function": 0,
                "image_path": "/path/to/image",
                "express_capability_device_type": 9
            }
        }
    }
}

```

```
    }
```

# 13. Base Platform FVPs

This chapter lists the Base Platform FVPs and the instances in them.

For the Base Platform memory map, see [Base Platform memory map](#) in the *Fast Models Reference Guide*.

## 13.1 FVP\_Base\_AEMvA-AEMvA

FVP\_Base\_AEMvA-AEMvA contains the following instances:

### FVP\_Base\_AEMvA-AEMvA instances

#### **FVP\_Base\_AEMvA\_AEMvA**

Base Platform Compute Subsystem for AEMvACT and AEMvACT.

Type: [FVP\\_Base\\_AEMvA\\_AEMvA](#).

#### **FVP\_Base\_AEMvA\_AEMvA\_bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_AEMvA\_AEMvA\_bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_AEMvA\_AEMvA\_bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_AEMvA\_AEMvA\_bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_AEMvA\_AEMvA\_bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_AEMvA\_AEMvA\_bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_AEMvA\_AEMvA\_bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.hd1cd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_AEMvA\_AEMvA\_bp.hd1cd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_AEMvA\_AEMvA\_bp.hd1cd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_AEMvA\_AEMvA\_bp.hd1cd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_AEMvA\_AEMvA\_bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_AEMvA\_AEMvA\_bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_AEMvA\_AEMvA\_bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_AEMvA\_AEMvA\_bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_AEMvA\_AEMvA\_bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_AEMvA\_AEMvA\_bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_AEMvA\_AEMvA\_bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA\_bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_AEMvA\_AEMvA\_bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.pl111\_clcd.pl11x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.pl111\_clcd.pl11x\_clcd.timer.thread.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.vis**

Display window for VE using Visualisation library.

Type: [vEVisualisation](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_AEMvA\_AEMvA.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_AEMvA\_AEMvA.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.clockdivider1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_AEMvA\_AEMvA.cluster0**

ARM AEMvA Cluster CT model.

Type: [Cluster\\_ARM\\_AEM-A\\_MP](#).

**FVP\_Base\_AEMvA\_AEMvA.cluster0.cpu0**

ARM AEM-A MP CT model.

Type: [ARM\\_AEM-A\\_MP](#).

**FVP\_Base\_AEMvA\_AEMvA.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_AEMvA\_AEMvA.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_AEMvA\_AEMvA.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_AEMvA\_AEMvA.cluster0.cpu1**

ARM AEM-A MP CT model.

Type: ARM\_AEM-A\_MP.

**FVP\_Base\_AEMvA\_AEMvA.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_AEMvA\_AEMvA.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_AEMvA\_AEMvA.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_AEMvA\_AEMvA.cluster0.cpu2**

ARM AEM-A MP CT model.

Type: ARM\_AEM-A\_MP.

**FVP\_Base\_AEMvA\_AEMvA.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_AEMvA\_AEMvA.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_AEMvA\_AEMvA.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_AEMvA\_AEMvA.cluster0.cpu3**

ARM AEM-A MP CT model.

Type: ARM\_AEM-A\_MP.

**FVP\_Base\_AEMvA\_AEMvA.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_AEMvA\_AEMvA.cluster0.cpu3.lldcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_AEMvA\_AEMvA.cluster0.cpu3.llicache**

PV Cache.

Type: PVCache.

**FVP\_Base\_AEMvA\_AEMvA.cluster0.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_AEMvA\_AEMvA.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_AEMvA\_AEMvA.cluster1**

ARM AEMvA Cluster CT model.

Type: [cluster\\_ARM\\_AEM-A\\_MP](#).

**FVP\_Base\_AEMvA\_AEMvA.cluster1.cpu0**

ARM AEM-A MP CT model.

Type: [ARM\\_AEM-A\\_MP](#).

**FVP\_Base\_AEMvA\_AEMvA.cluster1.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_AEMvA\_AEMvA.cluster1.cpu0.lldcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_AEMvA\_AEMvA.cluster1.cpu0.llicache**

PV Cache.

Type: PVCache.

**FVP\_Base\_AEMvA\_AEMvA.cluster1.cpu1**

ARM AEM-A MP CT model.

Type: [ARM\\_AEM-A\\_MP](#).

**FVP\_Base\_AEMvA\_AEMvA.cluster1.cpu1.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_AEMvA\_AEMvA.cluster1.cpu1.lldcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_AEMvA\_AEMvA.cluster1.cpu1.llicache**

PV Cache.

Type: PVCache.

**FVP\_Base\_AEMvA\_AEMvA.cluster1.cpu2**

ARM AEM-A MP CT model.

Type: ARM\_AEM-A\_MP.

**FVP\_Base\_AEMvA\_AEMvA.cluster1.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_AEMvA\_AEMvA.cluster1.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_AEMvA\_AEMvA.cluster1.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_AEMvA\_AEMvA.cluster1.cpu3**

ARM AEM-A MP CT model.

Type: ARM\_AEM-A\_MP.

**FVP\_Base\_AEMvA\_AEMvA.cluster1.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_AEMvA\_AEMvA.cluster1.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_AEMvA\_AEMvA.cluster1.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_AEMvA\_AEMvA.cluster1.l2\_cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_AEMvA\_AEMvA.cluster1\_labeller**

Type: [Labeller](#).

**FVP\_Base\_AEMvA\_AEMvA.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_AEMvA\_AEMvA.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_AEMvA\_AEMvA.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_AEMvA\_AEMvA.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_AEMvA\_AEMvA.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_AEMvA\_AEMvA.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_AEMvA\_AEMvA.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_AEMvA\_AEMvA.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.2 FVP\_Base\_Cortex-A32x1

FVP\_Base\_Cortex-A32x1 contains the following instances:

### FVP\_Base\_Cortex-A32x1 instances

**FVP\_Base\_Cortex\_A32x1**

Base Platform Compute Subsystem for ARM Cortex-A32x1CT.

Type: [FVP\\_Base\\_Cortex\\_A32x1](#).

**FVP\_Base\_Cortex\_A32x1.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A32x1.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A32x1.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A32x1.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A32x1.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A32x1.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A32x1.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A32x1.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A32x1.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A32x1.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x1.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x1.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x1.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x1.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x1.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBuseExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A32x1.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A32x1.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A32x1.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A32x1.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A32x1.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A32x1.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Cortex\_A32x1.bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A32x1.bp.hd1cd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A32x1.bp.hd1cd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A32x1.bp.hd1cd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A32x1.bp.hd1cd0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A32x1.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A32x1.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A32x1.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A32x1.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A32x1.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x1.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A32x1.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A32x1.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A32x1.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A32x1.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A32x1.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A32x1.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A32x1.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A32x1.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A32x1.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A32x1.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A32x1.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A32x1.bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A32x1.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A32x1.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A32x1.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A32x1.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A32x1.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A32x1.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x1.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A32x1.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A32x1.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x1.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x1.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x1.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x1.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x1.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A32x1.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A32x1.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Cortex\_A32x1.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A32x1.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A32x1.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x1.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A32x1.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A32x1.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A32x1.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A32x1.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A32x1.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A32x1.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A32x1.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A32x1.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A32x1.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A32x1.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A32x1.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A32x1.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A32x1.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.  
Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A32x1.bp.virtioblockdevice**

virtio block device.  
Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A32x1.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A32x1.bp.virtiop9device**

virtio P9 server.  
Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A32x1.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A32x1.bp.vis**

Display window for VE using Visualisation library.  
Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A32x1.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).  
Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A32x1.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.bp.vram**

RAM device, can be dynamic or static ram.  
Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x1.cci400**

Cache Coherent Interconnect for AXI4 ACE.  
Type: [CC1400](#).

**FVP\_Base\_Cortex\_A32x1.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x1.cluster0**

ARM Cortex-A32 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A32](#).

**FVP\_Base\_Cortex\_A32x1.cluster0.cpu0**

ARM Cortex-A32 CT model.

Type: [ARM\\_Cortex-A32](#).

**FVP\_Base\_Cortex\_A32x1.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A32x1.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A32x1.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A32x1.cluster0.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A32x1.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A32x1.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A32x1.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A32x1.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A32x1.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A32x1.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_Base\_Cortex\_A32x1.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_Base\_Cortex\_A32x1.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_Base\_Cortex\_A32x1.pctl.timer\_reset.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.3 FVP\_Base\_Cortex-A32x2

FVP\_Base\_Cortex-A32x2 contains the following instances:

### FVP\_Base\_Cortex-A32x2 instances

#### **FVP\_Base\_Cortex\_A32x2**

Base Platform Compute Subsystem for ARM Cortex A32x2 CT.

Type: [FVP\\_Base\\_Cortex\\_A32x2](#).

#### **FVP\_Base\_Cortex\_A32x2.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A32x2.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A32x2.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A32x2.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A32x2.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A32x2.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A32x2.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A32x2.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A32x2.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A32x2.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A32x2.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2\_bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2\_bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2\_bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2\_bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2\_bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2\_bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2\_bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2\_bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x2.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x2.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x2.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x2.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x2.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A32x2.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A32x2.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A32x2.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A32x2.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A32x2.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A32x2.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A32x2.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A32x2.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A32x2.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A32x2.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A32x2.bp.hdlcd0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A32x2.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A32x2.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A32x2.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A32x2.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A32x2.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x2.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A32x2.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A32x2.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A32x2.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A32x2.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A32x2.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A32x2.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A32x2.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A32x2.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A32x2.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A32x2.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A32x2.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A32x2.bp.p1111\_clcd.p111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A32x2.bp.p1111\_clcd.p111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A32x2.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A32x2.bp.pl1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A32x2.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A32x2.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A32x2.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x2.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A32x2.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A32x2.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x2.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x2.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x2.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x2.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x2.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A32x2.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A32x2.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [smsc\\_91c111](#).

**FVP\_Base\_Cortex\_A32x2.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A32x2.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A32x2.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x2.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A32x2.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A32x2.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A32x2.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A32x2.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A32x2.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A32x2.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A32x2.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A32x2.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A32x2.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A32x2.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A32x2.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A32x2.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A32x2.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [virtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A32x2.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A32x2.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A32x2.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A32x2.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A32x2.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A32x2.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A32x2.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x2.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A32x2.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x2.cluster0**

ARM Cortex-A32 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A32](#).

**FVP\_Base\_Cortex\_A32x2.cluster0.cpu0**

ARM Cortex-A32 CT model.

Type: ARM\_Cortex-A32.

**FVP\_Base\_Cortex\_A32x2.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A32x2.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A32x2.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A32x2.cluster0.cpu1**

ARM Cortex-A32 CT model.

Type: ARM\_Cortex-A32.

**FVP\_Base\_Cortex\_A32x2.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A32x2.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A32x2.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A32x2.cluster0.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A32x2.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A32x2.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A32x2.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A32x2.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A32x2.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

#### **FVP\_Base\_Cortex\_A32x2.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_Base\_Cortex\_A32x2.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_Base\_Cortex\_A32x2.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_Base\_Cortex\_A32x2.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.4 FVP\_Base\_Cortex-A32x4

FVP\_Base\_Cortex-A32x4 contains the following instances:

### **FVP\_Base\_Cortex-A32x4 instances**

#### **FVP\_Base\_Cortex\_A32x4**

Base Platform Compute Subsystem for ARM CortexA32x4CT.

Type: [FVP\\_Base\\_Cortex\\_A32x4](#).

#### **FVP\_Base\_Cortex\_A32x4.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A32x4.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A32x4.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A32x4.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A32x4.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A32x4.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A32x4.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A32x4.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A32x4.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A32x4.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x4.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x4.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x4.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x4.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x4.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A32x4.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A32x4.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A32x4.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A32x4.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A32x4.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A32x4.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A32x4.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A32x4.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A32x4.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A32x4.bp.hdlcd0.timer.thread.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A32x4.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A32x4.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A32x4.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A32x4.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A32x4.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A32x4.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x4.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A32x4.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A32x4.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A32x4.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A32x4.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A32x4.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A32x4.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A32x4.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A32x4.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A32x4.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A32x4.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A32x4.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A32x4.bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A32x4.bp.p1111\_clcd.p111x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A32x4.bp.p1111\_clcd.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A32x4.bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A32x4.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A32x4.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A32x4.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x4.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A32x4.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A32x4.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x4.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x4.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x4.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x4.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x4.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A32x4.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A32x4.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A32x4.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A32x4.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A32x4.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x4.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A32x4.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A32x4.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A32x4.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A32x4.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A32x4.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A32x4.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A32x4.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A32x4.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A32x4.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A32x4.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A32x4.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A32x4.bp.virtio\_net\_labeler**

Type: [Labeler](#).

**FVP\_Base\_Cortex\_A32x4.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [virtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A32x4.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A32x4.bp.virtioblockdevice\_labeler**

Type: [Labeler](#).

**FVP\_Base\_Cortex\_A32x4.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A32x4.bp.virtiop9device\_labeler**

Type: [Labeler](#).

**FVP\_Base\_Cortex\_A32x4.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A32x4.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A32x4.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A32x4.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCI400](#).

**FVP\_Base\_Cortex\_A32x4.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A32x4.cluster0**

ARM Cortex-A32 Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-A32](#).

**FVP\_Base\_Cortex\_A32x4.cluster0.cpu0**

ARM Cortex-A32 CT model.

Type: [ARM\\_Cortex-A32](#).

**FVP\_Base\_Cortex\_A32x4.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A32x4.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A32x4.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A32x4.cluster0.cpu1**

ARM Cortex-A32 CT model.

Type: [ARM\\_Cortex-A32](#).

**FVP\_Base\_Cortex\_A32x4.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A32x4.cluster0.cpu1.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A32x4.cluster0.cpu1.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A32x4.cluster0.cpu2**

ARM Cortex-A32 CT model.

Type: [ARM\\_Cortex-A32](#).

**FVP\_Base\_Cortex\_A32x4.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A32x4.cluster0.cpu2.l1dcache**

PV Cache.

Type: `PVCache`.

**FVP\_Base\_Cortex\_A32x4.cluster0.cpu2.l1icache**

PV Cache.

Type: `PVCache`.

**FVP\_Base\_Cortex\_A32x4.cluster0.cpu3**

ARM Cortex-A32 CT model.

Type: `ARM_Cortex-A32`.

**FVP\_Base\_Cortex\_A32x4.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: `TlbCadi`.

**FVP\_Base\_Cortex\_A32x4.cluster0.cpu3.l1dcache**

PV Cache.

Type: `PVCache`.

**FVP\_Base\_Cortex\_A32x4.cluster0.cpu3.l1icache**

PV Cache.

Type: `PVCache`.

**FVP\_Base\_Cortex\_A32x4.cluster0.12\_cache**

PV Cache.

Type: `PVCache`.

**FVP\_Base\_Cortex\_A32x4.cluster0\_labeller**

Type: `Labeller`.

**FVP\_Base\_Cortex\_A32x4.dapmemlogger**

Bus Logger.

Type: `PVBusLogger`.

**FVP\_Base\_Cortex\_A32x4.elfloader**

ELF loader component.

Type: `ElfLoader`.

**FVP\_Base\_Cortex\_A32x4.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: `GIC_IRI`.

**FVP\_Base\_Cortex\_A32x4.pctl**

Base Platforms Power Controller.

Type: `Base_PowerController`.

**FVP\_Base\_Cortex\_A32x4.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_Base\_Cortex\_A32x4.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_Base\_Cortex\_A32x4.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_Base\_Cortex\_A32x4.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.5 FVP\_Base\_Cortex-A35x1

FVP\_Base\_Cortex-A35x1 contains the following instances:

### FVP\_Base\_Cortex-A35x1 instances

#### **FVP\_Base\_Cortex\_A35x1**

Base Platform Compute Subsystem for ARM Cortex A35x1 CT.

Type: [FVP\\_Base\\_Cortex\\_A35x1](#).

#### **FVP\_Base\_Cortex\_A35x1.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A35x1.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A35x1.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A35x1.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A35x1.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A35x1.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A35x1.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A35x1.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A35x1.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A35x1.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A35x1.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x1.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x1.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x1.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x1.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x1.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A35x1.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A35x1.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A35x1.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A35x1.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A35x1.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A35x1.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A35x1.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A35x1.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A35x1.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A35x1.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A35x1.bp.hdlcd0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A35x1.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A35x1.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A35x1.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A35x1.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A35x1.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x1.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A35x1.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A35x1.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A35x1.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A35x1.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A35x1.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A35x1.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A35x1.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A35x1.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A35x1.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A35x1.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A35x1.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A35x1.bp.p1111\_clcd.p111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A35x1.bp.p1111\_clcd.p111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A35x1.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A35x1.bp.pl1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A35x1.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A35x1.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A35x1.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x1.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A35x1.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A35x1.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x1.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x1.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x1.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x1.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x1.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A35x1.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A35x1.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A35x1.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A35x1.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A35x1.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x1.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A35x1.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A35x1.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A35x1.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A35x1.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A35x1.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A35x1.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A35x1.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A35x1.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A35x1.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A35x1.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A35x1.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A35x1.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A35x1.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [virtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A35x1.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A35x1.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A35x1.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A35x1.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A35x1.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A35x1.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A35x1.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x1.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A35x1.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x1.cluster0**

ARM Cortex-A35 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A35](#).

**FVP\_Base\_Cortex\_A35x1.cluster0.cpu0**

ARM Cortex-A35 CT model.

Type: ARM\_Cortex-A35.

**FVP\_Base\_Cortex\_A35x1.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A35x1.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A35x1.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A35x1.cluster0.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A35x1.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A35x1.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A35x1.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A35x1.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A35x1.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A35x1.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A35x1.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke

wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_Base\_Cortex\_A35x1.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_Base\_Cortex\_A35x1.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.6 FVP\_Base\_Cortex-A35x2

FVP\_Base\_Cortex-A35x2 contains the following instances:

### **FVP\_Base\_Cortex-A35x2 instances**

#### **FVP\_Base\_Cortex\_A35x2**

Base Platform Compute Subsystem for ARM Cortex A35x2 CT.

Type: [FVP\\_Base\\_Cortex\\_A35x2](#).

#### **FVP\_Base\_Cortex\_A35x2.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A35x2.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A35x2.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A35x2.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A35x2.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A35x2.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A35x2.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A35x2.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A35x2.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A35x2.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A35x2.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A35x2.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2\_bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2\_bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2\_bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2\_bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2\_bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2\_bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2\_bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x2\_bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x2.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x2.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x2.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x2.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A35x2.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A35x2.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A35x2.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A35x2.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A35x2.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A35x2.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A35x2.bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A35x2.bp.hd1cd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a

proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A35x2.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A35x2.bp.hdlcd0.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A35x2.bp.hdlcd0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A35x2.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A35x2.bp.mmcc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A35x2.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A35x2.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A35x2.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x2.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A35x2.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A35x2\_bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2\_bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A35x2\_bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2\_bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A35x2\_bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2\_bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A35x2\_bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A35x2\_bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A35x2\_bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2\_bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A35x2\_bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2\_bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A35x2\_bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A35x2\_bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A35x2\_bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A35x2\_bp.p1111\_clcd.p111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A35x2\_bp.p1111\_clcd.p111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A35x2\_bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A35x2\_bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A35x2.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A35x2.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A35x2.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x2.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A35x2.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A35x2.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x2.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x2.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x2.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x2.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x2.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A35x2.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A35x2.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A35x2.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A35x2.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A35x2.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x2.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A35x2.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A35x2.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A35x2.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A35x2.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A35x2.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A35x2.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A35x2.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A35x2.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A35x2.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A35x2.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A35x2.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A35x2.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A35x2.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A35x2.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A35x2.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A35x2.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A35x2.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A35x2.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A35x2.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A35x2.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x2.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A35x2.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x2.cluster0**

ARM Cortex-A35 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A35](#).

**FVP\_Base\_Cortex\_A35x2.cluster0.cpu0**

ARM Cortex-A35 CT model.

Type: [ARM\\_Cortex-A35](#).

**FVP\_Base\_Cortex\_A35x2.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A35x2.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A35x2.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A35x2.cluster0.cpu1**

ARM Cortex-A35 CT model.

Type: [ARM\\_Cortex-A35](#).

**FVP\_Base\_Cortex\_A35x2.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A35x2.cluster0.cpu1.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A35x2.cluster0.cpu1.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A35x2.cluster0.l2\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A35x2.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A35x2.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A35x2.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A35x2.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A35x2.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A35x2.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A35x2.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A35x2.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A35x2.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.7 FVP\_Base\_Cortex-A35x4

FVP\_Base\_Cortex-A35x4 contains the following instances:

### FVP\_Base\_Cortex-A35x4 instances

**FVP\_Base\_Cortex\_A35x4**

Base Platform Compute Subsystem for ARM CortexA35x4CT.

Type: [FVP\\_Base\\_Cortex\\_A35x4](#).

**FVP\_Base\_Cortex\_A35x4.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A35x4.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A35x4.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A35x4.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A35x4.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A35x4.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A35x4.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A35x4.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A35x4.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A35x4.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x4.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x4.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x4.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x4.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x4.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBuseExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A35x4.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A35x4.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A35x4.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A35x4.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A35x4.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A35x4.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Cortex\_A35x4.bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A35x4.bp.hd1cd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A35x4.bp.hd1cd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A35x4.bp.hd1cd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A35x4.bp.hd1cd0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A35x4.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A35x4.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A35x4.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A35x4.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A35x4.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x4.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A35x4.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A35x4.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A35x4.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A35x4.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A35x4.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A35x4.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A35x4.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A35x4.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A35x4.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A35x4.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A35x4.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A35x4.bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A35x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A35x4.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A35x4.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A35x4.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A35x4.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A35x4.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x4.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A35x4.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A35x4.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x4.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x4.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x4.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x4.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x4.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A35x4.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A35x4.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Cortex\_A35x4.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A35x4.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A35x4.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x4.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A35x4.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A35x4.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A35x4.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A35x4.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A35x4.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A35x4.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A35x4.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A35x4.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A35x4.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A35x4.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A35x4.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A35x4.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A35x4.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.  
Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A35x4.bp.virtioblockdevice**

virtio block device.  
Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A35x4.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A35x4.bp.virtiop9device**

virtio P9 server.  
Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A35x4.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A35x4.bp.vis**

Display window for VE using Visualisation library.  
Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A35x4.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).  
Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A35x4.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.bp.vram**

RAM device, can be dynamic or static ram.  
Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A35x4.cci400**

Cache Coherent Interconnect for AXI4 ACE.  
Type: [CC1400](#).

**FVP\_Base\_Cortex\_A35x4.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A35x4.cluster0**

ARM Cortex-A35 Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-A35](#).

**FVP\_Base\_Cortex\_A35x4.cluster0.cpu0**

ARM Cortex-A35 CT model.

Type: [ARM\\_Cortex-A35](#).

**FVP\_Base\_Cortex\_A35x4.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A35x4.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A35x4.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A35x4.cluster0.cpu1**

ARM Cortex-A35 CT model.

Type: [ARM\\_Cortex-A35](#).

**FVP\_Base\_Cortex\_A35x4.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A35x4.cluster0.cpu1.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A35x4.cluster0.cpu1.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A35x4.cluster0.cpu2**

ARM Cortex-A35 CT model.

Type: [ARM\\_Cortex-A35](#).

**FVP\_Base\_Cortex\_A35x4.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A35x4.cluster0.cpu2.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A35x4.cluster0.cpu2.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A35x4.cluster0.cpu3**

ARM Cortex-A35 CT model.

Type: [ARM\\_Cortex-A35](#).

**FVP\_Base\_Cortex\_A35x4.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A35x4.cluster0.cpu3.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A35x4.cluster0.cpu3.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A35x4.cluster0.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A35x4.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A35x4.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A35x4.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A35x4.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A35x4.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A35x4.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A35x4.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A35x4.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A35x4.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.8 FVP\_Base\_Cortex-A510

FVP\_Base\_Cortex-A510 contains the following instances:

### FVP\_Base\_Cortex-A510 instances

**FVP\_Base\_Cortex\_A510**

Base Platform Compute Subsystem for ARM Cortex A510CT.

Type: [FVP\\_Base\\_Cortex\\_A510](#).

**FVP\_Base\_Cortex\_A510.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A510.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A510.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A510.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A510.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A510.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A510.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A510.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A510.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A510.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A510.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A510.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A510.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A510.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A510.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A510.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A510.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A510.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A510.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A510.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A510.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A510.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A510.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Cortex\_A510.bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A510\_bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A510\_bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A510\_bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A510\_bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A510\_bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A510\_bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A510\_bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A510\_bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A510\_bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510\_bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A510\_bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A510.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A510.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510.bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A510.bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A510.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A510.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A510.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A510.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A510.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A510.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A510.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A510.bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A510.bp.p1111\_clcd.p111x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A510.bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A510.bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A510.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A510.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A510.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A510.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A510.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A510.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A510.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Cortex\_A510.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A510.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A510.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A510.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A510.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A510.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A510.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A510.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A510.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A510.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A510.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A510.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A510.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A510.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A510.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A510.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A510.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A510.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A510.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A510.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A510.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A510.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A510.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A510.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510.cluster0**

ARM Cortex-A510Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A510](#).

**FVP\_Base\_Cortex\_A510.cluster0.cpu0**

ARM Cortex-A510CT model.

Type: [ARM\\_Cortex-A510](#).

**FVP\_Base\_Cortex\_A510.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A510.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu0.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu1**

ARM Cortex-A510CT model.

Type: ARM\_Cortex-A510.

**FVP\_Base\_Cortex\_A510.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A510.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu1.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu2**

ARM Cortex-A510CT model.

Type: ARM\_Cortex-A510.

**FVP\_Base\_Cortex\_A510.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A510.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu2.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu3**

ARM Cortex-A510CT model.

Type: ARM\_Cortex-A510.

**FVP\_Base\_Cortex\_A510.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A510.cluster0.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu3.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu4**

ARM Cortex-A510CT model.

Type: ARM\_Cortex-A510.

**FVP\_Base\_Cortex\_A510.cluster0.cpu4.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A510.cluster0.cpu4.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu4.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu4.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu5**

ARM Cortex-A510CT model.

Type: ARM\_Cortex-A510.

**FVP\_Base\_Cortex\_A510.cluster0.cpu5.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A510.cluster0.cpu5.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu5.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu5.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu6**

ARM Cortex-A510CT model.

Type: ARM\_Cortex-A510.

**FVP\_Base\_Cortex\_A510.cluster0.cpu6.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A510.cluster0.cpu6.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu6.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu6.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu7**

ARM Cortex-A510CT model.

Type: ARM\_Cortex-A510.

**FVP\_Base\_Cortex\_A510.cluster0.cpu7.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A510.cluster0.cpu7.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu7.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0.cpu7.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A510.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A510.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A510.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A510.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A510.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A510.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A510.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A510.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A510.pctl.timer\_reset.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.9 FVP\_Base\_Cortex-A510x4+Cortex-A710x4

FVP\_Base\_Cortex-A510x4+Cortex-A710x4 contains the following instances:

### FVP\_Base\_Cortex-A510x4+Cortex-A710x4 instances

#### **FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4**

Base Platform Compute Subsystem for ARMCortexA510x4CT\_CortexA710x4CT.

Type: [FVP\\_Base\\_Cortex\\_A510x4\\_Cortex\\_A710x4](#).

#### **FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.hdlcd0.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.pl111\_clcd.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.cluster0**

ARM Cortex-A710 CT heterogeneous cluster model.

Type: [cluster\\_ARM\\_CortexA710\\_Heterogeneous\\_Cluster](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.cluster0.subcluster0**

ARM Cortex-A510 CT Model in Heterogeneous SubCluster.

Type: [Subcluster\\_ARM\\_Cortex-A510](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.cluster0.subcluster0.cpu0**

ARM Cortex-A510 CT Model in Heterogeneous Cluster.

Type: [cluster\\_ARM\\_Cortex-A510](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.cluster0.subcluster0.cpu1**

ARM Cortex-A510 CT Model in Heterogeneous Cluster.

Type: [cluster\\_ARM\\_Cortex-A510](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.cluster0.subcluster0.cpu2**

ARM Cortex-A510 CT Model in Heterogeneous Cluster.

Type: [cluster\\_ARM\\_Cortex-A510](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.cluster0.subcluster0.cpu3**

ARM Cortex-A510 CT Model in Heterogeneous Cluster.

Type: [cluster\\_ARM\\_Cortex-A510](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.cluster0.subcluster1**

ARM Cortex-A710 Cluster CT model.

Type: [Subcluster\\_ARM\\_CortexA710](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.cluster0.subcluster1.cpu0**

ARM Cortex-A710 CT Model in Heterogeneous Cluster.

Type: [Cluster\\_ARM\\_CortexA710](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.cluster0.subcluster1.cpu1**

ARM Cortex-A710 CT Model in Heterogeneous Cluster.

Type: [Cluster\\_ARM\\_CortexA710](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.cluster0.subcluster1.cpu2**

ARM Cortex-A710 CT Model in Heterogeneous Cluster.

Type: [Cluster\\_ARM\\_CortexA710](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.cluster0.subcluster1.cpu3**

ARM Cortex-A710 CT Model in Heterogeneous Cluster.

Type: [Cluster\\_ARM\\_CortexA710](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_Base\_Cortex\_A510x4\_Cortex\_A710x4.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.10 FVP\_Base\_Cortex-A53x1

FVP\_Base\_Cortex-A53x1 contains the following instances:

### FVP\_Base\_Cortex-A53x1 instances

#### **FVP\_Base\_Cortex\_A53x1**

Base Platform Compute Subsystem for ARM Cortex A53x1 CT.

Type: [FVP\\_Base\\_Cortex\\_A53x1](#).

#### **FVP\_Base\_Cortex\_A53x1.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A53x1.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A53x1.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A53x1.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A53x1.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_A53x1.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A53x1.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A53x1.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x1.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x1.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A53x1.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A53x1.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A53x1.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A53x1.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x1.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x1.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A53x1.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A53x1.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A53x1.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A53x1.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A53x1.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A53x1.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

#### **FVP\_Base\_Cortex\_A53x1.bp.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

#### **FVP\_Base\_Cortex\_A53x1.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x1.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x1.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x1.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A53x1.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A53x1.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A53x1.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A53x1.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A53x1.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A53x1.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Cortex\_A53x1.bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A53x1.bp.hd1cd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component

which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A53x1.bp.hd1cd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A53x1.bp.hd1cd0.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A53x1.bp.hd1cd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A53x1.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A53x1.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A53x1.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A53x1.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A53x1.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x1.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A53x1.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x1.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A53x1.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x1.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A53x1.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x1.bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A53x1.bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x1.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A53x1.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A53x1.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A53x1.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x1.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A53x1\_bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x1\_bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A53x1\_bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A53x1\_bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A53x1\_bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A53x1\_bp.p1111\_clcd.p111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A53x1\_bp.p1111\_clcd.p111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A53x1\_bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A53x1\_bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A53x1.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A53x1.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A53x1.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x1.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A53x1.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A53x1.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x1.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x1.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x1.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x1.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x1.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A53x1.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A53x1.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.  
Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A53x1.bp.sp805\_wdog**

ARM Watchdog Module(SP805).  
Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A53x1.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.  
Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A53x1.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x1.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x1.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x1.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x1.bp.sram**

RAM device, can be dynamic or static ram.  
Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x1.bp.terminal\_0**

Telnet terminal interface.  
Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A53x1.bp.terminal\_1**

Telnet terminal interface.  
Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A53x1.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A53x1.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A53x1.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A53x1.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A53x1.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A53x1.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A53x1.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A53x1.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A53x1.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A53x1.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A53x1.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A53x1.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A53x1.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A53x1.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A53x1.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A53x1.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A53x1.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A53x1.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A53x1.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x1.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x1.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x1.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A53x1.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x1.cluster0**

ARM Cortex-A53 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A53](#).

**FVP\_Base\_Cortex\_A53x1.cluster0.cpu0**

ARM Cortex-A53 CT model.

Type: [ARM\\_Cortex-A53](#).

**FVP\_Base\_Cortex\_A53x1.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A53x1.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A53x1.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A53x1.cluster0.l2\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A53x1.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A53x1.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A53x1.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A53x1.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A53x1.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A53x1.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A53x1.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A53x1.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A53x1.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.11 FVP\_Base\_Cortex-A53x2

FVP\_Base\_Cortex-A53x2 contains the following instances:

### FVP\_Base\_Cortex-A53x2 instances

**FVP\_Base\_Cortex\_A53x2**

Base Platform Compute Subsystem for ARM Cortex A53x2 CT.

Type: [FVP\\_Base\\_Cortex\\_A53x2](#).

**FVP\_Base\_Cortex\_A53x2.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A53x2.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A53x2.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x2.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x2.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A53x2.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A53x2.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A53x2.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x2.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x2.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A53x2.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A53x2.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A53x2.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A53x2.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x2.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x2.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A53x2.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A53x2.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A53x2.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A53x2.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A53x2.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A53x2.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

#### **FVP\_Base\_Cortex\_A53x2.bp.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

#### **FVP\_Base\_Cortex\_A53x2.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x2.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x2.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x2.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A53x2.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A53x2.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A53x2.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A53x2.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A53x2.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A53x2.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Cortex\_A53x2.bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A53x2.bp.hd1cd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component

which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A53x2.bp.hd1cd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A53x2.bp.hd1cd0.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A53x2.bp.hd1cd0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A53x2.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A53x2.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A53x2.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A53x2.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A53x2.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x2.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A53x2.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x2.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A53x2\_bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x2\_bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A53x2\_bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x2\_bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A53x2\_bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x2\_bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A53x2\_bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A53x2\_bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A53x2\_bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x2\_bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A53x2\_bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x2\_bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A53x2\_bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A53x2\_bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A53x2\_bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A53x2\_bp.p1111\_clcd.p111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A53x2\_bp.p1111\_clcd.p111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A53x2\_bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A53x2\_bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A53x2.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A53x2.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A53x2.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x2.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A53x2.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A53x2.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x2.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x2.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x2.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x2.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x2.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A53x2.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A53x2.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A53x2.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A53x2.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A53x2.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x2.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x2.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x2.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x2.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x2.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A53x2.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A53x2.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A53x2.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A53x2.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A53x2.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A53x2.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A53x2.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A53x2.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A53x2.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A53x2.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A53x2.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A53x2.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A53x2.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A53x2.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A53x2.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A53x2.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A53x2.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A53x2.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A53x2.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A53x2.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x2.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x2.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x2.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCl400](#).

**FVP\_Base\_Cortex\_A53x2.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x2.cluster0**

ARM Cortex-A53 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A53](#).

**FVP\_Base\_Cortex\_A53x2.cluster0.cpu0**

ARM Cortex-A53 CT model.

Type: [ARM\\_Cortex-A53](#).

**FVP\_Base\_Cortex\_A53x2.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A53x2.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A53x2.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A53x2.cluster0.cpu1**

ARM Cortex-A53 CT model.

Type: [ARM\\_Cortex-A53](#).

**FVP\_Base\_Cortex\_A53x2.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A53x2.cluster0.cpu1.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A53x2.cluster0.cpu1.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A53x2.cluster0.l2\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A53x2.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A53x2.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A53x2.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A53x2.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A53x2.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A53x2.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A53x2.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A53x2.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A53x2.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.12 FVP\_Base\_Cortex-A53x4

FVP\_Base\_Cortex-A53x4 contains the following instances:

### FVP\_Base\_Cortex-A53x4 instances

**FVP\_Base\_Cortex\_A53x4**

Base Platform Compute Subsystem for ARM CortexA53x4CT.

Type: [FVP\\_Base\\_Cortex\\_A53x4](#).

**FVP\_Base\_Cortex\_A53x4.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A53x4.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A53x4.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A53x4.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A53x4.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A53x4.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A53x4.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A53x4.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A53x4.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A53x4.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x4.bp.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x4.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x4.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x4.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x4.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBuseExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A53x4.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A53x4.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A53x4.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A53x4.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A53x4.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A53x4.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Cortex\_A53x4.bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A53x4.bp.hd1cd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A53x4.bp.hd1cd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A53x4.bp.hd1cd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A53x4.bp.hd1cd0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A53x4.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A53x4.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A53x4.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A53x4.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A53x4.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x4.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A53x4.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A53x4.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A53x4.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A53x4.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A53x4.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A53x4.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A53x4.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A53x4.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A53x4.bp.pl111\_clcd.pl111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL111x\\_CLCD](#).

**FVP\_Base\_Cortex\_A53x4.bp.pl111\_clcd.pl111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A53x4.bp.pl111\_clcd.pl111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A53x4.bp.pl111\_clcd.pl111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A53x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A53x4.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A53x4.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A53x4.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A53x4.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A53x4.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x4.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A53x4.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A53x4.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x4.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x4.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x4.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x4.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x4.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A53x4.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A53x4.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Cortex\_A53x4.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A53x4.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x4.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A53x4.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A53x4.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A53x4.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A53x4.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A53x4.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A53x4.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A53x4.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A53x4.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A53x4.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A53x4.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A53x4.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A53x4.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A53x4.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.  
Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A53x4.bp.virtioblockdevice**

virtio block device.  
Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A53x4.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A53x4.bp.virtiop9device**

virtio P9 server.  
Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A53x4.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A53x4.bp.vis**

Display window for VE using Visualisation library.  
Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A53x4.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).  
Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A53x4.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.bp.vram**

RAM device, can be dynamic or static ram.  
Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A53x4.cci400**

Cache Coherent Interconnect for AXI4 ACE.  
Type: [CC1400](#).

**FVP\_Base\_Cortex\_A53x4.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A53x4.cluster0**

ARM Cortex-A53 Cluster CT model.

Type: cluster\_ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A53x4.cluster0.cpu0**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A53x4.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A53x4.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A53x4.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A53x4.cluster0.cpu1**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A53x4.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A53x4.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A53x4.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A53x4.cluster0.cpu2**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A53x4.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A53x4.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A53x4.cluster0.cpu2.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A53x4.cluster0.cpu3**

ARM Cortex-A53 CT model.

Type: [ARM\\_Cortex-A53](#).

**FVP\_Base\_Cortex\_A53x4.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A53x4.cluster0.cpu3.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A53x4.cluster0.cpu3.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A53x4.cluster0.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A53x4.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A53x4.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A53x4.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A53x4.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A53x4.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A53x4.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A53x4.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A53x4.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A53x4.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.13 FVP\_Base\_Cortex-A55

FVP\_Base\_Cortex-A55 contains the following instances:

### FVP\_Base\_Cortex-A55 instances

**FVP\_Base\_Cortex\_A55**

Base Platform Compute Subsystem for ARM Cortex A55 CT.

Type: [FVP\\_Base\\_Cortex\\_A55](#).

**FVP\_Base\_Cortex\_A55.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A55.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A55.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A55.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A55.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A55.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A55.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A55.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A55.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A55.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A55.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A55.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A55.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A55.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A55.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A55.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55.bp.hdlcd0.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A55.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A55.bp mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A55.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55.bp.p1011\_uart0**

ARM PrimeCell UART(PLO11).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55\_bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55\_bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55\_bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A55\_bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A55\_bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A55\_bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A55\_bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A55\_bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A55\_bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55\_bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55\_bp.p1111\_clcd.p111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55\_bp.p1111\_clcd.p111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A55\_bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55\_bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A55.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A55.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A55.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A55.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A55.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A55.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A55.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A55.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A55.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A55.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A55.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A55.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A55.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A55.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A55.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A55.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A55.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A55.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A55.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A55.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A55.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A55.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55.cluster0**

ARM Cortex-A55 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55.cluster0.cpu0**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A55.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu0.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu1**

ARM Cortex-A55 CT model.

Type: ARM\_Cortex-A55.

**FVP\_Base\_Cortex\_A55.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A55.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu1.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu2**

ARM Cortex-A55 CT model.

Type: ARM\_Cortex-A55.

**FVP\_Base\_Cortex\_A55.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A55.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu2.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu3**

ARM Cortex-A55 CT model.

Type: ARM\_Cortex-A55.

**FVP\_Base\_Cortex\_A55.cluster0.cpu3.dt1b**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A55.cluster0.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu3.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu4**

ARM Cortex-A55 CT model.

Type: ARM\_Cortex-A55.

**FVP\_Base\_Cortex\_A55.cluster0.cpu4.dt1b**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A55.cluster0.cpu4.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu4.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu4.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu5**

ARM Cortex-A55 CT model.

Type: ARM\_Cortex-A55.

**FVP\_Base\_Cortex\_A55.cluster0.cpu5.dt1b**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A55.cluster0.cpu5.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu5.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu5.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu6**

ARM Cortex-A55 CT model.

Type: ARM\_Cortex-A55.

**FVP\_Base\_Cortex\_A55.cluster0.cpu6.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A55.cluster0.cpu6.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu6.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu6.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu7**

ARM Cortex-A55 CT model.

Type: ARM\_Cortex-A55.

**FVP\_Base\_Cortex\_A55.cluster0.cpu7.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A55.cluster0.cpu7.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu7.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0.cpu7.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A55.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A55.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A55.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A55.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A55.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.14 FVP\_Base\_Cortex-A55+Cortex-A76

FVP\_Base\_Cortex-A55+Cortex-A76 contains the following instances:

### FVP\_Base\_Cortex-A55+Cortex-A76 instances

#### **FVP\_Base\_Cortex\_A55\_Cortex\_A76**

Base Platform Compute Subsystem for ARMCortexA55CT\_CortexA76CT.

Type: [FVP\\_Base\\_Cortex\\_A55\\_Cortex\\_A76](#).

#### **FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.mmcc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.cluster0**

ARM Cortex-A55\_Cortex-A76 Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-A55\\_Cortex-A76](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.cluster0.subcluster0**

ARM Cortex-A55 Cluster CT model.

Type: [Subcluster\\_ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.cluster0.subcluster0.cpu0**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.cluster0.subcluster1**

ARM Cortex-A76 Cluster CT model.

Type: [Subcluster\\_ARM\\_Cortex-A76](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.cluster0.subcluster1.cpu0**

ARM Cortex-A76 CT model.

Type: [ARM\\_Cortex-A76](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55\_Cortex\_A76.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.15 FVP\_Base\_Cortex-A55x1+Cortex-A75x1

FVP\_Base\_Cortex-A55x1+Cortex-A75x1 contains the following instances:

### FVP\_Base\_Cortex-A55x1+Cortex-A75x1 instances

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1**

Base Platform Compute Subsystem for ARMCortexA55x1CT\_CortexA75x1CT.

Type: [FVP\\_Base\\_Cortex\\_A55x1\\_Cortex\\_A75x1](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.pl111\_clcd.pl111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.pl111\_clcd.pl111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.pl111\_clcd.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSCHandler](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.sp810\_sysctrl1.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.vedcc**

Daughterboard Configuration Control (DCC).  
Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.virtio\_net**

VirtioNet device over MMIO transport.  
Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.  
Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.virtioblockdevice**

virtio block device.  
Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.virtiop9device**

virtio P9 server.  
Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.vis**

Display window for VE using Visualisation library.  
Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).  
Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCI400](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.cluster0**

ARM Cortex-A55\_Cortex-A75 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A55\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.cluster0.subcluster0**

ARM Cortex-A55 Cluster CT model.

Type: [Subcluster\\_ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.cluster0.subcluster0.cpu0**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.cluster0.subcluster1**

ARM Cortex-A75 Cluster CT model.

Type: [Subcluster\\_ARM\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.cluster0.subcluster1.cpu0**

ARM Cortex-A75 CT model.

Type: [ARM\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55x1\_Cortex\_A75x1.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.16 FVP\_Base\_Cortex-A55x2+Cortex-A75x2

FVP\_Base\_Cortex-A55x2+Cortex-A75x2 contains the following instances:

### FVP\_Base\_Cortex-A55x2+Cortex-A75x2 instances

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2**

Base Platform Compute Subsystem for ARMCortexA55x2CT\_CortexA75x2CT.

Type: [FVP\\_Base\\_Cortex\\_A55x2\\_Cortex\\_A75x2](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBuseExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.cluster0**

ARM Cortex-A55\_Cortex-A75 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A55\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.cluster0.subcluster0**

ARM Cortex-A55 Cluster CT model.

Type: [Subcluster\\_ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.cluster0.subcluster0.cpu0**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.cluster0.subcluster0.cpu1**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.cluster0.subcluster1**

ARM Cortex-A75 Cluster CT model.

Type: [Subcluster\\_ARM\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.cluster0.subcluster1.cpu0**

ARM Cortex-A75 CT model.

Type: [ARM\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.cluster0.subcluster1.cpu1**

ARM Cortex-A75 CT model.

Type: [ARM\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal()

callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_Base\_Cortex\_A55x2\_Cortex\_A75x2.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.17 FVP\_Base\_Cortex-A55x4+Cortex-A75x1

FVP\_Base\_Cortex-A55x4+Cortex-A75x1 contains the following instances:

### FVP\_Base\_Cortex-A55x4+Cortex-A75x1 instances

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1**

Base Platform Compute Subsystem for ARM Cortex A55x4 CT\_Cortex A75x1 CT.

Type: [FVP\\_Base\\_Cortex\\_A55x4\\_Cortex\\_A75x1](#).

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly

or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.p1011\_uart0**

ARM PrimeCell UART(PLO11).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.p1111\_clcd.p111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.r1\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.cluster0**

ARM Cortex-A55\_Cortex-A75 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A55\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.cluster0.subcluster0**

ARM Cortex-A55 Cluster CT model.

Type: [Subcluster\\_ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.cluster0.subcluster0.cpu0**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.cluster0.subcluster0.cpu1**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.cluster0.subcluster0.cpu2**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.cluster0.subcluster0.cpu3**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.cluster0.subcluster1**

ARM Cortex-A75 Cluster CT model.

Type: [Subcluster\\_ARM\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.cluster0.subcluster1.cpu0**

ARM Cortex-A75 CT model.

Type: [ARM\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x1.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.18 FVP\_Base\_Cortex-A55x4+Cortex-A75x2

FVP\_Base\_Cortex-A55x4+Cortex-A75x2 contains the following instances:

### FVP\_Base\_Cortex-A55x4+Cortex-A75x2 instances

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2**

Base Platform Compute Subsystem for ARMCortexA55x4CT\_CortexA75x2CT.

Type: [FVP\\_Base\\_Cortex\\_A55x4\\_Cortex\\_A75x2](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBuseExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.hdlcd0.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.cluster0**

ARM Cortex-A55\_Cortex-A75 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A55\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.cluster0.subcluster0**

ARM Cortex-A55 Cluster CT model.

Type: [Subcluster\\_ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.cluster0.subcluster0.cpu0**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.cluster0.subcluster0.cpu1**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.cluster0.subcluster0.cpu2**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.cluster0.subcluster0.cpu3**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.cluster0.subcluster1**

ARM Cortex-A75 Cluster CT model.

Type: [Subcluster\\_ARM\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.cluster0.subcluster1.cpu0**

ARM Cortex-A75 CT model.

Type: [ARM\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.cluster0.subcluster1.cpu1**

ARM Cortex-A75 CT model.

Type: [ARM\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x2.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.19 FVP\_Base\_Cortex-A55x4+Cortex-A75x4

FVP\_Base\_Cortex-A55x4+Cortex-A75x4 contains the following instances:

### FVP\_Base\_Cortex-A55x4+Cortex-A75x4 instances

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4**

Base Platform Compute Subsystem for ARMCortexA55x4CT\_CortexA75x4CT.

Type: [FVP\\_Base\\_Cortex\\_A55x4\\_Cortex\\_A75x4](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.virtio\_net\_labeler**

Type: [Labeler](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.virtioblockdevice\_labeler**

Type: [Labeler](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.virtiop9device\_labeler**

Type: [Labeler](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCI400](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.cluster0**

ARM Cortex-A55\_Cortex-A75 Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-A55\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.cluster0.subcluster0**

ARM Cortex-A55 Cluster CT model.

Type: [Subcluster\\_ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.cluster0.subcluster0.cpu0**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.cluster0.subcluster0.cpu1**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.cluster0.subcluster0.cpu2**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.cluster0.subcluster0.cpu3**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.cluster0.subcluster1**

ARM Cortex-A75 Cluster CT model.

Type: [Subcluster\\_ARM\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.cluster0.subcluster1.cpu0**

ARM Cortex-A75 CT model.

Type: [ARM\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.cluster0.subcluster1.cpu1**

ARM Cortex-A75 CT model.

Type: [ARM\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.cluster0.subcluster1.cpu2**

ARM Cortex-A75 CT model.

Type: [ARM\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.cluster0.subcluster1.cpu3**

ARM Cortex-A75 CT model.

Type: [ARM\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A75x4.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.20 FVP\_Base\_Cortex-A55x4+Cortex-A76x2

FVP\_Base\_Cortex-A55x4+Cortex-A76x2 contains the following instances:

### FVP\_Base\_Cortex-A55x4+Cortex-A76x2 instances

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2**

Base Platform Compute Subsystem for ARMCortexA55x4CT\_CortexA76x2CT.

Type: [FVP\\_Base\\_Cortex\\_A55x4\\_Cortex\\_A76x2](#).

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.pl111\_clcd.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.pl1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2\_bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.cluster0**

ARM Cortex-A55\_Cortex-A76 Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-A55\\_Cortex-A76](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.cluster0.subcluster0**

ARM Cortex-A55 Cluster CT model.

Type: [Subcluster\\_ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.cluster0.subcluster0.cpu0**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.cluster0.subcluster0.cpu1**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.cluster0.subcluster0.cpu2**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.cluster0.subcluster0.cpu3**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.cluster0.subcluster1**

ARM Cortex-A76 Cluster CT model.

Type: [Subcluster\\_ARM\\_Cortex-A76](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.cluster0.subcluster1.cpu0**

ARM Cortex-A76 CT model.

Type: ARM\_Cortex-A76.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.cluster0.subcluster1.cpu1**

ARM Cortex-A76 CT model.

Type: ARM\_Cortex-A76.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A76x2.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.21 FVP\_Base\_Cortex-A55x4+Cortex-A78x4

FVP\_Base\_Cortex-A55x4+Cortex-A78x4 contains the following instances:

### FVP\_Base\_Cortex-A55x4+Cortex-A78x4 instances

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4**

Base Platform Compute Subsystem for ARMCortexA55x4CT\_CortexA78x4CT.

Type: [FVP\\_Base\\_Cortex\\_A55x4\\_Cortex\\_A78x4](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4\_bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4\_bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4\_bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4\_bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4\_bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4\_bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4\_bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4\_bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4\_bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.hd1cd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.pl111\_clcd.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.pl1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl1](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal1](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal1](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal1](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal1](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [virtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.vis**

Display window for VE using Visualisation library.

Type: vEVisualisation.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.cluster0**

ARM Cortex-A55\_Cortex-A78 Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-A55\\_Cortex-A78](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.cluster0.subcluster0**

ARM Cortex-A55 Cluster CT model.

Type: [Subcluster\\_ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.cluster0.subcluster0.cpu0**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.cluster0.subcluster0.cpu1**

ARM Cortex-A55 CT model.

Type: [ARM\\_Cortex-A55](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.cluster0.subcluster0.cpu2**

ARM Cortex-A55 CT model.

Type: ARM\_Cortex-A55.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.cluster0.subcluster0.cpu3**

ARM Cortex-A55 CT model.

Type: ARM\_Cortex-A55.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.cluster0.subcluster1**

ARM Cortex-A78 Cluster CT model.

Type: Subcluster\_ARM\_Cortex-A78.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.cluster0.subcluster1.cpu0**

ARM Cortex-A78 CT model.

Type: ARM\_Cortex-A78.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.cluster0.subcluster1.cpu1**

ARM Cortex-A78 CT model.

Type: ARM\_Cortex-A78.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.cluster0.subcluster1.cpu2**

ARM Cortex-A78 CT model.

Type: ARM\_Cortex-A78.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.cluster0.subcluster1.cpu3**

ARM Cortex-A78 CT model.

Type: ARM\_Cortex-A78.

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_Base\_Cortex\_A55x4\_Cortex\_A78x4.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.22 FVP\_Base\_Cortex-A57x1

FVP\_Base\_Cortex-A57x1 contains the following instances:

### **FVP\_Base\_Cortex-A57x1 instances**

#### **FVP\_Base\_Cortex\_A57x1**

Base Platform Compute Subsystem for ARM Cortex A57x1 CT.

Type: [FVP\\_Base\\_Cortex\\_A57x1](#).

#### **FVP\_Base\_Cortex\_A57x1.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A57x1.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A57x1.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A57x1.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x1.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x1.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A57x1.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x1.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x1.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A57x1.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A57x1.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A57x1\_bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x1\_bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x1\_bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x1\_bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x1\_bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A57x1\_bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A57x1\_bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x1.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x1.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x1.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A57x1.bp.hdlcd0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x1.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A57x1.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A57x1.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x1.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x1.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x1.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x1.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x1.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x1.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A57x1.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A57x1.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A57x1.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A57x1\_bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A57x1\_bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A57x1\_bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x1\_bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x1\_bp.p1111\_clcd.p111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x1\_bp.p1111\_clcd.p111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A57x1\_bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x1\_bp.pl1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A57x1\_bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A57x1\_bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A57x1\_bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A57x1\_bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A57x1\_bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x1.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x1.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [smsc\\_91c111](#).

**FVP\_Base\_Cortex\_A57x1.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A57x1.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A57x1.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x1.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x1.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x1.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x1.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A57x1.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A57x1.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A57x1.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A57x1.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A57x1.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A57x1.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A57x1.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A57x1.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x1.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [virtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A57x1.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A57x1.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x1.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A57x1.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x1.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A57x1.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A57x1.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A57x1.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1.cluster0**

ARM Cortex-A57 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A57](#).

**FVP\_Base\_Cortex\_A57x1.cluster0.cpu0**

ARM Cortex-A57 CT model.

Type: ARM\_Cortex-A57.

**FVP\_Base\_Cortex\_A57x1.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TLbCadi.

**FVP\_Base\_Cortex\_A57x1.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x1.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x1.cluster0.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x1.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x1.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A57x1.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A57x1.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A57x1.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A57x1.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x1.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke

`wait()` functions to wait for time or events. This is not allowed for the `ClockTimer` component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use `ClockTimerThread(64)` rather than `ClockTimer(64)`.

Type: [ClockTimerThread64](#).

#### **FVP\_Base\_Cortex\_A57x1.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_Base\_Cortex\_A57x1.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.23 FVP\_Base\_Cortex-A57x1-A35x1

FVP\_Base\_Cortex-A57x1-A35x1 contains the following instances:

### FVP\_Base\_Cortex-A57x1-A35x1 instances

#### **FVP\_Base\_Cortex\_A57x1\_A35x1**

Base Platform Compute Subsystem for ARM Cortex A57x1CT and ARM Cortex A35x1CT.

Type: [FVP\\_Base\\_Cortex\\_A57x1\\_A35x1](#).

#### **FVP\_Base\_Cortex\_A57x1\_A35x1\_bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A57x1\_A35x1\_bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A57x1\_A35x1\_bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A57x1\_A35x1\_bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A57x1\_A35x1\_bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a

proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.hdlcd0.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.mmcc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.p1111\_clcd.p111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.p1111\_clcd.p111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.p1111\_clcd.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.terminal\_2**  
Telnet terminal interface.  
Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.terminal\_3**  
Telnet terminal interface.  
Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.trusted\_key\_storage**  
Trusted Root-Key Storage unit.  
Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.trusted\_nv\_counter**  
Trusted Non-Volatile Counter unit.  
Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.trusted\_rng**  
Random Number Generator unit.  
Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.trusted\_watchdog**  
ARM Watchdog Module(SP805).  
Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.tzc\_400**  
TrustZone Address Space Controller.  
Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.ve\_sysregs**  
Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.vedcc**  
Daughterboard Configuration Control (DCC).  
Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.virtio\_net**  
VirtioNet device over MMIO transport.  
Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.virtio\_net\_labeller**  
Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.virtio\_rng**  
VirtioEntropy device over MMIO transport.  
Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.virtioblockdevice**  
virtio block device.  
Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.virtioblockdevice\_labeller**  
Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.clockdivider1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.cluster0**

ARM Cortex-A57 Cluster CT model.

Type: cluster\_ARM\_Cortex-A57.

**FVP\_Base\_Cortex\_A57x1\_A35x1.cluster0.cpu0**

ARM Cortex-A57 CT model.

Type: ARM\_Cortex-A57.

**FVP\_Base\_Cortex\_A57x1\_A35x1.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x1\_A35x1.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x1\_A35x1.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x1\_A35x1.cluster0.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x1\_A35x1.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.cluster1**

ARM Cortex-A35 Cluster CT model.

Type: cluster\_ARM\_Cortex-A35.

**FVP\_Base\_Cortex\_A57x1\_A35x1.cluster1.cpu0**

ARM Cortex-A35 CT model.

Type: ARM\_Cortex-A35.

**FVP\_Base\_Cortex\_A57x1\_A35x1.cluster1.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x1\_A35x1.cluster1.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x1\_A35x1.cluster1.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x1\_A35x1.cluster1.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x1\_A35x1.cluster1.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x1\_A35x1.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.24 FVP\_Base\_Cortex-A57x1-A53x1

FVP\_Base\_Cortex-A57x1-A53x1 contains the following instances:

### FVP\_Base\_Cortex-A57x1-A53x1 instances

#### **FVP\_Base\_Cortex\_A57x1\_A53x1**

Base Platform Compute Subsystem for ARM Cortex A57x1CT and ARM Cortex A53x1CT.

Type: [FVP\\_Base\\_Cortex\\_A57x1\\_A53x1](#).

#### **FVP\_Base\_Cortex\_A57x1\_A53x1\_bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A57x1\_A53x1\_bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A57x1\_A53x1\_bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A57x1\_A53x1\_bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A57x1\_A53x1\_bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_A57x1\_A53x1\_bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_A57x1\_A53x1\_bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A57x1\_A53x1\_bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.hdlcd0.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.hd1cd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.mmci**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.clockdivider1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.cluster0**

ARM Cortex-A57 Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-A57](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.cluster0.cpu0**

ARM Cortex-A57 CT model.

Type: [ARM\\_Cortex-A57](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.cluster0.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.cluster1**

ARM Cortex-A53 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A53](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.cluster1.cpu0**

ARM Cortex-A53 CT model.

Type: [ARM\\_Cortex-A53](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.cluster1.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.cluster1.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.cluster1.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.cluster1.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.cluster1.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A57x1\_A53x1.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal()

callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_Base\_Cortex\_A57x1\_A53x1.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_Base\_Cortex\_A57x1\_A53x1.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_Base\_Cortex\_A57x1\_A53x1.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.25 FVP\_Base\_Cortex-A57x2

FVP\_Base\_Cortex-A57x2 contains the following instances:

### **FVP\_Base\_Cortex-A57x2 instances**

#### **FVP\_Base\_Cortex\_A57x2**

Base Platform Compute Subsystem for ARM Cortex A57x2CT.

Type: [FVP\\_Base\\_Cortex\\_A57x2](#).

#### **FVP\_Base\_Cortex\_A57x2.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A57x2.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A57x2.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x2\_bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x2\_bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A57x2\_bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x2\_bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x2\_bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A57x2\_bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A57x2\_bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A57x2\_bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A57x2\_bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A57x2\_bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A57x2\_bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A57x2\_bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A57x2\_bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A57x2\_bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A57x2.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x2.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x2.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x2.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x2.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A57x2.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Cortex\_A57x2.bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly

or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x2\_bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x2\_bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x2\_bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A57x2\_bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x2\_bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A57x2\_bp mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A57x2\_bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x2\_bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x2\_bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_bp.p1011\_uart0**

ARM PrimeCell UART(PLO11).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x2\_bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x2\_bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x2\_bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x2\_bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A57x2\_bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A57x2\_bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A57x2\_bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A57x2\_bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A57x2\_bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A57x2\_bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x2\_bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x2\_bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x2\_bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A57x2\_bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x2\_bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A57x2\_bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A57x2\_bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A57x2\_bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A57x2\_bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A57x2\_bp.r1\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x2\_bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x2\_bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Cortex\_A57x2\_bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A57x2\_bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A57x2\_bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal1](#).

**FVP\_Base\_Cortex\_A57x2\_bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal1](#).

**FVP\_Base\_Cortex\_A57x2\_bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal1](#).

**FVP\_Base\_Cortex\_A57x2\_bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal1](#).

**FVP\_Base\_Cortex\_A57x2\_bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A57x2\_bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A57x2\_bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A57x2\_bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A57x2\_bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A57x2\_bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A57x2\_bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A57x2\_bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A57x2\_bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x2.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.  
Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A57x2.bp.virtioblockdevice**

virtio block device.  
Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A57x2.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x2.bp.virtiop9device**

virtio P9 server.  
Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A57x2.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x2.bp.vis**

Display window for VE using Visualisation library.  
Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A57x2.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).  
Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A57x2.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2.bp.vram**

RAM device, can be dynamic or static ram.  
Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2.cci400**

Cache Coherent Interconnect for AXI4 ACE.  
Type: [CC1400](#).

**FVP\_Base\_Cortex\_A57x2.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2.cluster0**

ARM Cortex-A57 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A57](#).

**FVP\_Base\_Cortex\_A57x2.cluster0.cpu0**

ARM Cortex-A57 CT model.

Type: [ARM\\_Cortex-A57](#).

**FVP\_Base\_Cortex\_A57x2.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A57x2.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x2.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x2.cluster0.cpu1**

ARM Cortex-A57 CT model.

Type: [ARM\\_Cortex-A57](#).

**FVP\_Base\_Cortex\_A57x2.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A57x2.cluster0.cpu1.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x2.cluster0.cpu1.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x2.cluster0.l2\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x2.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x2.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A57x2.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A57x2.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A57x2.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A57x2.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x2.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x2.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x2.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.26 FVP\_Base\_Cortex-A57x2-A35x4

FVP\_Base\_Cortex-A57x2-A35x4 contains the following instances:

### FVP\_Base\_Cortex-A57x2-A35x4 instances

**FVP\_Base\_Cortex\_A57x2\_A35x4**

Base Platform Compute Subsystem for ARM Cortex A57x2CT and ARM Cortex A35x4CT.

Type: [FVP\\_Base\\_Cortex\\_A57x2\\_A35x4](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.hdlcd0.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke

wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.pl111\_clcd.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSCL\\_91C111](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [virtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCI400](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.clockdivider1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster0**

ARM Cortex-A57 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A57](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster0.cpu0**

ARM Cortex-A57 CT model.

Type: [ARM\\_Cortex-A57](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster0.cpu1**

ARM Cortex-A57 CT model.

Type: [ARM\\_Cortex-A57](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster0.cpu1.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster0.cpu1.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster0.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster1**

ARM Cortex-A35 Cluster CT model.

Type: Cluster\_ARM\_Cortex-A35.

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster1.cpu0**

ARM Cortex-A35 CT model.

Type: ARM\_Cortex-A35.

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster1.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster1.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster1.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster1.cpu1**

ARM Cortex-A35 CT model.

Type: ARM\_Cortex-A35.

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster1.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster1.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster1.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster1.cpu2**

ARM Cortex-A35 CT model.

Type: ARM\_Cortex-A35.

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster1.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster1.cpu2.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster1.cpu2.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster1.cpu3**

ARM Cortex-A35 CT model.

Type: [ARM\\_Cortex-A35](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster1.cpu3.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster1.cpu3.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster1.cpu3.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster1.l2\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.cluster1\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A57x2\_A35x4.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_Base\_Cortex\_A57x2\_A35x4.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_Base\_Cortex\_A57x2\_A35x4.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_Base\_Cortex\_A57x2\_A35x4.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.27 FVP\_Base\_Cortex-A57x2-A53x4

FVP\_Base\_Cortex-A57x2-A53x4 contains the following instances:

### FVP\_Base\_Cortex-A57x2-A53x4 instances

#### **FVP\_Base\_Cortex\_A57x2\_A53x4**

Base Platform Compute Subsystem for ARM Cortex A57x2CT and ARM Cortex A53x4CT.

Type: [FVP\\_Base\\_Cortex\\_A57x2\\_A53x4](#).

#### **FVP\_Base\_Cortex\_A57x2\_A53x4.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A57x2\_A53x4.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A57x2\_A53x4.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A57x2\_A53x4.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.hdlcd0.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.pl1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [smsc\\_91c111](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [virtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.clockdivider1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster0**

ARM Cortex-A57 Cluster CT model.

Type: cluster\_ARM\_Cortex-A57.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster0.cpu0**

ARM Cortex-A57 CT model.

Type: ARM\_Cortex-A57.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster0.cpu1**

ARM Cortex-A57 CT model.

Type: ARM\_Cortex-A57.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster0.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster1**

ARM Cortex-A53 Cluster CT model.

Type: cluster\_ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster1.cpu0**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster1.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster1.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster1.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster1.cpu1**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster1.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster1.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster1.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster1.cpu2**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster1.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster1.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster1.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster1.cpu3**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster1.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster1.cpu3.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster1.cpu3.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster1.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.cluster1\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x2\_A53x4.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.28 FVP\_Base\_Cortex-A57x4

FVP\_Base\_Cortex-A57x4 contains the following instances:

### FVP\_Base\_Cortex-A57x4 instances

**FVP\_Base\_Cortex\_A57x4**

Base Platform Compute Subsystem for ARMCortexA57x4CT.

Type: [FVP\\_Base\\_Cortex\\_A57x4](#).

**FVP\_Base\_Cortex\_A57x4.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A57x4.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A57x4.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A57x4.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A57x4.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A57x4\_bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x4\_bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x4\_bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A57x4\_bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A57x4\_bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A57x4.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x4.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x4.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x4.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x4.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A57x4.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A57x4.bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x4.bp.hd1cd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x4\_bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x4\_bp.hdlcd0.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A57x4\_bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x4\_bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A57x4\_bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A57x4\_bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x4\_bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x4\_bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x4\_bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x4\_bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x4.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4.bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x4.bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A57x4.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A57x4.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A57x4.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A57x4.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A57x4.bp.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A57x4.bp.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A57x4.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x4.bp.pl1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A57x4.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A57x4.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A57x4.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A57x4.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A57x4.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x4.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x4.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Cortex\_A57x4.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A57x4.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A57x4.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x4.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x4.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x4.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x4\_bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A57x4\_bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A57x4\_bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A57x4\_bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A57x4\_bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A57x4\_bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A57x4\_bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A57x4\_bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A57x4\_bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x4\_bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A57x4\_bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A57x4\_bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x4\_bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A57x4\_bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x4\_bp.vis**

Display window for VE using Visualisation library.

Type: vEVisualisation.

**FVP\_Base\_Cortex\_A57x4.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A57x4.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A57x4.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4.cluster0**

ARM Cortex-A57 Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-A57](#).

**FVP\_Base\_Cortex\_A57x4.cluster0.cpu0**

ARM Cortex-A57 CT model.

Type: [ARM\\_Cortex-A57](#).

**FVP\_Base\_Cortex\_A57x4.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A57x4.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x4.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4.cluster0.cpu1**

ARM Cortex-A57 CT model.

Type: ARM\_Cortex-A57.

**FVP\_Base\_Cortex\_A57x4.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x4.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4.cluster0.cpu2**

ARM Cortex-A57 CT model.

Type: ARM\_Cortex-A57.

**FVP\_Base\_Cortex\_A57x4.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x4.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4.cluster0.cpu3**

ARM Cortex-A57 CT model.

Type: ARM\_Cortex-A57.

**FVP\_Base\_Cortex\_A57x4.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x4.cluster0.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4.cluster0.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4.cluster0.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x4.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x4.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A57x4.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A57x4.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A57x4.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A57x4.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x4.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x4.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x4.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.29 FVP\_Base\_Cortex-A57x4-A35x4

FVP\_Base\_Cortex-A57x4-A35x4 contains the following instances:

### FVP\_Base\_Cortex-A57x4-A35x4 instances

#### **FVP\_Base\_Cortex\_A57x4\_A35x4**

Base Platform Compute Subsystem for ARM Cortex A57x4CT and ARM Cortex A35x4CT.

Type: [FVP\\_Base\\_Cortex\\_A57x4\\_A35x4](#).

#### **FVP\_Base\_Cortex\_A57x4\_A35x4\_bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A57x4\_A35x4\_bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A57x4\_A35x4\_bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A57x4\_A35x4\_bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A57x4\_A35x4\_bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_A57x4\_A35x4\_bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_A57x4\_A35x4\_bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A57x4\_A35x4\_bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.hdlcd0.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.hd1cd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.pl111\_clcd.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.clockdivider1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster0**

ARM Cortex-A57 Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-A57](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster0.cpu0**

ARM Cortex-A57 CT model.

Type: [ARM\\_Cortex-A57](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster0.cpu1**

ARM Cortex-A57 CT model.

Type: ARM\_Cortex-A57.

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster0.cpu2**

ARM Cortex-A57 CT model.

Type: ARM\_Cortex-A57.

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster0.cpu3**

ARM Cortex-A57 CT model.

Type: ARM\_Cortex-A57.

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster0.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster0.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster0.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster1**

ARM Cortex-A35 Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-A35](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster1.cpu0**

ARM Cortex-A35 CT model.

Type: [ARM\\_Cortex-A35](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster1.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster1.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster1.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster1.cpu1**

ARM Cortex-A35 CT model.

Type: [ARM\\_Cortex-A35](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster1.cpu1.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster1.cpu1.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster1.cpu1.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster1.cpu2**

ARM Cortex-A35 CT model.

Type: [ARM\\_Cortex-A35](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster1.cpu2.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster1.cpu2.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster1.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster1.cpu3**

ARM Cortex-A35 CT model.

Type: ARM\_Cortex-A35.

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster1.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster1.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster1.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster1.l2\_cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A35x4.cluster1\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x4\_A35x4.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.30 FVP\_Base\_Cortex-A57x4-A53x4

FVP\_Base\_Cortex-A57x4-A53x4 contains the following instances:

### FVP\_Base\_Cortex-A57x4-A53x4 instances

**FVP\_Base\_Cortex\_A57x4\_A53x4**

Base Platform Compute Subsystem for ARM Cortex A57x4CT and ARM Cortex A53x4CT.

Type: [FVP\\_Base\\_Cortex\\_A57x4\\_A53x4](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.  
Type: CounterModule.

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.  
Type: CounterModule.

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).  
Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.  
Type: CounterModule.

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.  
Type: CounterModule.

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.ap\_refclk**

ARM Generic Timer.  
Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.audioout**

SDL based Audio Output for PL041\_AACI.  
Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4\_bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4\_bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4\_bp.hdlcd0.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4\_bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4\_bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4\_bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4\_bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4\_bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4\_bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4\_bp.p1011\_uart0**

ARM PrimeCell UART(PLO11).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4\_bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.p1111\_clcd.p111x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSCL\\_91C111](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.terminal\_2**  
Telnet terminal interface.  
Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.terminal\_3**  
Telnet terminal interface.  
Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.trusted\_key\_storage**  
Trusted Root-Key Storage unit.  
Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.trusted\_nv\_counter**  
Trusted Non-Volatile Counter unit.  
Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.trusted\_rng**  
Random Number Generator unit.  
Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.trusted\_watchdog**  
ARM Watchdog Module(SP805).  
Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.tzc\_400**  
TrustZone Address Space Controller.  
Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.ve\_sysregs**  
Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.vedcc**  
Daughterboard Configuration Control (DCC).  
Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.virtio\_net**  
VirtioNet device over MMIO transport.  
Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.virtio\_net\_labeller**  
Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.virtio\_rng**  
VirtioEntropy device over MMIO transport.  
Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.virtioblockdevice**  
virtio block device.  
Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.virtioblockdevice\_labeller**  
Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.clockdivider1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster0**

ARM Cortex-A57 Cluster CT model.

Type: cluster\_ARM\_Cortex-A57.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster0.cpu0**

ARM Cortex-A57 CT model.

Type: ARM\_Cortex-A57.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster0.cpu1**

ARM Cortex-A57 CT model.

Type: ARM\_Cortex-A57.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster0.cpu2**

ARM Cortex-A57 CT model.

Type: ARM\_Cortex-A57.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster0.cpu3**

ARM Cortex-A57 CT model.

Type: ARM\_Cortex-A57.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster0.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster0.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster0.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster1**

ARM Cortex-A53 Cluster CT model.

Type: Cluster\_ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster1.cpu0**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster1.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster1.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster1.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster1.cpu1**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster1.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster1.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster1.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster1.cpu2**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster1.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster1.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster1.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster1.cpu3**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster1.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster1.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster1.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster1.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A57x4\_A53x4.cluster1\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A57x4\_A53x4.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.31 FVP\_Base\_Cortex-A65

FVP\_Base\_Cortex-A65 contains the following instances:

### FVP\_Base\_Cortex-A65 instances

**FVP\_Base\_Cortex\_A65**

Base Platform Compute Subsystem for ARM CortexA65CT.

Type: [FVP\\_Base\\_Cortex\\_A65](#).

**FVP\_Base\_Cortex\_A65.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A65.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A65.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A65.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A65.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A65.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A65.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A65.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A65.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A65.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A65.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A65.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A65.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A65.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A65.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A65.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Cortex\_A65.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A65.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A65.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A65.bp.hdlcd0.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A65.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A65.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A65.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A65.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A65.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A65.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A65.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A65.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A65.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A65.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A65.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A65.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A65.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A65.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A65.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A65.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke

wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A65.bp.pl111\_clcd.pl11x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A65.bp.pl111\_clcd.pl11x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A65.bp.pl111\_clcd.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A65.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A65.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A65.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A65.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A65.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A65.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A65.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A65.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A65.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A65.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A65.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A65.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A65.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A65.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A65.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A65.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A65.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A65.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A65.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A65.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A65.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A65.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [virtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A65.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A65.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A65.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A65.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A65.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCI400](#).

**FVP\_Base\_Cortex\_A65.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65.cluster0**

ARM Cortex-A65 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A65](#).

**FVP\_Base\_Cortex\_A65.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A65.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A65.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A65.cluster0.cpu0.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A65.cluster0.cpu0.thread0**

ARM Cortex-A65 CT model.

Type: [ARM\\_Cortex-A65](#).

**FVP\_Base\_Cortex\_A65.cluster0.cpu0.thread1**

ARM Cortex-A65 CT model.

Type: [ARM\\_Cortex-A65](#).

**FVP\_Base\_Cortex\_A65.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A65.cluster0.cpu1.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A65.cluster0.cpu1.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A65.cluster0.cpu1.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65.cluster0.cpu1.thread0**

ARM Cortex-A65 CT model.

Type: ARM\_Cortex-A65.

**FVP\_Base\_Cortex\_A65.cluster0.cpu1.thread1**

ARM Cortex-A65 CT model.

Type: ARM\_Cortex-A65.

**FVP\_Base\_Cortex\_A65.cluster0.cpu2.dt1b**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A65.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65.cluster0.cpu2.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65.cluster0.cpu2.thread0**

ARM Cortex-A65 CT model.

Type: ARM\_Cortex-A65.

**FVP\_Base\_Cortex\_A65.cluster0.cpu2.thread1**

ARM Cortex-A65 CT model.

Type: ARM\_Cortex-A65.

**FVP\_Base\_Cortex\_A65.cluster0.cpu3.dt1b**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A65.cluster0.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65.cluster0.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65.cluster0.cpu3.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65.cluster0.cpu3.thread0**

ARM Cortex-A65 CT model.

Type: ARM\_Cortex-A65.

**FVP\_Base\_Cortex\_A65.cluster0.cpu3.thread1**

ARM Cortex-A65 CT model.

Type: ARM\_Cortex-A65.

**FVP\_Base\_Cortex\_A65.cluster0.cpu4.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A65.cluster0.cpu4.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65.cluster0.cpu4.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65.cluster0.cpu4.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65.cluster0.cpu4.thread0**

ARM Cortex-A65 CT model.

Type: ARM\_Cortex-A65.

**FVP\_Base\_Cortex\_A65.cluster0.cpu4.thread1**

ARM Cortex-A65 CT model.

Type: ARM\_Cortex-A65.

**FVP\_Base\_Cortex\_A65.cluster0.cpu5.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A65.cluster0.cpu5.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65.cluster0.cpu5.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65.cluster0.cpu5.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65.cluster0.cpu5.thread0**

ARM Cortex-A65 CT model.

Type: ARM\_Cortex-A65.

**FVP\_Base\_Cortex\_A65.cluster0.cpu5.thread1**

ARM Cortex-A65 CT model.

Type: ARM\_Cortex-A65.

**FVP\_Base\_Cortex\_A65.cluster0.cpu6.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A65.cluster0.cpu6.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65.cluster0.cpu6.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65.cluster0.cpu6.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65.cluster0.cpu6.thread0**

ARM Cortex-A65 CT model.

Type: ARM\_Cortex-A65.

**FVP\_Base\_Cortex\_A65.cluster0.cpu6.thread1**

ARM Cortex-A65 CT model.

Type: ARM\_Cortex-A65.

**FVP\_Base\_Cortex\_A65.cluster0.cpu7.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A65.cluster0.cpu7.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65.cluster0.cpu7.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65.cluster0.cpu7.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65.cluster0.cpu7.thread0**

ARM Cortex-A65 CT model.

Type: ARM\_Cortex-A65.

**FVP\_Base\_Cortex\_A65.cluster0.cpu7.thread1**

ARM Cortex-A65 CT model.

Type: ARM\_Cortex-A65.

**FVP\_Base\_Cortex\_A65.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

#### **FVP\_Base\_Cortex\_A65.elfloader**

ELF loader component.

Type: [ElfLoader](#).

#### **FVP\_Base\_Cortex\_A65.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

#### **FVP\_Base\_Cortex\_A65.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

#### **FVP\_Base\_Cortex\_A65.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_Base\_Cortex\_A65.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_Base\_Cortex\_A65.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_Base\_Cortex\_A65.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.32 FVP\_Base\_Cortex-A65AE

FVP\_Base\_Cortex-A65AE contains the following instances:

### **FVP\_Base\_Cortex-A65AE instances**

#### **FVP\_Base\_Cortex\_A65AE**

Base Platform Compute Subsystem for ARM Cortex A65AE CT.

Type: `FVP_Base_Cortex_A65AE`.

**`FVP_Base_Cortex_A65AE.bp`**

Peripherals and address map for the Base Platform.

Type: `BasePlatformPeripherals`.

**`FVP_Base_Cortex_A65AE.bp.Timer_0_1`**

ARM Dual-Timer Module(SP804).

Type: `SP804_Timer`.

**`FVP_Base_Cortex_A65AE.bp.Timer_0_1.clk_div0`**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: `ClockDivider`.

**`FVP_Base_Cortex_A65AE.bp.Timer_0_1.clk_div1`**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: `ClockDivider`.

**`FVP_Base_Cortex_A65AE.bp.Timer_0_1.counter0`**

Internal component used by SP804 Timer module.

Type: `CounterModule`.

**`FVP_Base_Cortex_A65AE.bp.Timer_0_1.counter1`**

Internal component used by SP804 Timer module.

Type: `CounterModule`.

**`FVP_Base_Cortex_A65AE.bp.Timer_2_3`**

ARM Dual-Timer Module(SP804).

Type: `SP804_Timer`.

**`FVP_Base_Cortex_A65AE.bp.Timer_2_3.clk_div0`**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: `ClockDivider`.

**`FVP_Base_Cortex_A65AE.bp.Timer_2_3.clk_div1`**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: `ClockDivider`.

**`FVP_Base_Cortex_A65AE.bp.Timer_2_3.counter0`**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A65AE.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A65AE.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A65AE.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A65AE.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AE.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AE.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AE.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AE.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AE.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A65AE.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A65AE.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A65AE.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A65AE\_bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A65AE\_bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A65AE\_bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A65AE\_bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A65AE\_bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A65AE\_bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A65AE\_bp.hdlcd0.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A65AE\_bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65AE\_bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A65AE\_bp mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A65AE.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A65AE.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A65AE.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AE.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A65AE.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A65AE.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A65AE.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A65AE.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A65AE.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A65AE.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A65AE.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A65AE.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A65AE.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A65AE.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A65AE\_bp.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A65AE\_bp.pl111\_clcd.pl11x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A65AE\_bp.pl111\_clcd.pl11x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A65AE\_bp.pl111\_clcd.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65AE\_bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A65AE\_bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A65AE\_bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A65AE\_bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AE\_bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A65AE\_bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A65AE\_bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AE.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AE.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AE.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AE.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AE.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A65AE.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A65AE.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A65AE.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A65AE.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A65AE.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AE.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A65AE.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A65AE.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A65AE.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A65AE.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A65AE.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A65AE.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A65AE.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A65AE.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A65AE.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A65AE.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A65AE.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A65AE.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65AE.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A65AE.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A65AE.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65AE.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A65AE.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65AE.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A65AE.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A65AE.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AE.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCI400](#).

**FVP\_Base\_Cortex\_A65AE.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE.cluster0**

ARM Cortex-A65AE Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A65AE](#).

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu0.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu0.thread0**

ARM Cortex-A65AE CT model.

Type: [ARM\\_Cortex-A65AE](#).

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu0.thread1**

ARM Cortex-A65AE CT model.

Type: [ARM\\_Cortex-A65AE](#).

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu1.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu1.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu1.thread0**

ARM Cortex-A65AE CT model.

Type: ARM\_Cortex-A65AE.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu1.thread1**

ARM Cortex-A65AE CT model.

Type: ARM\_Cortex-A65AE.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu2.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu2.thread0**

ARM Cortex-A65AE CT model.

Type: ARM\_Cortex-A65AE.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu2.thread1**

ARM Cortex-A65AE CT model.

Type: ARM\_Cortex-A65AE.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu3.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu3.thread0**

ARM Cortex-A65AE CT model.

Type: ARM\_Cortex-A65AE.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu3.thread1**

ARM Cortex-A65AE CT model.

Type: ARM\_Cortex-A65AE.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu4.dt1b**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu4.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu4.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu4.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu4.thread0**

ARM Cortex-A65AE CT model.

Type: ARM\_Cortex-A65AE.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu4.thread1**

ARM Cortex-A65AE CT model.

Type: ARM\_Cortex-A65AE.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu5.dt1b**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu5.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu5.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu5.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu5.thread0**

ARM Cortex-A65AE CT model.

Type: ARM\_Cortex-A65AE.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu5.thread1**

ARM Cortex-A65AE CT model.

Type: ARM\_Cortex-A65AE.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu6.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu6.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu6.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu6.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu6.thread0**

ARM Cortex-A65AE CT model.

Type: ARM\_Cortex-A65AE.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu6.thread1**

ARM Cortex-A65AE CT model.

Type: ARM\_Cortex-A65AE.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu7.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu7.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu7.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu7.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu7.thread0**

ARM Cortex-A65AE CT model.

Type: ARM\_Cortex-A65AE.

**FVP\_Base\_Cortex\_A65AE.cluster0.cpu7.thread1**

ARM Cortex-A65AE CT model.

Type: ARM\_Cortex-A65AE.

**FVP\_Base\_Cortex\_A65AE.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65AE.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A65AE.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A65AE.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A65AE.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A65AE.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A65AE.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A65AE.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A65AE.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.33 FVP\_Base\_Cortex-A65AEx2+Cortex-A76AEx2

FVP\_Base\_Cortex-A65AEx2+Cortex-A76AEx2 contains the following instances:

### FVP\_Base\_Cortex-A65AEx2+Cortex-A76AEx2 instances

#### **FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2**

Base Platform Compute Subsystem for ARMCortexA65AEx2CT\_CortexA76AEx2CT.

Type: [FVP\\_Base\\_Cortex\\_A65AEx2\\_Cortex\\_A76AEx2](#).

#### **FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.pl111\_clcd.pl111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.pl111\_clcd.pl111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.pl111\_clcd.pl111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.pl111\_clcd.pl111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCI400](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.cluster0**

ARM Cortex-A65AE\_Cortex-A76AE Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A65AE\\_Cortex-A76AE](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.cluster0.subcluster0**

ARM Cortex-A65AE Cluster CT model.

Type: [Subcluster\\_ARM\\_Cortex-A65AE](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.cluster0.subcluster0.cpu0.thread0**

ARM Cortex-A65AE CT model.

Type: [ARM\\_Cortex-A65AE](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.cluster0.subcluster0.cpu0.thread1**

ARM Cortex-A65AE CT model.

Type: [ARM\\_Cortex-A65AE](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.cluster0.subcluster0.cpu1.thread0**

ARM Cortex-A65AE CT model.

Type: [ARM\\_Cortex-A65AE](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.cluster0.subcluster0.cpu1.thread1**

ARM Cortex-A65AE CT model.

Type: [ARM\\_Cortex-A65AE](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.cluster0.subcluster1**

ARM Cortex-A76AE Cluster CT model.

Type: [Subcluster\\_ARM\\_Cortex-A76AE](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.cluster0.subcluster1.cpu0**

ARM Cortex-A76AE CT model.

Type: ARM\_Cortex-A76AE.

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.cluster0.subcluster1.cpu1**

ARM Cortex-A76AE CT model.

Type: ARM\_Cortex-A76AE.

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>2\_Cortex\_A76AE<sub>x</sub>2.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A65AEx2\_Cortex\_A76AEx2.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.34 FVP\_Base\_Cortex-A65AEx4+Cortex-A76AEx4

FVP\_Base\_Cortex-A65AEx4+Cortex-A76AEx4 contains the following instances:

### FVP\_Base\_Cortex-A65AEx4+Cortex-A76AEx4 instances

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4**

Base Platform Compute Subsystem for ARM Cortex A65AEx4CT\_Cortex A76AEx4CT.

Type: [FVP\\_Base\\_Cortex\\_A65AEx4\\_Cortex\\_A76AEx4](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.pl111\_clcd.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl1](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [virtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.vis**

Display window for VE using Visualisation library.

Type: vEVisualisation.

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.cluster0**

ARM Cortex-A65AE\_Cortex-A76AE Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-A65AE\\_Cortex-A76AE](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.cluster0.subcluster0**

ARM Cortex-A65AE Cluster CT model.

Type: [Subcluster\\_ARM\\_Cortex-A65AE](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.cluster0.subcluster0.cpu0.thread0**

ARM Cortex-A65AE CT model.

Type: [ARM\\_Cortex-A65AE](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.cluster0.subcluster0.cpu0.thread1**

ARM Cortex-A65AE CT model.

Type: [ARM\\_Cortex-A65AE](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.cluster0.subcluster0.cpu1.thread0**

ARM Cortex-A65AE CT model.

Type: ARM\_Cortex-A65AE.

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.cluster0.subcluster0.cpu1.thread1**

ARM Cortex-A65AE CT model.

Type: ARM\_Cortex-A65AE.

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.cluster0.subcluster0.cpu2.thread0**

ARM Cortex-A65AE CT model.

Type: ARM\_Cortex-A65AE.

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.cluster0.subcluster0.cpu2.thread1**

ARM Cortex-A65AE CT model.

Type: ARM\_Cortex-A65AE.

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.cluster0.subcluster0.cpu3.thread0**

ARM Cortex-A65AE CT model.

Type: ARM\_Cortex-A65AE.

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.cluster0.subcluster0.cpu3.thread1**

ARM Cortex-A65AE CT model.

Type: ARM\_Cortex-A65AE.

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.cluster0.subcluster1**

ARM Cortex-A76AE Cluster CT model.

Type: Subcluster\_ARM\_Cortex-A76AE.

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.cluster0.subcluster1.cpu0**

ARM Cortex-A76AE CT model.

Type: ARM\_Cortex-A76AE.

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.cluster0.subcluster1.cpu1**

ARM Cortex-A76AE CT model.

Type: ARM\_Cortex-A76AE.

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.cluster0.subcluster1.cpu2**

ARM Cortex-A76AE CT model.

Type: ARM\_Cortex-A76AE.

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.cluster0.subcluster1.cpu3**

ARM Cortex-A76AE CT model.

Type: ARM\_Cortex-A76AE.

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A65AE<sub>x</sub>4\_Cortex\_A76AE<sub>x</sub>4.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A65AEx4\_Cortex\_A76AEx4.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.35 FVP\_Base\_Cortex-A710

FVP\_Base\_Cortex-A710 contains the following instances:

### FVP\_Base\_Cortex-A710 instances

**FVP\_Base\_Cortex\_A710**

Base Platform Compute Subsystem for ARMCortexA710CT.

Type: [FVP\\_Base\\_Cortex\\_A710](#).

**FVP\_Base\_Cortex\_A710.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A710.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A710.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A710.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A710.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A710.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A710.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A710.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A710.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A710.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A710.bp.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A710.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A710.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A710.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A710.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A710.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A710.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A710.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A710.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A710.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A710.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Cortex\_A710.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A710.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A710.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A710.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A710.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A710.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A710.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A710.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A710.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A710.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A710.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A710.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A710.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A710.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A710.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A710.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A710.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A710.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A710.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A710.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A710.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A710.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke

wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A710.bp.pl111\_clcd.pl111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A710.bp.pl111\_clcd.pl111x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A710.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A710.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A710.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A710.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A710.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A710.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A710.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A710.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A710.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A710.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A710.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A710.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A710.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A710.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A710.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A710.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A710.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A710.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A710.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A710.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A710.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A710.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A710.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A710.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A710.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A710.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A710.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A710.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A710.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A710.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A710.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A710.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [virtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A710.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A710.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A710.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A710.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A710.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A710.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A710.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A710.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCI400](#).

**FVP\_Base\_Cortex\_A710.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A710.cluster0**

ARM Cortex-A710 Cluster CT model.

Type: [Cluster\\_ARM\\_CortexA710](#).

**FVP\_Base\_Cortex\_A710.cluster0.cpu0**

ARM Cortex-A710 CT model.

Type: [ARM\\_Cortex-A710](#).

**FVP\_Base\_Cortex\_A710.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A710.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A710.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A710.cluster0.cpu0.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A710.cluster0.cpu1**

ARM Cortex-A710 CT model.

Type: [ARM\\_Cortex-A710](#).

**FVP\_Base\_Cortex\_A710.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A710.cluster0.cpu1.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A710.cluster0.cpu1.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A710.cluster0.cpu1.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A710.cluster0.cpu2**

ARM Cortex-A710 CT model.

Type: ARM\_Cortex-A710.

**FVP\_Base\_Cortex\_A710.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A710.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A710.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A710.cluster0.cpu2.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A710.cluster0.cpu3**

ARM Cortex-A710 CT model.

Type: ARM\_Cortex-A710.

**FVP\_Base\_Cortex\_A710.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A710.cluster0.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A710.cluster0.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A710.cluster0.cpu3.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A710.cluster0.cpu4**

ARM Cortex-A710 CT model.

Type: ARM\_Cortex-A710.

**FVP\_Base\_Cortex\_A710.cluster0.cpu4.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A710.cluster0.cpu4.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A710.cluster0.cpu4.ll1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A710.cluster0.cpu4.l12cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A710.cluster0.cpu5**

ARM Cortex-A710 CT model.

Type: ARM\_Cortex-A710.

**FVP\_Base\_Cortex\_A710.cluster0.cpu5.dt1b**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A710.cluster0.cpu5.ll1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A710.cluster0.cpu5.ll1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A710.cluster0.cpu5.l12cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A710.cluster0.cpu6**

ARM Cortex-A710 CT model.

Type: ARM\_Cortex-A710.

**FVP\_Base\_Cortex\_A710.cluster0.cpu6.dt1b**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A710.cluster0.cpu6.ll1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A710.cluster0.cpu6.ll1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A710.cluster0.cpu6.l12cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A710.cluster0.cpu7**

ARM Cortex-A710 CT model.

Type: ARM\_Cortex-A710.

**FVP\_Base\_Cortex\_A710.cluster0.cpu7.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A710.cluster0.cpu7.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A710.cluster0.cpu7.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A710.cluster0.cpu7.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A710.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A710.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A710.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A710.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A710.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A710.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A710.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A710.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A710.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.36 FVP\_Base\_Cortex-A715

FVP\_Base\_Cortex-A715 contains the following instances:

### FVP\_Base\_Cortex-A715 instances

**FVP\_Base\_Cortex\_A715**

Base Platform Compute Subsystem for ARM Cortex A715CT.

Type: [FVP\\_Base\\_Cortex\\_A715](#).

**FVP\_Base\_Cortex\_A715.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A715.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A715.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A715.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A715.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A715.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A715.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A715.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A715.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A715.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A715.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A715.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A715.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A715.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A715.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A715.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A715.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A715.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A715.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A715.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A715.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A715.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

#### **FVP\_Base\_Cortex\_A715.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

#### **FVP\_Base\_Cortex\_A715.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A715.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A715.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A715.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A715.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A715.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A715.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A715.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A715.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A715.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Cortex\_A715.bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A715.bp.hd1cd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component

which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A715.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A715.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A715.bp.hdlcd0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A715.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A715.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A715.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A715.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A715.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A715.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A715.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A715.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A715.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A715.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A715.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A715.bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A715.bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A715.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A715.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A715.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A715.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A715.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A715.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A715.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A715.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A715.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A715.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A715.bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A715.bp.p1111\_clcd.p111x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A715.bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A715.bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A715.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A715.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A715.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A715.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A715.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A715.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A715.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A715.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A715.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A715.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A715.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A715.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A715.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Cortex\_A715.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A715.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A715.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A715.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A715.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A715.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A715.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A715.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A715.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A715.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A715.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A715.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A715.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A715.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A715.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A715.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A715.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A715.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A715.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A715.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A715.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A715.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A715.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A715.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A715.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A715.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A715.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A715.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A715.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A715.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A715.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A715.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A715.cluster0**

ARM CortexA715 Cluster CT model.

Type: [Cluster\\_ARM\\_CortexA715](#).

**FVP\_Base\_Cortex\_A715.cluster0.cpu0**

ARM CortexA715 CT model.

Type: [ARM\\_Cortex-A715](#).

**FVP\_Base\_Cortex\_A715.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A715.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu0.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu1**

ARM CortexA715 CT model.

Type: ARM\_Cortex-A715.

**FVP\_Base\_Cortex\_A715.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A715.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu1.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu2**

ARM CortexA715 CT model.

Type: ARM\_Cortex-A715.

**FVP\_Base\_Cortex\_A715.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A715.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu2.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu3**

ARM CortexA715 CT model.

Type: ARM\_Cortex-A715.

**FVP\_Base\_Cortex\_A715.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A715.cluster0.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu3.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu4**

ARM CortexA715 CT model.

Type: ARM\_Cortex-A715.

**FVP\_Base\_Cortex\_A715.cluster0.cpu4.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A715.cluster0.cpu4.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu4.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu4.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu5**

ARM CortexA715 CT model.

Type: ARM\_Cortex-A715.

**FVP\_Base\_Cortex\_A715.cluster0.cpu5.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A715.cluster0.cpu5.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu5.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu5.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu6**

ARM CortexA715 CT model.

Type: ARM\_Cortex-A715.

**FVP\_Base\_Cortex\_A715.cluster0.cpu6.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A715.cluster0.cpu6.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu6.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu6.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu7**

ARM CortexA715 CT model.

Type: ARM\_Cortex-A715.

**FVP\_Base\_Cortex\_A715.cluster0.cpu7.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A715.cluster0.cpu7.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu7.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0.cpu7.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A715.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A715.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A715.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A715.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A715.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A715.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A715.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A715.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A715.pctl.timer\_reset.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.37 FVP\_Base\_Cortex-A72x1

FVP\_Base\_Cortex-A72x1 contains the following instances:

### FVP\_Base\_Cortex-A72x1 instances

#### **FVP\_Base\_Cortex\_A72x1**

Base Platform Compute Subsystem for ARMCortexA72x1CT.

Type: [FVP\\_Base\\_Cortex\\_A72x1](#).

#### **FVP\_Base\_Cortex\_A72x1\_bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A72x1\_bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A72x1\_bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A72x1\_bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A72x1\_bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_A72x1\_bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_A72x1\_bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A72x1\_bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A72x1\_bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A72x1\_bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A72x1\_bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A72x1\_bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A72x1.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x1.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x1.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x1.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x1.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A72x1.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A72x1.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A72x1.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A72x1.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A72x1.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A72x1.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x1.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A72x1.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A72x1.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x1.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x1.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x1.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x1.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x1.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x1.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A72x1.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A72x1.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A72x1.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1.bp.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A72x1.bp.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A72x1.bp.pl111\_clcd.pl111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A72x1\_bp.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A72x1\_bp.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A72x1\_bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A72x1\_bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A72x1\_bp.pl111\_clcd.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x1\_bp.pl1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A72x1\_bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A72x1\_bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A72x1\_bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A72x1.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A72x1.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x1.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x1.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A72x1.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A72x1.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A72x1.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x1.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x1.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x1.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x1.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A72x1.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A72x1.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A72x1.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A72x1.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A72x1.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A72x1.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A72x1.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A72x1.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x1.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A72x1.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A72x1.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x1.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A72x1.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x1.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A72x1.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A72x1.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A72x1.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1.cluster0**

ARM Cortex-A72 Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-A72](#).

**FVP\_Base\_Cortex\_A72x1.cluster0.cpu0**

ARM Cortex-A72 CT model.

Type: [ARM\\_Cortex-A72](#).

**FVP\_Base\_Cortex\_A72x1.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A72x1.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x1.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x1.cluster0.cpu0.l12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x1.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x1.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A72x1.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A72x1.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A72x1.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A72x1.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A72x1.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A72x1.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A72x1.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.38 FVP\_Base\_Cortex-A72x1-A53x1

FVP\_Base\_Cortex-A72x1-A53x1 contains the following instances:

### FVP\_Base\_Cortex-A72x1-A53x1 instances

#### **FVP\_Base\_Cortex\_A72x1\_A53x1**

Base Platform Compute Subsystem for ARM Cortex A72x1CT and ARM Cortex A53x1CT.

Type: [FVP\\_Base\\_Cortex\\_A72x1\\_A53x1](#).

#### **FVP\_Base\_Cortex\_A72x1\_A53x1\_bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A72x1\_A53x1\_bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A72x1\_A53x1\_bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A72x1\_A53x1\_bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A72x1\_A53x1\_bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_A72x1\_A53x1\_bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_A72x1\_A53x1\_bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A72x1\_A53x1\_bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.hdlcd0.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.hd1cd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.mmci**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.pl111\_clcd.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.clockdivider1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.cluster0**

ARM Cortex-A72 Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-A72](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.cluster0.cpu0**

ARM Cortex-A72 CT model.

Type: [ARM\\_Cortex-A72](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.cluster0.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.cluster1**

ARM Cortex-A53 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A53](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.cluster1.cpu0**

ARM Cortex-A53 CT model.

Type: [ARM\\_Cortex-A53](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.cluster1.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.cluster1.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.cluster1.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.cluster1.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.cluster1.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A72x1\_A53x1.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal()

callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_Base\_Cortex\_A72x1\_A53x1.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_Base\_Cortex\_A72x1\_A53x1.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_Base\_Cortex\_A72x1\_A53x1.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.39 FVP\_Base\_Cortex-A72x2

FVP\_Base\_Cortex-A72x2 contains the following instances:

### **FVP\_Base\_Cortex-A72x2 instances**

#### **FVP\_Base\_Cortex\_A72x2**

Base Platform Compute Subsystem for ARM Cortex A72x2CT.

Type: [FVP\\_Base\\_Cortex\\_A72x2](#).

#### **FVP\_Base\_Cortex\_A72x2.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A72x2.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A72x2.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A72x2.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A72x2.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A72x2.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A72x2.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A72x2.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A72x2.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A72x2.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A72x2.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A72x2.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A72x2.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A72x2.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A72x2.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A72x2.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A72x2.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A72x2.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x2.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x2.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x2.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x2.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A72x2.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A72x2.bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly

or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A72x2.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A72x2.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A72x2.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A72x2.bp.hdlcd0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x2.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A72x2.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A72x2.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x2.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x2.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2.bp.p1011\_uart0**

ARM PrimeCell UART(PLO11).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x2\_bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x2\_bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x2\_bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x2\_bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A72x2\_bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A72x2\_bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A72x2\_bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A72x2\_bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A72x2\_bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A72x2\_bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A72x2\_bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A72x2\_bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A72x2\_bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A72x2\_bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x2\_bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A72x2\_bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A72x2\_bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A72x2\_bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2\_bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A72x2\_bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A72x2\_bp.r1\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2\_bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2\_bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2\_bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2\_bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2\_bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x2\_bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x2\_bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Cortex\_A72x2\_bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A72x2\_bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A72x2\_bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x2.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x2.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x2.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x2.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A72x2.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A72x2.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A72x2.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A72x2.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A72x2.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A72x2.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A72x2.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A72x2.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x2.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.  
Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A72x2.bp.virtioblockdevice**

virtio block device.  
Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A72x2.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x2.bp.virtiop9device**

virtio P9 server.  
Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A72x2.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x2.bp.vis**

Display window for VE using Visualisation library.  
Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A72x2.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).  
Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A72x2.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2.bp.vram**

RAM device, can be dynamic or static ram.  
Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2.cci400**

Cache Coherent Interconnect for AXI4 ACE.  
Type: [CC1400](#).

**FVP\_Base\_Cortex\_A72x2.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2.cluster0**

ARM Cortex-A72 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A72](#).

**FVP\_Base\_Cortex\_A72x2.cluster0.cpu0**

ARM Cortex-A72 CT model.

Type: [ARM\\_Cortex-A72](#).

**FVP\_Base\_Cortex\_A72x2.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A72x2.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x2.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x2.cluster0.cpu1**

ARM Cortex-A72 CT model.

Type: [ARM\\_Cortex-A72](#).

**FVP\_Base\_Cortex\_A72x2.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A72x2.cluster0.cpu1.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x2.cluster0.cpu1.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x2.cluster0.l2\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x2.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x2.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A72x2.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A72x2.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A72x2.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A72x2.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A72x2.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A72x2.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A72x2.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.40 FVP\_Base\_Cortex-A72x2-A53x4

FVP\_Base\_Cortex-A72x2-A53x4 contains the following instances:

### FVP\_Base\_Cortex-A72x2-A53x4 instances

**FVP\_Base\_Cortex\_A72x2\_A53x4**

Base Platform Compute Subsystem for ARM Cortex A72x2CT and ARM Cortex A53x4CT.

Type: [FVP\\_Base\\_Cortex\\_A72x2\\_A53x4](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.hdlcd0.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke

wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.pl111\_clcd.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSCL\\_91C111](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [virtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCI400](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.clockdivider1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster0**

ARM Cortex-A72 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A72](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster0.cpu0**

ARM Cortex-A72 CT model.

Type: [ARM\\_Cortex-A72](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster0.cpu1**

ARM Cortex-A72 CT model.

Type: [ARM\\_Cortex-A72](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster0.cpu1.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster0.cpu1.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster0.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster1**

ARM Cortex-A53 Cluster CT model.

Type: Cluster\_ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster1.cpu0**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster1.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster1.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster1.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster1.cpu1**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster1.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster1.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster1.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster1.cpu2**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster1.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster1.cpu2.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster1.cpu2.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster1.cpu3**

ARM Cortex-A53 CT model.

Type: [ARM\\_Cortex-A53](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster1.cpu3.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster1.cpu3.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster1.cpu3.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster1.l2\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.cluster1\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A72x2\_A53x4.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_Base\_Cortex\_A72x2\_A53x4.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_Base\_Cortex\_A72x2\_A53x4.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_Base\_Cortex\_A72x2\_A53x4.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.41 FVP\_Base\_Cortex-A72x4

FVP\_Base\_Cortex-A72x4 contains the following instances:

### FVP\_Base\_Cortex-A72x4 instances

#### **FVP\_Base\_Cortex\_A72x4**

Base Platform Compute Subsystem for ARM Cortex A72x4CT.

Type: [FVP\\_Base\\_Cortex\\_A72x4](#).

#### **FVP\_Base\_Cortex\_A72x4.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A72x4.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A72x4.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A72x4.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A72x4.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A72x4.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A72x4.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A72x4.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A72x4.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A72x4.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A72x4.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A72x4.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x4.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x4.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x4.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x4.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A72x4.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A72x4.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_Base\_Cortex\_A72x4.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_Base\_Cortex\_A72x4.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_Base\_Cortex\_A72x4.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

#### **FVP\_Base\_Cortex\_A72x4.bp.hdlcd0.labeller**

Type: [Labeller](#).

#### **FVP\_Base\_Cortex\_A72x4.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

#### **FVP\_Base\_Cortex\_A72x4.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

#### **FVP\_Base\_Cortex\_A72x4.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

#### **FVP\_Base\_Cortex\_A72x4.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

#### **FVP\_Base\_Cortex\_A72x4.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

#### **FVP\_Base\_Cortex\_A72x4.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

#### **FVP\_Base\_Cortex\_A72x4.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x4.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x4.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x4.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A72x4.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A72x4.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A72x4.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A72x4.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A72x4.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A72x4.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A72x4.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A72x4.bp.p1111\_clcd.p111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A72x4.bp.p1111\_clcd.p111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A72x4.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x4.bp.pl1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A72x4.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A72x4.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A72x4.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A72x4.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A72x4.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x4.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x4.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [smsc\\_91c111](#).

**FVP\_Base\_Cortex\_A72x4.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A72x4.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A72x4.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x4.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x4.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x4.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x4.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A72x4.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A72x4.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A72x4.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A72x4.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A72x4.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A72x4.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A72x4.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A72x4.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x4.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [virtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A72x4.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A72x4.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x4.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A72x4.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x4.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A72x4.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A72x4.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A72x4.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4.cluster0**

ARM Cortex-A72 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A72](#).

**FVP\_Base\_Cortex\_A72x4.cluster0.cpu0**

ARM Cortex-A72 CT model.

Type: ARM\_Cortex-A72.

**FVP\_Base\_Cortex\_A72x4.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A72x4.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4.cluster0.cpu1**

ARM Cortex-A72 CT model.

Type: ARM\_Cortex-A72.

**FVP\_Base\_Cortex\_A72x4.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A72x4.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4.cluster0.cpu2**

ARM Cortex-A72 CT model.

Type: ARM\_Cortex-A72.

**FVP\_Base\_Cortex\_A72x4.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A72x4.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4.cluster0.cpu3**

ARM Cortex-A72 CT model.

Type: ARM\_Cortex-A72.

**FVP\_Base\_Cortex\_A72x4.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A72x4.cluster0.cpu3.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x4.cluster0.cpu3.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x4.cluster0.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A72x4.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x4.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A72x4.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A72x4.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A72x4.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A72x4.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A72x4.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A72x4.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A72x4.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.42 FVP\_Base\_Cortex-A72x4-A53x4

FVP\_Base\_Cortex-A72x4-A53x4 contains the following instances:

### FVP\_Base\_Cortex-A72x4-A53x4 instances

**FVP\_Base\_Cortex\_A72x4\_A53x4**

Base Platform Compute Subsystem for ARM Cortex A72x4CT and ARM Cortex A53x4CT.

Type: [FVP\\_Base\\_Cortex\\_A72x4\\_A53x4](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.hd1cd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component

which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.hdlcd0.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.hdlcd0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.p1111\_clcd.p111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.p1111\_clcd.p111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.p1111\_clcd.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSCL\\_91C111](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.terminal\_2**  
Telnet terminal interface.  
Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.terminal\_3**  
Telnet terminal interface.  
Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.trusted\_key\_storage**  
Trusted Root-Key Storage unit.  
Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.trusted\_nv\_counter**  
Trusted Non-Volatile Counter unit.  
Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.trusted\_rng**  
Random Number Generator unit.  
Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.trusted\_watchdog**  
ARM Watchdog Module(SP805).  
Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.tzc\_400**  
TrustZone Address Space Controller.  
Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.ve\_sysregs**  
Type: VE\_SysRegs.

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.vedcc**  
Daughterboard Configuration Control (DCC).  
Type: VEDCC.

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.virtio\_net**  
VirtioNet device over MMIO transport.  
Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.virtio\_net\_labeller**  
Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.virtio\_rng**  
VirtioEntropy device over MMIO transport.  
Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.virtioblockdevice**  
virtio block device.  
Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.virtioblockdevice\_labeller**  
Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCl400](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.clockdivider1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster0**

ARM Cortex-A72 Cluster CT model.

Type: cluster\_ARM\_Cortex-A72.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster0.cpu0**

ARM Cortex-A72 CT model.

Type: ARM\_Cortex-A72.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster0.cpu1**

ARM Cortex-A72 CT model.

Type: ARM\_Cortex-A72.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster0.cpu2**

ARM Cortex-A72 CT model.

Type: ARM\_Cortex-A72.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster0.cpu3**

ARM Cortex-A72 CT model.

Type: ARM\_Cortex-A72.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster0.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster0.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster0.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster1**

ARM Cortex-A53 Cluster CT model.

Type: cluster\_ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster1.cpu0**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster1.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster1.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster1.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster1.cpu1**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster1.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster1.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster1.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster1.cpu2**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster1.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster1.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster1.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster1.cpu3**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster1.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster1.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster1.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster1.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A72x4\_A53x4.cluster1\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A72x4\_A53x4.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.43 FVP\_Base\_Cortex-A73x1

FVP\_Base\_Cortex-A73x1 contains the following instances:

### FVP\_Base\_Cortex-A73x1 instances

**FVP\_Base\_Cortex\_A73x1**

Base Platform Compute Subsystem for ARM Cortex A73x1CT.

Type: [FVP\\_Base\\_Cortex\\_A73x1](#).

**FVP\_Base\_Cortex\_A73x1.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A73x1.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A73x1.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A73x1.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A73x1.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A73x1.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A73x1.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A73x1.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A73x1.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A73x1.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A73x1.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x1.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x1.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x1.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x1.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A73x1.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Cortex\_A73x1.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A73x1.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A73x1.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A73x1.bp.hdlcd0.timer.thread.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A73x1.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x1.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A73x1.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A73x1.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x1.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x1.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x1.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x1.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x1.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x1.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A73x1.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A73x1.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A73x1.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A73x1.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A73x1.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A73x1.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A73x1.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke

wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A73x1.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A73x1.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A73x1.bp.pl111\_clcd.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x1.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A73x1.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A73x1.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A73x1.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A73x1.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A73x1.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x1.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x1.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A73x1.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A73x1.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A73x1.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x1.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x1.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x1.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x1.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A73x1.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A73x1.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A73x1.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A73x1.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A73x1.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A73x1.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A73x1.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A73x1.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x1.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [virtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A73x1.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A73x1.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x1.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A73x1.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x1.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A73x1.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A73x1.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCI400](#).

**FVP\_Base\_Cortex\_A73x1.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1.cluster0**

ARM Cortex-A73 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A73](#).

**FVP\_Base\_Cortex\_A73x1.cluster0.cpu0**

ARM Cortex-A73 CT model.

Type: [ARM\\_Cortex-A73](#).

**FVP\_Base\_Cortex\_A73x1.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TLbCadi](#).

**FVP\_Base\_Cortex\_A73x1.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x1.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x1.cluster0.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x1.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x1.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A73x1.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A73x1.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A73x1.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A73x1.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A73x1.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A73x1.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A73x1.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.44 FVP\_Base\_Cortex-A73x1-A53x1

FVP\_Base\_Cortex-A73x1-A53x1 contains the following instances:

### FVP\_Base\_Cortex-A73x1-A53x1 instances

**FVP\_Base\_Cortex\_A73x1\_A53x1**

Base Platform Compute Subsystem for ARM Cortex A73x1CT and ARM Cortex A53x1CT.

Type: [FVP\\_Base\\_Cortex\\_A73x1\\_A53x1](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBuseExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.hd1lcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.hdlcd0.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.hdlcd0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL111x\\_CLCD](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.p1111\_clcd.p111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.  
Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.virtioblockdevice**

virtio block device.  
Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.virtiop9device**

virtio P9 server.  
Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.vis**

Display window for VE using Visualisation library.  
Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).  
Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.bp.vram**

RAM device, can be dynamic or static ram.  
Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.cci400**

Cache Coherent Interconnect for AXI4 ACE.  
Type: [CC1400](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.clockdivider1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.cluster0**

ARM Cortex-A73 Cluster CT model.

Type: Cluster\_ARM\_Cortex-A73.

**FVP\_Base\_Cortex\_A73x1\_A53x1.cluster0.cpu0**

ARM Cortex-A73 CT model.

Type: ARM\_Cortex-A73.

**FVP\_Base\_Cortex\_A73x1\_A53x1.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A73x1\_A53x1.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x1\_A53x1.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x1\_A53x1.cluster0.l2\_cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x1\_A53x1.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.cluster1**

ARM Cortex-A53 Cluster CT model.

Type: Cluster\_ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A73x1\_A53x1.cluster1.cpu0**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A73x1\_A53x1.cluster1.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A73x1\_A53x1.cluster1.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x1\_A53x1.cluster1.cpu0.llicache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.cluster1.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.cluster1.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A73x1\_A53x1.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.45 FVP\_Base\_Cortex-A73x2

FVP\_Base\_Cortex-A73x2 contains the following instances:

### FVP\_Base\_Cortex-A73x2 instances

**FVP\_Base\_Cortex\_A73x2**

Base Platform Compute Subsystem for ARM Cortex A73x2 CT.

Type: [FVP\\_Base\\_Cortex\\_A73x2](#).

**FVP\_Base\_Cortex\_A73x2.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A73x2.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A73x2.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A73x2.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A73x2.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A73x2\_bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A73x2\_bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A73x2\_bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A73x2\_bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A73x2\_bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2\_bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2\_bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2\_bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A73x2.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x2.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x2.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x2.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x2.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A73x2.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A73x2.bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A73x2.bp.hd1cd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A73x2\_bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A73x2\_bp.hdlcd0.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A73x2\_bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x2\_bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A73x2\_bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A73x2\_bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x2\_bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x2\_bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2\_bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x2\_bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x2\_bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x2\_bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x2\_bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A73x2\_bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A73x2\_bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A73x2\_bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A73x2\_bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A73x2.bp.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A73x2.bp.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A73x2.bp.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A73x2.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A73x2.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A73x2.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x2.bp.pl1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A73x2.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A73x2.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A73x2.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A73x2.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A73x2.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x2.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x2.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Cortex\_A73x2.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A73x2.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A73x2.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x2.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x2.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x2.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x2.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A73x2.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A73x2.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A73x2.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A73x2.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A73x2.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A73x2.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A73x2.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A73x2.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x2.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A73x2.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A73x2.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x2.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A73x2.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x2.bp.vis**

Display window for VE using Visualisation library.

Type: vEVisualisation.

**FVP\_Base\_Cortex\_A73x2.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A73x2.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A73x2.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2.cluster0**

ARM Cortex-A73 Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-A73](#).

**FVP\_Base\_Cortex\_A73x2.cluster0.cpu0**

ARM Cortex-A73 CT model.

Type: [ARM\\_Cortex-A73](#).

**FVP\_Base\_Cortex\_A73x2.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A73x2.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x2.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x2.cluster0.cpu1**

ARM Cortex-A73 CT model.

Type: [ARM\\_Cortex-A73](#).

**FVP\_Base\_Cortex\_A73x2.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A73x2.cluster0.cpu1.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x2.cluster0.cpu1.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x2.cluster0.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x2.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x2.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A73x2.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A73x2.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A73x2.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A73x2.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A73x2.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A73x2.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A73x2.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.46 FVP\_Base\_Cortex-A73x2-A53x4

FVP\_Base\_Cortex-A73x2-A53x4 contains the following instances:

### FVP\_Base\_Cortex-A73x2-A53x4 instances

**FVP\_Base\_Cortex\_A73x2\_A53x4**

Base Platform Compute Subsystem for ARM Cortex A73x2CT and ARM Cortex A53x4CT.

Type: [FVP\\_Base\\_Cortex\\_A73x2\\_A53x4](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.  
Type: CounterModule.

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.  
Type: CounterModule.

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).  
Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.  
Type: CounterModule.

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.  
Type: CounterModule.

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.ap\_refclk**

ARM Generic Timer.  
Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.audioout**

SDL based Audio Output for PL041\_AACI.  
Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.hdlcd0.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.hdlcd0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.mmcc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.p1011\_uart0**

ARM PrimeCell UART(PLO11).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.p1111\_clcd.p111x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSCL\\_91C111](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.terminal\_2**  
Telnet terminal interface.  
Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.terminal\_3**  
Telnet terminal interface.  
Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.trusted\_key\_storage**  
Trusted Root-Key Storage unit.  
Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.trusted\_nv\_counter**  
Trusted Non-Volatile Counter unit.  
Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.trusted\_rng**  
Random Number Generator unit.  
Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.trusted\_watchdog**  
ARM Watchdog Module(SP805).  
Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.tzc\_400**  
TrustZone Address Space Controller.  
Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.ve\_sysregs**  
Type: VE\_SysRegs.

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.vedcc**  
Daughterboard Configuration Control (DCC).  
Type: VEDCC.

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.virtio\_net**  
VirtioNet device over MMIO transport.  
Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.virtio\_net\_labeller**  
Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.virtio\_rng**  
VirtioEntropy device over MMIO transport.  
Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.virtioblockdevice**  
virtio block device.  
Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.virtioblockdevice\_labeller**  
Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCl400](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.clockdivider1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster0**

ARM Cortex-A73 Cluster CT model.

Type: Cluster\_ARM\_Cortex-A73.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster0.cpu0**

ARM Cortex-A73 CT model.

Type: ARM\_Cortex-A73.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster0.cpu1**

ARM Cortex-A73 CT model.

Type: ARM\_Cortex-A73.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster0.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster1**

ARM Cortex-A53 Cluster CT model.

Type: Cluster\_ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster1.cpu0**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster1.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster1.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster1.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster1.cpu1**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster1.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster1.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster1.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster1.cpu2**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster1.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster1.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster1.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster1.cpu3**

ARM Cortex-A53 CT model.

Type: ARM\_Cortex-A53.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster1.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster1.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster1.cpu3.llicache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster1.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.cluster1.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A73x2\_A53x4.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.47 FVP\_Base\_Cortex-A73x4

FVP\_Base\_Cortex-A73x4 contains the following instances:

### FVP\_Base\_Cortex-A73x4 instances

**FVP\_Base\_Cortex\_A73x4**

Base Platform Compute Subsystem for ARM Cortex A73x4 CT.

Type: [FVP\\_Base\\_Cortex\\_A73x4](#).

**FVP\_Base\_Cortex\_A73x4.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A73x4.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A73x4.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A73x4.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Cortex\_A73x4.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A73x4.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A73x4.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A73x4.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A73x4.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A73x4.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A73x4.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x4.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x4.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x4.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x4.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A73x4.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A73x4.bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A73x4.bp.hd1cd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A73x4\_bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A73x4\_bp.hdlcd0.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A73x4\_bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x4\_bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A73x4\_bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A73x4\_bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x4\_bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x4\_bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4\_bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x4\_bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x4\_bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x4.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x4.bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A73x4.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A73x4.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A73x4.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A73x4.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A73x4.bp.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A73x4.bp.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A73x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A73x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A73x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A73x4.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x4.bp.pl1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A73x4.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A73x4.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A73x4.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A73x4.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A73x4.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x4.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x4.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Cortex\_A73x4.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A73x4.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A73x4.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x4.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x4.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x4.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x4.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A73x4.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A73x4.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A73x4.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A73x4.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A73x4.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A73x4.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A73x4.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A73x4.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x4.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A73x4.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A73x4.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x4.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A73x4.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x4.bp.vis**

Display window for VE using Visualisation library.

Type: vEVisualisation.

**FVP\_Base\_Cortex\_A73x4.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A73x4.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A73x4.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4.cluster0**

ARM Cortex-A73 Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-A73](#).

**FVP\_Base\_Cortex\_A73x4.cluster0.cpu0**

ARM Cortex-A73 CT model.

Type: [ARM\\_Cortex-A73](#).

**FVP\_Base\_Cortex\_A73x4.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A73x4.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x4.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x4.cluster0.cpu1**

ARM Cortex-A73 CT model.

Type: ARM\_Cortex-A73.

**FVP\_Base\_Cortex\_A73x4.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A73x4.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x4.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x4.cluster0.cpu2**

ARM Cortex-A73 CT model.

Type: ARM\_Cortex-A73.

**FVP\_Base\_Cortex\_A73x4.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A73x4.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x4.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x4.cluster0.cpu3**

ARM Cortex-A73 CT model.

Type: ARM\_Cortex-A73.

**FVP\_Base\_Cortex\_A73x4.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A73x4.cluster0.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x4.cluster0.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x4.cluster0.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x4.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x4.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A73x4.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A73x4.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A73x4.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A73x4.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A73x4.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A73x4.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A73x4.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.48 FVP\_Base\_Cortex-A73x4-A53x4

FVP\_Base\_Cortex-A73x4-A53x4 contains the following instances:

### FVP\_Base\_Cortex-A73x4-A53x4 instances

#### **FVP\_Base\_Cortex\_A73x4\_A53x4**

Base Platform Compute Subsystem for ARM Cortex A73x4CT and ARM Cortex A53x4CT.

Type: [FVP\\_Base\\_Cortex\\_A73x4\\_A53x4](#).

#### **FVP\_Base\_Cortex\_A73x4\_A53x4\_bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_A73x4\_A53x4\_bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A73x4\_A53x4\_bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A73x4\_A53x4\_bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A73x4\_A53x4\_bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_A73x4\_A53x4\_bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_A73x4\_A53x4\_bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_A73x4\_A53x4\_bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.hdlcd0.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.hd1cd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.mmci**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.pl111\_clcd.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.clockdivider1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster0**

ARM Cortex-A73 Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-A73](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster0.cpu0**

ARM Cortex-A73 CT model.

Type: [ARM\\_Cortex-A73](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster0.cpu1**

ARM Cortex-A73 CT model.

Type: ARM\_Cortex-A73.

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster0.cpu2**

ARM Cortex-A73 CT model.

Type: ARM\_Cortex-A73.

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster0.cpu3**

ARM Cortex-A73 CT model.

Type: ARM\_Cortex-A73.

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster0.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster0.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster0.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster1**

ARM Cortex-A53 Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-A53](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster1.cpu0**

ARM Cortex-A53 CT model.

Type: [ARM\\_Cortex-A53](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster1.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster1.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster1.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster1.cpu1**

ARM Cortex-A53 CT model.

Type: [ARM\\_Cortex-A53](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster1.cpu1.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster1.cpu1.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster1.cpu1.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster1.cpu2**

ARM Cortex-A53 CT model.

Type: [ARM\\_Cortex-A53](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster1.cpu2.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster1.cpu2.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster1.cpu2.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster1.cpu3**

ARM Cortex-A53 CT model.

Type: [ARM\\_Cortex-A53](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster1.cpu3.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster1.cpu3.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster1.cpu3.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster1.l2\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.cluster1\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A73x4\_A53x4.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.49 FVP\_Base\_Cortex-A75

FVP\_Base\_Cortex-A75 contains the following instances:

### FVP\_Base\_Cortex-A75 instances

**FVP\_Base\_Cortex\_A75**

Base Platform Compute Subsystem for ARM Cortex A75CT.

Type: [FVP\\_Base\\_Cortex\\_A75](#).

**FVP\_Base\_Cortex\_A75.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A75.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A75.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A75.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A75.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A75.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A75.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A75.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A75.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A75.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A75.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A75.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A75.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A75.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A75.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A75.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A75.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A75.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A75.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A75.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A75.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A75.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A75.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A75.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A75.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A75.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A75.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A75.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A75.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A75.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A75.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A75.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A75.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A75.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A75\_bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A75\_bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A75\_bp.hdlcd0.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A75\_bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A75\_bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A75\_bp mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A75\_bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A75\_bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A75\_bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A75\_bp.p1011\_uart0**

ARM PrimeCell UART(PLO11).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A75\_bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A75.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A75.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A75.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A75.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A75.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A75.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A75.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A75.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A75.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A75.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A75.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A75.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A75.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A75.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A75.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A75.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A75.bp.p1111\_clcd.p111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A75.bp.p1111\_clcd.p111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A75.bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A75.bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A75.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A75.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A75.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A75.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A75.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A75.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A75.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A75.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A75.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A75.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A75.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A75.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A75.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A75.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A75.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A75.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A75.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A75.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A75.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A75.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A75.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A75.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A75.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A75.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A75.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A75.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A75.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A75.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A75.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A75.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A75.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A75.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A75.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A75.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A75.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A75.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A75.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A75.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A75.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A75.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A75.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A75.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A75.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A75.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A75.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A75.cluster0**

ARM Cortex-A75 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A75.cluster0.cpu0**

ARM Cortex-A75 CT model.

Type: [ARM\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A75.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A75.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A75.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A75.cluster0.cpu0.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A75.cluster0.cpu1**

ARM Cortex-A75 CT model.

Type: ARM\_Cortex-A75.

**FVP\_Base\_Cortex\_A75.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A75.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A75.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A75.cluster0.cpu1.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A75.cluster0.cpu2**

ARM Cortex-A75 CT model.

Type: ARM\_Cortex-A75.

**FVP\_Base\_Cortex\_A75.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A75.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A75.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A75.cluster0.cpu2.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A75.cluster0.cpu3**

ARM Cortex-A75 CT model.

Type: [ARM\\_Cortex-A75](#).

**FVP\_Base\_Cortex\_A75.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A75.cluster0.cpu3.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A75.cluster0.cpu3.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A75.cluster0.cpu3.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A75.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A75.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A75.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A75.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A75.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A75.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A75.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A75.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A75.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.50 FVP\_Base\_Cortex-A76

FVP\_Base\_Cortex-A76 contains the following instances:

### FVP\_Base\_Cortex-A76 instances

**FVP\_Base\_Cortex\_A76**

Base Platform Compute Subsystem for ARM CortexA76CT.

Type: [FVP\\_Base\\_Cortex\\_A76](#).

**FVP\_Base\_Cortex\_A76.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A76.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A76.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A76.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A76.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A76.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A76.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A76.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A76.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A76.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A76.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A76.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A76.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A76.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A76.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A76.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A76.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A76.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A76.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A76.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A76.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A76.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A76.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A76.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A76\_bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A76\_bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A76\_bp.hdlcd0.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A76\_bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A76\_bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A76\_bp mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A76\_bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A76\_bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A76\_bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76\_bp.p1011\_uart0**

ARM PrimeCell UART(PLO11).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A76\_bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76\_bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A76\_bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76\_bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A76\_bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76\_bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A76\_bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76\_bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A76\_bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A76\_bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A76\_bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76\_bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A76\_bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76\_bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A76\_bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A76\_bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A76\_bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A76\_bp.p1111\_clcd.p111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A76\_bp.p1111\_clcd.p111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A76\_bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A76\_bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A76.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A76.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A76.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A76.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A76.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A76.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A76.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A76.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A76.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A76.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A76.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A76.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A76.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A76.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A76.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A76.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A76.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A76.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A76.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A76.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A76.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A76.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A76.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A76.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A76.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A76.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A76.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A76.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A76.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A76.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A76.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76.cluster0**

ARM Cortex-A76 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A76](#).

**FVP\_Base\_Cortex\_A76.cluster0.cpu0**

ARM Cortex-A76 CT model.

Type: [ARM\\_Cortex-A76](#).

**FVP\_Base\_Cortex\_A76.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A76.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A76.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A76.cluster0.cpu0.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A76.cluster0.cpu1**

ARM Cortex-A76 CT model.

Type: ARM\_Cortex-A76.

**FVP\_Base\_Cortex\_A76.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A76.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A76.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A76.cluster0.cpu1.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A76.cluster0.cpu2**

ARM Cortex-A76 CT model.

Type: ARM\_Cortex-A76.

**FVP\_Base\_Cortex\_A76.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A76.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A76.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A76.cluster0.cpu2.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A76.cluster0.cpu3**

ARM Cortex-A76 CT model.

Type: [ARM\\_Cortex-A76](#).

**FVP\_Base\_Cortex\_A76.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A76.cluster0.cpu3.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A76.cluster0.cpu3.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A76.cluster0.cpu3.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A76.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A76.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A76.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A76.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A76.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A76.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A76.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A76.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A76.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.51 FVP\_Base\_Cortex-A76AE

FVP\_Base\_Cortex-A76AE contains the following instances:

### FVP\_Base\_Cortex-A76AE instances

**FVP\_Base\_Cortex\_A76AE**

Base Platform Compute Subsystem for ARM Cortex A76AE.

Type: [FVP\\_Base\\_Cortex\\_A76AE](#).

**FVP\_Base\_Cortex\_A76AE.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A76AE.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A76AE.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76AE.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76AE\_bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A76AE\_bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A76AE\_bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A76AE\_bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76AE\_bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76AE\_bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A76AE\_bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A76AE\_bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A76AE\_bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A76AE\_bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76AE\_bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A76AE.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A76AE.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A76AE.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A76AE.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A76AE.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A76AE.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A76AE.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76AE\_bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76AE\_bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76AE\_bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76AE\_bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76AE\_bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A76AE\_bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A76AE\_bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A76AE\_bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A76AE\_bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A76AE\_bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A76AE\_bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Cortex\_A76AE\_bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A76AE\_bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A76AE\_bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A76AE\_bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A76AE\_bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A76AE\_bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A76AE\_bp mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A76AE\_bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A76AE\_bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A76AE\_bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1011\_uart0**

ARM PrimeCell UART(PLO11).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1111\_clcd.p111x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A76AE\_bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A76AE.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A76AE.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A76AE.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76AE.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A76AE.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A76AE.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76AE.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76AE.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76AE.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76AE.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76AE.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A76AE.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A76AE.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A76AE.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A76AE.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A76AE.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76AE.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76AE.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76AE.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76AE.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76AE.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A76AE.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A76AE.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A76AE.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A76AE.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A76AE.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A76AE.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A76AE.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A76AE.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A76AE.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A76AE.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A76AE.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A76AE.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A76AE.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A76AE.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A76AE.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A76AE.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A76AE.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A76AE.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A76AE.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A76AE.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76AE.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76AE.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A76AE.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCl400](#).

**FVP\_Base\_Cortex\_A76AE.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A76AE.cluster0**

ARM Cortex-A76AE Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A76AE](#).

**FVP\_Base\_Cortex\_A76AE.cluster0.cpu0**

ARM Cortex-A76AE CT model.

Type: [ARM\\_Cortex-A76AE](#).

**FVP\_Base\_Cortex\_A76AE.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A76AE.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A76AE.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A76AE.cluster0.cpu0.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A76AE.cluster0.cpu1**

ARM Cortex-A76AE CT model.

Type: ARM\_Cortex-A76AE.

**FVP\_Base\_Cortex\_A76AE.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A76AE.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A76AE.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A76AE.cluster0.cpu1.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A76AE.cluster0.cpu2**

ARM Cortex-A76AE CT model.

Type: ARM\_Cortex-A76AE.

**FVP\_Base\_Cortex\_A76AE.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A76AE.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A76AE.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A76AE.cluster0.cpu2.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A76AE.cluster0.cpu3**

ARM Cortex-A76AE CT model.

Type: [ARM\\_Cortex-A76AE](#).

**FVP\_Base\_Cortex\_A76AE.cluster0.cpu3.dt1b**

TLB - instruction, data or unified.

Type: [T1bCadi](#).

**FVP\_Base\_Cortex\_A76AE.cluster0.cpu3.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A76AE.cluster0.cpu3.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A76AE.cluster0.cpu3.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A76AE.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A76AE.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A76AE.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A76AE.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A76AE.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A76AE.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A76AE.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A76AE.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A76AE.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.52 FVP\_Base\_Cortex-A77

FVP\_Base\_Cortex-A77 contains the following instances:

### FVP\_Base\_Cortex-A77 instances

**FVP\_Base\_Cortex\_A77**

Base Platform Compute Subsystem for ARM CortexA77CT.

Type: [FVP\\_Base\\_Cortex\\_A77](#).

**FVP\_Base\_Cortex\_A77.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A77.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A77.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A77.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A77.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A77.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A77.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A77.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A77.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A77.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A77.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A77.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A77.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A77.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A77.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A77.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A77.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A77.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A77.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A77.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A77.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A77.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A77.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A77.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A77.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A77.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A77.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A77.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A77.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A77.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A77.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A77.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A77.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A77.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A77\_bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A77\_bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A77\_bp.hdlcd0.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A77\_bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A77\_bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A77\_bp mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A77\_bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A77\_bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A77\_bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A77\_bp.p1011\_uart0**

ARM PrimeCell UART(PLO11).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A77\_bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A77\_bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A77\_bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A77\_bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A77\_bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A77\_bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A77\_bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A77\_bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A77\_bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A77\_bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A77\_bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A77\_bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A77\_bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A77\_bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A77\_bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A77\_bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A77\_bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A77\_bp.p1111\_clcd.p111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A77\_bp.p1111\_clcd.p111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A77\_bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A77\_bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A77.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A77.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A77.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A77.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A77.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A77.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A77.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A77.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A77.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A77.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A77.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A77.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A77.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Cortex\_A77.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A77.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A77.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A77.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A77.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A77.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A77.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A77.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A77.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A77.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A77.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A77.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A77.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A77.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A77.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A77.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A77.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A77.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A77.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A77.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A77.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A77.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A77.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A77.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A77.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A77.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A77.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A77.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A77.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A77.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A77.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A77.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A77.cluster0**

ARM Cortex-A77 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A77](#).

**FVP\_Base\_Cortex\_A77.cluster0.cpu0**

ARM Cortex-A77 CT model.

Type: [ARM\\_Cortex-A77](#).

**FVP\_Base\_Cortex\_A77.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A77.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A77.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A77.cluster0.cpu0.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A77.cluster0.cpu1**

ARM Cortex-A77 CT model.

Type: ARM\_Cortex-A77.

**FVP\_Base\_Cortex\_A77.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A77.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A77.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A77.cluster0.cpu1.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A77.cluster0.cpu2**

ARM Cortex-A77 CT model.

Type: ARM\_Cortex-A77.

**FVP\_Base\_Cortex\_A77.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A77.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A77.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A77.cluster0.cpu2.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A77.cluster0.cpu3**

ARM Cortex-A77 CT model.

Type: [ARM\\_Cortex-A77](#).

**FVP\_Base\_Cortex\_A77.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A77.cluster0.cpu3.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A77.cluster0.cpu3.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A77.cluster0.cpu3.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A77.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A77.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A77.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A77.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A77.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A77.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A77.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A77.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A77.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.53 FVP\_Base\_Cortex-A78

FVP\_Base\_Cortex-A78 contains the following instances:

### FVP\_Base\_Cortex-A78 instances

**FVP\_Base\_Cortex\_A78**

Base Platform Compute Subsystem for ARM CortexA78CT.

Type: [FVP\\_Base\\_Cortex\\_A78](#).

**FVP\_Base\_Cortex\_A78.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A78.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A78.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A78.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A78.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A78.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A78.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A78.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A78.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A78.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A78.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A78.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A78.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A78.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A78.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A78.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A78.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A78\_bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A78\_bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A78\_bp.hdlcd0.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A78\_bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A78\_bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A78\_bp mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A78\_bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A78\_bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A78\_bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78\_bp.p1011\_uart0**

ARM PrimeCell UART(PLO11).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A78\_bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A78.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A78.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A78.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A78.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A78.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A78.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A78.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A78.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A78.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A78.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A78.bp.p1111\_clcd.p111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A78.bp.p1111\_clcd.p111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A78.bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A78.bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A78.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A78.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A78.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A78.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A78.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A78.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A78.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A78.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A78.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A78.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A78.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A78.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A78.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A78.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A78.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A78.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A78.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A78.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A78.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A78.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A78.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A78.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A78.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A78.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A78.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A78.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A78.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A78.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A78.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A78.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A78.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78.cluster0**

ARM Cortex-A78 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A78](#).

**FVP\_Base\_Cortex\_A78.cluster0.cpu0**

ARM Cortex-A78 CT model.

Type: [ARM\\_Cortex-A78](#).

**FVP\_Base\_Cortex\_A78.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A78.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78.cluster0.cpu0.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78.cluster0.cpu1**

ARM Cortex-A78 CT model.

Type: ARM\_Cortex-A78.

**FVP\_Base\_Cortex\_A78.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A78.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78.cluster0.cpu1.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78.cluster0.cpu2**

ARM Cortex-A78 CT model.

Type: ARM\_Cortex-A78.

**FVP\_Base\_Cortex\_A78.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A78.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78.cluster0.cpu2.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A78.cluster0.cpu3**

ARM Cortex-A78 CT model.

Type: [ARM\\_Cortex-A78](#).

**FVP\_Base\_Cortex\_A78.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A78.cluster0.cpu3.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A78.cluster0.cpu3.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A78.cluster0.cpu3.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A78.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A78.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A78.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A78.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A78.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A78.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A78.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A78.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A78.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.54 FVP\_Base\_Cortex-A78AE

FVP\_Base\_Cortex-A78AE contains the following instances:

### FVP\_Base\_Cortex-A78AE instances

**FVP\_Base\_Cortex\_A78AE**

Base Platform Compute Subsystem for ARM Cortex A78AE.

Type: [FVP\\_Base\\_Cortex\\_A78AE](#).

**FVP\_Base\_Cortex\_A78AE.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A78AE.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A78AE.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78AE.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78AE.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A78AE.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A78AE.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A78AE.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78AE.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78AE.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A78AE.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A78AE.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A78AE.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A78AE.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78AE.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78AE.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78AE.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78AE.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78AE.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78AE.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78AE.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78AE.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78AE\_bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78AE\_bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78AE\_bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78AE\_bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78AE\_bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A78AE\_bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A78AE\_bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A78AE\_bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A78AE\_bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A78AE\_bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A78AE\_bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Cortex\_A78AE\_bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A78AE\_bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A78AE\_bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A78AE\_bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A78AE\_bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A78AE\_bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A78AE\_bp mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A78AE\_bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A78AE\_bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A78AE\_bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1011\_uart0**

ARM PrimeCell UART(PLO11).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1111\_clcd.p111x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A78AE\_bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A78AE\_bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A78AE\_bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A78AE\_bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78AE\_bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A78AE\_bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A78AE\_bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78AE\_bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78AE\_bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78AE\_bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78AE\_bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78AE\_bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A78AE\_bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A78AE.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_A78AE.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A78AE.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A78AE.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78AE.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78AE.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78AE.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78AE.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78AE.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A78AE.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A78AE.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A78AE.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A78AE.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A78AE.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A78AE.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A78AE.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A78AE.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A78AE.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A78AE.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A78AE.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A78AE.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A78AE.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A78AE.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A78AE.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A78AE.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A78AE.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A78AE.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A78AE.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A78AE.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78AE.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78AE.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78AE.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCl400](#).

**FVP\_Base\_Cortex\_A78AE.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78AE.cluster0**

ARM Cortex-A78AE Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A78AE](#).

**FVP\_Base\_Cortex\_A78AE.cluster0.cpu0**

ARM Cortex-A78AE CT model.

Type: [ARM\\_Cortex-A78AE](#).

**FVP\_Base\_Cortex\_A78AE.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A78AE.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78AE.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78AE.cluster0.cpu0.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78AE.cluster0.cpu1**

ARM Cortex-A78AE CT model.

Type: ARM\_Cortex-A78AE.

**FVP\_Base\_Cortex\_A78AE.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A78AE.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78AE.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78AE.cluster0.cpu1.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78AE.cluster0.cpu2**

ARM Cortex-A78AE CT model.

Type: ARM\_Cortex-A78AE.

**FVP\_Base\_Cortex\_A78AE.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A78AE.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78AE.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78AE.cluster0.cpu2.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A78AE.cluster0.cpu3**

ARM Cortex-A78AE CT model.

Type: [ARM\\_Cortex-A78AE](#).

**FVP\_Base\_Cortex\_A78AE.cluster0.cpu3.dt1b**

TLB - instruction, data or unified.

Type: [T1bCadi](#).

**FVP\_Base\_Cortex\_A78AE.cluster0.cpu3.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A78AE.cluster0.cpu3.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A78AE.cluster0.cpu3.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A78AE.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A78AE.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A78AE.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A78AE.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A78AE.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A78AE.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A78AE.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A78AE.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A78AE.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.55 FVP\_Base\_Cortex-A78C

FVP\_Base\_Cortex-A78C contains the following instances:

### FVP\_Base\_Cortex-A78C instances

**FVP\_Base\_Cortex\_A78C**

Base Platform Compute Subsystem for ARM Cortex A78CCT.

Type: [FVP\\_Base\\_Cortex\\_A78C](#).

**FVP\_Base\_Cortex\_A78C.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_A78C.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A78C.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78C.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78C.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A78C.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A78C.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_A78C.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78C.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78C.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A78C.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_A78C.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_A78C.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_A78C.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78C.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78C.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78C.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78C.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78C.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78C.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78C.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_A78C.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78C.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78C.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78C.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78C.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78C.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_A78C.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A78C.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A78C.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A78C.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A78C.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_A78C.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_A78C.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A78C\_bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A78C\_bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A78C\_bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A78C\_bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A78C\_bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_A78C\_bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_A78C\_bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A78C\_bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A78C\_bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78C\_bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A78C\_bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78C.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A78C.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78C.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A78C.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78C.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_A78C.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78C.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_A78C.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_A78C.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A78C.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78C.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_A78C.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78C.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_A78C.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_A78C.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A78C.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A78C.bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A78C.bp.p1111\_clcd.p111x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_A78C.bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A78C.bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_A78C.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_A78C.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_A78C.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78C.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_A78C.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_A78C.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78C.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78C.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78C.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78C.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78C.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_A78C.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_A78C.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Cortex\_A78C.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A78C.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_A78C.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78C.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78C.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78C.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78C.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78C.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A78C.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A78C.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A78C.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_A78C.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_A78C.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_A78C.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_A78C.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_A78C.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_A78C.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_A78C.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_A78C.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_A78C.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A78C.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_A78C.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_A78C.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A78C.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_A78C.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A78C.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_A78C.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_A78C.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78C.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78C.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_A78C.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_A78C.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_A78C.cluster0**

ARM Cortex-A78C Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A78C](#).

**FVP\_Base\_Cortex\_A78C.cluster0.cpu0**

ARM Cortex-A78C CT model.

Type: [ARM\\_Cortex-A78C](#).

**FVP\_Base\_Cortex\_A78C.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A78C.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78C.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78C.cluster0.cpu0.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78C.cluster0.cpu1**

ARM Cortex-A78C CT model.

Type: ARM\_Cortex-A78C.

**FVP\_Base\_Cortex\_A78C.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A78C.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78C.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78C.cluster0.cpu1.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78C.cluster0.cpu2**

ARM Cortex-A78C CT model.

Type: ARM\_Cortex-A78C.

**FVP\_Base\_Cortex\_A78C.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_A78C.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78C.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_A78C.cluster0.cpu2.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A78C.cluster0.cpu3**

ARM Cortex-A78C CT model.

Type: [ARM\\_Cortex-A78C](#).

**FVP\_Base\_Cortex\_A78C.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_A78C.cluster0.cpu3.lldcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A78C.cluster0.cpu3.llicache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A78C.cluster0.cpu3.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_A78C.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_A78C.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_A78C.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_A78C.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_A78C.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_A78C.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_A78C.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_A78C.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_A78C.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.56 FVP\_Base\_Cortex-X1

FVP\_Base\_Cortex-X1 contains the following instances:

### FVP\_Base\_Cortex-X1 instances

**FVP\_Base\_Cortex\_X1**

Base Platform Compute Subsystem for ARM CortexX1CT.

Type: [FVP\\_Base\\_Cortex\\_X1](#).

**FVP\_Base\_Cortex\_X1.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_X1.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_X1.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_X1.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_X1.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_X1.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_X1.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_X1.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_X1.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_X1.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X1.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X1.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X1.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X1.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X1.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X1.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X1.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_X1.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_X1.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_X1.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_X1.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_X1.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_X1.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_X1.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_X1\_bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_X1\_bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_X1\_bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_X1\_bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X1\_bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_X1\_bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_X1\_bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_X1\_bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_X1\_bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1\_bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_X1\_bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_X1.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_X1.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_X1.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_X1.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_X1.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_X1.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_X1.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_X1.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_X1.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_X1.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_X1.bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_X1.bp.p1111\_clcd.p111x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_X1.bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X1.bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_X1.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_X1.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_X1.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_X1.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_X1.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_X1.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_X1.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Cortex\_X1.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_X1.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_X1.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_X1.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_X1.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_X1.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_X1.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_X1.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_X1.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_X1.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_X1.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_X1.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_X1.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_X1.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_X1.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X1.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_X1.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_X1.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X1.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_X1.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X1.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_X1.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_X1.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_X1.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1.cluster0**

ARM Cortex-X1 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-X1](#).

**FVP\_Base\_Cortex\_X1.cluster0.cpu0**

ARM Cortex-X1 CT model.

Type: [ARM\\_Cortex-X1](#).

**FVP\_Base\_Cortex\_X1.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_X1.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X1.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X1.cluster0.cpu0.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X1.cluster0.cpu1**

ARM Cortex-X1 CT model.

Type: ARM\_Cortex-X1.

**FVP\_Base\_Cortex\_X1.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_X1.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X1.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X1.cluster0.cpu1.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X1.cluster0.cpu2**

ARM Cortex-X1 CT model.

Type: ARM\_Cortex-X1.

**FVP\_Base\_Cortex\_X1.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_X1.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X1.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X1.cluster0.cpu2.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_X1.cluster0.cpu3**

ARM Cortex-X1 CT model.

Type: [ARM\\_Cortex-X1](#).

**FVP\_Base\_Cortex\_X1.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_X1.cluster0.cpu3.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_X1.cluster0.cpu3.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_X1.cluster0.cpu3.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_X1.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X1.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_X1.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_X1.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_X1.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_X1.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_X1.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_X1.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_X1.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.57 FVP\_Base\_Cortex-X1C

FVP\_Base\_Cortex-X1C contains the following instances:

### FVP\_Base\_Cortex-X1C instances

**FVP\_Base\_Cortex\_X1C**

Base Platform Compute Subsystem for ARM CortexX1CCT.

Type: [FVP\\_Base\\_Cortex\\_X1C](#).

**FVP\_Base\_Cortex\_X1C.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_X1C.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_X1C.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1C.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1C.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_X1C.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_X1C.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_X1C.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1C.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1C.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_X1C.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_X1C.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_X1C.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_X1C.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1C.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X1C.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X1C.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X1C.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X1C.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X1C.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X1C.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X1C.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1C.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1C.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1C.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1C.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1C.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_X1C.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_X1C.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_X1C.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_X1C.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_X1C.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_X1C.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Cortex\_X1C.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_X1C.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_X1C.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_X1C.bp.hdlcd0.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_X1C.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X1C.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_X1C.bp mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_X1C.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_X1C.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_X1C.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1C.bp.p1011\_uart0**

ARM PrimeCell UART(PLO11).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_X1C.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1C.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_X1C.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1C.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_X1C.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1C.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_X1C.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1C.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_X1C.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_X1C.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_X1C.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1C.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_X1C.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1C.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_X1C.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_X1C.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_X1C.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_X1C.bp.p1111\_clcd.p111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_X1C.bp.p1111\_clcd.p111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_X1C.bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X1C.bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_X1C.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_X1C.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_X1C.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1C.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_X1C.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_X1C.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1C.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1C.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1C.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1C.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1C.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_X1C.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_X1C.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Cortex\_X1C.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_X1C.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_X1C.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1C.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1C.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1C.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1C.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1C.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_X1C.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_X1C.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_X1C.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_X1C.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_X1C.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_X1C.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_X1C.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_X1C.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_X1C.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_X1C.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_X1C.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_X1C.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X1C.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_X1C.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_X1C.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X1C.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_X1C.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X1C.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_X1C.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_X1C.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1C.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1C.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X1C.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_X1C.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X1C.cluster0**

ARM Cortex-X1C Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-X1C](#).

**FVP\_Base\_Cortex\_X1C.cluster0.cpu0**

ARM Cortex-X1C CT model.

Type: [ARM\\_Cortex-X1C](#).

**FVP\_Base\_Cortex\_X1C.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_X1C.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X1C.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X1C.cluster0.cpu0.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X1C.cluster0.cpu1**

ARM Cortex-X1C CT model.

Type: ARM\_Cortex-X1C.

**FVP\_Base\_Cortex\_X1C.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_X1C.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X1C.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X1C.cluster0.cpu1.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X1C.cluster0.cpu2**

ARM Cortex-X1C CT model.

Type: ARM\_Cortex-X1C.

**FVP\_Base\_Cortex\_X1C.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_X1C.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X1C.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X1C.cluster0.cpu2.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_X1C.cluster0.cpu3**

ARM Cortex-X1C CT model.

Type: [ARM\\_Cortex-X1c](#).

**FVP\_Base\_Cortex\_X1C.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_X1C.cluster0.cpu3.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_X1C.cluster0.cpu3.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_X1C.cluster0.cpu3.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_X1C.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X1C.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_X1C.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_X1C.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_X1C.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_X1C.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_X1C.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_X1C.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_X1C.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.58 FVP\_Base\_Cortex-X2

FVP\_Base\_Cortex-X2 contains the following instances:

### FVP\_Base\_Cortex-X2 instances

**FVP\_Base\_Cortex\_X2**

Base Platform Compute Subsystem for ARM CortexX2CT.

Type: [FVP\\_Base\\_Cortex\\_X2](#).

**FVP\_Base\_Cortex\_X2.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Cortex\_X2.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_X2.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X2.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X2.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_X2.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_X2.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Cortex\_X2.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X2.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X2.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_X2.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_X2.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_X2.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_X2.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X2.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X2.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X2.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X2.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X2.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X2.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X2.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X2.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X2.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X2.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X2.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X2.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X2.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_X2.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_X2.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_X2.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_X2.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_X2.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_X2.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Cortex\_X2.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_X2\_bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_X2\_bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_X2\_bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_X2\_bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X2\_bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_X2\_bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_X2\_bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_X2\_bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_X2\_bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X2\_bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_X2\_bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X2.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_X2.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X2.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_X2.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X2.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_X2.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X2.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_X2.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_X2.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_X2.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X2.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_X2.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X2.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_X2.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_X2.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_X2.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_X2.bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_X2.bp.p1111\_clcd.p111x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_X2.bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X2.bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_X2.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_X2.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_X2.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X2.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_X2.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_X2.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X2.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X2.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X2.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X2.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X2.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_X2.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_X2.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Cortex\_X2.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_X2.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_X2.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X2.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X2.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X2.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X2.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X2.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_X2.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_X2.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_X2.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_X2.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_X2.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_X2.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_X2.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_X2.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_X2.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_X2.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_X2.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_X2.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X2.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_X2.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_X2.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X2.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_X2.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X2.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_X2.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_X2.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X2.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X2.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X2.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_X2.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X2.cluster0**

ARM Cortex-X2 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-X2](#).

**FVP\_Base\_Cortex\_X2.cluster0.cpu0**

ARM Cortex-X2 CT model.

Type: [ARM\\_Cortex-X2](#).

**FVP\_Base\_Cortex\_X2.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_X2.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu0.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu1**

ARM Cortex-X2 CT model.

Type: ARM\_Cortex-X2.

**FVP\_Base\_Cortex\_X2.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_X2.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu1.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu2**

ARM Cortex-X2 CT model.

Type: ARM\_Cortex-X2.

**FVP\_Base\_Cortex\_X2.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_X2.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu2.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu3**

ARM Cortex-X2 CT model.

Type: ARM\_Cortex-X2.

**FVP\_Base\_Cortex\_X2.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_X2.cluster0.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu3.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu4**

ARM Cortex-X2 CT model.

Type: ARM\_Cortex-X2.

**FVP\_Base\_Cortex\_X2.cluster0.cpu4.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_X2.cluster0.cpu4.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu4.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu4.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu5**

ARM Cortex-X2 CT model.

Type: ARM\_Cortex-X2.

**FVP\_Base\_Cortex\_X2.cluster0.cpu5.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_X2.cluster0.cpu5.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu5.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu5.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu6**

ARM Cortex-X2 CT model.

Type: ARM\_Cortex-X2.

**FVP\_Base\_Cortex\_X2.cluster0.cpu6.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_X2.cluster0.cpu6.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu6.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu6.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu7**

ARM Cortex-X2 CT model.

Type: ARM\_Cortex-X2.

**FVP\_Base\_Cortex\_X2.cluster0.cpu7.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_X2.cluster0.cpu7.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu7.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0.cpu7.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X2.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X2.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_X2.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_X2.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_X2.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_X2.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_X2.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_X2.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_X2.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.59 FVP\_Base\_Cortex-X3

FVP\_Base\_Cortex-X3 contains the following instances:

### FVP\_Base\_Cortex-X3 instances

#### **FVP\_Base\_Cortex\_X3**

Base Platform Compute Subsystem for ARM CortexX3CT.

Type: [FVP\\_Base\\_Cortex\\_X3](#).

#### **FVP\_Base\_Cortex\_X3.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Cortex\_X3.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_X3.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X3.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Cortex\_X3.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_X3.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Cortex\_X3.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Cortex\_X3.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_X3.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Cortex\_X3.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Cortex\_X3.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Cortex\_X3.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X3.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X3.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X3.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X3.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X3.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Cortex\_X3.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_X3.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_X3.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_X3.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_X3.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Cortex\_X3.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Cortex\_X3.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_X3.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_X3.bp.hdlcd0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_X3.bp.hdlcd0.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_X3.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X3.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Cortex\_X3.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Cortex\_X3.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_X3.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_X3.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X3.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_X3.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_X3.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_X3.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Cortex\_X3.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Cortex\_X3.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Cortex\_X3.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_X3.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Cortex\_X3.bp.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Cortex\_X3.bp.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Cortex\_X3.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_X3.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_X3.bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_X3.bp.p1111\_clcd.p111x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Cortex\_X3.bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X3.bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Cortex\_X3.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Cortex\_X3.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Cortex\_X3.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X3.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Cortex\_X3.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Cortex\_X3.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X3.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X3.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X3.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X3.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X3.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Cortex\_X3.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Cortex\_X3.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Cortex\_X3.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_X3.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Cortex\_X3.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X3.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_X3.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_X3.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_X3.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Cortex\_X3.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Cortex\_X3.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Cortex\_X3.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Cortex\_X3.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Cortex\_X3.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Cortex\_X3.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Cortex\_X3.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Cortex\_X3.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Cortex\_X3.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X3.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Cortex\_X3.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Cortex\_X3.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X3.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Cortex\_X3.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X3.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Cortex\_X3.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Cortex\_X3.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Cortex\_X3.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Cortex\_X3.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Cortex\_X3.cluster0**

ARM Cortex-X3 Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-X3](#).

**FVP\_Base\_Cortex\_X3.cluster0.cpu0**

ARM Cortex-X3 CT model.

Type: [ARM\\_Cortex-X3](#).

**FVP\_Base\_Cortex\_X3.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_X3.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_X3.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_X3.cluster0.cpu0.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_X3.cluster0.cpu1**

ARM Cortex-X3 CT model.

Type: [ARM\\_Cortex-X3](#).

**FVP\_Base\_Cortex\_X3.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_X3.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X3.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X3.cluster0.cpu1.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X3.cluster0.cpu2**

ARM Cortex-X3 CT model.

Type: ARM\_Cortex-X3.

**FVP\_Base\_Cortex\_X3.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_X3.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X3.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X3.cluster0.cpu2.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X3.cluster0.cpu3**

ARM Cortex-X3 CT model.

Type: ARM\_Cortex-X3.

**FVP\_Base\_Cortex\_X3.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_X3.cluster0.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X3.cluster0.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X3.cluster0.cpu3.12cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X3.cluster0.cpu4**

ARM Cortex-X3 CT model.

Type: ARM\_Cortex-X3.

**FVP\_Base\_Cortex\_X3.cluster0.cpu4.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_X3.cluster0.cpu4.11dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X3.cluster0.cpu4.11icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X3.cluster0.cpu4.12cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X3.cluster0.cpu5**

ARM Cortex-X3 CT model.

Type: ARM\_Cortex-X3.

**FVP\_Base\_Cortex\_X3.cluster0.cpu5.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_X3.cluster0.cpu5.11dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X3.cluster0.cpu5.11icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X3.cluster0.cpu5.12cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Cortex\_X3.cluster0.cpu6**

ARM Cortex-X3 CT model.

Type: ARM\_Cortex-X3.

**FVP\_Base\_Cortex\_X3.cluster0.cpu6.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Cortex\_X3.cluster0.cpu6.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_X3.cluster0.cpu6.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_X3.cluster0.cpu6.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_X3.cluster0.cpu7**

ARM Cortex-X3 CT model.

Type: [ARM\\_Cortex-X3](#).

**FVP\_Base\_Cortex\_X3.cluster0.cpu7.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Cortex\_X3.cluster0.cpu7.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_X3.cluster0.cpu7.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_X3.cluster0.cpu7.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Cortex\_X3.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Cortex\_X3.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Cortex\_X3.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Cortex\_X3.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Cortex\_X3.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Cortex\_X3.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Cortex\_X3.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Cortex\_X3.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Cortex\_X3.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.60 FVP\_Base\_Neoverse-E1

FVP\_Base\_Neoverse-E1 contains the following instances:

### FVP\_Base\_Neoverse-E1 instances

**FVP\_Base\_Neoverse\_E1**

Base Platform Compute Subsystem for ARMNeoverseE1CT.

Type: [FVP\\_Base\\_Neoverse\\_E1](#).

**FVP\_Base\_Neoverse\_E1.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Neoverse\_E1.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Neoverse\_E1.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_E1.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_E1.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Neoverse\_E1.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_E1.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_E1.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Neoverse\_E1.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Neoverse\_E1.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_E1.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_E1.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_E1.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_E1.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_E1.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_Base\_Neoverse\_E1.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_E1.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_E1.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_E1.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_E1.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Neoverse\_E1.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Neoverse\_E1.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Neoverse\_E1.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Neoverse\_E1.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Neoverse\_E1.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Neoverse\_E1.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_E1.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Neoverse\_E1.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Neoverse\_E1.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_E1.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_E1.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_E1.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_E1.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_E1.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_E1.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_E1.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Neoverse\_E1.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Neoverse\_E1.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Neoverse\_E1.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Neoverse\_E1.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Neoverse\_E1.bp.pl111\_clcd.pl111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL111x\\_CLCD](#).

**FVP\_Base\_Neoverse\_E1.bp.pl111\_clcd.pl111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Neoverse\_E1.bp.pl111\_clcd.pl111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Neoverse\_E1.bp.pl111\_clcd.pl111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Neoverse\_E1.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Neoverse\_E1.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_E1.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Neoverse\_E1.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Neoverse\_E1.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Neoverse\_E1.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_E1.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Neoverse\_E1.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Neoverse\_E1.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_E1.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_E1.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_E1.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_E1.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_E1.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_E1.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_E1.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Neoverse\_E1.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Neoverse\_E1.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Neoverse\_E1.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_E1.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_E1.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_E1.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_E1.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_E1.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Neoverse\_E1.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Neoverse\_E1.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Neoverse\_E1.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Neoverse\_E1.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Neoverse\_E1.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Neoverse\_E1.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Neoverse\_E1.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Neoverse\_E1.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_E1.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.  
Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Neoverse\_E1.bp.virtioblockdevice**

virtio block device.  
Type: [VirtioBlockDevice](#).

**FVP\_Base\_Neoverse\_E1.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_E1.bp.virtiop9device**

virtio P9 server.  
Type: [VirtioP9Device](#).

**FVP\_Base\_Neoverse\_E1.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_E1.bp.vis**

Display window for VE using Visualisation library.  
Type: [VEVisualisation](#).

**FVP\_Base\_Neoverse\_E1.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).  
Type: [VisEventRecorder](#).

**FVP\_Base\_Neoverse\_E1.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.bp.vram**

RAM device, can be dynamic or static ram.  
Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_E1.cci400**

Cache Coherent Interconnect for AXI4 ACE.  
Type: [CC1400](#).

**FVP\_Base\_Neoverse\_E1.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_E1.cluster0**

ARM Neoverse-E1 Cluster CT model.

Type: [cluster\\_ARM\\_Neoverse-E1](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu0.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu0.thread0**

ARM Neoverse-E1 CT model.

Type: [ARM\\_Neoverse-E1](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu0.thread1**

ARM Neoverse-E1 CT model.

Type: [ARM\\_Neoverse-E1](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu1.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu1.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu1.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu1.thread0**

ARM Neoverse-E1 CT model.

Type: [ARM\\_Neoverse-E1](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu1.thread1**

ARM Neoverse-E1 CT model.

Type: ARM\_Neoverse-E1.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu2.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu2.thread0**

ARM Neoverse-E1 CT model.

Type: ARM\_Neoverse-E1.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu2.thread1**

ARM Neoverse-E1 CT model.

Type: ARM\_Neoverse-E1.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu3.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu3.thread0**

ARM Neoverse-E1 CT model.

Type: ARM\_Neoverse-E1.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu3.thread1**

ARM Neoverse-E1 CT model.

Type: ARM\_Neoverse-E1.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu4.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu4.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu4.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu4.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu4.thread0**

ARM Neoverse-E1 CT model.

Type: ARM\_Neoverse-E1.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu4.thread1**

ARM Neoverse-E1 CT model.

Type: ARM\_Neoverse-E1.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu5.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu5.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu5.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu5.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu5.thread0**

ARM Neoverse-E1 CT model.

Type: ARM\_Neoverse-E1.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu5.thread1**

ARM Neoverse-E1 CT model.

Type: ARM\_Neoverse-E1.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu5.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu6.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_E1.cluster0.cpu6.ll1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu6.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu6.thread0**

ARM Neoverse-E1 CT model.

Type: [ARM\\_Neoverse-E1](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu6.thread1**

ARM Neoverse-E1 CT model.

Type: [ARM\\_Neoverse-E1](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu7.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu7.ll1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu7.ll1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu7.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu7.thread0**

ARM Neoverse-E1 CT model.

Type: [ARM\\_Neoverse-E1](#).

**FVP\_Base\_Neoverse\_E1.cluster0.cpu7.thread1**

ARM Neoverse-E1 CT model.

Type: [ARM\\_Neoverse-E1](#).

**FVP\_Base\_Neoverse\_E1.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_E1.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Neoverse\_E1.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Neoverse\_E1.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

#### **FVP\_Base\_Neoverse\_E1.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

#### **FVP\_Base\_Neoverse\_E1.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_Base\_Neoverse\_E1.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_Base\_Neoverse\_E1.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_Base\_Neoverse\_E1.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.61 FVP\_Base\_Neoverse-N1

FVP\_Base\_Neoverse-N1 contains the following instances:

### **FVP\_Base\_Neoverse-N1 instances**

#### **FVP\_Base\_Neoverse\_N1**

Base Platform Compute Subsystem for ARMNeoverseN1CT.

Type: [FVP\\_Base\\_Neoverse\\_N1](#).

#### **FVP\_Base\_Neoverse\_N1.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Neoverse\_N1.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Neoverse\_N1.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_N1.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_N1.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Neoverse\_N1.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_N1.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_N1.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Neoverse\_N1.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Neoverse\_N1.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N1.bp.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N1.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N1.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N1.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N1.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Neoverse\_N1.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_N1.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_N1.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_N1.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_N1.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Neoverse\_N1.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Neoverse\_N1.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Neoverse\_N1.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Neoverse\_N1.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Neoverse\_N1.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Neoverse\_N1.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_N1.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Neoverse\_N1.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Neoverse\_N1.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_N1.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_N1.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N1.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_N1.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_N1.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_N1.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_N1.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Neoverse\_N1.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Neoverse\_N1.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Neoverse\_N1.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Neoverse\_N1.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Neoverse\_N1.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Neoverse\_N1.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Neoverse\_N1.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Neoverse\_N1.bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Neoverse\_N1.bp.p1111\_clcd.p111x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Neoverse\_N1.bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_N1.bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Neoverse\_N1.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Neoverse\_N1.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Neoverse\_N1.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N1.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Neoverse\_N1.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Neoverse\_N1.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N1.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N1.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N1.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N1.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N1.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_N1.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_N1.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Neoverse\_N1.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Neoverse\_N1.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Neoverse\_N1.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N1.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_N1.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_N1.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_N1.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_N1.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Neoverse\_N1.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Neoverse\_N1.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Neoverse\_N1.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Neoverse\_N1.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Neoverse\_N1.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Neoverse\_N1.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Neoverse\_N1.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Neoverse\_N1.bp.virtio\_net\_labeler**

Type: [Labeler](#).

**FVP\_Base\_Neoverse\_N1.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.  
Type: [virtioEntropyMMIO](#).

**FVP\_Base\_Neoverse\_N1.bp.virtioblockdevice**

virtio block device.  
Type: [VirtioBlockDevice](#).

**FVP\_Base\_Neoverse\_N1.bp.virtioblockdevice\_labeler**

Type: [Labeler](#).

**FVP\_Base\_Neoverse\_N1.bp.virtiop9device**

virtio P9 server.  
Type: [VirtioP9Device](#).

**FVP\_Base\_Neoverse\_N1.bp.virtiop9device\_labeler**

Type: [Labeler](#).

**FVP\_Base\_Neoverse\_N1.bp.vis**

Display window for VE using Visualisation library.  
Type: [VEVisualisation](#).

**FVP\_Base\_Neoverse\_N1.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).  
Type: [VisEventRecorder](#).

**FVP\_Base\_Neoverse\_N1.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.bp.vram**

RAM device, can be dynamic or static ram.  
Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N1.cci400**

Cache Coherent Interconnect for AXI4 ACE.  
Type: [CCI400](#).

**FVP\_Base\_Neoverse\_N1.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N1.cluster0**

ARM Neoverse-N1 Cluster CT model.

Type: [cluster\\_ARM\\_Neoverse-N1](#).

**FVP\_Base\_Neoverse\_N1.cluster0.cpu0**

ARM Neoverse-N1 CT model.

Type: [ARM\\_Neoverse-N1](#).

**FVP\_Base\_Neoverse\_N1.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Neoverse\_N1.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_N1.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_N1.cluster0.cpu0.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_N1.cluster0.cpu1**

ARM Neoverse-N1 CT model.

Type: [ARM\\_Neoverse-N1](#).

**FVP\_Base\_Neoverse\_N1.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Neoverse\_N1.cluster0.cpu1.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_N1.cluster0.cpu1.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_N1.cluster0.cpu1.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_N1.cluster0.cpu2**

ARM Neoverse-N1 CT model.

Type: ARM\_Neoverse-N1.

**FVP\_Base\_Neoverse\_N1.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Neoverse\_N1.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_N1.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_N1.cluster0.cpu2.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_N1.cluster0.cpu3**

ARM Neoverse-N1 CT model.

Type: ARM\_Neoverse-N1.

**FVP\_Base\_Neoverse\_N1.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Neoverse\_N1.cluster0.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_N1.cluster0.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_N1.cluster0.cpu3.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_N1.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_N1.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Neoverse\_N1.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Neoverse\_N1.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Neoverse\_N1.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Neoverse\_N1.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Neoverse\_N1.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Neoverse\_N1.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Neoverse\_N1.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.62 FVP\_Base\_Neoverse-N2

FVP\_Base\_Neoverse-N2 contains the following instances:

### FVP\_Base\_Neoverse-N2 instances

**FVP\_Base\_Neoverse\_N2**

Base Platform Compute Subsystem for ARMNeoverseN2CT.

Type: [FVP\\_Base\\_Neoverse\\_N2](#).

**FVP\_Base\_Neoverse\_N2.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Neoverse\_N2.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Neoverse\_N2.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_N2.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_N2.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Neoverse\_N2.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_N2.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_N2.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Neoverse\_N2.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Neoverse\_N2.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2.bp.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Neoverse\_N2.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_N2.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_N2.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_N2.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_N2.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Neoverse\_N2.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Neoverse\_N2.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Neoverse\_N2.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Neoverse\_N2.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Neoverse\_N2.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Neoverse\_N2.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_N2.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Neoverse\_N2.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Neoverse\_N2.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_N2.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_N2.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_N2.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_N2.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_N2.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_N2.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Neoverse\_N2.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Neoverse\_N2.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Neoverse\_N2.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Neoverse\_N2.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Neoverse\_N2.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Neoverse\_N2.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Neoverse\_N2.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Neoverse\_N2.bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Neoverse\_N2.bp.p1111\_clcd.p111x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Neoverse\_N2.bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_N2.bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Neoverse\_N2.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Neoverse\_N2.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Neoverse\_N2.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Neoverse\_N2.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Neoverse\_N2.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_N2.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_N2.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Neoverse\_N2.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Neoverse\_N2.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Neoverse\_N2.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_N2.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_N2.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_N2.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_N2.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Neoverse\_N2.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Neoverse\_N2.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Neoverse\_N2.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Neoverse\_N2.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Neoverse\_N2.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Neoverse\_N2.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Neoverse\_N2.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Neoverse\_N2.bp.virtio\_net\_labeler**

Type: [Labeler](#).

**FVP\_Base\_Neoverse\_N2.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.  
Type: [virtioEntropyMMIO](#).

**FVP\_Base\_Neoverse\_N2.bp.virtioblockdevice**

virtio block device.  
Type: [VirtioBlockDevice](#).

**FVP\_Base\_Neoverse\_N2.bp.virtioblockdevice\_labeler**

Type: [Labeler](#).

**FVP\_Base\_Neoverse\_N2.bp.virtiop9device**

virtio P9 server.  
Type: [VirtioP9Device](#).

**FVP\_Base\_Neoverse\_N2.bp.virtiop9device\_labeler**

Type: [Labeler](#).

**FVP\_Base\_Neoverse\_N2.bp.vis**

Display window for VE using Visualisation library.  
Type: [VEVisualisation](#).

**FVP\_Base\_Neoverse\_N2.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).  
Type: [VisEventRecorder](#).

**FVP\_Base\_Neoverse\_N2.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.bp.vram**

RAM device, can be dynamic or static ram.  
Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2.cci400**

Cache Coherent Interconnect for AXI4 ACE.  
Type: [CC1400](#).

**FVP\_Base\_Neoverse\_N2.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2.cluster0**

ARM Neoverse-N2 Cluster CT model.

Type: [cluster\\_ARM\\_Neoverse-N2](#).

**FVP\_Base\_Neoverse\_N2.cluster0.cpu0**

ARM Neoverse-N2 CT model.

Type: [ARM\\_Neoverse-N2](#).

**FVP\_Base\_Neoverse\_N2.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Neoverse\_N2.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_N2.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_N2.cluster0.cpu0.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_N2.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_N2.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Neoverse\_N2.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Neoverse\_N2.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Neoverse\_N2.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Neoverse\_N2.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal()

callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_Base\_Neoverse\_N2.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_Base\_Neoverse\_N2.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_Base\_Neoverse\_N2.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.63 FVP\_Base\_Neoverse-N2x1-Neoverse-N2x1

FVP\_Base\_Neoverse-N2x1-Neoverse-N2x1 contains the following instances:

### **FVP\_Base\_Neoverse-N2x1-Neoverse-N2x1 instances**

#### **FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1**

Base Platform Compute Subsystem for ARMNeoverseN2x1CT and ARMNeoverseN2x1CT.

Type: [FVP\\_Base\\_Neoverse\\_N2x1\\_Neoverse\\_N2x1](#).

#### **FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly

or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.p1011\_uart0**

ARM PrimeCell UART(PLO11).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.clockdivider1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.cluster0**

ARM Neoverse-N2 Cluster CT model.

Type: Cluster\_ARM\_Neoverse-N2.

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.cluster0.cpu0**

ARM Neoverse-N2 CT model.

Type: ARM\_Neoverse-N2.

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.cluster0.cpu0.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.cluster1**

ARM Neoverse-N2 Cluster CT model.

Type: Cluster\_ARM\_Neoverse-N2.

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.cluster1.cpu0**

ARM Neoverse-N2 CT model.

Type: ARM\_Neoverse-N2.

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.cluster1.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.cluster1.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.cluster1.cpu0.11icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.cluster1.cpu0.12cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.cluster1.labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Neoverse\_N2x1\_Neoverse\_N2x1.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.64 FVP\_Base\_Neoverse-V1

FVP\_Base\_Neoverse-V1 contains the following instances:

### FVP\_Base\_Neoverse-V1 instances

**FVP\_Base\_Neoverse\_V1**

Base Platform Compute Subsystem for ARMNeoverseV1CT.

Type: [FVP\\_Base\\_Neoverse\\_V1](#).

**FVP\_Base\_Neoverse\_V1.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_Base\_Neoverse\_V1.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Neoverse\_V1.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Neoverse\_V1.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Neoverse\_V1.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Neoverse\_V1.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_V1.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_V1.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Neoverse\_V1.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Neoverse\_V1.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V1.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V1.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V1.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V1.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V1.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Neoverse\_V1.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_V1.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_V1.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_V1.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_V1.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Neoverse\_V1.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Neoverse\_V1.bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Neoverse\_V1.bp.hd1cd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Neoverse\_V1.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Neoverse\_V1.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Neoverse\_V1.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_V1.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Neoverse\_V1.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Neoverse\_V1.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_V1.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_V1.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V1.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_V1.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_V1.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_V1.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_V1.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Neoverse\_V1.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Neoverse\_V1.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Neoverse\_V1.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Neoverse\_V1.bp.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Neoverse\_V1.bp.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Neoverse\_V1.bp.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Neoverse\_V1.bp.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Neoverse\_V1.bp.pl111\_clcd.pl11x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Neoverse\_V1.bp.pl111\_clcd.pl11x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Neoverse\_V1.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_V1.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Neoverse\_V1.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Neoverse\_V1.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Neoverse\_V1.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V1.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Neoverse\_V1.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Neoverse\_V1.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V1.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V1.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V1.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V1.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V1.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_V1.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_V1.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Neoverse\_V1.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Neoverse\_V1.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Neoverse\_V1.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V1.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_V1.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_V1.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_V1.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_V1.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Neoverse\_V1.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Neoverse\_V1.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Neoverse\_V1.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Neoverse\_V1.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Neoverse\_V1.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Neoverse\_V1.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Neoverse\_V1.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Neoverse\_V1.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_V1.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Neoverse\_V1.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Neoverse\_V1.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_V1.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Neoverse\_V1.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_V1.bp.vis**

Display window for VE using Visualisation library.

Type: vEVisualisation.

**FVP\_Base\_Neoverse\_V1.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Neoverse\_V1.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V1.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Neoverse\_V1.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V1.cluster0**

ARM Neoverse-V1 Cluster CT model.

Type: [cluster\\_ARM\\_Neoverse-V1](#).

**FVP\_Base\_Neoverse\_V1.cluster0.cpu0**

ARM Neoverse-V1 CT model.

Type: [ARM\\_Neoverse-V1](#).

**FVP\_Base\_Neoverse\_V1.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Neoverse\_V1.cluster0.cpu0.lldcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_V1.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_V1.cluster0.cpu0.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_V1.cluster0.cpu1**

ARM Neoverse-V1 CT model.

Type: ARM\_Neoverse-V1.

**FVP\_Base\_Neoverse\_V1.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Neoverse\_V1.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_V1.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_V1.cluster0.cpu1.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_V1.cluster0.cpu2**

ARM Neoverse-V1 CT model.

Type: ARM\_Neoverse-V1.

**FVP\_Base\_Neoverse\_V1.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Neoverse\_V1.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_V1.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_V1.cluster0.cpu2.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_V1.cluster0.cpu3**

ARM Neoverse-V1 CT model.

Type: ARM\_Neoverse-V1.

**FVP\_Base\_Neoverse\_V1.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Neoverse\_V1.cluster0.cpu3.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_V1.cluster0.cpu3.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_V1.cluster0.cpu3.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_V1.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_V1.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Neoverse\_V1.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Neoverse\_V1.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Neoverse\_V1.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Neoverse\_V1.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Neoverse\_V1.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_Base\_Neoverse\_V1.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_Base\_Neoverse\_V1.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.65 FVP\_Base\_Neoverse-V2

FVP\_Base\_Neoverse-V2 contains the following instances:

### FVP\_Base\_Neoverse-V2 instances

#### **FVP\_Base\_Neoverse\_V2**

Base Platform Compute Subsystem for ARMNeoverseV2CT.

Type: [FVP\\_Base\\_Neoverse\\_V2](#).

#### **FVP\_Base\_Neoverse\_V2.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Neoverse\_V2.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Neoverse\_V2.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_V2.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_V2.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Neoverse\_V2.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Neoverse\_V2.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Neoverse\_V2.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_V2.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_V2.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Neoverse\_V2.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Neoverse\_V2.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_V2.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_V2.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_V2.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_V2.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_V2.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_V2.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

#### **FVP\_Base\_Neoverse\_V2.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

#### **FVP\_Base\_Neoverse\_V2.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Neoverse\_V2.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_V2.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_V2.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_V2.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_V2.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Neoverse\_V2.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_Base\_Neoverse\_V2.bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Neoverse\_V2.bp.hd1cd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component

which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Neoverse\_V2.bp.hd1cd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Neoverse\_V2.bp.hd1cd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Neoverse\_V2.bp.hd1cd0\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_V2.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Neoverse\_V2.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Neoverse\_V2.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_V2.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_V2.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_V2.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_V2.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_V2.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2.bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_V2.bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Neoverse\_V2.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Neoverse\_V2.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Neoverse\_V2.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Neoverse\_V2.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Neoverse\_V2.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Neoverse\_V2.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Neoverse\_V2.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Neoverse\_V2.bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Neoverse\_V2.bp.p1111\_clcd.p111x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Neoverse\_V2.bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_V2.bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Neoverse\_V2.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Neoverse\_V2.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Neoverse\_V2.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Neoverse\_V2.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Neoverse\_V2.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_V2.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_V2.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_Base\_Neoverse\_V2.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Neoverse\_V2.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Neoverse\_V2.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_V2.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_V2.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_V2.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_V2.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Neoverse\_V2.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Neoverse\_V2.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Neoverse\_V2.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Neoverse\_V2.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Neoverse\_V2.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Neoverse\_V2.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Neoverse\_V2.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Neoverse\_V2.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_V2.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Neoverse\_V2.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Neoverse\_V2.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_V2.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Neoverse\_V2.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_V2.bp.vis**

Display window for VE using Visualisation library.

Type: [vEVisualisation](#).

**FVP\_Base\_Neoverse\_V2.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Neoverse\_V2.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCl400](#).

**FVP\_Base\_Neoverse\_V2.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2.cluster0**

ARM NeoverseV2 Cluster CT model.

Type: [cluster\\_ARM\\_NeoverseV2](#).

**FVP\_Base\_Neoverse\_V2.cluster0.cpu0**

ARM NeoverseV2 CT model.

Type: [ARM\\_NeoverseV2](#).

**FVP\_Base\_Neoverse\_V2.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_Base\_Neoverse\_V2.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_V2.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_V2.cluster0.cpu0.l2cache**

PV Cache.

Type: [PVCache](#).

**FVP\_Base\_Neoverse\_V2.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_V2.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Neoverse\_V2.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Neoverse\_V2.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Neoverse\_V2.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Neoverse\_V2.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Neoverse\_V2.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_Base\_Neoverse\_V2.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_Base\_Neoverse\_V2.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 13.66 FVP\_Base\_Neoverse-V2x1-Neoverse-V2x1

FVP\_Base\_Neoverse-V2x1-Neoverse-V2x1 contains the following instances:

### FVP\_Base\_Neoverse-V2x1-Neoverse-V2x1 instances

#### **FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1**

Base Platform Compute Subsystem for ARMNeoverseV2x1CT and ARMNeoverseV2x1CT.

Type: [FVP\\_Base\\_Neoverse\\_V2x1\\_Neoverse\\_V2x1](#).

#### **FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

#### **FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

#### **FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component

which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.hdlcd0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1111\_clcd.p111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1111\_clcd.p111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.clockdivider1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.cluster0**

ARM NeoverseV2 Cluster CT model.

Type: cluster\_ARM\_NeoverseV2.

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.cluster0.cpu0**

ARM NeoverseV2 CT model.

Type: ARM\_NeoverseV2.

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.cluster0.cpu0.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.cluster0.labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.cluster1**

ARM NeoverseV2 Cluster CT model.

Type: cluster\_ARM\_NeoverseV2.

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.cluster1.cpu0**

ARM NeoverseV2 CT model.

Type: ARM\_NeoverseV2.

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.cluster1.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.cluster1.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.cluster1.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.cluster1.cpu0.l2cache**

PV Cache.

Type: PVCache.

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.cluster1.labeller**

Type: [Labeller](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_Base\_Neoverse\_V2x1\_Neoverse\_V2x1.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

# 14. BaseR Platform FVPs

This chapter lists the BaseR Platform FVPs and the instances in them.

For the BaseR Platform memory map, see [BaseR Platform memory map](#) in the *Fast Models Reference Guide*.

## 14.1 FVP\_BaseR\_Cortex-R52Plus

FVP\_BaseR\_Cortex-R52Plus contains the following instances:

### FVP\_BaseR\_Cortex-R52Plus instances

#### **FVP\_BaseR\_Cortex\_R52Plus**

Base Platform Compute Subsystem for ARM Cortex R52PlusCT.

Type: [FVP\\_BaseR\\_Cortex\\_R52Plus](#).

#### **FVP\_BaseR\_Cortex\_R52Plus.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_BaseR\_Cortex\_R52Plus.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_BaseR\_Cortex\_R52Plus.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_BaseR\_Cortex\_R52Plus.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_BaseR\_Cortex\_R52Plus.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_BaseR\_Cortex\_R52Plus.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_BaseR\_Cortex\_R52Plus.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_BaseR\_Cortex\_R52Plus.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_BaseR\_Cortex\_R52Plus.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.pl111\_clcd.labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.pl1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl1](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.vis**

Display window for VE using Visualisation library.

Type: vEVisualisation.

**FVP\_BaseR\_Cortex\_R52Plus.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52Plus.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_BaseR\_Cortex\_R52Plus.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52Plus.cluster0**

ARM Cortex-R52Plus CT model.

Type: [ARM\\_Cortex-R52Plus](#).

**FVP\_BaseR\_Cortex\_R52Plus.cluster0.cpu0**

ARM Cortex-R52Plus CT model.

Type: [ARM\\_Cortex-R52Plus](#).

**FVP\_BaseR\_Cortex\_R52Plus.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TLBCadi](#).

**FVP\_BaseR\_Cortex\_R52Plus.cluster0.cpu0.lldcache**

PV Cache.

Type: [PVCache](#).

**FVP\_BaseR\_Cortex\_R52Plus.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_BaseR\_Cortex\_R52Plus.cluster0.cpu1**

ARM Cortex-R52Plus CT model.

Type: ARM\_Cortex-R52Plus.

**FVP\_BaseR\_Cortex\_R52Plus.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_BaseR\_Cortex\_R52Plus.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_BaseR\_Cortex\_R52Plus.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_BaseR\_Cortex\_R52Plus.cluster0.cpu2**

ARM Cortex-R52Plus CT model.

Type: ARM\_Cortex-R52Plus.

**FVP\_BaseR\_Cortex\_R52Plus.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_BaseR\_Cortex\_R52Plus.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_BaseR\_Cortex\_R52Plus.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_BaseR\_Cortex\_R52Plus.cluster0.cpu3**

ARM Cortex-R52Plus CT model.

Type: ARM\_Cortex-R52Plus.

**FVP\_BaseR\_Cortex\_R52Plus.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_BaseR\_Cortex\_R52Plus.cluster0.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_BaseR\_Cortex\_R52Plus.cluster0.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_BaseR\_Cortex\_R52Plus.cluster0.gic\_iri**

GIC IRI internal to cluster.

Type: [gic\\_iri](#).

**FVP\_BaseR\_Cortex\_R52Plus.cluster0.labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52Plus.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_BaseR\_Cortex\_R52Plus.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_BaseR\_Cortex\_R52Plus.flash\_ram0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52Plus.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_BaseR\_Cortex\_R52Plus.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R52Plus.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R52Plus.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R52Plus.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 14.2 FVP\_BaseR\_Cortex-R52x1

FVP\_BaseR\_Cortex-R52x1 contains the following instances:

### FVP\_BaseR\_Cortex-R52x1 instances

#### **FVP\_BaseR\_Cortex\_R52x1**

Base Platform Compute Subsystem for ARM Cortex R52x1 CT.

Type: [FVP\\_BaseR\\_Cortex\\_R52x1](#).

#### **FVP\_BaseR\_Cortex\_R52x1\_bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_BaseR\_Cortex\_R52x1\_bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_BaseR\_Cortex\_R52x1\_bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_BaseR\_Cortex\_R52x1\_bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_BaseR\_Cortex\_R52x1\_bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_BaseR\_Cortex\_R52x1\_bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_BaseR\_Cortex\_R52x1\_bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_BaseR\_Cortex\_R52x1\_bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_BaseR\_Cortex\_R52x1.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_BaseR\_Cortex\_R52x1.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl111\_clcd.pl111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl111\_clcd.pl111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl111\_clcd.pl111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl111\_clcd.pl111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl111\_clcd.pl111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x1.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_BaseR\_Cortex\_R52x1.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x1.cluster0**

ARM CortexR52 MP CT model.

Type: [ARM\\_CortexR52](#).

**FVP\_BaseR\_Cortex\_R52x1.cluster0.cpu0**

ARM CortexR52 MP CT model.

Type: [ARM\\_CortexR52](#).

**FVP\_BaseR\_Cortex\_R52x1.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_BaseR\_Cortex\_R52x1.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_BaseR\_Cortex\_R52x1.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_BaseR\_Cortex\_R52x1.cluster0.gic\_iri**

GIC IRI internal to cluster.

Type: [gic\\_iri](#).

**FVP\_BaseR\_Cortex\_R52x1.cluster0\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52x1.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_BaseR\_Cortex\_R52x1.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_BaseR\_Cortex\_R52x1.flash\_ram0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x1.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_BaseR\_Cortex\_R52x1.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R52x1.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R52x1.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R52x1.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 14.3 FVP\_BaseR\_Cortex-R52x2

FVP\_BaseR\_Cortex-R52x2 contains the following instances:

### FVP\_BaseR\_Cortex-R52x2 instances

#### **FVP\_BaseR\_Cortex\_R52x2**

Base Platform Compute Subsystem for ARM Cortex-R52x2CT.

Type: [FVP\\_BaseR\\_Cortex\\_R52x2](#).

#### **FVP\_BaseR\_Cortex\_R52x2\_bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_BaseR\_Cortex\_R52x2\_bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_BaseR\_Cortex\_R52x2\_bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_BaseR\_Cortex\_R52x2\_bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_BaseR\_Cortex\_R52x2\_bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_BaseR\_Cortex\_R52x2\_bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_BaseR\_Cortex\_R52x2\_bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_BaseR\_Cortex\_R52x2\_bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_BaseR\_Cortex\_R52x2.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_BaseR\_Cortex\_R52x2.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2\_bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2\_bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2\_bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2\_bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2\_bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x2\_bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x2\_bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x2\_bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x2\_bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x2\_bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl111\_clcd.pl111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl111\_clcd.pl111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl111\_clcd.pl111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl111\_clcd.pl111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl111\_clcd.pl111x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x2.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_BaseR\_Cortex\_R52x2.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x2.cluster0**

ARM CortexR52 MP CT model.

Type: [ARM\\_CortexR52](#).

**FVP\_BaseR\_Cortex\_R52x2.cluster0.cpu0**

ARM CortexR52 MP CT model.

Type: [ARM\\_CortexR52](#).

**FVP\_BaseR\_Cortex\_R52x2.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_BaseR\_Cortex\_R52x2.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_BaseR\_Cortex\_R52x2.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_BaseR\_Cortex\_R52x2.cluster0.cpu1**

ARM CortexR52 MP CT model.

Type: [ARM\\_CortexR52](#).

**FVP\_BaseR\_Cortex\_R52x2.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_BaseR\_Cortex\_R52x2.cluster0.cpu1.lldcache**

PV Cache.

Type: [PVCache](#).

**FVP\_BaseR\_Cortex\_R52x2.cluster0.cpu1.llicache**

PV Cache.

Type: [PVCache](#).

**FVP\_BaseR\_Cortex\_R52x2.cluster0.gic\_iri**

GIC IRI internal to cluster.

Type: [gic\\_iri](#).

**FVP\_BaseR\_Cortex\_R52x2.cluster0.labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52x2.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_BaseR\_Cortex\_R52x2.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_BaseR\_Cortex\_R52x2.flash\_ram0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x2.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_BaseR\_Cortex\_R52x2.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R52x2.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R52x2.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R52x2.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 14.4 FVP\_BaseR\_Cortex-R52x4

FVP\_BaseR\_Cortex-R52x4 contains the following instances:

### FVP\_BaseR\_Cortex-R52x4 instances

**FVP\_BaseR\_Cortex\_R52x4**

Base Platform Compute Subsystem for ARMCortexR52x4CT.

Type: [FVP\\_BaseR\\_Cortex\\_R52x4](#).

**FVP\_BaseR\_Cortex\_R52x4.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_BaseR\_Cortex\_R52x4.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_BaseR\_Cortex\_R52x4.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.hd1cd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.pl111\_clcd.pl11x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.pl111\_clcd.pl11x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.pl1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.virtio\_net\_labeler**

Type: [Labeler](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.virtioblockdevice\_labeler**

Type: [Labeler](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.virtiop9device\_labeler**

Type: [Labeler](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.vis**

Display window for VE using Visualisation library.

Type: vEVisualisation.

**FVP\_BaseR\_Cortex\_R52x4.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x4.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_BaseR\_Cortex\_R52x4.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R52x4.cluster0**

ARM CortexR52 MP CT model.

Type: [ARM\\_CortexR52](#).

**FVP\_BaseR\_Cortex\_R52x4.cluster0.cpu0**

ARM CortexR52 MP CT model.

Type: [ARM\\_CortexR52](#).

**FVP\_BaseR\_Cortex\_R52x4.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TLBCadi](#).

**FVP\_BaseR\_Cortex\_R52x4.cluster0.cpu0.lldcache**

PV Cache.

Type: [PVCache](#).

**FVP\_BaseR\_Cortex\_R52x4.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_BaseR\_Cortex\_R52x4.cluster0.cpu1**

ARM CortexR52 MP CT model.

Type: ARM\_CortexR52.

**FVP\_BaseR\_Cortex\_R52x4.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_BaseR\_Cortex\_R52x4.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_BaseR\_Cortex\_R52x4.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_BaseR\_Cortex\_R52x4.cluster0.cpu2**

ARM CortexR52 MP CT model.

Type: ARM\_CortexR52.

**FVP\_BaseR\_Cortex\_R52x4.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_BaseR\_Cortex\_R52x4.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_BaseR\_Cortex\_R52x4.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_BaseR\_Cortex\_R52x4.cluster0.cpu3**

ARM CortexR52 MP CT model.

Type: ARM\_CortexR52.

**FVP\_BaseR\_Cortex\_R52x4.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_BaseR\_Cortex\_R52x4.cluster0.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_BaseR\_Cortex\_R52x4.cluster0.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_BaseR\_Cortex\_R52x4.cluster0.gic\_iri**

GIC IRI internal to cluster.

Type: [gic\\_iri](#).

**FVP\_BaseR\_Cortex\_R52x4.cluster0.labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R52x4.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_BaseR\_Cortex\_R52x4.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_BaseR\_Cortex\_R52x4.flash\_ram0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R52x4.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_BaseR\_Cortex\_R52x4.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R52x4.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R52x4.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R52x4.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 14.5 FVP\_BaseR\_Cortex-R82x1

FVP\_BaseR\_Cortex-R82x1 contains the following instances:

### FVP\_BaseR\_Cortex-R82x1 instances

#### **FVP\_BaseR\_Cortex\_R82x1**

Base Platform Compute Subsystem for ARM Cortex R82x1 CT.

Type: [FVP\\_BaseR\\_Cortex\\_R82x1](#).

#### **FVP\_BaseR\_Cortex\_R82x1\_bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_BaseR\_Cortex\_R82x1\_bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_BaseR\_Cortex\_R82x1\_bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_BaseR\_Cortex\_R82x1\_bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_BaseR\_Cortex\_R82x1\_bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_BaseR\_Cortex\_R82x1\_bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_BaseR\_Cortex\_R82x1\_bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_BaseR\_Cortex\_R82x1\_bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_BaseR\_Cortex\_R82x1.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_BaseR\_Cortex\_R82x1.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl111\_clcd.pl111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl111\_clcd.pl111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl111\_clcd.pl111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl111\_clcd.pl111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl111\_clcd.pl111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x1.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_BaseR\_Cortex\_R82x1.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x1.cluster0**

ARM Cortex-R82 CT model.

Type: [ARM\\_Cortex-R82](#).

**FVP\_BaseR\_Cortex\_R82x1.cluster0.cpu0**

ARM Cortex-R82 CT model.

Type: [ARM\\_Cortex-R82](#).

**FVP\_BaseR\_Cortex\_R82x1.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_BaseR\_Cortex\_R82x1.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_BaseR\_Cortex\_R82x1.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_BaseR\_Cortex\_R82x1.cluster0.cpu0.l2\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_BaseR\_Cortex\_R82x1.cluster0.labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R82x1.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_BaseR\_Cortex\_R82x1.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_BaseR\_Cortex\_R82x1.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_BaseR\_Cortex\_R82x1.llram0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x1.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_BaseR\_Cortex\_R82x1.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R82x1.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R82x1.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R82x1.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 14.6 FVP\_BaseR\_Cortex-R82x2

FVP\_BaseR\_Cortex-R82x2 contains the following instances:

### FVP\_BaseR\_Cortex-R82x2 instances

#### **FVP\_BaseR\_Cortex\_R82x2**

Base Platform Compute Subsystem for ARM Cortex R82x2 CT.

Type: [FVP\\_BaseR\\_Cortex\\_R82x2](#).

#### **FVP\_BaseR\_Cortex\_R82x2\_bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

#### **FVP\_BaseR\_Cortex\_R82x2\_bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_BaseR\_Cortex\_R82x2\_bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_BaseR\_Cortex\_R82x2\_bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_BaseR\_Cortex\_R82x2\_bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_BaseR\_Cortex\_R82x2\_bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

#### **FVP\_BaseR\_Cortex\_R82x2\_bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

#### **FVP\_BaseR\_Cortex\_R82x2\_bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_BaseR\_Cortex\_R82x2.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_BaseR\_Cortex\_R82x2.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2\_bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2\_bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2\_bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2\_bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2\_bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x2\_bp.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x2\_bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x2\_bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x2\_bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x2\_bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.hdlcd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.hdlcd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.hdlcd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl111\_clcd.pl111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl111\_clcd.pl111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl111\_clcd.pl111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl111\_clcd.pl111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl111\_clcd.pl111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x2.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_BaseR\_Cortex\_R82x2.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x2.cluster0**

ARM Cortex-R82 CT model.

Type: [ARM\\_Cortex-R82](#).

**FVP\_BaseR\_Cortex\_R82x2.cluster0.cpu0**

ARM Cortex-R82 CT model.

Type: [ARM\\_Cortex-R82](#).

**FVP\_BaseR\_Cortex\_R82x2.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_BaseR\_Cortex\_R82x2.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_BaseR\_Cortex\_R82x2.cluster0.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_BaseR\_Cortex\_R82x2.cluster0.cpu1**

ARM Cortex-R82 CT model.

Type: [ARM\\_Cortex-R82](#).

**FVP\_BaseR\_Cortex\_R82x2.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_BaseR\_Cortex\_R82x2.cluster0.cpu1.lldcache**

PV Cache.

Type: [PVCache](#).

**FVP\_BaseR\_Cortex\_R82x2.cluster0.cpu1.llicache**

PV Cache.

Type: [PVCache](#).

**FVP\_BaseR\_Cortex\_R82x2.cluster0.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_BaseR\_Cortex\_R82x2.cluster0.labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R82x2.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_BaseR\_Cortex\_R82x2.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_BaseR\_Cortex\_R82x2.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_BaseR\_Cortex\_R82x2.llram0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x2.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_BaseR\_Cortex\_R82x2.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R82x2.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R82x2.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R82x2.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

## 14.7 FVP\_BaseR\_Cortex-R82x4

FVP\_BaseR\_Cortex-R82x4 contains the following instances:

### FVP\_BaseR\_Cortex-R82x4 instances

**FVP\_BaseR\_Cortex\_R82x4**

Base Platform Compute Subsystem for ARM Cortex R82x4CT.

Type: [FVP\\_BaseR\\_Cortex\\_R82x4](#).

**FVP\_BaseR\_Cortex\_R82x4.bp**

Peripherals and address map for the Base Platform.

Type: [BasePlatformPeripherals](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_BaseR\_Cortex\_R82x4.bp.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_BaseR\_Cortex\_R82x4.bp.ap\_refclk**

ARM Generic Timer.

Type: [MemoryMappedGenericTimer](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.clock300MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_BaseR\_Cortex\_R82x4.bp.clock32KHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_BaseR\_Cortex\_R82x4.bp.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_BaseR\_Cortex\_R82x4.bp.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_BaseR\_Cortex\_R82x4.bp.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_BaseR\_Cortex\_R82x4.bp.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_BaseR\_Cortex\_R82x4.bp.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

#### **FVP\_BaseR\_Cortex\_R82x4.bp.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

#### **FVP\_BaseR\_Cortex\_R82x4.bp.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.generic\_watchdog**

ARM Generic Watchdog.

Type: [MemoryMappedGenericWatchdog](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.hd1cd0**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.hd1cd0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.hd1cd0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component

which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.hdlcd0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.hdlcd0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.hdlcd0\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.nontrustedrom**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.nontrustedromloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.ns\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.p1111\_clcd.p111x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.p1111\_clcd\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.refcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.reset\_or**

Or Gate.

Type: [OrGate](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.rl\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.rt\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.s\_dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.secureflash**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.secureflashloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.trusted\_key\_storage**

Trusted Root-Key Storage unit.

Type: [RootKeyStorage](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.trusted\_nv\_counter**

Trusted Non-Volatile Counter unit.

Type: [NonVolatileCounter](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.trusted\_rng**

Random Number Generator unit.

Type: [RandomNumberGenerator](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.trusted\_watchdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.tzc\_400**

TrustZone Address Space Controller.

Type: [Tzc\\_400](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.virtio\_net**

VirtioNet device over MMIO transport.

Type: [VirtioNetMMIO](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.virtio\_net\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.virtio\_rng**

VirtioEntropy device over MMIO transport.

Type: [VirtioEntropyMMIO](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.virtioblockdevice\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.virtiop9device\_labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x4.bp.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x4.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CC1400](#).

**FVP\_BaseR\_Cortex\_R82x4.clockdivider0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_BaseR\_Cortex\_R82x4.cluster0**

ARM Cortex-R82 CT model.

Type: [ARM\\_Cortex-R82](#).

**FVP\_BaseR\_Cortex\_R82x4.cluster0.cpu0**

ARM Cortex-R82 CT model.

Type: [ARM\\_Cortex-R82](#).

**FVP\_BaseR\_Cortex\_R82x4.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.  
Type: TlbCadi.

**FVP\_BaseR\_Cortex\_R82x4.cluster0.cpu0.l1dcache**

PV Cache.  
Type: PVCache.

**FVP\_BaseR\_Cortex\_R82x4.cluster0.cpu0.l1icache**

PV Cache.  
Type: PVCache.

**FVP\_BaseR\_Cortex\_R82x4.cluster0.cpu1**

ARM Cortex-R82 CT model.  
Type: ARM\_Cortex-R82.

**FVP\_BaseR\_Cortex\_R82x4.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.  
Type: TlbCadi.

**FVP\_BaseR\_Cortex\_R82x4.cluster0.cpu1.l1dcache**

PV Cache.  
Type: PVCache.

**FVP\_BaseR\_Cortex\_R82x4.cluster0.cpu1.l1icache**

PV Cache.  
Type: PVCache.

**FVP\_BaseR\_Cortex\_R82x4.cluster0.cpu2**

ARM Cortex-R82 CT model.  
Type: ARM\_Cortex-R82.

**FVP\_BaseR\_Cortex\_R82x4.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.  
Type: TlbCadi.

**FVP\_BaseR\_Cortex\_R82x4.cluster0.cpu2.l1dcache**

PV Cache.  
Type: PVCache.

**FVP\_BaseR\_Cortex\_R82x4.cluster0.cpu2.l1icache**

PV Cache.  
Type: PVCache.

**FVP\_BaseR\_Cortex\_R82x4.cluster0.cpu3**

ARM Cortex-R82 CT model.  
Type: ARM\_Cortex-R82.

**FVP\_BaseR\_Cortex\_R82x4.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.  
Type: TlbCadi.

**FVP\_BaseR\_Cortex\_R82x4.cluster0.cpu3.lldcache**

PV Cache.

Type: [PVCache](#).

**FVP\_BaseR\_Cortex\_R82x4.cluster0.cpu3.llicache**

PV Cache.

Type: [PVCache](#).

**FVP\_BaseR\_Cortex\_R82x4.cluster0.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_BaseR\_Cortex\_R82x4.cluster0.labeller**

Type: [Labeller](#).

**FVP\_BaseR\_Cortex\_R82x4.dapmemlogger**

Bus Logger.

Type: [PVBusLogger](#).

**FVP\_BaseR\_Cortex\_R82x4.elfloader**

ELF loader component.

Type: [ElfLoader](#).

**FVP\_BaseR\_Cortex\_R82x4.gic\_distributor**

GIC Interrupt Redistribution Infrastructure component.

Type: [GIC\\_IRI](#).

**FVP\_BaseR\_Cortex\_R82x4.llram0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_BaseR\_Cortex\_R82x4.pctl**

Base Platforms Power Controller.

Type: [Base\\_PowerController](#).

**FVP\_BaseR\_Cortex\_R82x4.pctl.timer\_reset**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_BaseR\_Cortex\_R82x4.pctl.timer\_reset.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_BaseR\_Cortex\_R82x4.pctl.timer\_reset.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_BaseR\_Cortex\_R82x4.pctl.timer\_reset.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

# 15. VE Platform FVPs

This chapter lists the VE Platform FVPs and the instances in them.

For the VE memory maps, see [VE memory map for Cortex-A series](#) and [VE memory map for Cortex-R series](#) in the Fast Models Reference Guide.

## 15.1 FVP\_VE\_Cortex-A15x1

FVP\_VE\_Cortex-A15x1 contains the following instances:

### FVP\_VE\_Cortex-A15x1 instances

#### **FVP\_VE\_Cortex\_A15x1**

Top level component of the Cortex\_A15x1 Versatile Express inspired model.

Type: `FVP_VE_Cortex_A15x1`.

#### **FVP\_VE\_Cortex\_A15x1.cluster**

ARM Cortex-A15 Cluster CT model.

Type: `cluster_ARM_Cortex-A15`.

#### **FVP\_VE\_Cortex\_A15x1.cluster.cpu0**

ARM Cortex-A15 CT model.

Type: `ARM_Cortex-A15`.

#### **FVP\_VE\_Cortex\_A15x1.cluster.cpu0.dtlb**

TLB - instruction, data or unified.

Type: `TlbCadi`.

#### **FVP\_VE\_Cortex\_A15x1.cluster.cpu0.itlb**

TLB - instruction, data or unified.

Type: `TlbCadi`.

#### **FVP\_VE\_Cortex\_A15x1.cluster.cpu0.l1dcache**

PV Cache.

Type: `PVCache`.

#### **FVP\_VE\_Cortex\_A15x1.cluster.cpu0.l1icache**

PV Cache.

Type: `PVCache`.

#### **FVP\_VE\_Cortex\_A15x1.cluster.12\_cache**

PV Cache.

Type: `PVCache`.

#### **FVP\_VE\_Cortex\_A15x1.daughterboard**

Daughtercard, inspired by the ARM Versatile Express development platform.

Type: `VEDaughterBoard`.

**FVP\_VE\_Cortex\_A15x1.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.dram\_aliased**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.dram\_limit\_4**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.dram\_limit\_8**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.hdlcd**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.hdlcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.hlcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.hlcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.hlcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.introuter**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.nonsecure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.secureRO**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.secureROloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.secure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x1.daughterboard.vedcc**

Daughterboard Configuration Control (DCC).

Type: VEDCC.

**FVP\_VE\_Cortex\_A15x1.globalcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_VE\_Cortex\_A15x1.motherboard**

Model inspired by the ARM Versatile Express Motherboard.

Type: VEMotherBoard.

**FVP\_VE\_Cortex\_A15x1.motherboard.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A15x1.motherboard.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A15x1.motherboard.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A15x1.motherboard.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A15x1.motherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.mmcc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1011\_uart0**

ARM PrimeCell UART(PLO11).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1011\_uart1**

ARM PrimeCell UART(PLO11).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1111\_clcd.p111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1111\_clcd.p111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.p1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1.motherboard.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

## 15.2 FVP\_VE\_Cortex-A15x1-A7x1

FVP\_VE\_Cortex-A15x1-A7x1 contains the following instances:

### FVP\_VE\_Cortex-A15x1-A7x1 instances

#### **FVP\_VE\_Cortex\_A15x1\_A7x1**

Top level component of the Cortex A15x1 A7x1 Versatile Express inspired model.

Type: [FVP\\_VE\\_Cortex\\_A15x1\\_A7x1](#).

#### **FVP\_VE\_Cortex\_A15x1\_A7x1.coretile**

Dual cluster ARM Cortex-A15x1 and ARM Cortex-A7x1 Core Tile.

Type: [ARM\\_Cortex\\_A15x1\\_A7x1\\_CT](#).

#### **FVP\_VE\_Cortex\_A15x1\_A7x1.coretile.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCI400](#).

#### **FVP\_VE\_Cortex\_A15x1\_A7x1.coretile.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_A15x1\_A7x1.coretile.clockdivider1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_A15x1\_A7x1.coretile.cluster0**

ARM Cortex-A15 Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-A15](#).

#### **FVP\_VE\_Cortex\_A15x1\_A7x1.coretile.cluster0.cpu0**

ARM Cortex-A15 CT model.

Type: [ARM\\_Cortex-A15](#).

#### **FVP\_VE\_Cortex\_A15x1\_A7x1.coretile.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

#### **FVP\_VE\_Cortex\_A15x1\_A7x1.coretile.cluster0.cpu0.itlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

#### **FVP\_VE\_Cortex\_A15x1\_A7x1.coretile.cluster0.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.coretile.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x1\_A7x1.coretile.cluster0.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x1\_A7x1.coretile.cluster1**

ARM Cortex-A7 Cluster CT model.

Type: Cluster\_ARM\_Cortex-A7.

**FVP\_VE\_Cortex\_A15x1\_A7x1.coretile.cluster1.cpu0**

ARM Cortex-A7 CT model.

Type: ARM\_Cortex-A7.

**FVP\_VE\_Cortex\_A15x1\_A7x1.coretile.cluster1.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x1\_A7x1.coretile.cluster1.cpu0.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x1\_A7x1.coretile.cluster1.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x1\_A7x1.coretile.cluster1.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x1\_A7x1.coretile.cluster1.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x1\_A7x1.coretile.dualclustersystemconfigurationblock**

Dual Cluster System Configuration Block.

Type: [DualClusterSystemConfigurationBlock](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.coretile.globalcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.coretile.v7\_vgic**

System VGIC architecture version v7.

Type: [v7\\_VGIC](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard**

Daughtercard, inspired by the ARM Versatile Express development platform.

Type: VEDaughterBoard.

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.dram\_aliased**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.dram\_limit\_4**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.dram\_limit\_8**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.hdlcd**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.hdlcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.hdlcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.hdlcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.hdlcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.introuter**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.nonsecure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TzSwitch](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.secureRO**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.secureROloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.secure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TzSwitch](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.daughterboard.vedcc**

Daughterboard Configuration Control (DCC).  
Type: VEDCC.

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard**

Model inspired by the ARM Versatile Express Motherboard.  
Type: VEMotherBoard.

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.Timer\_0\_1**

ARM Dual-Timer Module(SP804).  
Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.  
Type: CounterModule.

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.  
Type: CounterModule.

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.Timer\_2\_3**

ARM Dual-Timer Module(SP804).  
Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.mmcc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.pl1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.ve\_sysregs**

Type: ve\_SysRegs.

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.vis**

Display window for VE using Visualisation library.

Type: VEVisualisation.

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x1\_A7x1.motherboard.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

## 15.3 FVP\_VE\_Cortex-A15x2

FVP\_VE\_Cortex-A15x2 contains the following instances:

### FVP\_VE\_Cortex-A15x2 instances

#### **FVP\_VE\_Cortex\_A15x2**

Top level component of the Cortex\_A15x2 Versatile Express inspired model.  
Type: FVP\_VE\_Cortex\_A15x2.

#### **FVP\_VE\_Cortex\_A15x2.cluster**

ARM Cortex-A15 Cluster CT model.  
Type: Cluster\_ARM\_Cortex-A15.

#### **FVP\_VE\_Cortex\_A15x2.cluster.cpu0**

ARM Cortex-A15 CT model.  
Type: ARM\_Cortex-A15.

#### **FVP\_VE\_Cortex\_A15x2.cluster.cpu0.dtlb**

TLB - instruction, data or unified.  
Type: TlbCadi.

#### **FVP\_VE\_Cortex\_A15x2.cluster.cpu0.itlb**

TLB - instruction, data or unified.  
Type: TlbCadi.

#### **FVP\_VE\_Cortex\_A15x2.cluster.cpu0.lldcache**

PV Cache.  
Type: PVCache.

#### **FVP\_VE\_Cortex\_A15x2.cluster.cpu0.llicache**

PV Cache.  
Type: PVCache.

#### **FVP\_VE\_Cortex\_A15x2.cluster.cpu1**

ARM Cortex-A15 CT model.  
Type: ARM\_Cortex-A15.

#### **FVP\_VE\_Cortex\_A15x2.cluster.cpu1.dtlb**

TLB - instruction, data or unified.  
Type: TlbCadi.

#### **FVP\_VE\_Cortex\_A15x2.cluster.cpu1.itlb**

TLB - instruction, data or unified.  
Type: TlbCadi.

#### **FVP\_VE\_Cortex\_A15x2.cluster.cpu1.lldcache**

PV Cache.  
Type: PVCache.

#### **FVP\_VE\_Cortex\_A15x2.cluster.cpu1.llicache**

PV Cache.  
Type: PVCache.

**FVP\_VE\_Cortex\_A15x2.cluster.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard**

Daughtercard, inspired by the ARM Versatile Express development platform.

Type: [VEDaughterBoard](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.dram\_aliased**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.dram\_limit\_4**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.dram\_limit\_8**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.hdlcd**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.hlcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.hlcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.hlcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.hlcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.introuter**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.nonsecure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.secureRO**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.secureROloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.secure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x2.daughterboard.vedcc**

Daughterboard Configuration Control (DCC).

Type: VEDCC.

**FVP\_VE\_Cortex\_A15x2.globalcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_VE\_Cortex\_A15x2.motherboard**

Model inspired by the ARM Versatile Express Motherboard.

Type: VEMotherBoard.

**FVP\_VE\_Cortex\_A15x2.motherboard.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A15x2.motherboard.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A15x2.motherboard.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A15x2.motherboard.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A15x2.motherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.mmcc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl050\_kmil**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2.motherboard.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

## 15.4 FVP\_VE\_Cortex-A15x2-A7x2

FVP\_VE\_Cortex-A15x2-A7x2 contains the following instances:

### FVP\_VE\_Cortex-A15x2-A7x2 instances

**FVP\_VE\_Cortex\_A15x2\_A7x2**

Top level component of the Cortex A15x2 A7x2 Versatile Express inspired model.

Type: [FVP\\_VE\\_Cortex\\_A15x2\\_A7x2](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile**

Dual cluster ARM Cortex-A15x2 and ARM Cortex-A7x2 Core Tile.

Type: [ARM\\_Cortex\\_A15x2\\_A7x2\\_CT](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCI400](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.clockdivider1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster0**

ARM Cortex-A15 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A15](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster0.cpu0**

ARM Cortex-A15 CT model.

Type: [ARM\\_Cortex-A15](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster0.cpu0.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster0.cpu0.11dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster0.cpu0.11icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster0.cpu1**

ARM Cortex-A15 CT model.

Type: ARM\_Cortex-A15.

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster0.cpu1.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster0.cpu1.11dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster0.cpu1.11icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster0.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster1**

ARM Cortex-A7 Cluster CT model.

Type: Cluster\_ARM\_Cortex-A7.

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster1.cpu0**

ARM Cortex-A7 CT model.

Type: ARM\_Cortex-A7.

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster1.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster1.cpu0.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster1.cpu0.11dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster1.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster1.cpu1**

ARM Cortex-A7 CT model.

Type: [ARM\\_Cortex-A7](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster1.cpu1.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster1.cpu1.itlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster1.cpu1.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster1.cpu1.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.cluster1.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.dualclustersystemconfigurationblock**

Dual Cluster System Configuration Block.

Type: [DualClusterSystemConfigurationBlock](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.globalcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.coretile.v7\_vgic**

System VGIC architecture version v7.

Type: [v7\\_VGIC](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard**

Daughtercard, inspired by the ARM Versatile Express development platform.

Type: [VEDaughterBoard](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.dram\_aliased**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.dram\_limit\_4**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.dram\_limit\_8**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBuseExclusiveMonitor](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.hdlcd**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.hdlcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.hdlcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a

proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.hdlcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.hdlcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.introuter**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.nonsecure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TzSwitch](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.secureRO**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.secureROloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.secure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TzSwitch](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.daughterboard.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard**

Model inspired by the ARM Versatile Express Motherboard.

Type: `vEMotherBoard`.

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: `SP804_Timer`.

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: `ClockDivider`.

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: `ClockDivider`.

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: `CounterModule`.

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: `CounterModule`.

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: `SP804_Timer`.

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: `ClockDivider`.

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: `ClockDivider`.

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: `CounterModule`.

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.mmcc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl111\_clcd.pl111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl111\_clcd.pl111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl111\_clcd.pl111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl111\_clcd.pl111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.pl1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.ve\_sysregs**

Type: [ve\\_sysRegs](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x2\_A7x2.motherboard.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

## 15.5 FVP\_VE\_Cortex-A15x4

FVP\_VE\_Cortex-A15x4 contains the following instances:

### FVP\_VE\_Cortex-A15x4 instances

**FVP\_VE\_Cortex\_A15x4**

Top level component of the Cortex\_A15x4 Versatile Express inspired model.

Type: [FVP\\_VE\\_Cortex\\_A15x4](#).

**FVP\_VE\_Cortex\_A15x4.cluster**

ARM Cortex-A15 Cluster CT model.

Type: cluster\_ARM\_Cortex-A15.

**FVP\_VE\_Cortex\_A15x4.cluster.cpu0**

ARM Cortex-A15 CT model.

Type: ARM\_Cortex-A15.

**FVP\_VE\_Cortex\_A15x4.cluster.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4.cluster.cpu0.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4.cluster.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4.cluster.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4.cluster.cpu1**

ARM Cortex-A15 CT model.

Type: ARM\_Cortex-A15.

**FVP\_VE\_Cortex\_A15x4.cluster.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4.cluster.cpu1.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4.cluster.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4.cluster.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4.cluster.cpu2**

ARM Cortex-A15 CT model.

Type: ARM\_Cortex-A15.

**FVP\_VE\_Cortex\_A15x4.cluster.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4.cluster.cpu2.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4.cluster.cpu2.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A15x4.cluster.cpu2.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A15x4.cluster.cpu3**

ARM Cortex-A15 CT model.

Type: [ARM\\_Cortex-A15](#).

**FVP\_VE\_Cortex\_A15x4.cluster.cpu3.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_VE\_Cortex\_A15x4.cluster.cpu3.itlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_VE\_Cortex\_A15x4.cluster.cpu3.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A15x4.cluster.cpu3.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A15x4.cluster.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard**

Daughtercard, inspired by the ARM Versatile Express development platform.

Type: [VEDaughterBoard](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.dram\_aliased**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.dram\_limit\_4**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.dram\_limit\_8**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.hdlcd**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.hlcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.hlcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.hlcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.hdlcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.introuter**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.nonsecure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.secureRO**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.secureROloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.secure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x4.daughterboard.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_VE\_Cortex\_A15x4.globalcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_VE\_Cortex\_A15x4.motherboard**

Model inspired by the ARM Versatile Express Motherboard.

Type: [VEMotherBoard](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A15x4.motherboard.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A15x4.motherboard.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A15x4.motherboard.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A15x4.motherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.mmcc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.p1031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal()

callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.pl111\_clcd.pl111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.pl111\_clcd.pl111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.pl111\_clcd.pl111x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4.motherboard.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

## 15.6 FVP\_VE\_Cortex-A15x4-A7x4

FVP\_VE\_Cortex-A15x4-A7x4 contains the following instances:

### FVP\_VE\_Cortex-A15x4-A7x4 instances

**FVP\_VE\_Cortex\_A15x4\_A7x4**

Top level component of the Cortex A15x4 A7x4 Versatile Express inspired model.

Type: [FVP\\_VE\\_Cortex\\_A15x4\\_A7x4](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile**

Dual cluster ARM Cortex-A15x4 and ARM Cortex-A7x4 Core Tile.

Type: [ARM\\_Cortex\\_A15x4\\_A7x4\\_CT](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCI400](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.clockdivider1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0**

ARM Cortex-A15 Cluster CT model.

Type: Cluster\_ARM\_Cortex-A15.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.cpu0**

ARM Cortex-A15 CT model.

Type: ARM\_Cortex-A15.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.cpu0.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.cpu1**

ARM Cortex-A15 CT model.

Type: ARM\_Cortex-A15.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.cpu1.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.cpu2**

ARM Cortex-A15 CT model.

Type: ARM\_Cortex-A15.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.cpu2.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.cpu3**

ARM Cortex-A15 CT model.

Type: ARM\_Cortex-A15.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.cpu3.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster0.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1**

ARM Cortex-A7 Cluster CT model.

Type: Cluster\_ARM\_Cortex-A7.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.cpu0**

ARM Cortex-A7 CT model.

Type: ARM\_Cortex-A7.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.cpu0.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.cpu1**

ARM Cortex-A7 CT model.

Type: ARM\_Cortex-A7.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.cpu1.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.cpu2**

ARM Cortex-A7 CT model.

Type: ARM\_Cortex-A7.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.cpu2.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.cpu3**

ARM Cortex-A7 CT model.

Type: ARM\_Cortex-A7.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.cpu3.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.cluster1.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.dualclustersystemconfigurationblock**

Dual Cluster System Configuration Block.

Type: [DualClusterSystemConfigurationBlock](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.globalcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.coretile.v7\_vgic**

System VGIC architecture version v7.

Type: [v7\\_VGIC](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard**

Daughtercard, inspired by the ARM Versatile Express development platform.

Type: VEDaughterBoard.

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.dram\_aliased**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.dram\_limit\_4**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.dram\_limit\_8**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.hdlcd**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.hdlcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.hdlcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.hdlcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.hdlcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.introuter**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.nonsecure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.secureRO**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.secureROloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.secure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.daughterboard.vedcc**

Daughterboard Configuration Control (DCC).  
Type: VEDCC.

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard**

Model inspired by the ARM Versatile Express Motherboard.  
Type: VEMotherBoard.

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.Timer\_0\_1**

ARM Dual-Timer Module(SP804).  
Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.  
Type: CounterModule.

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.  
Type: CounterModule.

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.Timer\_2\_3**

ARM Dual-Timer Module(SP804).  
Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.pl1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.ve\_sysregs**

Type: ve\_SysRegs.

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.vis**

Display window for VE using Visualisation library.

Type: VEVisualisation.

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A15x4\_A7x4.motherboard.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

## 15.7 FVP\_VE\_Cortex-A17x1

FVP\_VE\_Cortex-A17x1 contains the following instances:

### FVP\_VE\_Cortex-A17x1 instances

#### **FVP\_VE\_Cortex\_A17x1**

Top level component of the Cortex\_A17x1 Versatile Express inspired model.

Type: [FVP\\_VE\\_Cortex\\_A17x1](#).

#### **FVP\_VE\_Cortex\_A17x1.cluster**

ARM Cortex-A17 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A17](#).

#### **FVP\_VE\_Cortex\_A17x1.cluster.cpu0**

ARM Cortex-A17 CT model.

Type: [ARM\\_Cortex-A17](#).

#### **FVP\_VE\_Cortex\_A17x1.cluster.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

#### **FVP\_VE\_Cortex\_A17x1.cluster.cpu0.itlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

#### **FVP\_VE\_Cortex\_A17x1.cluster.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

#### **FVP\_VE\_Cortex\_A17x1.cluster.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

#### **FVP\_VE\_Cortex\_A17x1.cluster.l2\_cache**

PV Cache.

Type: [PVCache](#).

#### **FVP\_VE\_Cortex\_A17x1.daughterboard**

Daughtercard, inspired by the ARM Versatile Express development platform.

Type: [VEDaughterBoard](#).

#### **FVP\_VE\_Cortex\_A17x1.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_A17x1.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.dram\_aliased**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.dram\_limit\_4**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.dram\_limit\_8**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.hdlcd**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.hdlcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.hdlcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component

which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.hdlcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.hdlcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.introuter**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.nonsecure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.secureRO**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.secureROloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.secure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x1.daughterboard.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_VE\_Cortex\_A17x1.gic400**

GIC-400 Generic Interrupt Controller.

Type: [GIC\\_400](#).

**FVP\_VE\_Cortex\_A17x1.globalcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_VE\_Cortex\_A17x1.motherboard**

Model inspired by the ARM Versatile Express Motherboard.

Type: [VEMotherBoard](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_A17x1.motherboard mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.ve\_sysregs**

Type: [ve\\_SysRegs](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1.motherboard.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

## 15.8 FVP\_VE\_Cortex-A17x1-A7x1

FVP\_VE\_Cortex-A17x1-A7x1 contains the following instances:

### FVP\_VE\_Cortex-A17x1-A7x1 instances

#### **FVP\_VE\_Cortex\_A17x1\_A7x1**

Top level component of the Cortex A17x1 A7x1 Versatile Express inspired model.

Type: [FVP\\_VE\\_Cortex\\_A17x1\\_A7x1](#).

#### **FVP\_VE\_Cortex\_A17x1\_A7x1.coretile**

Dual cluster ARM Cortex-A17x1 and ARM Cortex-A7x1 Core Tile.

Type: [ARM\\_Cortex\\_A17x1\\_A7x1\\_CT](#).

#### **FVP\_VE\_Cortex\_A17x1\_A7x1.coretile.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCI400](#).

#### **FVP\_VE\_Cortex\_A17x1\_A7x1.coretile.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_A17x1\_A7x1.coretile.clockdivider1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_A17x1\_A7x1.coretile.cluster0**

ARM Cortex-A17 Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-A17](#).

#### **FVP\_VE\_Cortex\_A17x1\_A7x1.coretile.cluster0.cpu0**

ARM Cortex-A17 CT model.

Type: [ARM\\_Cortex-A17](#).

#### **FVP\_VE\_Cortex\_A17x1\_A7x1.coretile.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

#### **FVP\_VE\_Cortex\_A17x1\_A7x1.coretile.cluster0.cpu0.itlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

#### **FVP\_VE\_Cortex\_A17x1\_A7x1.coretile.cluster0.cpu0.lldcache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.coretile.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x1\_A7x1.coretile.cluster0.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x1\_A7x1.coretile.cluster1**

ARM Cortex-A7 Cluster CT model.

Type: Cluster\_ARM\_Cortex-A7.

**FVP\_VE\_Cortex\_A17x1\_A7x1.coretile.cluster1.cpu0**

ARM Cortex-A7 CT model.

Type: ARM\_Cortex-A7.

**FVP\_VE\_Cortex\_A17x1\_A7x1.coretile.cluster1.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x1\_A7x1.coretile.cluster1.cpu0.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x1\_A7x1.coretile.cluster1.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x1\_A7x1.coretile.cluster1.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x1\_A7x1.coretile.cluster1.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x1\_A7x1.coretile.dualclustersystemconfigurationblock**

Dual Cluster System Configuration Block.

Type: [DualClusterSystemConfigurationBlock](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.coretile.globalcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.coretile.v7\_vgic**

System VGIC architecture version v7.

Type: [v7\\_VGIC](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard**

Daughtercard, inspired by the ARM Versatile Express development platform.

Type: VEDaughterBoard.

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.dram\_aliased**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.dram\_limit\_4**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.dram\_limit\_8**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.hdlcd**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.hdlcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.hdlcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.hdlcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.hdlcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.introuter**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.nonsecure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TzSwitch](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.secureRO**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.secureROloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.secure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TzSwitch](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.daughterboard.vedcc**

Daughterboard Configuration Control (DCC).  
Type: VEDCC.

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard**

Model inspired by the ARM Versatile Express Motherboard.  
Type: VEMotherBoard.

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.Timer\_0\_1**

ARM Dual-Timer Module(SP804).  
Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.  
Type: CounterModule.

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.  
Type: CounterModule.

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.Timer\_2\_3**

ARM Dual-Timer Module(SP804).  
Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.mmcc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.pl1180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.ve\_sysregs**

Type: ve\_SysRegs.

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.vis**

Display window for VE using Visualisation library.

Type: VEVisualisation.

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x1\_A7x1.motherboard.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

## 15.9 FVP\_VE\_Cortex-A17x2

FVP\_VE\_Cortex-A17x2 contains the following instances:

### FVP\_VE\_Cortex-A17x2 instances

#### **FVP\_VE\_Cortex\_A17x2**

Top level component of the Cortex\_A17x2 Versatile Express inspired model.  
Type: FVP\_VE\_Cortex\_A17x2.

#### **FVP\_VE\_Cortex\_A17x2.cluster**

ARM Cortex-A17 Cluster CT model.  
Type: Cluster\_ARM\_Cortex-A17.

#### **FVP\_VE\_Cortex\_A17x2.cluster.cpu0**

ARM Cortex-A17 CT model.  
Type: ARM\_Cortex-A17.

#### **FVP\_VE\_Cortex\_A17x2.cluster.cpu0.dtlb**

TLB - instruction, data or unified.  
Type: TlbCadi.

#### **FVP\_VE\_Cortex\_A17x2.cluster.cpu0.itlb**

TLB - instruction, data or unified.  
Type: TlbCadi.

#### **FVP\_VE\_Cortex\_A17x2.cluster.cpu0.lldcache**

PV Cache.  
Type: PVCache.

#### **FVP\_VE\_Cortex\_A17x2.cluster.cpu0.llicache**

PV Cache.  
Type: PVCache.

#### **FVP\_VE\_Cortex\_A17x2.cluster.cpu1**

ARM Cortex-A17 CT model.  
Type: ARM\_Cortex-A17.

#### **FVP\_VE\_Cortex\_A17x2.cluster.cpu1.dtlb**

TLB - instruction, data or unified.  
Type: TlbCadi.

#### **FVP\_VE\_Cortex\_A17x2.cluster.cpu1.itlb**

TLB - instruction, data or unified.  
Type: TlbCadi.

#### **FVP\_VE\_Cortex\_A17x2.cluster.cpu1.lldcache**

PV Cache.  
Type: PVCache.

#### **FVP\_VE\_Cortex\_A17x2.cluster.cpu1.llicache**

PV Cache.  
Type: PVCache.

**FVP\_VE\_Cortex\_A17x2.cluster.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard**

Daughtercard, inspired by the ARM Versatile Express development platform.

Type: [VEDaughterBoard](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.dram\_aliased**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.dram\_limit\_4**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.dram\_limit\_8**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.hdlcd**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.hlcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.hlcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.hlcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.hlcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.introuter**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.nonsecure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.secureRO**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.secureROloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.secure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x2.daughterboard.vedcc**

Daughterboard Configuration Control (DCC).

Type: VEDCC.

**FVP\_VE\_Cortex\_A17x2.gic400**

GIC-400 Generic Interrupt Controller.

Type: [GIC\\_400](#).

**FVP\_VE\_Cortex\_A17x2.globalcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_VE\_Cortex\_A17x2.motherboard**

Model inspired by the ARM Versatile Express Motherboard.

Type: [vEMotherBoard](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A17x2.motherboard.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A17x2.motherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_A17x2.motherboard mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.p1111\_clcd.p111x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS91C111](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_A17x2.motherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_A17x2.motherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_A17x2.motherboard.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

## 15.10 FVP\_VE\_Cortex-A17x4

FVP\_VE\_Cortex-A17x4 contains the following instances:

### FVP\_VE\_Cortex-A17x4 instances

#### **FVP\_VE\_Cortex\_A17x4**

Top level component of the Cortex\_A17x4 Versatile Express inspired model.

Type: [FVP\\_VE\\_Cortex\\_A17x4](#).

#### **FVP\_VE\_Cortex\_A17x4.cluster**

ARM Cortex-A17 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A17](#).

#### **FVP\_VE\_Cortex\_A17x4.cluster.cpu0**

ARM Cortex-A17 CT model.

Type: [ARM\\_Cortex-A17](#).

#### **FVP\_VE\_Cortex\_A17x4.cluster.cpu0.dtlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

#### **FVP\_VE\_Cortex\_A17x4.cluster.cpu0.itlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

#### **FVP\_VE\_Cortex\_A17x4.cluster.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

#### **FVP\_VE\_Cortex\_A17x4.cluster.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

#### **FVP\_VE\_Cortex\_A17x4.cluster.cpu1**

ARM Cortex-A17 CT model.

Type: ARM\_Cortex-A17.

**FVP\_VE\_Cortex\_A17x4.cluster.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4.cluster.cpu1.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4.cluster.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x4.cluster.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x4.cluster.cpu2**

ARM Cortex-A17 CT model.

Type: ARM\_Cortex-A17.

**FVP\_VE\_Cortex\_A17x4.cluster.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4.cluster.cpu2.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4.cluster.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x4.cluster.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x4.cluster.cpu3**

ARM Cortex-A17 CT model.

Type: ARM\_Cortex-A17.

**FVP\_VE\_Cortex\_A17x4.cluster.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4.cluster.cpu3.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4.cluster.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x4.cluster.cpu3.ll1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A17x4.cluster.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard**

Daughtercard, inspired by the ARM Versatile Express development platform.

Type: [VEDaughterBoard](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.dram\_aliased**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.dram\_limit\_4**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.dram\_limit\_8**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.hdlcd**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.hdlcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.hdlcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.hdlcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.hdlcd.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.introuter**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.nonsecure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.secureRO**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.secureROloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.secure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x4.daughterboard.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_VE\_Cortex\_A17x4.gic400**

GIC-400 Generic Interrupt Controller.

Type: [GIC\\_400](#).

**FVP\_VE\_Cortex\_A17x4.globalcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_VE\_Cortex\_A17x4.motherboard**

Model inspired by the ARM Versatile Express Motherboard.

Type: [vEMotherBoard](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A17x4.motherboard.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A17x4.motherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.p1111\_clcd.p111x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS91C111](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_A17x4.motherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_A17x4.motherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_A17x4.motherboard.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

## **15.11 FVP\_VE\_Cortex-A17x4-A7x4**

FVP\_VE\_Cortex-A17x4-A7x4 contains the following instances:

### **FVP\_VE\_Cortex-A17x4-A7x4 instances**

#### **FVP\_VE\_Cortex\_A17x4\_A7x4**

Top level component of the Cortex A17x4 A7x4 Versatile Express inspired model.

Type: [FVP\\_VE\\_Cortex\\_A17x4\\_A7x4](#).

#### **FVP\_VE\_Cortex\_A17x4\_A7x4.coretile**

Dual cluster ARM Cortex-A17x4 and ARM Cortex-A7x4 Core Tile.

Type: [ARM\\_Cortex\\_A17x4\\_A7x4\\_CT](#).

#### **FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cci400**

Cache Coherent Interconnect for AXI4 ACE.

Type: [CCI400](#).

#### **FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.clockdivider1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0**

ARM Cortex-A17 Cluster CT model.

Type: [cluster\\_ARM\\_Cortex-A17](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.cpu0**

ARM Cortex-A17 CT model.

Type: ARM\_Cortex-A17.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.cpu0.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.cpu1**

ARM Cortex-A17 CT model.

Type: ARM\_Cortex-A17.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.cpu1.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.cpu2**

ARM Cortex-A17 CT model.

Type: ARM\_Cortex-A17.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.cpu2.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.cpu2.11dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.cpu2.11icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.cpu3**

ARM Cortex-A17 CT model.

Type: ARM\_Cortex-A17.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.cpu3.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.cpu3.11dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.cpu3.11icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster0.12\_cache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1**

ARM Cortex-A7 Cluster CT model.

Type: Cluster\_ARM\_Cortex-A7.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.cpu0**

ARM Cortex-A7 CT model.

Type: ARM\_Cortex-A7.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.cpu0.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.cpu0.11dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.cpu1**

ARM Cortex-A7 CT model.

Type: ARM\_Cortex-A7.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.cpu1.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.cpu2**

ARM Cortex-A7 CT model.

Type: ARM\_Cortex-A7.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.cpu2.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.cpu3**

ARM Cortex-A7 CT model.

Type: ARM\_Cortex-A7.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.cpu3.itlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.cpu3.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.cpu3.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.cluster1.12\_cache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.dualclustersystemconfigurationblock**

Dual Cluster System Configuration Block.

Type: [DualClusterSystemConfigurationBlock](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.globalcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.coretile.v7\_vgic**

System VGIC architecture version v7.

Type: [v7\\_VGIC](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard**

Daughtercard, inspired by the ARM Versatile Express development platform.

Type: [VEDaughterBoard](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.dram\_aliased**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.dram\_limit\_4**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.dram\_limit\_8**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.hdlcd**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.hdlcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.hdlcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.hdlcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.hdlcd.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.introuter**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.nonsecure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.secureRO**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.secureROloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.secure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.daughterboard.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard**

Model inspired by the ARM Versatile Express Motherboard.

Type: [VEMotherBoard](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.mmcc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl111\_clcd.pl111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl111\_clcd.pl111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl111\_clcd.pl11x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl111\_clcd.pl11x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A17x4\_A7x4.motherboard.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

## 15.12 FVP\_VE\_Cortex-A5x1

FVP\_VE\_Cortex-A5x1 contains the following instances:

### FVP\_VE\_Cortex-A5x1 instances

**FVP\_VE\_Cortex\_A5x1**

Top level component of the Cortex-A5x1 Versatile Express inspired model.

Type: [FVP\\_VE\\_Cortex\\_A5x1](#).

**FVP\_VE\_Cortex\_A5x1.cluster**

ARM CORTEXA5MP Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A5MP](#).

**FVP\_VE\_Cortex\_A5x1.cluster.cpu0**

ARM CORTEXA5MP CT model.

Type: [ARM\\_Cortex-A5MP](#).

**FVP\_VE\_Cortex\_A5x1.cluster.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A5x1.cluster.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A5x1.cluster.cpu0.utlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard**

Daughtercard, inspired by the ARM Versatile Express development platform.

Type: [VEDaughterBoard](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.dram\_aliased**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.dram\_limit\_4**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.dram\_limit\_8**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.hdlcd**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.hdlcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.hdlcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.hdlcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.hdlcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.introuter**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.nonsecure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.secureRO**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.secureROloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.secure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x1.daughterboard.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_VE\_Cortex\_A5x1.motherboard**

Model inspired by the ARM Versatile Express Motherboard.

Type: [VEMotherBoard](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A5x1.motherboard.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A5x1.motherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_A5x1.motherboard mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl111\_clcd.pl11x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS91C111](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_A5x1.motherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_A5x1.motherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_A5x1.motherboard.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

#### **FVP\_VE\_Cortex\_A5x1.periph\_clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

## **15.13 FVP\_VE\_Cortex-A5x2**

FVP\_VE\_Cortex-A5x2 contains the following instances:

### **FVP\_VE\_Cortex-A5x2 instances**

#### **FVP\_VE\_Cortex\_A5x2**

Top level component of the Cortex-A5x2 Versatile Express inspired model.

Type: [FVP\\_VE\\_Cortex\\_A5x2](#).

#### **FVP\_VE\_Cortex\_A5x2.cluster**

ARM CORTEXA5MP Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A5MP](#).

#### **FVP\_VE\_Cortex\_A5x2.cluster.cpu0**

ARM CORTEXA5MP CT model.

Type: [ARM\\_Cortex-A5MP](#).

#### **FVP\_VE\_Cortex\_A5x2.cluster.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

#### **FVP\_VE\_Cortex\_A5x2.cluster.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

#### **FVP\_VE\_Cortex\_A5x2.cluster.cpu0.utlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_VE\_Cortex\_A5x2.cluster.cpu1**

ARM CORTEXA5MP CT model.

Type: [ARM\\_Cortex-A5MP](#).

**FVP\_VE\_Cortex\_A5x2.cluster.cpu1.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A5x2.cluster.cpu1.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_A5x2.cluster.cpu1.utlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard**

Daughtercard, inspired by the ARM Versatile Express development platform.

Type: [VEDaughterBoard](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.dram\_aliased**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.dram\_limit\_4**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.dram\_limit\_8**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.hdlcd**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.hdlcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.hdlcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.hdlcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.hdlcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.introuter**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.nonsecure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.secureDRAM**

RAM device, can be dynamic or static ram.  
Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.secureRO**

Intel Strata Flash J3 LISA+ model.  
Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.secureROloader**

A device that can preload a gzipped image into flash at startup.  
Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.secureSRAM**

RAM device, can be dynamic or static ram.  
Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.secure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.  
Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.sram**

RAM device, can be dynamic or static ram.  
Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x2.daughterboard.vedcc**

Daughterboard Configuration Control (DCC).  
Type: [VEDCC](#).

**FVP\_VE\_Cortex\_A5x2.motherboard**

Model inspired by the ARM Versatile Express Motherboard.  
Type: [VEMotherBoard](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.Timer\_0\_1**

ARM Dual-Timer Module(SP804).  
Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.  
Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.  
Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.  
Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A5x2.motherboard.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A5x2.motherboard.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A5x2.motherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_A5x2.motherboard mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_A5x2.motherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_A5x2.motherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_A5x2.motherboard.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

#### **FVP\_VE\_Cortex\_A5x2.periph\_clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

## 15.14 FVP\_VE\_Cortex-A5x4

FVP\_VE\_Cortex-A5x4 contains the following instances:

### **FVP\_VE\_Cortex-A5x4 instances**

#### **FVP\_VE\_Cortex\_A5x4**

Top level component of the Cortex-A5x4 Versatile Express inspired model.

Type: [FVP\\_VE\\_Cortex\\_A5x4](#).

#### **FVP\_VE\_Cortex\_A5x4.cluster**

ARM CORTEXA5MP Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A5MP](#).

#### **FVP\_VE\_Cortex\_A5x4.cluster.cpu0**

ARM CORTEXA5MP CT model.

Type: [ARM\\_Cortex-A5MP](#).

#### **FVP\_VE\_Cortex\_A5x4.cluster.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

#### **FVP\_VE\_Cortex\_A5x4.cluster.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

#### **FVP\_VE\_Cortex\_A5x4.cluster.cpu0.utlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A5x4.cluster.cpu1**

ARM CORTEXA5MP CT model.

Type: ARM\_Cortex-A5MP.

**FVP\_VE\_Cortex\_A5x4.cluster.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A5x4.cluster.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A5x4.cluster.cpu1.utlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A5x4.cluster.cpu2**

ARM CORTEXA5MP CT model.

Type: ARM\_Cortex-A5MP.

**FVP\_VE\_Cortex\_A5x4.cluster.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A5x4.cluster.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A5x4.cluster.cpu2.utlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A5x4.cluster.cpu3**

ARM CORTEXA5MP CT model.

Type: ARM\_Cortex-A5MP.

**FVP\_VE\_Cortex\_A5x4.cluster.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A5x4.cluster.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A5x4.cluster.cpu3.utlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A5x4.daughterboard**

Daughtercard, inspired by the ARM Versatile Express development platform.

Type: VEDAughterBoard.

**FVP\_VE\_Cortex\_A5x4.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.dram\_aliased**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.dram\_limit\_4**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.dram\_limit\_8**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.hdlcd**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.hdlcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.hdlcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.hdlcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.hdlcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.introuter**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.nonsecure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.secureRO**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.secureROloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.secure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x4.daughterboard.vedcc**

Daughterboard Configuration Control (DCC).

Type: VEDCC.

**FVP\_VE\_Cortex\_A5x4.motherboard**

Model inspired by the ARM Versatile Express Motherboard.

Type: VEMotherBoard.

**FVP\_VE\_Cortex\_A5x4.motherboard.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A5x4.motherboard.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A5x4.motherboard.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_A5x4.motherboard mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.ve\_sysregs**

Type: ve\_SysRegs.

**FVP\_VE\_Cortex\_A5x4.motherboard.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.vis**

Display window for VE using Visualisation library.

Type: VEVisualisation.

**FVP\_VE\_Cortex\_A5x4.motherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A5x4.motherboard.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A5x4.periph\_clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

## 15.15 FVP\_VE\_Cortex-A7x1

FVP\_VE\_Cortex-A7x1 contains the following instances:

### **FVP\_VE\_Cortex-A7x1 instances**

#### **FVP\_VE\_Cortex\_A7x1**

Top level component of the Cortex\_A7x1 Versatile Express inspired model.

Type: `FVP_VE_Cortex_A7x1`.

#### **FVP\_VE\_Cortex\_A7x1.cluster**

ARM Cortex-A7 Cluster CT model.

Type: `Cluster_ARM_Cortex-A7`.

#### **FVP\_VE\_Cortex\_A7x1.cluster.cpu0**

ARM Cortex-A7 CT model.

Type: `ARM_Cortex-A7`.

#### **FVP\_VE\_Cortex\_A7x1.cluster.cpu0.dtlb**

TLB - instruction, data or unified.

Type: `TlbCadi`.

#### **FVP\_VE\_Cortex\_A7x1.cluster.cpu0.itlb**

TLB - instruction, data or unified.

Type: `TlbCadi`.

#### **FVP\_VE\_Cortex\_A7x1.cluster.cpu0.l1dcache**

PV Cache.

Type: `PVCache`.

#### **FVP\_VE\_Cortex\_A7x1.cluster.cpu0.l1icache**

PV Cache.

Type: `PVCache`.

#### **FVP\_VE\_Cortex\_A7x1.cluster.l2\_cache**

PV Cache.

Type: `PVCache`.

#### **FVP\_VE\_Cortex\_A7x1.daughterboard**

Daughtercard, inspired by the ARM Versatile Express development platform.

Type: `VEDaughterBoard`.

#### **FVP\_VE\_Cortex\_A7x1.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: `ClockDivider`.

**FVP\_VE\_Cortex\_A7x1.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.dram\_aliased**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.dram\_limit\_4**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.dram\_limit\_8**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBuseExclusiveMonitor](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.hdlcd**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HLCD](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.hdlcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.hdlcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a

proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.hdlcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.hdlcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.introuter**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.nonsecure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.secureRO**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.secureROloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.secure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x1.daughterboard.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_VE\_Cortex\_A7x1.globalcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_VE\_Cortex\_A7x1.motherboard**

Model inspired by the ARM Versatile Express Motherboard.

Type: [vEMotherBoard](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A7x1.motherboard.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A7x1.motherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_A7x1.motherboard mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x1.motherboard.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

## 15.16 FVP\_VE\_Cortex-A7x2

FVP\_VE\_Cortex-A7x2 contains the following instances:

### FVP\_VE\_Cortex-A7x2 instances

**FVP\_VE\_Cortex\_A7x2**

Top level component of the Cortex\_A7x2 Versatile Express inspired model.

Type: `FVP_VE_Cortex_A7x2`.

**`FVP_VE_Cortex_A7x2.cluster`**

ARM Cortex-A7 Cluster CT model.

Type: `cluster_ARM_Cortex-A7`.

**`FVP_VE_Cortex_A7x2.cluster.cpu0`**

ARM Cortex-A7 CT model.

Type: `ARM_Cortex-A7`.

**`FVP_VE_Cortex_A7x2.cluster.cpu0.dtlb`**

TLB - instruction, data or unified.

Type: `TlbCadi`.

**`FVP_VE_Cortex_A7x2.cluster.cpu0.itlb`**

TLB - instruction, data or unified.

Type: `TlbCadi`.

**`FVP_VE_Cortex_A7x2.cluster.cpu0.lldcache`**

PV Cache.

Type: `PVCache`.

**`FVP_VE_Cortex_A7x2.cluster.cpu0.llicache`**

PV Cache.

Type: `PVCache`.

**`FVP_VE_Cortex_A7x2.cluster.cpu1`**

ARM Cortex-A7 CT model.

Type: `ARM_Cortex-A7`.

**`FVP_VE_Cortex_A7x2.cluster.cpu1.dtlb`**

TLB - instruction, data or unified.

Type: `TlbCadi`.

**`FVP_VE_Cortex_A7x2.cluster.cpu1.itlb`**

TLB - instruction, data or unified.

Type: `TlbCadi`.

**`FVP_VE_Cortex_A7x2.cluster.cpu1.lldcache`**

PV Cache.

Type: `PVCache`.

**`FVP_VE_Cortex_A7x2.cluster.cpu1.llicache`**

PV Cache.

Type: `PVCache`.

**`FVP_VE_Cortex_A7x2.cluster.l2_cache`**

PV Cache.

Type: `PVCache`.

**`FVP_VE_Cortex_A7x2.daughterboard`**

Daughtercard, inspired by the ARM Versatile Express development platform.

Type: `VEDaughterBoard`.

**FVP\_VE\_Cortex\_A7x2.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.dram\_aliased**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.dram\_limit\_4**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.dram\_limit\_8**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.hdlcd**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.hdlcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.hdlcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.hdlcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.hdlcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.introuter**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.nonsecure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TzSwitch](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.secureRO**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.secureROloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.secure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TzSwitch](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x2.daughterboard.vedcc**

Daughterboard Configuration Control (DCC).

Type: VEDCC.

**FVP\_VE\_Cortex\_A7x2.globalcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_VE\_Cortex\_A7x2.motherboard**

Model inspired by the ARM Versatile Express Motherboard.

Type: VEMotherBoard.

**FVP\_VE\_Cortex\_A7x2.motherboard.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A7x2.motherboard.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A7x2.motherboard.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A7x2.motherboard.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A7x2.motherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_A7x2.motherboard mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x2.motherboard.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

## 15.17 FVP\_VE\_Cortex-A7x4

FVP\_VE\_Cortex-A7x4 contains the following instances:

### FVP\_VE\_Cortex-A7x4 instances

#### **FVP\_VE\_Cortex\_A7x4**

Top level component of the Cortex\_A7x3 Versatile Express inspired model.

Type: FVP\_VE\_Cortex\_A7x4.

#### **FVP\_VE\_Cortex\_A7x4.cluster**

ARM Cortex-A7 Cluster CT model.

Type: Cluster\_ARM\_Cortex-A7.

#### **FVP\_VE\_Cortex\_A7x4.cluster.cpu0**

ARM Cortex-A7 CT model.

Type: ARM\_Cortex-A7.

#### **FVP\_VE\_Cortex\_A7x4.cluster.cpu0.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

#### **FVP\_VE\_Cortex\_A7x4.cluster.cpu0.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

#### **FVP\_VE\_Cortex\_A7x4.cluster.cpu0.l1dcache**

PV Cache.

Type: PVCache.

#### **FVP\_VE\_Cortex\_A7x4.cluster.cpu0.l1icache**

PV Cache.

Type: PVCache.

#### **FVP\_VE\_Cortex\_A7x4.cluster.cpu1**

ARM Cortex-A7 CT model.

Type: ARM\_Cortex-A7.

#### **FVP\_VE\_Cortex\_A7x4.cluster.cpu1.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

#### **FVP\_VE\_Cortex\_A7x4.cluster.cpu1.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

#### **FVP\_VE\_Cortex\_A7x4.cluster.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A7x4.cluster.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A7x4.cluster.cpu2**

ARM Cortex-A7 CT model.

Type: ARM\_Cortex-A7.

**FVP\_VE\_Cortex\_A7x4.cluster.cpu2.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A7x4.cluster.cpu2.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A7x4.cluster.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A7x4.cluster.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A7x4.cluster.cpu3**

ARM Cortex-A7 CT model.

Type: ARM\_Cortex-A7.

**FVP\_VE\_Cortex\_A7x4.cluster.cpu3.dtlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A7x4.cluster.cpu3.itlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A7x4.cluster.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A7x4.cluster.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A7x4.cluster.l2\_cache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A7x4.daughterboard**

Daughtercard, inspired by the ARM Versatile Express development platform.

Type: VEDAughterBoard.

**FVP\_VE\_Cortex\_A7x4.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.dram\_aliased**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.dram\_limit\_4**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.dram\_limit\_8**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.hdlcd**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.hdlcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.hdlcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This means that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.hdlcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.hdlcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.introuter**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.nonsecure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.secureRO**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.secureROloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.secure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x4.daughterboard.vedcc**

Daughterboard Configuration Control (DCC).

Type: VEDCC.

**FVP\_VE\_Cortex\_A7x4.globalcounter**

Memory Mapped Counter Module for Generic Timers.

Type: [MemoryMappedCounterModule](#).

**FVP\_VE\_Cortex\_A7x4.motherboard**

Model inspired by the ARM Versatile Express Motherboard.

Type: VEMotherBoard.

**FVP\_VE\_Cortex\_A7x4.motherboard.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A7x4.motherboard.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A7x4.motherboard.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A7x4.motherboard.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A7x4.motherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_A7x4.motherboard mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A7x4.motherboard.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

## 15.18 FVP\_VE\_Cortex-A9x1

FVP\_VE\_Cortex-A9x1 contains the following instances:

### FVP\_VE\_Cortex-A9x1 instances

#### **FVP\_VE\_Cortex\_A9x1**

Top level component of the Cortex-A9x1 Versatile Express inspired model.

Type: [FVP\\_VE\\_Cortex\\_A9x1](#).

#### **FVP\_VE\_Cortex\_A9x1.cluster**

ARM CORTEXA9MP Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-A9MP](#).

#### **FVP\_VE\_Cortex\_A9x1.cluster.cpu0**

ARM CORTEXA9MP CT model.

Type: [ARM\\_Cortex-A9MP](#).

#### **FVP\_VE\_Cortex\_A9x1.cluster.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

#### **FVP\_VE\_Cortex\_A9x1.cluster.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

#### **FVP\_VE\_Cortex\_A9x1.cluster.cpu0.utlb**

TLB - instruction, data or unified.

Type: [TlbCadi](#).

#### **FVP\_VE\_Cortex\_A9x1.daughterboard**

Daughtercard, inspired by the ARM Versatile Express development platform.

Type: [VEDaughterBoard](#).

#### **FVP\_VE\_Cortex\_A9x1.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_A9x1.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_A9x1.daughterboard.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x1.daughterboard.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x1.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x1.daughterboard.dram\_aliased**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A9x1.daughterboard.dram\_limit\_4**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A9x1.daughterboard.dram\_limit\_8**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A9x1.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_VE\_Cortex\_A9x1.daughterboard.hdlcd**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLCD](#).

**FVP\_VE\_Cortex\_A9x1.daughterboard.hlcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A9x1.daughterboard.hlcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A9x1.daughterboard.hlcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A9x1.daughterboard.hdlcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A9x1.daughterboard.introuter**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_A9x1.daughterboard.nonsecure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A9x1.daughterboard.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x1.daughterboard.secureRO**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A9x1.daughterboard.secureROloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A9x1.daughterboard.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x1.daughterboard.secure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A9x1.daughterboard.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x1.daughterboard.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_VE\_Cortex\_A9x1.motherboard**

Model inspired by the ARM Versatile Express Motherboard.

Type: [VEMotherBoard](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A9x1.motherboard.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A9x1.motherboard.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A9x1.motherboard.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A9x1.motherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.mmci**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x1.motherboard.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x1.periph\_clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

## 15.19 FVP\_VE\_Cortex-A9x2

FVP\_VE\_Cortex-A9x2 contains the following instances:

### FVP\_VE\_Cortex-A9x2 instances

**FVP\_VE\_Cortex\_A9x2**

Top level component of the Cortex-A9x2 Versatile Express inspired model.

Type: [FVP\\_VE\\_Cortex\\_A9x2](#).

**FVP\_VE\_Cortex\_A9x2.cluster**

ARM CORTEXA9MP Cluster CT model.

Type: `cluster_ARM_Cortex-A9MP`.

**`FVP_VE_Cortex_A9x2.cluster.cpu0`**

ARM CORTEXA9MP CT model.

Type: `ARM_Cortex-A9MP`.

**`FVP_VE_Cortex_A9x2.cluster.cpu0.l1dcache`**

PV Cache.

Type: `PVCache`.

**`FVP_VE_Cortex_A9x2.cluster.cpu0.l1icache`**

PV Cache.

Type: `PVCache`.

**`FVP_VE_Cortex_A9x2.cluster.cpu0.utlb`**

TLB - instruction, data or unified.

Type: `Tlbcadi`.

**`FVP_VE_Cortex_A9x2.cluster.cpu1`**

ARM CORTEXA9MP CT model.

Type: `ARM_Cortex-A9MP`.

**`FVP_VE_Cortex_A9x2.cluster.cpu1.l1dcache`**

PV Cache.

Type: `PVCache`.

**`FVP_VE_Cortex_A9x2.cluster.cpu1.l1icache`**

PV Cache.

Type: `PVCache`.

**`FVP_VE_Cortex_A9x2.cluster.cpu1.utlb`**

TLB - instruction, data or unified.

Type: `Tlbcadi`.

**`FVP_VE_Cortex_A9x2.daughterboard`**

Daughtercard, inspired by the ARM Versatile Express development platform.

Type: `VEDAughterBoard`.

**`FVP_VE_Cortex_A9x2.daughterboard.clockCLCD`**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: `ClockDivider`.

**`FVP_VE_Cortex_A9x2.daughterboard.clockdivider`**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: `ClockDivider`.

**FVP\_VE\_Cortex\_A9x2.daughterboard.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x2.daughterboard.dmc\_phy**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x2.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x2.daughterboard.dram\_aliased**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A9x2.daughterboard.dram\_limit\_4**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A9x2.daughterboard.dram\_limit\_8**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A9x2.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_VE\_Cortex\_A9x2.daughterboard.hdlcd**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_VE\_Cortex\_A9x2.daughterboard.hdlcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A9x2.daughterboard.hdlcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A9x2.daughterboard.hdlcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A9x2.daughterboard.hdlcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A9x2.daughterboard.introuter**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_A9x2.daughterboard.nonsecure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A9x2.daughterboard.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x2.daughterboard.secureRO**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A9x2.daughterboard.secureROloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A9x2.daughterboard.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x2.daughterboard.secure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A9x2.daughterboard.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x2.daughterboard.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_VE\_Cortex\_A9x2.motherboard**

Model inspired by the ARM Versatile Express Motherboard.

Type: [VEMotherBoard](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A9x2.motherboard.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A9x2.motherboard.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A9x2.motherboard.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A9x2.motherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_A9x2.motherboard mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal()

callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl1](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal1](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal1](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal1](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal1](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x2.motherboard.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x2.periph\_clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

## 15.20 FVP\_VE\_Cortex-A9x4

FVP\_VE\_Cortex-A9x4 contains the following instances:

### FVP\_VE\_Cortex-A9x4 instances

**FVP\_VE\_Cortex\_A9x4**

Top level component of the Cortex-A9x4 Versatile Express inspired model.

Type: FVP\_VE\_Cortex\_A9x4.

**FVP\_VE\_Cortex\_A9x4.cluster**

ARM CORTEXA9MP Cluster CT model.

Type: cluster\_ARM\_Cortex-A9MP.

**FVP\_VE\_Cortex\_A9x4.cluster.cpu0**

ARM CORTEXA9MP CT model.

Type: ARM\_Cortex-A9MP.

**FVP\_VE\_Cortex\_A9x4.cluster.cpu0.ll1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A9x4.cluster.cpu0.ll1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A9x4.cluster.cpu0.utlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A9x4.cluster.cpu1**

ARM CORTEXA9MP CT model.

Type: ARM\_Cortex-A9MP.

**FVP\_VE\_Cortex\_A9x4.cluster.cpu1.ll1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A9x4.cluster.cpu1.ll1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A9x4.cluster.cpu1.utlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A9x4.cluster.cpu2**

ARM CORTEXA9MP CT model.

Type: ARM\_Cortex-A9MP.

**FVP\_VE\_Cortex\_A9x4.cluster.cpu2.ll1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A9x4.cluster.cpu2.ll1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A9x4.cluster.cpu2.utlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A9x4.cluster.cpu3**

ARM CORTEXA9MP CT model.

Type: ARM\_Cortex-A9MP.

**FVP\_VE\_Cortex\_A9x4.cluster.cpu3.ll1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A9x4.cluster.cpu3.ll1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_A9x4.cluster.cpu3.utlb**

TLB - instruction, data or unified.

Type: TlbCadi.

**FVP\_VE\_Cortex\_A9x4.daughterboard**

Daughtercard, inspired by the ARM Versatile Express development platform.

Type: VEDAughterBoard.

**FVP\_VE\_Cortex\_A9x4.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.dmc**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.dmc\_phys**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.dram\_aliased**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.dram\_limit\_4**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.dram\_limit\_8**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.hdlcd**

ARM PrimeCell HD Color LCD Controller (Nominal Designation PL370).

Type: [PL370\\_HDLC](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.hdlcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.hdlcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.hdlcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.hdlcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.introuter**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.nonsecure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.secureDRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.secureRO**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.secureROloader**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.secureSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.secure\_region**

Allow TrustZone secure/normal bus signals to be routed separately.

Type: [TZSwitch](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.sram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x4.daughterboard.vedcc**

Daughterboard Configuration Control (DCC).

Type: [VEDCC](#).

**FVP\_VE\_Cortex\_A9x4.motherboard**

Model inspired by the ARM Versatile Express Motherboard.

Type: [VEMotherBoard](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.Timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.Timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.Timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.Timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.Timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.Timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.Timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.Timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.Timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A9x4.motherboard.Timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_A9x4.motherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.dummy\_local\_dap\_rom**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_A9x4.motherboard mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.p1011\_uart0**

ARM PrimeCell UART(PLO11).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS91C111](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.virtioblockdevice**

virtio block device.

Type: [VirtioBlockDevice](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.virtiop9device**

virtio P9 server.

Type: [VirtioP9Device](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_A9x4.motherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_A9x4.motherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_A9x4.motherboard.vram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

#### **FVP\_VE\_Cortex\_A9x4.periph\_clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

## 15.21 FVP\_VE\_Cortex-R4

FVP\_VE\_Cortex-R4 contains the following instances:

### FVP\_VE\_Cortex-R4 instances

#### **FVP\_VE\_Cortex\_R4**

Top level component of the Cortex\_R4 Versatile Express inspired model.

Type: [FVP\\_VE\\_Cortex\\_R4](#).

#### **FVP\_VE\_Cortex\_R4.daughterboard**

Cortex-R4 DaughterBoard for Versatile Express.

Type: [VEDaughterBoardCortex\\_R4](#).

#### **FVP\_VE\_Cortex\_R4.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_R4.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.daughterboard.core**

ARM CORTEXR4 CT model.

Type: ARM\_Cortex-R4.

**FVP\_VE\_Cortex\_R4.daughterboard.core.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_R4.daughterboard.core.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_R4.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: RAMDevice.

**FVP\_VE\_Cortex\_R4.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: PVBusExclusiveMonitor.

**FVP\_VE\_Cortex\_R4.daughterboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: PL111\_CLCD.

**FVP\_VE\_Cortex\_R4.daughterboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: PL11x\_CLCD.

**FVP\_VE\_Cortex\_R4.daughterboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: ClockTimerThread.

**FVP\_VE\_Cortex\_R4.daughterboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: ClockTimerThread64.

**FVP\_VE\_Cortex\_R4.daughterboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: SchedulerThread.

**FVP\_VE\_Cortex\_R4.daughterboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_R4.daughterboard.pl310\_l2cc**

ARM PrimeCell Level 2 Cache Controller (PL310).

Type: [PL310\\_L2CC](#).

**FVP\_VE\_Cortex\_R4.daughterboard.pl390\_gic**

Generic Interrupt Controller (PL390).

Type: [PL390\\_GIC](#).

**FVP\_VE\_Cortex\_R4.daughterboard.veinterruptmapper**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_R4.vemotherboard**

Model inspired by the ARM Versatile Express Motherboard for R profile.

Type: [VEMotherBoardR](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_R4.vemotherboard mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl011\_uart4**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl011\_uart4.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS91C111](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.terminal\_4**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.timer\_0\_1.counter0**

Internal component used by SP804 Timer module.  
Type: CounterModule.

**FVP\_VE\_Cortex\_R4.vemotherboard.timer\_0\_1.counter1**

Internal component used by SP804 Timer module.  
Type: CounterModule.

**FVP\_VE\_Cortex\_R4.vemotherboard.timer\_2\_3**

ARM Dual-Timer Module(SP804).  
Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.timer\_2\_3.counter0**

Internal component used by SP804 Timer module.  
Type: CounterModule.

**FVP\_VE\_Cortex\_R4.vemotherboard.timer\_2\_3.counter1**

Internal component used by SP804 Timer module.  
Type: CounterModule.

**FVP\_VE\_Cortex\_R4.vemotherboard.ve\_sysregs**

Type: VE\_SysRegs.

**FVP\_VE\_Cortex\_R4.vemotherboard.video\_ram**

RAM device, can be dynamic or static ram.  
Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.vis**

Display window for VE using Visualisation library.  
Type: VEVisualisation.

**FVP\_VE\_Cortex\_R4.vemotherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).  
Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_R4.vemotherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_R4.vemotherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

## **15.22 FVP\_VE\_Cortex-R5x1**

FVP\_VE\_Cortex-R5x1 contains the following instances:

### **FVP\_VE\_Cortex-R5x1 instances**

#### **FVP\_VE\_Cortex\_R5x1**

Top level component of the Cortex\_R5x1 Versatile Express inspired model.

Type: [FVP\\_VE\\_Cortex\\_R5x1](#).

#### **FVP\_VE\_Cortex\_R5x1.daughterboard**

Cortex-R5x1 DaughterBoard for Versatile Express.

Type: [VEDaughterBoardCortex\\_R5x1](#).

#### **FVP\_VE\_Cortex\_R5x1.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_R5x1.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_R5x1.daughterboard.core**

ARM CORTEXR5 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-R5](#).

#### **FVP\_VE\_Cortex\_R5x1.daughterboard.core.cpu0**

ARM CORTEXR5 CT model.

Type: [ARM\\_Cortex-R5](#).

#### **FVP\_VE\_Cortex\_R5x1.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R5x1.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_VE\_Cortex\_R5x1.daughterboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_R5x1.daughterboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_R5x1.daughterboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_R5x1.daughterboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_R5x1.daughterboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_R5x1.daughterboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_R5x1.daughterboard.pl310\_l2cc**

ARM PrimeCell Level 2 Cache Controller (PL310).

Type: [PL310\\_L2CC](#).

**FVP\_VE\_Cortex\_R5x1.daughterboard.pl390\_gic**

Generic Interrupt Controller (PL390).

Type: [PL390\\_GIC](#).

**FVP\_VE\_Cortex\_R5x1.daughterboard.veinterruptmapper**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard**

Model inspired by the ARM Versatile Express Motherboard for R profile.

Type: [VEMotherBoardR](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.pl011\_uart4**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.pl011\_uart4.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_R5x1.vemotherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

#### **FVP\_VE\_Cortex\_R5x1.vemotherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

#### **FVP\_VE\_Cortex\_R5x1.vemotherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_VE\_Cortex\_R5x1.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_VE\_Cortex\_R5x1.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_VE\_Cortex\_R5x1.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

#### **FVP\_VE\_Cortex\_R5x1.vemotherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

#### **FVP\_VE\_Cortex\_R5x1.vemotherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.terminal\_4**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R5x1.vemotherboard.timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R5x1.vemotherboard.ve\_sysregs**

Type: ve\_SysRegs.

**FVP\_VE\_Cortex\_R5x1.vemotherboard.video\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.vis**

Display window for VE using Visualisation library.

Type: VEVisualisation.

**FVP\_VE\_Cortex\_R5x1.vemotherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x1.vemotherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

## 15.23 FVP\_VE\_Cortex-R5x2

FVP\_VE\_Cortex-R5x2 contains the following instances:

### **FVP\_VE\_Cortex-R5x2 instances**

#### **FVP\_VE\_Cortex\_R5x2**

Top level component of the Cortex\_R5x2 Versatile Express inspired model.

Type: [FVP\\_VE\\_Cortex\\_R5x2](#).

#### **FVP\_VE\_Cortex\_R5x2.daughterboard**

Cortex-R5x2 DaughterBoard for Versatile Express.

Type: [VEDaughterBoardCortex\\_R5x2](#).

#### **FVP\_VE\_Cortex\_R5x2.daughterboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_R5x2.daughterboard.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_R5x2.daughterboard.core**

ARM CORTEXR5 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-R5](#).

#### **FVP\_VE\_Cortex\_R5x2.daughterboard.core.cpu0**

ARM CORTEXR5 CT model.

Type: [ARM\\_Cortex-R5](#).

#### **FVP\_VE\_Cortex\_R5x2.daughterboard.core.cpu1**

ARM CORTEXR5 CT model.

Type: [ARM\\_Cortex-R5](#).

#### **FVP\_VE\_Cortex\_R5x2.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

#### **FVP\_VE\_Cortex\_R5x2.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

#### **FVP\_VE\_Cortex\_R5x2.daughterboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_R5x2.daughterboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_R5x2.daughterboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_R5x2.daughterboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_R5x2.daughterboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_R5x2.daughterboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_R5x2.daughterboard.pl310\_l2cc**

ARM PrimeCell Level 2 Cache Controller (PL310).

Type: [PL310\\_L2CC](#).

**FVP\_VE\_Cortex\_R5x2.daughterboard.pl390\_gic**

Generic Interrupt Controller (PL390).

Type: [PL390\\_GIC](#).

**FVP\_VE\_Cortex\_R5x2.daughterboard.veinterruptmapper**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard**

Model inspired by the ARM Versatile Express Motherboard for R profile.

Type: [VEMotherBoardR](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.mmcc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.pl011\_uart4**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.pl011\_uart4.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.terminal\_4**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R5x2.vemotherboard.timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R5x2.vemotherboard.timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R5x2.vemotherboard.timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R5x2.vemotherboard.timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R5x2.vemotherboard.ve\_sysregs**

Type: ve\_SysRegs.

**FVP\_VE\_Cortex\_R5x2.vemotherboard.video\_ram**

RAM device, can be dynamic or static ram.

Type: RAMDevice.

**FVP\_VE\_Cortex\_R5x2.vemotherboard.vis**

Display window for VE using Visualisation library.

Type: VEVisualisation.

**FVP\_VE\_Cortex\_R5x2.vemotherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: VisEventRecorder.

**FVP\_VE\_Cortex\_R5x2.vemotherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: ClockDivider.

**FVP\_VE\_Cortex\_R5x2.vemotherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: ClockDivider.

## 15.24 FVP\_VE\_Cortex-R7x1

FVP\_VE\_Cortex-R7x1 contains the following instances:

### FVP\_VE\_Cortex-R7x1 instances

**FVP\_VE\_Cortex\_R7x1**

Top level component of the Cortex\_R7x1 Versatile Express inspired model.

Type: FVP\_VE\_Cortex\_R7x1.

**FVP\_VE\_Cortex\_R7x1.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.daughterboard**

Cortex\_R7x1 DaughterBoard for Versatile Express.

Type: [VEDaughterBoardCortex\\_R7x1](#).

**FVP\_VE\_Cortex\_R7x1.daughterboard.core**

ARM CORTEXR7 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-R7](#).

**FVP\_VE\_Cortex\_R7x1.daughterboard.core.cpu0**

ARM CORTEXR7 CT model.

Type: [ARM\\_Cortex-R7](#).

**FVP\_VE\_Cortex\_R7x1.daughterboard.core.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_R7x1.daughterboard.core.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_R7x1.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R7x1.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_VE\_Cortex\_R7x1.daughterboard.periph\_clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.daughterboard.p1310\_l2cc**

ARM PrimeCell Level 2 Cache Controller (PL310).

Type: [PL310\\_L2CC](#).

**FVP\_VE\_Cortex\_R7x1.daughterboard.veinterruptmapper**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard**

Model inspired by the ARM Versatile Express Motherboard for R profile.

Type: [VEMotherBoard](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl011\_uart4**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl011\_uart4.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.terminal\_4**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R7x1.vemotherboard.timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R7x1.vemotherboard.timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x1.vemotherboard.timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_R7x1.vemotherboard.timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_VE\_Cortex\_R7x1.vemotherboard.timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_VE\_Cortex\_R7x1.vemotherboard.ve\_sysregs**

Type: VE\_SysRegs.

#### **FVP\_VE\_Cortex\_R7x1.vemotherboard.video\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

#### **FVP\_VE\_Cortex\_R7x1.vemotherboard.vis**

Display window for VE using Visualisation library.

Type: VEVisualisation.

#### **FVP\_VE\_Cortex\_R7x1.vemotherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

#### **FVP\_VE\_Cortex\_R7x1.vemotherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_R7x1.vemotherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

## 15.25 FVP\_VE\_Cortex-R7x2

FVP\_VE\_Cortex-R7x2 contains the following instances:

### **FVP\_VE\_Cortex-R7x2 instances**

#### **FVP\_VE\_Cortex\_R7x2**

Top level component of the Cortex\_R7x2 Versatile Express inspired model.

Type: `FVP_VE_Cortex_R7x2`.

**`FVP_VE_Cortex_R7x2.clockdivider`**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: `ClockDivider`.

**`FVP_VE_Cortex_R7x2.daughterboard`**

Cortex\_R7x2 DaughterBoard for Versatile Express.

Type: `VEDaughterBoardCortex_R7x2`.

**`FVP_VE_Cortex_R7x2.daughterboard.core`**

ARM CORTEXR7 Cluster CT model.

Type: `cluster_ARM_Cortex-R7`.

**`FVP_VE_Cortex_R7x2.daughterboard.core.cpu0`**

ARM CORTEXR7 CT model.

Type: `ARM_Cortex-R7`.

**`FVP_VE_Cortex_R7x2.daughterboard.core.cpu0.11dcache`**

PV Cache.

Type: `PVCache`.

**`FVP_VE_Cortex_R7x2.daughterboard.core.cpu0.11icache`**

PV Cache.

Type: `PVCache`.

**`FVP_VE_Cortex_R7x2.daughterboard.core.cpu1`**

ARM CORTEXR7 CT model.

Type: `ARM_Cortex-R7`.

**`FVP_VE_Cortex_R7x2.daughterboard.core.cpu1.11dcache`**

PV Cache.

Type: `PVCache`.

**`FVP_VE_Cortex_R7x2.daughterboard.core.cpu1.11icache`**

PV Cache.

Type: `PVCache`.

**`FVP_VE_Cortex_R7x2.daughterboard.dram`**

RAM device, can be dynamic or static ram.

Type: `RAMDevice`.

**`FVP_VE_Cortex_R7x2.daughterboard.exclusive_monitor`**

Global exclusive monitor.

Type: `PVBusExclusiveMonitor`.

**`FVP_VE_Cortex_R7x2.daughterboard.periph_clockdivider`**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.daughterboard.pl310\_l2cc**

ARM PrimeCell Level 2 Cache Controller (PL310).

Type: [PL310\\_L2CC](#).

**FVP\_VE\_Cortex\_R7x2.daughterboard.veinterruptmapper**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard**

Model inspired by the ARM Versatile Express Motherboard for R profile.

Type: [VEMotherBoardR](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl011\_uart4**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl011\_uart4.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS91C111](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.terminal\_4**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R7x2.vemotherboard.timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R7x2.vemotherboard.timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R7x2.vemotherboard.timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R7x2.vemotherboard.ve\_sysregs**

Type: VE\_SysRegs.

**FVP\_VE\_Cortex\_R7x2.vemotherboard.video\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.vis**

Display window for VE using Visualisation library.

Type: VEVisualisation.

**FVP\_VE\_Cortex\_R7x2.vemotherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_R7x2.vemotherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_R7x2.vemotherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

## 15.26 FVP\_VE\_Cortex-R8x1

FVP\_VE\_Cortex-R8x1 contains the following instances:

### FVP\_VE\_Cortex-R8x1 instances

#### **FVP\_VE\_Cortex\_R8x1**

Top level component of the Cortex\_R8x1 Versatile Express inspired model.

Type: [FVP\\_VE\\_Cortex\\_R8x1](#).

#### **FVP\_VE\_Cortex\_R8x1.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_R8x1.daughterboard**

Cortex\_R8x1 DaughterBoard for Versatile Express.

Type: [VEDaughterBoardCortex\\_R8x1](#).

#### **FVP\_VE\_Cortex\_R8x1.daughterboard.core**

ARM CORTEXR8 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-R8](#).

#### **FVP\_VE\_Cortex\_R8x1.daughterboard.core.cpu0**

ARM CORTEXR8 CT model.

Type: [ARM\\_Cortex-R8](#).

#### **FVP\_VE\_Cortex\_R8x1.daughterboard.core.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

#### **FVP\_VE\_Cortex\_R8x1.daughterboard.core.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

#### **FVP\_VE\_Cortex\_R8x1.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R8x1.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_VE\_Cortex\_R8x1.daughterboard.periph\_clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.daughterboard.pl310\_l2cc**

ARM PrimeCell Level 2 Cache Controller (PL310).

Type: [PL310\\_L2CC](#).

**FVP\_VE\_Cortex\_R8x1.daughterboard.veinterruptmapper**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard**

Model inspired by the ARM Versatile Express Motherboard for R profile.

Type: [VEMotherBoardR](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.pl011\_uart4**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.pl011\_uart4.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.p1041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.p1050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.p1050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.p1050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.p1050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.p1111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.p1111\_clcd.p111x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.p1111\_clcd.p111x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.p1111\_clcd.p111x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.terminal\_4**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R8x1.vemotherboard.timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R8x1.vemotherboard.timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R8x1.vemotherboard.timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R8x1.vemotherboard.ve\_sysregs**

Type: [VE\\_SysRegs](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.video\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x1.vemotherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

## 15.27 FVP\_VE\_Cortex-R8x2

FVP\_VE\_Cortex-R8x2 contains the following instances:

### FVP\_VE\_Cortex-R8x2 instances

**FVP\_VE\_Cortex\_R8x2**

Top level component of the Cortex\_R8x2 Versatile Express inspired model.

Type: [FVP\\_VE\\_Cortex\\_R8x2](#).

**FVP\_VE\_Cortex\_R8x2.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.daughterboard**

Cortex\_R8x2 DaughterBoard for Versatile Express.

Type: [VEDaughterBoardCortex\\_R8x2](#).

**FVP\_VE\_Cortex\_R8x2.daughterboard.core**

ARM CORTEXR8 Cluster CT model.

Type: [Cluster\\_ARM\\_Cortex-R8](#).

**FVP\_VE\_Cortex\_R8x2.daughterboard.core.cpu0**

ARM CORTEXR8 CT model.

Type: [ARM\\_Cortex-R8](#).

**FVP\_VE\_Cortex\_R8x2.daughterboard.core.cpu0.l1dcache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_R8x2.daughterboard.core.cpu0.l1icache**

PV Cache.

Type: [PVCache](#).

**FVP\_VE\_Cortex\_R8x2.daughterboard.core.cpu1**

ARM CORTEXR8 CT model.

Type: ARM\_Cortex-R8.

**FVP\_VE\_Cortex\_R8x2.daughterboard.core.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_R8x2.daughterboard.core.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_R8x2.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: RAMDevice.

**FVP\_VE\_Cortex\_R8x2.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: PVBusExclusiveMonitor.

**FVP\_VE\_Cortex\_R8x2.daughterboard.periph\_clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: ClockDivider.

**FVP\_VE\_Cortex\_R8x2.daughterboard.pl310\_l2cc**

ARM PrimeCell Level 2 Cache Controller (PL310).

Type: PL310\_L2CC.

**FVP\_VE\_Cortex\_R8x2.daughterboard.veinterruptmapper**

Interrupt Mapping peripheral (non-cascaded).

Type: VEInterruptMapper.

**FVP\_VE\_Cortex\_R8x2.vemotherboard**

Model inspired by the ARM Versatile Express Motherboard for R profile.

Type: VEMotherBoardR.

**FVP\_VE\_Cortex\_R8x2.vemotherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: AudioOut SDL.

**FVP\_VE\_Cortex\_R8x2.vemotherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: ClockDivider.

**FVP\_VE\_Cortex\_R8x2.vemotherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.p1011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.p1011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.p1011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.p1011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.p1011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.p1011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.p1011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.p1011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.p1011\_uart4**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.pl011\_uart4.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_VE\_Cortex\_R8x2.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_VE\_Cortex\_R8x2.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_VE\_Cortex\_R8x2.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

#### **FVP\_VE\_Cortex\_R8x2.vemotherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

#### **FVP\_VE\_Cortex\_R8x2.vemotherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

#### **FVP\_VE\_Cortex\_R8x2.vemotherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

#### **FVP\_VE\_Cortex\_R8x2.vemotherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

#### **FVP\_VE\_Cortex\_R8x2.vemotherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

#### **FVP\_VE\_Cortex\_R8x2.vemotherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

#### **FVP\_VE\_Cortex\_R8x2.vemotherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.terminal\_4**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R8x2.vemotherboard.timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R8x2.vemotherboard.timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R8x2.vemotherboard.timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R8x2.vemotherboard.ve\_sysregs**

Type: ve\_SysRegs.

**FVP\_VE\_Cortex\_R8x2.vemotherboard.video\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.vis**

Display window for VE using Visualisation library.

Type: [VEVisualisation](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x2.vemotherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

## 15.28 FVP\_VE\_Cortex-R8x4

FVP\_VE\_Cortex-R8x4 contains the following instances:

### FVP\_VE\_Cortex-R8x4 instances

**FVP\_VE\_Cortex\_R8x4**

Top level component of the Cortex\_R8x4 Versatile Express inspired model.

Type: [FVP\\_VE\\_Cortex\\_R8x4](#).

**FVP\_VE\_Cortex\_R8x4.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.daughterboard**

Cortex\_R8x4 DaughterBoard for Versatile Express.

Type: [VEDaughterBoardCortex\\_R8x4](#).

**FVP\_VE\_Cortex\_R8x4.daughterboard.core**

ARM CORTEXR8 Cluster CT model.

Type: Cluster\_ARM\_Cortex-R8.

**FVP\_VE\_Cortex\_R8x4.daughterboard.core.cpu0**

ARM CORTEXR8 CT model.

Type: ARM\_Cortex-R8.

**FVP\_VE\_Cortex\_R8x4.daughterboard.core.cpu0.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_R8x4.daughterboard.core.cpu0.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_R8x4.daughterboard.core.cpu1**

ARM CORTEXR8 CT model.

Type: ARM\_Cortex-R8.

**FVP\_VE\_Cortex\_R8x4.daughterboard.core.cpu1.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_R8x4.daughterboard.core.cpu1.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_R8x4.daughterboard.core.cpu2**

ARM CORTEXR8 CT model.

Type: ARM\_Cortex-R8.

**FVP\_VE\_Cortex\_R8x4.daughterboard.core.cpu2.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_R8x4.daughterboard.core.cpu2.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_R8x4.daughterboard.core.cpu3**

ARM CORTEXR8 CT model.

Type: ARM\_Cortex-R8.

**FVP\_VE\_Cortex\_R8x4.daughterboard.core.cpu3.l1dcache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_R8x4.daughterboard.core.cpu3.l1icache**

PV Cache.

Type: PVCache.

**FVP\_VE\_Cortex\_R8x4.daughterboard.dram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R8x4.daughterboard.exclusive\_monitor**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_VE\_Cortex\_R8x4.daughterboard.periph\_clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.daughterboard.p1310\_l2cc**

ARM PrimeCell Level 2 Cache Controller (PL310).

Type: [PL310\\_L2CC](#).

**FVP\_VE\_Cortex\_R8x4.daughterboard.veinterruptmapper**

Interrupt Mapping peripheral (non-cascaded).

Type: [VEInterruptMapper](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard**

Model inspired by the ARM Versatile Express Motherboard for R profile.

Type: [VEMotherBoard](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.audioout**

SDL based Audio Output for PL041\_AACI.

Type: [AudioOut SDL](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.clock100Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.clock24MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.clock35MHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.clockCLCD**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.dummy\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.dummy\_usb**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.flash0**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.flash1**

Intel Strata Flash J3 LISA+ model.

Type: [IntelStrataFlashJ3](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.flashloader0**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.flashloader1**

A device that can preload a gzipped image into flash at startup.

Type: [FlashLoader](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard mmc**

Generic Multimedia Card.

Type: [MMC](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl011\_uart0**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl011\_uart0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl011\_uart1**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl011\_uart1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl011\_uart2**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl011\_uart2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl011\_uart3**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl011\_uart3.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl011\_uart4**

ARM PrimeCell UART(PL011).

Type: [PL011\\_Uart](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl011\_uart4.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl031\_rtc**

ARM PrimeCell Real Time Clock(PL031).

Type: [PL031\\_RTC](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl041\_aaci**

ARM PrimeCell Advanced Audio CODEC Interface(PL041).

Type: [PL041\\_AACI](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl050\_kmi0**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl050\_kmi0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl050\_kmi1**

ARM PrimeCell PS2 Keyboard/Mouse Interface(PL050).

Type: [PL050\\_KMI](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl050\_kmi1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl111\_clcd**

ARM PrimeCell Color LCD Controller(PL111).

Type: [PL111\\_CLCD](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl111\_clcd.pl11x\_clcd**

Internal component used by PL110 and PL111 CLCD controllers.

Type: [PL11x\\_CLCD](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl111\_clcd.pl11x\_clcd.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl111\_clcd.pl11x\_clcd.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.pl180\_mci**

ARM PrimeCell Multimedia Card Interface (PL180).

Type: [PL180\\_MCI](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.ps2keyboard**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Keyboard](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.ps2mouse**

Interface component, which takes the keypress/release signals from the Visualisation component and translates them into clocked PS2Data signals which can be routed to a PL050\_KMI component.

Type: [PS2Mouse](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.psram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.sp805\_wdog**

ARM Watchdog Module(SP805).

Type: [SP805\\_Watchdog](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.sp810\_sysctrl**

Only EB relevant functionalities are fully implemented.

Type: [SP810\\_SysCtrl](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.sp810\_sysctrl.clkdiv\_clk0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.sp810\_sysctrl.clkdiv\_clk1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.sp810\_sysctrl.clkdiv\_clk2**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.sp810\_sysctrl.clkdiv\_clk3**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.terminal\_0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.terminal\_1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.terminal\_2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.terminal\_3**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.terminal\_4**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.timer\_0\_1**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.timer\_0\_1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.timer\_0\_1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.timer\_0\_1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R8x4.vemotherboard.timer\_0\_1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R8x4.vemotherboard.timer\_2\_3**

ARM Dual-Timer Module(SP804).

Type: [SP804\\_Timer](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.timer\_2\_3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.timer\_2\_3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.timer\_2\_3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R8x4.vemotherboard.timer\_2\_3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_VE\_Cortex\_R8x4.vemotherboard.ve\_sysregs**

Type: VE\_SysRegs.

**FVP\_VE\_Cortex\_R8x4.vemotherboard.video\_ram**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.vis**

Display window for VE using Visualisation library.

Type: VEVisualisation.

**FVP\_VE\_Cortex\_R8x4.vemotherboard.vis.recorder**

Event recorder component for visualisation component (allows to playback and record interactive GUI sessions).

Type: [VisEventRecorder](#).

**FVP\_VE\_Cortex\_R8x4.vemotherboard.vis.recorder.playbackDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_VE\_Cortex\_R8x4.vemotherboard.vis.recorder.recordingDivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

# 16. MPS2 Platform FVPs

This chapter lists the MPS2 Platform FVPs and the instances in them.

For the MPS2 memory maps, see [MPS2 - memory maps](#) in the *Fast Models Reference Guide*.

## 16.1 FVP\_MPS2\_AEMv8M

FVP\_MPS2\_AEMv8M contains the following instances:

### FVP\_MPS2\_AEMv8M instances

#### **FVP\_MPS2\_AEMv8M**

Type: [FVP\\_MPS2\\_AEMv8M](#).

#### **FVP\_MPS2\_AEMv8M.clk25Mhz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_AEMv8M.clk25khz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_AEMv8M.cpu0**

ARM AEMv8M CT model.

Type: [ARM\\_AEMv8M](#).

#### **FVP\_MPS2\_AEMv8M.cpu1**

ARM AEMv8M CT model.

Type: [ARM\\_AEMv8M](#).

#### **FVP\_MPS2\_AEMv8M.fvp\_mps2**

MPS2 DUT.

Type: [FVP\\_MPS2](#).

#### **FVP\_MPS2\_AEMv8M.fvp\_mps2.GPIO0**

ARM PrimeCell General Purpose Input/Output.

Type: [CMSDK\\_GPIO](#).

#### **FVP\_MPS2\_AEMv8M.fvp\_mps2.GPIO1**

ARM PrimeCell General Purpose Input/Output.

Type: [CMSDK\\_GPIO](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.GPIO2**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.GPIO3**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.GPIO\_connection\_test**

Type: GPIO\_Connection\_Test.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.GPIO\_connection\_test.GPIO0\_port\_trans**

Type: GPIO\_Port\_Transfer.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.GPIO\_connection\_test.GPIO1\_port\_test**

Type: GPIO1\_Connection\_Test.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.PSRAM**

RAM device, can be dynamic or static ram.

Type: RAMDevice.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.PSRAM\_M7**

RAM device, can be dynamic or static ram.

Type: RAMDevice.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.UART0**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.UART0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: ClockDivider.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.UART1**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.UART1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: ClockDivider.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.UART2**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.UART2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.VGA\_interface**

VGA display interface between main bus and visualisation.

Type: [MPS2\\_VGA](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.ahb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.ahb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.apb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.apb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.apb\_ppc\_iotss\_expansion2**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.cmsdk\_sysctrl**

Cortex-M Simple System Control.

Type: [CMSDK\\_SysCtrl](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.cmsdk\_watchdog**

ARM Watchdog Module.

Type: [CMSDK\\_Watchdog](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.cpu\_wait\_or\_gate\_0**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.cpu\_wait\_or\_gate\_1**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dbgen\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma0**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma0.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma0\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma0\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma1**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMPC](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma1.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma1.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma1.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma1.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma1\_idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma1\_securitymodifier**

Type: [SecurityModifier](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma2**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMPC](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma2.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma2.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma2.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma2.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma2\_idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma2\_securitymodifier**

Type: [SecurityModifier](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma3**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma3.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma3.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma3.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma3.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma3\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.dma3\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.exclusive\_monitor\_psram**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.exclusive\_monitor\_psram\_iotss**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.exclusive\_monitor\_zbtsram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.exclusive\_monitor\_zbtsram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.fpga\_sysctrl**

FPGA SysCtrl timers LEDs and switches.

Type: [FPGA\\_SysCtrl](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.fpga\_sysctrl.callBack100HzCounter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.fpga\_sysctrl.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.gpio\_0\_or\_2**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.gpio\_1\_or\_3**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mem\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mem\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mpc\_iotss\_ssram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mpc\_iotss\_ssram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mpc\_iotss\_ssram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mpc\_iotss\_ssram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mps2\_audio**

MPS2 Audio.

Type: [MPS2\\_Audio](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mps2\_cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mps2\_exclusive\_monitor\_zbtssram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mps2\_exclusive\_monitor\_zbtssram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mps2\_lcd**

MPS2 LCD I2C interface.

Type: MPS2\_LCD.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mps2\_mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mps2\_mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mps2\_secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: MPS2\_SecureCtrl.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mps2\_timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mps2\_timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mps2\_timer0.counter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mps2\_timer1**

ARM Timer Module.

Type: [CMSDK\\_Timer](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mps2\_timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mps2\_timer1.counter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.mps2\_visualisation**

Display window for MPS2 using Visualisation library.

Type: [MPS2\\_Visualisation](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.niden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.p1022\_ssp\_mps2**

ARM PrimeCell Synchronous Serial Port(PL022).

Type: [PL022\\_SSP\\_MPS2](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.p1022\_ssp\_mps2.prescaler**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.platform\_bus\_switch**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.platform\_switch\_dma0**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.platform\_switch\_dma1**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.signal\_router**

Signal router.

Type: [SignalRouter](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.spiden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.spniden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200**

SSE-200 subsystem.

Type: [sse200](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.acg\_cpu0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.acg\_cpu1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.acg\_sram0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.acg\_sram1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.acg\_sram2**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.acg\_sram3**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem0**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem1**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.clock32kHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.cmsdk\_dualtimer.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.cordio\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.cpu0core\_ppu**

ARM Power Policy Unit (PPU) architectural model.  
Type: [PPUv0](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.cpu0dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.  
Type: [PPUv0](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.cpu1core\_ppu**

ARM Power Policy Unit (PPU) architectural model.  
Type: [PPUv0](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.cpu1dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.  
Type: [PPUv0](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.crypto\_ppu**

ARM Power Policy Unit (PPU) architectural model.  
Type: [PPUv0](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.  
Type: [PPUv0](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram0**

Global exclusive monitor.  
Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram1**

Global exclusive monitor.  
Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram2**

Global exclusive monitor.  
Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram3**

Global exclusive monitor.  
Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.  
Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.iotss\_cpuidentity**

IoT Subsystem CPU\_IDENTITY registers.  
Type: IoTSS\_CPUIdentity.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.iotss\_internal\_sram0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.iotss\_internal\_sram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.iotss\_internal\_sram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.iotss\_internal\_sram3**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.iotss\_systemcontrol**

IoT Subsystem System Control registers.

Type: [IoTSS\\_SystemControl](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.iotss\_systeminfo**

IoT Subsystem System Information registers.

Type: [IoTSS\\_SystemInfo](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.mem\_switch\_internal\_sram**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.mem\_switch\_internal\_sram\_mpc**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.mem\_switch\_ppu**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.mhu0**

IoT Subsystem Message Handling Unit.

Type: [IoTSS\\_MessageHandlingUnit](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.mhu1**

IoT Subsystem Message Handling Unit.

Type: [IoTSS\\_MessageHandlingUnit](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.nonsecure\_watchdog**

ARM Watchdog Module.

Type: [CMSDK\\_Watchdog](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.ram0\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.ram1\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.ram2\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.ram3\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.s32k\_timer**

ARM Timer Module.

Type: [CMSDK\\_Timer](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.s32k\_timer.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.s32k\_timer.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.s32k\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: MPS2\_SecureCtrl.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.secure\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.signal\_router**

Signal router.

Type: SignalRouter.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.sys\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.timer0.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.timer1**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.sse200.timer1.counter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.ssram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.ssram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.stub0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.stub1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.stub\_i2c1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.stub\_i2s**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.stub\_spi0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.stub\_spi2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer**

Type: [svos\\_DualTimer](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.switch\_PSRAM\_M7**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.switch\_svos\_dualltimer**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.telnetterminal0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.telnetterminal1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.telnetterminal2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.touchscreen\_interface**

MPS2 Touch Screen.

Type: [MPS2\\_TouchScreen](#).

**FVP\_MPS2\_AEMv8M.fvp\_mps2.uart\_overflows\_or\_gate**

Or Gate.

Type: [OrGate](#).

## 16.2 FVP\_MPS2\_Cortex-M0

FVP\_MPS2\_Cortex-M0 contains the following instances:

### FVP\_MPS2\_Cortex-M0 instances

**FVP\_MPS2\_Cortex\_M0**

Type: [FVP\\_MPS2\\_Cortex\\_M0](#).

**FVP\_MPS2\_Cortex\_M0.armcortexm0ct**

ARM CORTEXM0 CT model.

Type: [ARM\\_Cortex-M0](#).

**FVP\_MPS2\_Cortex\_M0.clk25Mhz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.clk25khz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2**

MPS2 DUT.

Type: [FVP\\_MPS2](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.GPIO0**

ARM PrimeCell General Purpose Input/Output.

Type: [CMSDK\\_GPIO](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.GPIO1**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.GPIO2**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.GPIO3**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.GPIO\_connection\_test**

Type: GPIO\_Connection\_Test.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.GPIO\_connection\_test.GPIO0\_port\_trans**

Type: GPIO\_Port\_Transfer.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.GPIO\_connection\_test.GPIO1\_port\_test**

Type: GPIO1\_Connection\_Test.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.PSRAM**

RAM device, can be dynamic or static ram.

Type: RAMDevice.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.PSRAM\_M7**

RAM device, can be dynamic or static ram.

Type: RAMDevice.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.UART0**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.UART0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: ClockDivider.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.UART1**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.UART1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: ClockDivider.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.UART2**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.UART2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.VGA\_interface**

VGA display interface between main bus and visualisation.

Type: MPS2\_VGA.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.ahb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.ahb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.apb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.apb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.apb\_ppc\_iotss\_expansion2**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.cmsdk\_sysctrl**

Cortex-M Simple System Control.

Type: CMSDK\_SysCtrl.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.cmsdk\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.cpu\_wait\_or\_gate\_0**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.cpu\_wait\_or\_gate\_1**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dbgen\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma0**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma0\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma0\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma1**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma1.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma1.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma1.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma1.timer.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma1\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma1\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma2**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma2.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma2.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma2.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma2.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma2.idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma2.securitymodifier**

Type: [SecurityModifier](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma3**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma3.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma3.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma3.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma3.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma3.idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.dma3.securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.exclusive\_monitor\_psram**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.exclusive\_monitor\_psram\_iotss**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.exclusive\_monitor\_zbtsram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.exclusive\_monitor\_zbtsram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.fpga\_sysctrl**

FPGA SysCtrl timers LEDs and switches.

Type: [FPGA\\_SysCtrl](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.fpga\_sysctrl.callBack100HzCounter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.fpga\_sysctrl.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.gpio\_0\_or\_2**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.gpio\_1\_or\_3**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mem\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mem\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mpc\_iotss\_ssram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mpc\_iotss\_ssram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mpc\_iotss\_ssram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mpc\_iotss\_ssram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mps2\_audio**

MPS2 Audio.

Type: [MPS2\\_Audio](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mps2\_cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mps2\_exclusive\_monitor\_zbtsram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mps2\_exclusive\_monitor\_zbtsram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mps2\_lcd**

MPS2 LCD I2C interface.

Type: MPS2\_LCD.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mps2\_mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mps2\_mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mps2\_secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: MPS2\_SecureCtrl.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mps2\_timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mps2\_timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mps2\_timer0.counter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mps2\_timer1**

ARM Timer Module.

Type: [CMSDK\\_Timer](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mps2\_timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mps2\_timer1.counter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.mps2\_visualisation**

Display window for MPS2 using Visualisation library.

Type: [MPS2\\_Visualisation](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.niden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.p1022\_ssp\_mps2**

ARM PrimeCell Synchronous Serial Port(PL022).

Type: [PL022\\_SSP\\_MPS2](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.p1022\_ssp\_mps2.prescaler**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.platform\_bus\_switch**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.platform\_switch\_dma0**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.platform\_switch\_dma1**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.signal\_router**

Signal router.

Type: [SignalRouter](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.spiden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.spniden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200**

SSE-200 subsystem.

Type: [sse200](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.acg\_cpu0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.acg\_cpu1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.acg\_sram0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.acg\_sram1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.acg\_sram2**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.acg\_sram3**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem0**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.clock32kHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.cmsdk\_dualtimer.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.cordio\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.cpu0core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.cpu0dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.cpu1core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.cpu1dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.crypto\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram0**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram3**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.iotss\_cpuidentity**

IoT Subsystem CPU\_IDENTITY registers.

Type: IoTSS\_CPUIdentity.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.iotss\_internal\_sram0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.iotss\_internal\_sram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.iotss\_internal\_sram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.iotss\_internal\_sram3**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.iotss\_systemcontrol**

IoT Subsystem System Control registers.

Type: [IoTSS\\_SystemControl](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.iotss\_systeminfo**

IoT Subsystem System Information registers.

Type: [IoTSS\\_SystemInfo](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.mem\_switch\_internal\_sram**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.mem\_switch\_internal\_sram\_mpc**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.mem\_switch\_ppu**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.mhu0**

IoT Subsystem Message Handling Unit.

Type: [IoTSS\\_MessageHandlingUnit](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.mhu1**

IoT Subsystem Message Handling Unit.

Type: [IoTSS\\_MessageHandlingUnit](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.nonsecure\_watchdog**

ARM Watchdog Module.

Type: [CMSDK\\_Watchdog](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.ram0\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.ram1\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.ram2\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.ram3\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.s32k\_timer**

ARM Timer Module.

Type: [CMSDK\\_Timer](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.s32k\_timer.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.s32k\_timer.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.s32k\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: MPS2\_SecureCtrl.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.secure\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.signal\_router**

Signal router.

Type: SignalRouter.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.sys\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: PPUv0.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.timer0.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.timer1**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.sse200.timer1.counter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.ssram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.ssram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.stub0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.stub1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.stub\_i2c1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.stub\_i2s**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.stub\_spi0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.stub\_spi2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualtimer**

Type: [svos\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.switch\_PSRAM\_M7**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.switch\_svos\_dualltimer**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.telnetterminal0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.telnetterminal1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.telnetterminal2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.touchescreen\_interface**

MPS2 Touch Screen.

Type: [MPS2\\_TouchScreen](#).

**FVP\_MPS2\_Cortex\_M0.fvp\_mps2.uart\_overflows\_or\_gate**

Or Gate.

Type: [OrGate](#).

## 16.3 FVP\_MPS2\_Cortex-M0plus

FVP\_MPS2\_Cortex-M0plus contains the following instances:

### FVP\_MPS2\_Cortex-M0plus instances

**FVP\_MPS2\_Cortex\_M0plus**

Type: [FVP\\_MPS2\\_Cortex\\_M0plus](#).

**FVP\_MPS2\_Cortex\_M0plus.armcortexm0plusct**

ARM CORTEXM0+ CT model.

Type: [ARM\\_Cortex-M0+](#).

**FVP\_MPS2\_Cortex\_M0plus.clk25Mhz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.clk25khz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2**

MPS2 DUT.

Type: [FVP\\_MPS2](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.GPIO0**

ARM PrimeCell General Purpose Input/Output.

Type: [CMSDK\\_GPIO](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.GPIO1**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.GPIO2**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.GPIO3**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.GPIO\_connection\_test**

Type: GPIO\_Connection\_Test.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.GPIO\_connection\_test.GPIO0\_port\_trans**

Type: GPIO\_Port\_Transfer.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.GPIO\_connection\_test.GPIO1\_port\_test**

Type: GPIO1\_Connection\_Test.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.PSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.PSRAM\_M7**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.UART0**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.UART0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.UART1**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.UART1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.UART2**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.UART2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.VGA\_interface**

VGA display interface between main bus and visualisation.

Type: MPS2\_VGA.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.ahb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.ahb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.apb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.apb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.apb\_ppc\_iotss\_expansion2**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.cmsdk\_sysctrl**

Cortex-M Simple System Control.

Type: CMSDK\_SysCtrl.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.cmsdk\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.cpu\_wait\_or\_gate\_0**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.cpu\_wait\_or\_gate\_1**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dbgen\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma0**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma0\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma0\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma1**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma1.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma1.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma1.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma1.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma1\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma1\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma2**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma2.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma2.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma2.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma2.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma2\_idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma2\_securitymodifier**

Type: [SecurityModifier](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma3**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma3.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma3.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma3.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma3.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma3.idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.dma3.securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.exclusive\_monitor\_psram**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.exclusive\_monitor\_psram\_iotss**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.exclusive\_monitor\_zbtsram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.exclusive\_monitor\_zbtsram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.fpga\_sysctrl**

FPGA SysCtrl timers LEDs and switches.

Type: [FPGA\\_SysCtrl](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.fpga\_sysctrl.callBack100HzCounter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.fpga\_sysctrl.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.gpio\_0\_or\_2**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.gpio\_1\_or\_3**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mem\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mem\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mpc\_iotss\_ssram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mpc\_iotss\_ssram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mpc\_iotss\_ssram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mpc\_iotss\_ssram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mps2\_audio**

MPS2 Audio.

Type: [MPS2\\_Audio](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mps2\_cmsdk\_dualltimer**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mps2\_exclusive\_monitor\_zbtsram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mps2\_exclusive\_monitor\_zbtsram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mps2\_lcd**

MPS2 LCD I2C interface.

Type: MPS2\_LCD.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mps2\_mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mps2\_mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mps2\_secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: MPS2\_SecureCtrl.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mps2\_timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mps2\_timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mps2\_timer0.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mps2\_timer1**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mps2\_timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mps2\_timer1.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.mps2\_visualisation**

Display window for MPS2 using Visualisation library.

Type: MPS2\_Visualisation.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.niden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.p1022\_ssp\_mps2**

ARM PrimeCell Synchronous Serial Port(PL022).

Type: PL022\_SSP\_MPS2.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.p1022\_ssp\_mps2.prescaler**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.platform\_bus\_switch**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.platform\_switch\_dma0**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.platform\_switch\_dma1**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.signal\_router**

Signal router.

Type: [SignalRouter](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.spiden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.spniden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200**

SSE-200 subsystem.

Type: [sse200](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.acg\_cpu0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.acg\_cpu1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.acg\_sram0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.acg\_sram1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.acg\_sram2**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.acg\_sram3**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem0**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.clock32kHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.cmsdk\_dualtimer.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.cordio\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.cpu0core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.cpu0dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.cpu1core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.cpu1dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.crypto\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram0**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram1**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram2**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram3**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBUSExclusiveSquasher](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.iotss\_cpuidentity**

IoT Subsystem CPU\_IDENTITY registers.

Type: IoTSS\_CPUIdentity.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.iotss\_internal\_sram0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.iotss\_internal\_sram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.iotss\_internal\_sram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.iotss\_internal\_sram3**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.iotss\_systemcontrol**

IoT Subsystem System Control registers.

Type: [IoTSS\\_SystemControl](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.iotss\_systeminfo**

IoT Subsystem System Information registers.

Type: [IoTSS\\_SystemInfo](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.mem\_switch\_internal\_sram**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.mem\_switch\_internal\_sram\_mpc**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.mem\_switch\_ppu**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.mhu0**

IoT Subsystem Message Handling Unit.

Type: [IoTSS\\_MessageHandlingUnit](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.mhu1**

IoT Subsystem Message Handling Unit.

Type: [IoTSS\\_MessageHandlingUnit](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.nonsecure\_watchdog**

ARM Watchdog Module.

Type: [CMSDK\\_Watchdog](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.ram0\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.ram1\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.ram2\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.ram3\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.s32k\_timer**

ARM Timer Module.

Type: [CMSDK\\_Timer](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.s32k\_timer.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.s32k\_timer.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.s32k\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: MPS2\_SecureCtrl.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.secure\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.signal\_router**

Signal router.

Type: SignalRouter.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.sys\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: PPUv0.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.timer0.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.timer1**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.sse200.timer1.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.ssram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.ssram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.stub0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.stub1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.stub\_i2c1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.stub\_i2s**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.stub\_spi0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.stub\_spi2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer**

Type: [svos\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.switch\_PSRAM\_M7**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.switch\_svos\_dualltimer**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.telnetterminal0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.telnetterminal1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.telnetterminal2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.touchescreen\_interface**

MPS2 Touch Screen.

Type: MPS2\_TouchScreen.

**FVP\_MPS2\_Cortex\_M0plus.fvp\_mps2.uart\_overflows\_or\_gate**

Or Gate.

Type: [OrGate](#).

## 16.4 FVP\_MPS2\_Cortex-M23

FVP\_MPS2\_Cortex-M23 contains the following instances:

### FVP\_MPS2\_Cortex-M23 instances

**FVP\_MPS2\_Cortex\_M23**

Type: FVP\_MPS2\_Cortex\_M23.

**FVP\_MPS2\_Cortex\_M23.clk25Mhz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M23.clk25khz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M23.cpu0**

ARM CORTEXM23 CT model.

Type: ARM\_Cortex-M23.

**FVP\_MPS2\_Cortex\_M23.cpu1**

ARM CORTEXM23 CT model.

Type: ARM\_Cortex-M23.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2**

MPS2 DUT.

Type: FVP\_MPS2.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.GPIO0**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.GPIO1**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.GPIO2**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.GPIO3**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.GPIO\_connection\_test**

Type: GPIO\_Connection\_Test.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.GPIO\_connection\_test.GPIO0\_port\_trans**

Type: GPIO\_Port\_Transfer.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.GPIO\_connection\_test.GPIO1\_port\_test**

Type: GPIO1\_Connection\_Test.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.PSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.PSRAM\_M7**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.UART0**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.UART0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.UART1**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.UART1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.UART2**

ARM CMSDK UART Module.

Type: [cmsdk\\_UART](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.UART2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.VGA\_interface**

VGA display interface between main bus and visualisation.

Type: [MPS2\\_VGA](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.ahb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.ahb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.apb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.apb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.apb\_ppc\_iotss\_expansion2**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.cmsdk\_sysctrl**

Cortex-M Simple System Control.

Type: CMSDK\_SysCtrl.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.cmsdk\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.cpu\_wait\_or\_gate\_0**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.cpu\_wait\_or\_gate\_1**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dbgen\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma0**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma0\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma0\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma1**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma1.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma1.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma1.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma1.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma1\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma1\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma2**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma2.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma2.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma2.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma2.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma2\_idau\_labeller**

Type: LabellerIdauSecurity.

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma2\_securitymodifier**

Type: SecurityModifier.

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma3**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma3.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma3.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma3.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma3.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma3.idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.dma3.securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.exclusive\_monitor\_psram**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.exclusive\_monitor\_psram\_iotss**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.exclusive\_monitor\_zbtsram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.exclusive\_monitor\_zbtsram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.fpga\_sysctrl**

FPGA SysCtrl timers LEDs and switches.

Type: [FPGA\\_SysCtrl](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.fpga\_sysctrl.callBack100HzCounter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.fpga\_sysctrl.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.gpio\_0\_or\_2**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.gpio\_1\_or\_3**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mem\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mem\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mpc\_iotss\_ssram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mpc\_iotss\_ssram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mpc\_iotss\_ssram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mpc\_iotss\_ssram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mps2\_audio**

MPS2 Audio.

Type: MPS2\_Audio.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mps2\_cmsdk\_dualltimer**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mps2\_cmsdk\_dualltimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mps2\_cmsdk\_dualltimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mps2\_cmsdk\_dualltimer.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mps2\_cmsdk\_dualltimer.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mps2\_exclusive\_monitor\_zbtsram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mps2\_exclusive\_monitor\_zbtsram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mps2\_lcd**

MPS2 LCD I2C interface.

Type: MPS2\_LCD.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mps2\_mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mps2\_mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mps2\_secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: MPS2\_SecureCtrl.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mps2\_timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mps2\_timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mps2\_timer0.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mps2\_timer1**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mps2\_timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mps2\_timer1.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.mps2\_visualisation**

Display window for MPS2 using Visualisation library.

Type: MPS2\_Visualisation.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.niden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.pl022\_ssp\_mps2**

ARM PrimeCell Synchronous Serial Port(PL022).

Type: PL022\_SSP\_MPS2.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.pl022\_ssp\_mps2.prescaler**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.platform\_bus\_switch**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.platform\_switch\_dma0**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.platform\_switch\_dma1**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.signal\_router**

Signal router.

Type: [SignalRouter](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.spiden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.spniden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200**

SSE-200 subsystem.

Type: [sse200](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.acg\_cpu0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.acg\_cpu1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.acg\_sram0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.acg\_sram1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.acg\_sram2**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.acg\_sram3**

IoT Subsystem Access Control Gate.

Type: IoTSS\_AccessControlGate.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem0**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.clock32kHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.cmsdk\_dualtimer.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.cordio\_ppu**

ARM Power Policy Unit (PPU) architectural model.  
Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.cpu0core\_ppu**

ARM Power Policy Unit (PPU) architectural model.  
Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.cpu0dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.  
Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.cpu1core\_ppu**

ARM Power Policy Unit (PPU) architectural model.  
Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.cpu1dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.  
Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.crypto\_ppu**

ARM Power Policy Unit (PPU) architectural model.  
Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.  
Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram0**

Global exclusive monitor.  
Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram1**

Global exclusive monitor.  
Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram2**

Global exclusive monitor.  
Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram3**

Global exclusive monitor.  
Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.  
Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.iotss\_cpuidentity**

IoT Subsystem CPU\_IDENTITY registers.

Type: IoTSS\_CPUIdentity.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.iotss\_internal\_sram0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.iotss\_internal\_sram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.iotss\_internal\_sram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.iotss\_internal\_sram3**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.iotss\_systemcontrol**

IoT Subsystem System Control registers.

Type: [IoTSS\\_SystemControl](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.iotss\_systeminfo**

IoT Subsystem System Information registers.

Type: [IoTSS\\_SystemInfo](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.mem\_switch\_internal\_sram**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.mem\_switch\_internal\_sram\_mpc**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.mem\_switch\_ppu**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.mhu0**

IoT Subsystem Message Handling Unit.

Type: [IoTSS\\_MessageHandlingUnit](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.mhu1**

IoT Subsystem Message Handling Unit.

Type: [IoTSS\\_MessageHandlingUnit](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.nonsecure\_watchdog**

ARM Watchdog Module.

Type: [CMSDK\\_Watchdog](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.ram0\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.ram1\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.ram2\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.ram3\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.s32k\_timer**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.s32k\_timer.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.s32k\_timer.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.s32k\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: MPS2\_SecureCtrl.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.secure\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.signal\_router**

Signal router.

Type: signalRouter.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.sys\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.timer0.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.timer1**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.sse200.timer1.counter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.ssram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.ssram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.stub0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.stub1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.stub\_i2c1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.stub\_i2s**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.stub\_spi0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.stub\_spi2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualtimer**

Type: [svos\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.switch\_PSRAM\_M7**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

#### **FVP\_MPS2\_Cortex\_M23.fvp\_mps2.switch\_svos\_dualltimer**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.telnetterminal0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.telnetterminal1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.telnetterminal2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2.touchscreen\_interface**

MPS2 Touch Screen.

Type: [MPS2\\_TouchScreen](#).

**FVP\_MPS2\_Cortex\_M23.fvp\_mps2 uart\_overflows\_or\_gate**

Or Gate.

Type: [OrGate](#).

## 16.5 FVP\_MPS2\_Cortex-M3

FVP\_MPS2\_Cortex-M3 contains the following instances:

### FVP\_MPS2\_Cortex-M3 instances

**FVP\_MPS2\_Cortex\_M3**

Type: [FVP\\_MPS2\\_Cortex\\_M3](#).

**FVP\_MPS2\_Cortex\_M3.armcortexm3ct**

ARM CORTEXM3 CT model.

Type: [ARM\\_Cortex-M3](#).

**FVP\_MPS2\_Cortex\_M3.clk25Mhz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.clk25khz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2**

MPS2 DUT.

Type: [FVP\\_MPS2](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.GPIO00**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.GPIO01**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.GPIO02**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.GPIO03**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.GPIO\_connection\_test**

Type: GPIO\_Connection\_Test.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.GPIO\_connection\_test.GPIO00\_port\_trans**

Type: GPIO\_Port\_Transfer.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.GPIO\_connection\_test.GPIO1\_port\_test**

Type: GPIO1\_Connection\_Test.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.PSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.PSRAM\_M7**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.UART0**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.UART0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.UART1**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.UART1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.UART2**

ARM CMSDK UART Module.

Type: [cmsdk\\_UART](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.UART2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.VGA\_interface**

VGA display interface between main bus and visualisation.

Type: [MPS2\\_VGA](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.ahb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.ahb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.apb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.apb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.apb\_ppc\_iotss\_expansion2**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.cmsdk\_sysctrl**

Cortex-M Simple System Control.

Type: CMSDK\_SysCtrl.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.cmsdk\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.cpu\_wait\_or\_gate\_0**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.cpu\_wait\_or\_gate\_1**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dbgen\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma0**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma0.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma0\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma0\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma1**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma1.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma1.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma1.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma1.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma1\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma1\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma2**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma2.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma2.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma2.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma2.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

#### **FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma2\_idau\_labeller**

Type: LabellerIdauSecurity.

#### **FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma2\_securitymodifier**

Type: SecurityModifier.

#### **FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma3**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

#### **FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma3.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma3.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma3.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma3.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma3.idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.dma3.securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.exclusive\_monitor\_psram**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.exclusive\_monitor\_psram\_iotss**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.exclusive\_monitor\_zbtsram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.exclusive\_monitor\_zbtsram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.fpga\_sysctrl**

FPGA SysCtrl timers LEDs and switches.

Type: [FPGA\\_SysCtrl](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.fpga\_sysctrl.callBack100HzCounter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.fpga\_sysctrl.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.gpio\_0\_or\_2**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.gpio\_1\_or\_3**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mem\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mem\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mpc\_iotss\_ssram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mpc\_iotss\_ssram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mpc\_iotss\_ssram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mpc\_iotss\_ssram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mps2\_audio**

MPS2 Audio.

Type: MPS2\_Audio.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mps2\_cmsdk\_dualltimer**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mps2\_cmsdk\_dualltimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mps2\_cmsdk\_dualltimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mps2\_cmsdk\_dualltimer.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mps2\_cmsdk\_dualltimer.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mps2\_exclusive\_monitor\_zbtssram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mps2\_exclusive\_monitor\_zbtssram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mps2\_lcd**

MPS2 LCD I2C interface.

Type: MPS2\_LCD.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mps2\_mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mps2\_mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mps2\_secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: MPS2\_SecureCtrl.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mps2\_timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mps2\_timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mps2\_timer0.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mps2\_timer1**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mps2\_timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mps2\_timer1.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.mps2\_visualisation**

Display window for MPS2 using Visualisation library.

Type: MPS2\_Visualisation.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.niden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.p1022\_ssp\_mps2**

ARM PrimeCell Synchronous Serial Port(PL022).

Type: PL022\_SSP\_MPS2.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.p1022\_ssp\_mps2.prescaler**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.platform\_bus\_switch**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.platform\_switch\_dma0**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.platform\_switch\_dma1**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.signal\_router**

Signal router.

Type: [SignalRouter](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.spiden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.spniden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200**

SSE-200 subsystem.

Type: [sse200](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.acg\_cpu0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.acg\_cpu1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.acg\_sram0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.acg\_sram1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.acg\_sram2**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.acg\_sram3**

IoT Subsystem Access Control Gate.

Type: IoTSS\_AccessControlGate.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem0**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.clock32kHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.cmsdk\_dualtimer.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.cordio\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.cpu0core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.cpu0dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.cpu1core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.cpu1dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.crypto\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram0**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram3**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.iotss\_cpidentity**

IoT Subsystem CPU\_IDENTITY registers.

Type: `IoTSS_CPUIdentity`.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.iotss\_internal\_sram0**

RAM device, can be dynamic or static ram.

Type: `RAMDevice`.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.iotss\_internal\_sram1**

RAM device, can be dynamic or static ram.

Type: `RAMDevice`.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.iotss\_internal\_sram2**

RAM device, can be dynamic or static ram.

Type: `RAMDevice`.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.iotss\_internal\_sram3**

RAM device, can be dynamic or static ram.

Type: `RAMDevice`.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.iotss\_systemcontrol**

IoT Subsystem System Control registers.

Type: `IoTSS_SystemControl`.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.iotss\_systeminfo**

IoT Subsystem System Information registers.

Type: `IoTSS_SystemInfo`.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.mem\_switch\_internal\_sram**

Allow transactions to be routed arbitrarily.

Type: `PVBusRouter`.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.mem\_switch\_internal\_sram\_mpc**

Allow transactions to be routed arbitrarily.

Type: `PVBusRouter`.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.mem\_switch\_ppu**

Allow transactions to be routed arbitrarily.

Type: `PVBusRouter`.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.mhu0**

IoT Subsystem Message Handling Unit.

Type: `IoTSS_MessageHandlingUnit`.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.mhu1**

IoT Subsystem Message Handling Unit.

Type: `IoTSS_MessageHandlingUnit`.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0**

IoT Subsystem Memory Protection Controller.

Type: `IoTSS_MemoryProtectionController`.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: `SchedulerThreadEvent`.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.nonsecure\_watchdog**

ARM Watchdog Module.

Type: [CMSDK\\_Watchdog](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.ram0\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.ram1\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.ram2\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.ram3\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.s32k\_timer**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.s32k\_timer.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.s32k\_timer.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.s32k\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: MPS2\_SecureCtrl.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.secure\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.signal\_router**

Signal router.

Type: signalRouter.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.sys\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.timer0.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.timer1**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sse200.timer1.counter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.sram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.stub0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.stub1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.stub\_i2c1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.stub\_i2s**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.stub\_spi0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.stub\_spi2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer**

Type: [svos\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.switch\_PSRAM\_M7**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.switch\_svos\_dualltimer**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.telnetterminal10**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.telnetterminal11**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.telnetterminal12**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.touchscreen\_interface**

MPS2 Touch Screen.

Type: [MPS2\\_TouchScreen](#).

**FVP\_MPS2\_Cortex\_M3.fvp\_mps2.uart\_overflows\_or\_gate**

Or Gate.

Type: [OrGate](#).

## 16.6 FVP\_MPS2\_Cortex-M33

FVP\_MPS2\_Cortex-M33 contains the following instances:

### FVP\_MPS2\_Cortex-M33 instances

**FVP\_MPS2\_Cortex\_M33**

Type: [FVP\\_MPS2\\_Cortex\\_M33](#).

**FVP\_MPS2\_Cortex\_M33.clk25Mhz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.clk25khz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.cpu0**

ARM CORTEXM33 CT model.

Type: [ARM\\_Cortex-M33](#).

**FVP\_MPS2\_Cortex\_M33.cpu1**

ARM CORTEXM33 CT model.

Type: [ARM\\_Cortex-M33](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2**

MPS2 DUT.

Type: FVP\_MPS2.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.GPIO00**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.GPIO1**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.GPIO2**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.GPIO3**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.GPIO\_connection\_test**

Type: GPIO\_Connection\_Test.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.GPIO\_connection\_test.GPIO00\_port\_trans**

Type: GPIO\_Port\_Transfer.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.GPIO\_connection\_test.GPIO1\_port\_test**

Type: GPIO1\_Connection\_Test.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.PSRAM**

RAM device, can be dynamic or static ram.

Type: RAMDevice.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.PSRAM\_M7**

RAM device, can be dynamic or static ram.

Type: RAMDevice.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.UART0**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.UART0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: ClockDivider.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.UART1**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.UART1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.UART2**

ARM CMSDK UART Module.

Type: [CMSDK\\_UART](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.UART2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.VGA\_interface**

VGA display interface between main bus and visualisation.

Type: [MPS2\\_VGA](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.ahb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.ahb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.apb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.apb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.apb\_ppc\_iotss\_expansion2**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.cmsdk\_sysctrl**

Cortex-M Simple System Control.

Type: CMSDK\_SysCtrl.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.cmsdk\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.cpu\_wait\_or\_gate\_0**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.cpu\_wait\_or\_gate\_1**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dbgen\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma0**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma0.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma0\_idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma0\_securitymodifier**

Type: [SecurityModifier](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma1**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma1.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma1.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma1.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma1.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma1\_idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma1\_securitymodifier**

Type: [SecurityModifier](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma2**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma2.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma2.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma2.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma2.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma2\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma2\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma3**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma3.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma3.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a

proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma3.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma3.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma3\_idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.dma3\_securitymodifier**

Type: [SecurityModifier](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.exclusive\_monitor\_psram**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.exclusive\_monitor\_psram\_iotss**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.exclusive\_monitor\_zbtsram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.exclusive\_monitor\_zbtsram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.fpga\_sysctrl**

FPGA SysCtrl timers LEDs and switches.

Type: [FPGA\\_SysCtrl](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.fpga\_sysctrl.callback100HzCounter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.fpga\_sysctrl.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.gpio\_0\_or\_2**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.gpio\_1\_or\_3**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mem\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mem\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mpc\_iotss\_ssram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mpc\_iotss\_ssram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mpc\_iotss\_ssram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mpc\_iotss\_ssram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mps2\_audio**

MPS2 Audio.

Type: [MPS2\\_Audio](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mps2\_cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mps2\_exclusive\_monitor\_zbtsram1**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mps2\_exclusive\_monitor\_zbtsram2**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mps2\_lcd**

MPS2 LCD I2C interface.

Type: [MPS2\\_LCD](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mps2\_mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mps2\_mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mps2\_secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: [MPS2\\_SecureCtrl](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mps2\_timer0**

ARM Timer Module.

Type: [CMSDK\\_Timer](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mps2\_timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mps2\_timer0.counter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mps2\_timer1**

ARM Timer Module.

Type: [CMSDK\\_Timer](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mps2\_timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mps2\_timer1.counter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.mps2\_visualisation**

Display window for MPS2 using Visualisation library.

Type: [MPS2\\_Visualisation](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.niden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.p1022\_ssp\_mps2**

ARM PrimeCell Synchronous Serial Port(PLO22).

Type: [PL022\\_SSP\\_MPS2](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.pl022\_ssp\_mps2.prescaler**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.platform\_bus\_switch**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.platform\_switch\_dma0**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.platform\_switch\_dma1**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.signal\_router**

Signal router.

Type: [SignalRouter](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.spiden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.spniden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200**

SSE-200 subsystem.

Type: [sse200](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.acg\_cpu0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.acg\_cpu1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.acg\_sram0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.acg\_sram1**

IoT Subsystem Access Control Gate.

Type: IoTSS\_AccessControlGate.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.acg\_sram2**

IoT Subsystem Access Control Gate.

Type: IoTSS\_AccessControlGate.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.acg\_sram3**

IoT Subsystem Access Control Gate.

Type: IoTSS\_AccessControlGate.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem0**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.clock32kHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.cmsdk\_dualltimer.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.cmsdk\_dualltimer.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.cordio\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.cpu0core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.cpu0dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.cpu1core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.cpu1dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.crypto\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.debug\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram0**

Global exclusive monitor.

Type: [PVBuseExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram1**

Global exclusive monitor.

Type: [PVBuseExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram2**

Global exclusive monitor.

Type: [PVBuseExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram3**

Global exclusive monitor.

Type: [PVBuseExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.iotss\_cpuidentity**

IoT Subsystem CPU\_IDENTITY registers.

Type: [IoTSS\\_CPUIdentity](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.iotss\_internal\_sram0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.iotss\_internal\_sram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.iotss\_internal\_sram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.iotss\_internal\_sram3**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.iotss\_systemcontrol**

IoT Subsystem System Control registers.

Type: [IoTSS\\_SystemControl](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.iotss\_systeminfo**

IoT Subsystem System Information registers.

Type: [IoTSS\\_SystemInfo](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.mem\_switch\_internal\_sram**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.mem\_switch\_internal\_sram\_mpc**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.mem\_switch\_ppu**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.mhu0**

IoT Subsystem Message Handling Unit.

Type: [IoTSS\\_MessageHandlingUnit](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.mhu1**

IoT Subsystem Message Handling Unit.

Type: IoTSS\_MessageHandlingUnit.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: SchedulerThreadEvent.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: SchedulerThreadEvent.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: SchedulerThreadEvent.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: SchedulerThreadEvent.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.nmi\_or\_gate**

Or Gate.

Type: OrGate.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.nonsecure\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.ram0\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: PPUv0.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.ram1\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: PPUv0.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.ram2\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.ram3\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.s32k\_timer**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.s32k\_timer.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.s32k\_timer.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.s32k\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: MPS2\_SecureCtrl.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.secure\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.signal\_router**

Signal router.

Type: SignalRouter.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.sys\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.timer0.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.timer1**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.sse200.timer1.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.ssram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.ssram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.stub0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.stub1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.stub\_i2c1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.stub\_i2s**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.stub\_spi0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.stub\_spi2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer**

Type: svos\_DualTimer.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.switch\_PSRAM\_M7**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.switch\_svos\_dualltimer**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.telnetterminal0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.telnetterminal1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.telnetterminal2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2.touchscreen\_interface**

MPS2 Touch Screen.

Type: [MPS2\\_TouchScreen](#).

**FVP\_MPS2\_Cortex\_M33.fvp\_mps2 uart\_overflows\_or\_gate**

Or Gate.

Type: [OrGate](#).

## 16.7 FVP\_MPS2\_Cortex-M35P

FVP\_MPS2\_Cortex-M35P contains the following instances:

### FVP\_MPS2\_Cortex-M35P instances

**FVP\_MPS2\_Cortex\_M35P**

Type: [FVP\\_MPS2\\_Cortex\\_M35P](#).

**FVP\_MPS2\_Cortex\_M35P.clk25Mhz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.clk25khz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.cpu0**

ARM CORTEXM35P CT model.

Type: ARM\_Cortex-M35P.

**FVP\_MPS2\_Cortex\_M35P.cpu1**

ARM CORTEXM35P CT model.

Type: ARM\_Cortex-M35P.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2**

MPS2 DUT.

Type: FVP\_MPS2.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.GPIO0**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.GPIO1**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.GPIO2**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.GPIO3**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.GPIO\_connection\_test**

Type: GPIO\_Connection\_Test.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.GPIO\_connection\_test.GPIO0\_port\_trans**

Type: GPIO\_Port\_Transfer.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.GPIO\_connection\_test.GPIO1\_port\_test**

Type: GPIO1\_Connection\_Test.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.PSRAM**

RAM device, can be dynamic or static ram.

Type: RAMDevice.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.PSRAM\_M7**

RAM device, can be dynamic or static ram.

Type: RAMDevice.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.UART0**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.UART0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.UART1**

ARM CMSDK UART Module.

Type: [CMSDK\\_UART](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.UART1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.UART2**

ARM CMSDK UART Module.

Type: [CMSDK\\_UART](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.UART2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.VGA\_interface**

VGA display interface between main bus and visualisation.

Type: [MPS2\\_VGA](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.ahb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.ahb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.apb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.apb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.apb\_ppc\_iotss\_expansion2**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.cmsdk\_sysctrl**

Cortex-M Simple System Control.

Type: CMSDK\_SysCtrl.

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.cmsdk\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.cpu\_wait\_or\_gate\_0**

Or Gate.

Type: [OrGate](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.cpu\_wait\_or\_gate\_1**

Or Gate.

Type: [OrGate](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dbgen\_or\_gate**

Or Gate.

Type: [OrGate](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma0**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma0.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma0\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma0\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma1**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma1.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma1.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma1.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma1.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma1\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma1\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma2**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma2.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma2.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma2.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma2.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma2\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma2\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma3**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma3.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma3.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma3.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma3.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma3\_idau\_labeller**

Type: LabellerIdauSecurity.

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.dma3\_securitymodifier**

Type: SecurityModifier.

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.exclusive\_monitor\_psram**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.exclusive\_monitor\_psram\_iotss**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.exclusive\_monitor\_zbtsram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.exclusive\_monitor\_zbtsram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.fpga\_sysctrl**

FPGA SysCtrl timers LEDs and switches.

Type: [FPGA\\_SysCtrl](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.fpga\_sysctrl.callBack100HzCounter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.fpga\_sysctrl.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.gpio\_0\_or\_2**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.gpio\_1\_or\_3**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mem\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mem\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mpc\_iotss\_ssram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mpc\_iotss\_ssram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mpc\_iotss\_ssram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mpc\_iotss\_ssram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mps2\_audio**

MPS2 Audio.

Type: [MPS2\\_Audio](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mps2\_cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mps2\_exclusive\_monitor\_zbtsram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mps2\_exclusive\_monitor\_zbtsram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mps2\_lcd**

MPS2 LCD I2C interface.

Type: MPS2\_LCD.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mps2\_mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mps2\_mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: SchedulerThreadEvent.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mps2\_secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: MPS2\_SecureCtrl.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mps2\_timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mps2\_timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: ClockDivider.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mps2\_timer0.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mps2\_timer1**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mps2\_timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: ClockDivider.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mps2\_timer1.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.mps2\_visualisation**

Display window for MPS2 using Visualisation library.

Type: MPS2\_Visualisation.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.niden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.p1022\_ssp\_mps2**

ARM PrimeCell Synchronous Serial Port(PLO22).

Type: [PL022\\_SSP\\_MPS2](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.p1022\_ssp\_mps2.prescaler**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.platform\_bus\_switch**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.platform\_switch\_dma0**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.platform\_switch\_dma1**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.signal\_router**

Signal router.

Type: [SignalRouter](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.spiden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.spniden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200**

SSE-200 subsystem.

Type: [SSE200](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.acg\_cpu0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.acg\_cpu1**

IoT Subsystem Access Control Gate.

Type: IoTSS\_AccessControlGate.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.acg\_sram0**

IoT Subsystem Access Control Gate.

Type: IoTSS\_AccessControlGate.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.acg\_sram1**

IoT Subsystem Access Control Gate.

Type: IoTSS\_AccessControlGate.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.acg\_sram2**

IoT Subsystem Access Control Gate.

Type: IoTSS\_AccessControlGate.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.acg\_sram3**

IoT Subsystem Access Control Gate.

Type: IoTSS\_AccessControlGate.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem0**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.clock32kHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.cmsdk\_dualtimer.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.cordio\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.cpu0core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.cpu0dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.cpu1core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.cpu1dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.crypto\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram0**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram3**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.iotss\_cpuidentity**

IoT Subsystem CPU\_IDENTITY registers.

Type: [IoTSS\\_CPUIdentity](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.iotss\_internal\_sram0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.iotss\_internal\_sram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.iotss\_internal\_sram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.iotss\_internal\_sram3**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.iotss\_systemcontrol**

IoT Subsystem System Control registers.

Type: [IoTSS\\_SystemControl](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.iotss\_systeminfo**

IoT Subsystem System Information registers.

Type: [IoTSS\\_SystemInfo](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.mem\_switch\_internal\_sram**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.mem\_switch\_internal\_sram\_mpc**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.mem\_switch\_ppu**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.mhu0**

IoT Subsystem Message Handling Unit.

Type: IoTSS\_MessageHandlingUnit.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.mhu1**

IoT Subsystem Message Handling Unit.

Type: IoTSS\_MessageHandlingUnit.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.nonsecure\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.ram0\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.ram1\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.ram2\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.ram3\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.s32k\_timer**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.s32k\_timer.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.s32k\_timer.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.s32k\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: MPS2\_SecureCtrl.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.secure\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.signal\_router**

Signal router.

Type: SignalRouter.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.sys\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.timer0.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.timer1**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.sse200.timer1.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.ssram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.ssram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.stub0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.stub1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.stub\_i2c1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.stub\_i2s**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.stub\_spi0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.stub\_spi2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer**

Type: svos\_DualTimer.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.switch\_PSRAM\_M7**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.switch\_svos\_dualltimer**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.telnetterminal0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.telnetterminal1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.telnetterminal2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2.touchscreen\_interface**

MPS2 Touch Screen.

Type: MPS2\_TouchScreen.

#### **FVP\_MPS2\_Cortex\_M35P.fvp\_mps2 uart\_overflows\_or\_gate**

Or Gate.

Type: [OrGate](#).

## 16.8 FVP\_MPS2\_Cortex-M4

FVP\_MPS2\_Cortex-M4 contains the following instances:

### **FVP\_MPS2\_Cortex-M4 instances**

#### **FVP\_MPS2\_Cortex\_M4**

Type: [FVP\\_MPS2\\_Cortex\\_M4](#).

#### **FVP\_MPS2\_Cortex\_M4.armcortexm4ct**

ARM CORTEXM4 CT model.

Type: ARM\_Cortex-M4.

**FVP\_MPS2\_Cortex\_M4.clk25Mhz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.clk25khz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2**

MPS2 DUT.

Type: FVP\_MPS2.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.GPIO00**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.GPIO01**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.GPIO02**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.GPIO03**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.GPIO\_connection\_test**

Type: GPIO\_Connection\_Test.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.GPIO\_connection\_test.GPIO00\_port\_trans**

Type: GPIO\_Port\_Transfer.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.GPIO\_connection\_test.GPIO1\_port\_test**

Type: GPIO1\_Connection\_Test.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.PSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.PSRAM\_M7**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.UART0**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.UART0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.UART1**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.UART1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.UART2**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.UART2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.VGA\_interface**

VGA display interface between main bus and visualisation.

Type: MPS2\_VGA.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.ahb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.ahb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.apb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.apb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.apb\_ppc\_iotss\_expansion2**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.cmsdk\_sysctrl**

Cortex-M Simple System Control.

Type: [CMSDK\\_SysCtrl](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.cmsdk\_watchdog**

ARM Watchdog Module.

Type: [CMSDK\\_Watchdog](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.cpu\_wait\_or\_gate\_0**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.cpu\_wait\_or\_gate\_1**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dbgeng\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma0**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma0\_idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma0\_securitymodifier**

Type: [SecurityModifier](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma1**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma1.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma1.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma1.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma1.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma1.idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma1.securitymodifier**

Type: [SecurityModifier](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma2**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma2.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma2.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma2.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma2.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma2.idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma2.securitymodifier**

Type: [SecurityModifier](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma3**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma3.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma3.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma3.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma3.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma3.idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.dma3.securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.exclusive\_monitor\_psram**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.exclusive\_monitor\_psram\_iotss**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.exclusive\_monitor\_zbtssram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.exclusive\_monitor\_zbtsram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.fpga\_sysctrl**

FPGA SysCtrl timers LEDs and switches.

Type: [FPGA\\_SysCtrl](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.fpga\_sysctrl.callBack100HzCounter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.fpga\_sysctrl.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.gpio\_0\_or\_2**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.gpio\_1\_or\_3**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mem\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mem\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mpc\_iotss\_ssram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mpc\_iotss\_ssram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mpc\_iotss\_ssram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mpc\_iotss\_ssram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mps2\_audio**

MPS2 Audio.

Type: [MPS2\\_Audio](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mps2\_cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mps2\_exclusive\_monitor\_zbtssram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mps2\_exclusive\_monitor\_zbtssram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mps2\_lcd**

MPS2 LCD I2C interface.

Type: [MPS2\\_LCD](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mps2\_mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mps2\_mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mps2\_secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: [MPS2\\_SecureCtrl](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mps2\_timer0**

ARM Timer Module.

Type: [CMSDK\\_Timer](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mps2\_timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mps2\_timer0.counter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mps2\_timer1**

ARM Timer Module.

Type: [CMSDK\\_Timer](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mps2\_timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mps2\_timer1.counter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.mps2\_visualisation**

Display window for MPS2 using Visualisation library.

Type: MPS2\_Visualisation.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.niden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.p1022\_ssp\_mps2**

ARM PrimeCell Synchronous Serial Port(PL022).

Type: [PL022\\_SSP\\_MPS2](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.p1022\_ssp\_mps2.prescaler**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.platform\_bus\_switch**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.platform\_switch\_dma0**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.platform\_switch\_dmal**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.signal\_router**

Signal router.

Type: [SignalRouter](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.spiden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.spniden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200**

SSE-200 subsystem.

Type: [sse200](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.acg\_cpu0**

IoT Subsystem Access Control Gate.

Type: IoTSS\_AccessControlGate.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.acg\_cpu1**

IoT Subsystem Access Control Gate.

Type: IoTSS\_AccessControlGate.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.acg\_sram0**

IoT Subsystem Access Control Gate.

Type: IoTSS\_AccessControlGate.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.acg\_sram1**

IoT Subsystem Access Control Gate.

Type: IoTSS\_AccessControlGate.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.acg\_sram2**

IoT Subsystem Access Control Gate.

Type: IoTSS\_AccessControlGate.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.acg\_sram3**

IoT Subsystem Access Control Gate.

Type: IoTSS\_AccessControlGate.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem0**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.clock32kHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.cmsdk\_dualtimer.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.cordio\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.cpu0core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.cpu0dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.cpu1core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.cpu1dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.crypto\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.debug\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram0**

Global exclusive monitor.

Type: [PVBuseExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram3**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.iotss\_cpuidentity**

IoT Subsystem CPU\_IDENTITY registers.

Type: [IoTSS\\_CPUIdentity](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.iotss\_internal\_sram0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.iotss\_internal\_sram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.iotss\_internal\_sram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.iotss\_internal\_sram3**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.iotss\_systemcontrol**

IoT Subsystem System Control registers.

Type: [IoTSS\\_SystemControl](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.iotss\_systeminfo**

IoT Subsystem System Information registers.

Type: [IoTSS\\_SystemInfo](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.mem\_switch\_internal\_sram**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.mem\_switch\_internal\_sram\_mpc**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.mem\_switch\_ppu**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.mhu0**

IoT Subsystem Message Handling Unit.

Type: [IoTSS\\_MessageHandlingUnit](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.mhu1**

IoT Subsystem Message Handling Unit.

Type: [IoTSS\\_MessageHandlingUnit](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.nonsecure\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.ram0\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.ram1\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.ram2\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.ram3\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.s32k\_timer**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.s32k\_timer.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.s32k\_timer.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.s32k\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: MPS2\_SecureCtrl.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.secure\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.signal\_router**

Signal router.

Type: SignalRouter.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.sys\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.timer0**

ARM Timer Module.

Type: [CMSDK\\_Timer](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.timer0.counter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.timer1**

ARM Timer Module.

Type: [CMSDK\\_Timer](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.sse200.timer1.counter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.ssram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.ssram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.stub0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.stub1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.stub\_i2c1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.stub\_i2s**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.stub\_spi0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.stub\_spi2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualtimer**

Type: [svos\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualtimer.svos\_dualtimer1**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualtimer.svos\_dualtimer1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.switch\_PSRAM\_M7**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.switch\_svos\_dualltimer**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.telnetterminal10**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.telnetterminal11**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.telnetterminal12**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2.touchscreen\_interface**

MPS2 Touch Screen.

Type: [MPS2\\_TouchScreen](#).

**FVP\_MPS2\_Cortex\_M4.fvp\_mps2 uart\_overflows\_or\_gate**

Or Gate.

Type: [OrGate](#).

## 16.9 FVP\_MPS2\_Cortex-M55

FVP\_MPS2\_Cortex-M55 contains the following instances:

### FVP\_MPS2\_Cortex-M55 instances

**FVP\_MPS2\_Cortex\_M55**

Type: [FVP\\_MPS2\\_Cortex\\_M55](#).

Copyright © 2017–2022 Arm Limited (or its affiliates). All rights reserved.

Non-Confidential

**FVP\_MPS2\_Cortex\_M55.clk25Mhz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.clk25khz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.core0\_bus\_gasket**

writes are ignored, non-word reads abort, and word reads take values from that fifo.

Type: [STLBusGasket](#).

**FVP\_MPS2\_Cortex\_M55.cpu0**

ARM Cortex-M55 CT model.

Type: [ARM\\_Cortex-M55](#).

**FVP\_MPS2\_Cortex\_M55.cpu1**

ARM Cortex-M55 CT model.

Type: [ARM\\_Cortex-M55](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2**

MPS2 DUT.

Type: [FVP\\_MPS2](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.GPIO0**

ARM PrimeCell General Purpose Input/Output.

Type: [CMSDK\\_GPIO](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.GPIO1**

ARM PrimeCell General Purpose Input/Output.

Type: [CMSDK\\_GPIO](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.GPIO2**

ARM PrimeCell General Purpose Input/Output.

Type: [CMSDK\\_GPIO](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.GPIO3**

ARM PrimeCell General Purpose Input/Output.

Type: [CMSDK\\_GPIO](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.GPIO\_connection\_test**

Type: [GPIO\\_Connection\\_Test](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.GPIO\_connection\_test.GPIO0\_port\_trans**

Type: [GPIO\\_Port\\_Transfer](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.GPIO\_connection\_test.GPIO1\_port\_test**

Type: [GPIO1\\_Connection\\_Test](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.PSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.PSRAM\_M7**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.UART0**

ARM CMSDK UART Module.

Type: [CMSDK\\_UART](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.UART0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.UART1**

ARM CMSDK UART Module.

Type: [CMSDK\\_UART](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.UART1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.UART2**

ARM CMSDK UART Module.

Type: [CMSDK\\_UART](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.UART2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.VGA\_interface**

VGA display interface between main bus and visualisation.

Type: [MPS2\\_VGA](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.ahb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.ahb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.apb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.apb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.apb\_ppc\_iotss\_expansion2**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.cmsdk\_sysctrl**

Cortex-M Simple System Control.

Type: CMSDK\_SysCtrl.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.cmsdk\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.cpu\_wait\_or\_gate\_0**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.cpu\_wait\_or\_gate\_1**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dbgen\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma0**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAM](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma0\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma0\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma1**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma1.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma1.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a

proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma1.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma1.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma1\_idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma1\_securitymodifier**

Type: [SecurityModifier](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma2**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma2.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma2.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma2.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma2.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma2\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma2\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma3**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma3.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma3.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma3.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma3.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma3\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.dma3\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.exclusive\_monitor\_psram**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.exclusive\_monitor\_psram\_iotss**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.exclusive\_monitor\_zbtsram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.exclusive\_monitor\_zbtsram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.fpga\_sysctrl**

FPGA SysCtrl timers LEDs and switches.

Type: [FPGA\\_SysCtrl](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.fpga\_sysctrl.callBack100HzCounter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.fpga\_sysctrl.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.gpio\_0\_or\_2**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.gpio\_1\_or\_3**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mem\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mem\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mpc\_iotss\_ssram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mpc\_iotss\_ssram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mpc\_iotss\_ssram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mpc\_iotss\_ssram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mps2\_audio**

MPS2 Audio.

Type: [MPS2\\_Audio](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mps2\_cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mps2\_exclusive\_monitor\_zbtsram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mps2\_exclusive\_monitor\_zbtsram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mps2\_lcd**

MPS2 LCD I2C interface.

Type: [MPS2\\_LCD](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mps2\_mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mps2\_mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mps2\_secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: [MPS2\\_SecureCtrl](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mps2\_timer0**

ARM Timer Module.

Type: [CMSDK\\_Timer](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mps2\_timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mps2\_timer0.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mps2\_timer1**

ARM Timer Module.

Type: [CMSDK\\_Timer](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mps2\_timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mps2\_timer1.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.mps2\_visualisation**

Display window for MPS2 using Visualisation library.

Type: MPS2\_Visualisation.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.niden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.pl022\_ssp\_mps2**

ARM PrimeCell Synchronous Serial Port(PL022).

Type: PL022\_SSP\_MPS2.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.pl022\_ssp\_mps2.prescaler**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.platform\_bus\_switch**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.platform\_switch\_dma0**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.platform\_switch\_dma1**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.signal\_router**

Signal router.

Type: SignalRouter.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.spiden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.spniden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200**

SSE-200 subsystem.

Type: sse200.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.acg\_cpu0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.acg\_cpu1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.acg\_sram0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.acg\_sram1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.acg\_sram2**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.acg\_sram3**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem0**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem1**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.clock32kHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.cmsdk\_dualltimer**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.cmsdk\_dualltimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.cmsdk\_dualltimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.cmsdk\_dualltimer.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.cmsdk\_dualltimer.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.cordio\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.cpu0core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.cpu0dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.cpu1core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.cpu1dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.crypto\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram0**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram3**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.iotss\_cpuidentity**

IoT Subsystem CPU\_IDENTITY registers.

Type: [IoTSS\\_CPUIdentity](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.iotss\_internal\_sram0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.iotss\_internal\_sram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.iotss\_internal\_sram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.iotss\_internal\_sram3**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.iotss\_systemcontrol**

IoT Subsystem System Control registers.

Type: [IoTSS\\_SystemControl](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.iotss\_systeminfo**

IoT Subsystem System Information registers.

Type: IoTSS\_SystemInfo.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.mem\_switch\_internal\_sram**

Allow transactions to be routed arbitrarily.

Type: PVBusRouter.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.mem\_switch\_internal\_sram\_mpc**

Allow transactions to be routed arbitrarily.

Type: PVBusRouter.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.mem\_switch\_ppu**

Allow transactions to be routed arbitrarily.

Type: PVBusRouter.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.mhu0**

IoT Subsystem Message Handling Unit.

Type: IoTSS\_MessageHandlingUnit.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.mhu1**

IoT Subsystem Message Handling Unit.

Type: IoTSS\_MessageHandlingUnit.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: SchedulerThreadEvent.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: SchedulerThreadEvent.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: SchedulerThreadEvent.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.nonsecure\_watchdog**

ARM Watchdog Module.

Type: [CMSDK\\_Watchdog](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.ram0\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.ram1\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.ram2\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.ram3\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.s32k\_timer**

ARM Timer Module.

Type: [CMSDK\\_Timer](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.s32k\_timer.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.s32k\_timer.counter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.s32k\_watchdog**

ARM Watchdog Module.

Type: [CMSDK\\_Watchdog](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: [MPS2\\_SecureCtrl](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.secure\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.signal\_router**

Signal router.

Type: SignalRouter.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.sys\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: PPUv0.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.timer0.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.timer1**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.sse200.timer1.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.ssram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.ssram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.stub0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.stub1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.stub\_i2c1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.stub\_i2s**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.stub\_spi0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.stub\_spi2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualtimer**

Type: [svos\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualtimer.svos\_dualtimer1**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.switch\_PSRAM\_M7**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.switch\_svos\_dualltimer**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.telnetterminal0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.telnetterminal1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.telnetterminal2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2.touchscreen\_interface**

MPS2 Touch Screen.

Type: [MPS2\\_TouchScreen](#).

**FVP\_MPS2\_Cortex\_M55.fvp\_mps2 uart\_overflows\_or\_gate**

Or Gate.

Type: [OrGate](#).

## 16.10 FVP\_MPS2\_Cortex-M7

FVP\_MPS2\_Cortex-M7 contains the following instances:

### FVP\_MPS2\_Cortex-M7 instances

#### **FVP\_MPS2\_Cortex\_M7**

Type: FVP\_MPS2\_Cortex\_M7.

#### **FVP\_MPS2\_Cortex\_M7.armcortexm7ct**

ARM CORTEXM7 CT model.

Type: ARM\_Cortex-M7.

#### **FVP\_MPS2\_Cortex\_M7.clk25Mhz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_Cortex\_M7.clk25khz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_Cortex\_M7.fvp\_mps2**

MPS2 DUT.

Type: FVP\_MPS2.

#### **FVP\_MPS2\_Cortex\_M7.fvp\_mps2.GPIO0**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

#### **FVP\_MPS2\_Cortex\_M7.fvp\_mps2.GPIO1**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

#### **FVP\_MPS2\_Cortex\_M7.fvp\_mps2.GPIO2**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

#### **FVP\_MPS2\_Cortex\_M7.fvp\_mps2.GPIO3**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

#### **FVP\_MPS2\_Cortex\_M7.fvp\_mps2.GPIO\_connection\_test**

Type: GPIO\_Connection\_Test.

#### **FVP\_MPS2\_Cortex\_M7.fvp\_mps2.GPIO\_connection\_test.GPIO0\_port\_trans**

Type: GPIO\_Port\_Transfer.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.GPIO\_connection\_test.GPIO1\_port\_test**

Type: [GPIO1\\_Connection\\_Test](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.PSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.PSRAM\_M7**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.UART0**

ARM CMSDK UART Module.

Type: [CMSDK\\_UART](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.UART0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.UART1**

ARM CMSDK UART Module.

Type: [CMSDK\\_UART](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.UART1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.UART2**

ARM CMSDK UART Module.

Type: [CMSDK\\_UART](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.UART2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.VGA\_interface**

VGA display interface between main bus and visualisation.

Type: [MPS2\\_VGA](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.ahb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.ahb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.apb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.apb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.apb\_ppc\_iotss\_expansion2**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.cmsdk\_sysctrl**

Cortex-M Simple System Control.

Type: CMSDK\_SysCtrl.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.cmsdk\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.cpu\_wait\_or\_gate\_0**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.cpu\_wait\_or\_gate\_1**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dbgen\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma0**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAM](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma0\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma0\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma1**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma1.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma1.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a

proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma1.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma1.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma1\_idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma1\_securitymodifier**

Type: [SecurityModifier](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma2**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma2.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma2.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma2.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma2.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma2\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma2\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma3**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma3.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma3.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma3.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma3.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma3\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.dma3\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.exclusive\_monitor\_psram**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.exclusive\_monitor\_psram\_iotss**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.exclusive\_monitor\_zbtsram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.exclusive\_monitor\_zbtsram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.fpga\_sysctrl**

FPGA SysCtrl timers LEDs and switches.

Type: [FPGA\\_SysCtrl](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.fpga\_sysctrl.callBack100HzCounter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.fpga\_sysctrl.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.gpio\_0\_or\_2**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.gpio\_1\_or\_3**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mem\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mem\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mpc\_iotss\_ssram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mpc\_iotss\_ssram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mpc\_iotss\_ssram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mpc\_iotss\_ssram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mps2\_audio**

MPS2 Audio.

Type: [MPS2\\_Audio](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mps2\_cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mps2\_cmsdk\_dualltimer.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mps2\_exclusive\_monitor\_zbtssram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mps2\_exclusive\_monitor\_zbtssram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mps2\_lcd**

MPS2 LCD I2C interface.

Type: [MPS2\\_LCD](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mps2\_mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mps2\_mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mps2\_secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: [MPS2\\_SecureCtrl](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mps2\_timer0**

ARM Timer Module.

Type: [CMSDK\\_Timer](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mps2\_timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mps2\_timer0.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mps2\_timer1**

ARM Timer Module.

Type: [CMSDK\\_Timer](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mps2\_timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mps2\_timer1.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.mps2\_visualisation**

Display window for MPS2 using Visualisation library.

Type: MPS2\_Visualisation.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.niden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.p1022\_ssp\_mps2**

ARM PrimeCell Synchronous Serial Port(PLO22).

Type: PL022\_SSP\_MPS2.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.p1022\_ssp\_mps2.prescaler**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.platform\_bus\_switch**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.platform\_switch\_dma0**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.platform\_switch\_dma1**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.signal\_router**

Signal router.

Type: SignalRouter.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.spiden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.spniden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200**

SSE-200 subsystem.

Type: sse200.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.acg\_cpu0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.acg\_cpu1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.acg\_sram0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.acg\_sram1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.acg\_sram2**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.acg\_sram3**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem0**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem1**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.clock32kHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.cmsdk\_dualltimer**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.cmsdk\_dualltimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.cmsdk\_dualltimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.cmsdk\_dualltimer.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.cmsdk\_dualltimer.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.cordio\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.cpu0core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.cpu0dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.cpu1core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.cpu1dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.crypto\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram0**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram3**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.iotss\_cpuidentity**

IoT Subsystem CPU\_IDENTITY registers.

Type: [IoTSS\\_CPUIdentity](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.iotss\_internal\_sram0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.iotss\_internal\_sram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.iotss\_internal\_sram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.iotss\_internal\_sram3**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.iotss\_systemcontrol**

IoT Subsystem System Control registers.

Type: [IoTSS\\_SystemControl](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.iotss\_systeminfo**

IoT Subsystem System Information registers.

Type: IoTSS\_SystemInfo.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.mem\_switch\_internal\_sram**

Allow transactions to be routed arbitrarily.

Type: PVBusRouter.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.mem\_switch\_internal\_sram\_mpc**

Allow transactions to be routed arbitrarily.

Type: PVBusRouter.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.mem\_switch\_ppu**

Allow transactions to be routed arbitrarily.

Type: PVBusRouter.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.mhu0**

IoT Subsystem Message Handling Unit.

Type: IoTSS\_MessageHandlingUnit.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.mhu1**

IoT Subsystem Message Handling Unit.

Type: IoTSS\_MessageHandlingUnit.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: SchedulerThreadEvent.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: SchedulerThreadEvent.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: SchedulerThreadEvent.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.nonsecure\_watchdog**

ARM Watchdog Module.

Type: [CMSDK\\_Watchdog](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.ram0\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.ram1\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.ram2\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.ram3\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.s32k\_timer**

ARM Timer Module.

Type: [CMSDK\\_Timer](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.s32k\_timer.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.s32k\_timer.counter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.s32k\_watchdog**

ARM Watchdog Module.

Type: [CMSDK\\_Watchdog](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: [MPS2\\_SecureCtrl](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.secure\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.signal\_router**

Signal router.

Type: SignalRouter.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.sys\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: PPUv0.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: ClockDivider.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.timer0.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.timer1**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: ClockDivider.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.sse200.timer1.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.ssram1**

RAM device, can be dynamic or static ram.

Type: RAMDevice.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.ssram2**

RAM device, can be dynamic or static ram.

Type: RAMDevice.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.stub0**

RAM device, can be dynamic or static ram.

Type: RAMDevice.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.stub1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.stub\_i2c1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.stub\_i2s**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.stub\_spi0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.stub\_spi2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer**

Type: svos\_DualTimer.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.switch\_PSRAM\_M7**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.switch\_svos\_dualltimer**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.telnetterminal0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.telnetterminal1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.telnetterminal2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2.touchscreen\_interface**

MPS2 Touch Screen.

Type: [MPS2\\_TouchScreen](#).

**FVP\_MPS2\_Cortex\_M7.fvp\_mps2 uart\_overflows\_or\_gate**

Or Gate.

Type: [OrGate](#).

## 16.11 FVP\_MPS2\_Cortex-M85

FVP\_MPS2\_Cortex-M85 contains the following instances:

### FVP\_MPS2\_Cortex-M85 instances

#### **FVP\_MPS2\_Cortex\_M85**

Type: FVP\_MPS2\_Cortex\_M85.

#### **FVP\_MPS2\_Cortex\_M85.clk25Mhz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_Cortex\_M85.clk25khz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_Cortex\_M85.core0\_bus\_gasket**

writes are ignored, non-word reads abort, and word reads take values from that fifo.

Type: [STLBusGasket](#).

#### **FVP\_MPS2\_Cortex\_M85.cpu0**

ARM Cortex-M85 CT model.

Type: ARM\_Cortex-M85.

#### **FVP\_MPS2\_Cortex\_M85.cpu1**

ARM Cortex-M85 CT model.

Type: ARM\_Cortex-M85.

#### **FVP\_MPS2\_Cortex\_M85.fvp\_mps2**

MPS2 DUT.

Type: FVP\_MPS2.

#### **FVP\_MPS2\_Cortex\_M85.fvp\_mps2.GPIO0**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

#### **FVP\_MPS2\_Cortex\_M85.fvp\_mps2.GPIO1**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

#### **FVP\_MPS2\_Cortex\_M85.fvp\_mps2.GPIO2**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.GPIO3**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.GPIO\_connection\_test**

Type: GPIO\_Connection\_Test.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.GPIO\_connection\_test.GPIO0\_port\_trans**

Type: GPIO\_Port\_Transfer.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.GPIO\_connection\_test.GPIO1\_port\_test**

Type: GPIO1\_Connection\_Test.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.PSRAM**

RAM device, can be dynamic or static ram.

Type: RAMDevice.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.PSRAM\_M7**

RAM device, can be dynamic or static ram.

Type: RAMDevice.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.UART0**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.UART0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: ClockDivider.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.UART1**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.UART1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: ClockDivider.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.UART2**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.UART2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: ClockDivider.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.VGA\_interface**

VGA display interface between main bus and visualisation.

Type: MPS2\_VGA.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.ahb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.ahb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.apb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.apb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.apb\_ppc\_iotss\_expansion2**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.cmsdk\_sysctrl**

Cortex-M Simple System Control.

Type: CMSDK\_SysCtrl.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.cmsdk\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.cpu\_wait\_or\_gate\_0**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.cpu\_wait\_or\_gate\_1**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dbgen\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma0**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma0.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma0.idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma0.securitymodifier**

Type: [SecurityModifier](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma1**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma1.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma1.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma1.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma1.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

#### **FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma1\_idau\_labeller**

Type: LabellerIdauSecurity.

#### **FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma1\_securitymodifier**

Type: SecurityModifier.

#### **FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma2**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

#### **FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma2.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma2.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma2.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma2.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma2.idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma2.securitymodifier**

Type: [SecurityModifier](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma3**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma3.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma3.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma3.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma3.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma3.idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.dma3.securitymodifier**

Type: [SecurityModifier](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.exclusive\_monitor\_psram**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.exclusive\_monitor\_psram\_iotss**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.exclusive\_monitor\_zbtsram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.exclusive\_monitor\_zbtsram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.fpga\_sysctrl**

FPGA SysCtrl timers LEDs and switches.

Type: [FPGA\\_SysCtrl](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.fpga\_sysctrl.callBack100HzCounter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.fpga\_sysctrl.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.gpio\_0\_or\_2**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.gpio\_1\_or\_3**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mem\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mem\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mpc\_iotss\_ssram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mpc\_iotss\_ssram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mpc\_iotss\_ssram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mpc\_iotss\_ssram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mps2\_audio**

MPS2 Audio.

Type: [MPS2\\_Audio](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mps2\_cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mps2\_exclusive\_monitor\_zbtssram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mps2\_exclusive\_monitor\_zbtssram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mps2\_lcd**

MPS2 LCD I2C interface.

Type: MPS2\_LCD.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mps2\_mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mps2\_mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mps2\_secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: MPS2\_SecureCtrl.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mps2\_timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mps2\_timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mps2\_timer0.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mps2\_timer1**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mps2\_timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mps2\_timer1.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.mps2\_visualisation**

Display window for MPS2 using Visualisation library.

Type: MPS2\_Visualisation.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.niden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.p1022\_ssp\_mps2**

ARM PrimeCell Synchronous Serial Port(PLO22).

Type: PL022\_SSP\_MPS2.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.p1022\_ssp\_mps2.prescaler**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.platform\_bus\_switch**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.platform\_switch\_dma0**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.platform\_switch\_dma1**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.signal\_router**

Signal router.

Type: [SignalRouter](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.spiden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.spniden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200**

SSE-200 subsystem.

Type: [sse200](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.acg\_cpu0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.acg\_cpu1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.acg\_sram0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.acg\_sram1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.acg\_sram2**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.acg\_sram3**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem0**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem1**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.clock32kHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.cmsdk\_dualtimer.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.cordio\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.cpu0core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.cpu0dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.cpu1core\_ppu**

ARM Power Policy Unit (PPU) architectural model.  
Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.cpu1dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.  
Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.crypto\_ppu**

ARM Power Policy Unit (PPU) architectural model.  
Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.debug\_ppu**

ARM Power Policy Unit (PPU) architectural model.  
Type: [PPUv0](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram0**

Global exclusive monitor.  
Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram1**

Global exclusive monitor.  
Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram2**

Global exclusive monitor.  
Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram3**

Global exclusive monitor.  
Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.  
Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.iotss\_cpuidentity**

IoT Subsystem CPU\_IDENTITY registers.  
Type: IoTSS\_CPUIdentity.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.iotss\_internal\_sram0**

RAM device, can be dynamic or static ram.  
Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.iotss\_internal\_sram1**

RAM device, can be dynamic or static ram.  
Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.iotss\_internal\_sram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.iotss\_internal\_sram3**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.iotss\_systemcontrol**

IoT Subsystem System Control registers.

Type: [IoTSS\\_SystemControl](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.iotss\_systeminfo**

IoT Subsystem System Information registers.

Type: [IoTSS\\_SystemInfo](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.mem\_switch\_internal\_sram**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.mem\_switch\_internal\_sram\_mpc**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.mem\_switch\_ppu**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.mhu0**

IoT Subsystem Message Handling Unit.

Type: [IoTSS\\_MessageHandlingUnit](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.mhu1**

IoT Subsystem Message Handling Unit.

Type: [IoTSS\\_MessageHandlingUnit](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: SchedulerThreadEvent.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: SchedulerThreadEvent.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.nmi\_or\_gate**

Or Gate.

Type: OrGate.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.nonsecure\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.ram0\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: PPUv0.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.ram1\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: PPUv0.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.ram2\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: PPUv0.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.ram3\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: PPUv0.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.s32k\_timer**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.s32k\_timer.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: ClockDivider.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.s32k\_timer.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.s32k\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: MPS2\_SecureCtrl.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.secure\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.signal\_router**

Signal router.

Type: SignalRouter.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.sys\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: PPUv0.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: ClockDivider.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.timer0.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.timer1**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: ClockDivider.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.sse200.timer1.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.ssram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.ssram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.stub0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.stub1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.stub\_i2c1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.stub\_i2s**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.stub\_spi0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.stub\_spi2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualtimer**

Type: [svos\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0**

ARM Dual-Timer Module.

Type: [cmsdk\\_DualTimer](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.switch\_PSRAM\_M7**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.switch\_svos\_dualltimer**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.telnetterminal10**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.telnetterminal11**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.telnetterminal12**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2.touchscreen\_interface**

MPS2 Touch Screen.

Type: MPS2\_TouchScreen.

**FVP\_MPS2\_Cortex\_M85.fvp\_mps2 uart\_overflows\_or\_gate**

Or Gate.

Type: [OrGate](#).

## 16.12 FVP\_MPS2\_SSE-200\_Cortex-M33

FVP\_MPS2\_SSE-200\_Cortex-M33 contains the following instances:

### FVP\_MPS2\_SSE-200\_Cortex-M33 instances

**FVP\_MPS2\_SSE\_200\_Cortex\_M33**

Type: [FVP\\_MPS2\\_SSE\\_200\\_Cortex\\_M33](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.clk25Mhz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.clk25khz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.cpu0**

ARM CORTEXM33 CT model.

Type: ARM\_Cortex-M33.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.cpu1**

ARM CORTEXM33 CT model.

Type: ARM\_Cortex-M33.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2**

MPS2 DUT.

Type: [FVP\\_MPS2](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.GPIO0**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.GPIO1**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.GPIO2**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.GPIO3**

ARM PrimeCell General Purpose Input/Output.

Type: CMSDK\_GPIO.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.GPIO\_connection\_test**

Type: GPIO\_Connection\_Test.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.GPIO\_connection\_test.GPIO0\_port\_trans**

Type: GPIO\_Port\_Transfer.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.GPIO\_connection\_test.GPIO1\_port\_test**

Type: GPIO1\_Connection\_Test.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.PSRAM**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.PSRAM\_M7**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.UART0**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.UART0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.UART1**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.UART1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.UART2**

ARM CMSDK UART Module.

Type: CMSDK\_UART.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.UART2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.VGA\_interface**

VGA display interface between main bus and visualisation.

Type: [MPS2\\_VGA](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.ahb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.ahb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.apb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.apb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.apb\_ppc\_iotss\_expansion2**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.cmsdk\_sysctrl**

Cortex-M Simple System Control.

Type: [CMSDK\\_SysCtrl](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.cmsdk\_watchdog**

ARM Watchdog Module.

Type: [CMSDK\\_Watchdog](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.cpu\_wait\_or\_gate\_0**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.cpu\_wait\_or\_gate\_1**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dbgen\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma0**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma0.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma0.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma0\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma0\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma1**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMPC](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma1.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma1.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma1.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma1.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma1\_idau\_labeller**

Type: [LabellerIdauSecurity](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma1\_securitymodifier**

Type: [SecurityModifier](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma2**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMPC](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma2.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma2.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma2.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma2.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma2\_idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma2\_securitymodifier**

Type: [SecurityModifier](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma3**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma3.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma3.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma3.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma3.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma3.idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.dma3.securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.exclusive\_monitor\_psram**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.exclusive\_monitor\_psram\_iotss**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.exclusive\_monitor\_zbtssram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.exclusive\_monitor\_zbtssram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.fpga\_sysctrl**

FPGA SysCtrl timers LEDs and switches.

Type: [FPGA\\_SysCtrl](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.fpga\_sysctrl.callBack100HzCounter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.fpga\_sysctrl.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.gpio\_0\_or\_2**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.gpio\_1\_or\_3**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mem\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mem\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mpc\_iotss\_ssram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mpc\_iotss\_ssram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mpc\_iotss\_ssram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mpc\_iotss\_ssram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mps2\_audio**

MPS2 Audio.

Type: [MPS2\\_Audio](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mps2\_cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mps2\_exclusive\_monitor\_zbtsram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mps2\_exclusive\_monitor\_zbtsram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mps2\_lcd**

MPS2 LCD I2C interface.

Type: MPS2\_LCD.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mps2\_mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mps2\_mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mps2\_secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: MPS2\_SecureCtrl.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mps2\_timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mps2\_timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mps2\_timer0.counter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mps2\_timer1**

ARM Timer Module.

Type: [CMSDK\\_Timer](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mps2\_timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mps2\_timer1.counter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.mps2\_visualisation**

Display window for MPS2 using Visualisation library.

Type: [MPS2\\_Visualisation](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.niden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.p1022\_ssp\_mps2**

ARM PrimeCell Synchronous Serial Port(PL022).

Type: [PL022\\_SSP\\_MPS2](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.p1022\_ssp\_mps2.prescaler**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.platform\_bus\_switch**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.platform\_switch\_dma0**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.platform\_switch\_dma1**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.signal\_router**

Signal router.

Type: [SignalRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMSC\\_91C111](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.spiden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.spniden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200**

SSE-200 subsystem.

Type: [sse200](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.acg\_cpu0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.acg\_cpu1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.acg\_sram0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.acg\_sram1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.acg\_sram2**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.acg\_sram3**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem0**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.clock32kHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.cmsdk\_dualtimer.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.cordio\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.cpu0core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.cpu0dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.cpu1core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.cpu1dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.crypto\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.debug\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram0**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram3**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.iotss\_cpuidentity**

IoT Subsystem CPU\_IDENTITY registers.

Type: IoTSS\_CPUIdentity.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.iotss\_internal\_sram0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.iotss\_internal\_sram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.iotss\_internal\_sram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.iotss\_internal\_sram3**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.iotss\_systemcontrol**

IoT Subsystem System Control registers.

Type: [IoTSS\\_SystemControl](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.iotss\_systeminfo**

IoT Subsystem System Information registers.

Type: [IoTSS\\_SystemInfo](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.mem\_switch\_internal\_sram**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.mem\_switch\_internal\_sram\_mpc**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.mem\_switch\_ppu**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.mhu0**

IoT Subsystem Message Handling Unit.

Type: [IoTSS\\_MessageHandlingUnit](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.mhu1**

IoT Subsystem Message Handling Unit.

Type: [IoTSS\\_MessageHandlingUnit](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.nonsecure\_watchdog**

ARM Watchdog Module.

Type: [CMSDK\\_Watchdog](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.ram0\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.ram1\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.ram2\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.ram3\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.s32k\_timer**

ARM Timer Module.

Type: [CMSDK\\_Timer](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.s32k\_timer.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.s32k\_timer.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.s32k\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: MPS2\_SecureCtrl.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.secure\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.signal\_router**

Signal router.

Type: SignalRouter.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.sys\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: PPUv0.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.timer0.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.timer1**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.sse200.timer1.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.ssram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.ssram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.stub0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.stub1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.stub\_i2c1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.stub\_i2s**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.stub\_spi0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.stub\_spi2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualtimer**

Type: [svos\\_DualTimer](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter0**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter1**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.switch\_PSRAM\_M7**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.switch\_svos\_dualltimer**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.telnetterminal0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.telnetterminal1**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.telnetterminal2**

Telnet terminal interface.

Type: [TelnetTerminal1](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.touchscreen\_interface**

MPS2 Touch Screen.

Type: MPS2\_TouchScreen.

**FVP\_MPS2\_SSE\_200\_Cortex\_M33.fvp\_mps2.uart\_overflows\_or\_gate**

Or Gate.

Type: [OrGate](#).

## 16.13 FVP\_MPS2\_SSE-200\_Cortex-M55

FVP\_MPS2\_SSE-200\_Cortex-M55 contains the following instances:

### FVP\_MPS2\_SSE-200\_Cortex-M55 instances

**FVP\_MPS2\_SSE\_200\_Cortex\_M55**

Type: FVP\_MPS2\_SSE\_200\_Cortex\_M55.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.clk25Mhz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.clk25khz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.cpu0**

ARM Cortex-M55 CT model.

Type: ARM\_Cortex-M55.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.cpu1**

ARM Cortex-M55 CT model.

Type: ARM\_Cortex-M55.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2**

MPS2 DUT.

Type: FVP\_MPS2.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.GPIO00**

ARM PrimeCell General Purpose Input/Output.  
Type: CMSDK\_GPIO.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.GPIO01**

ARM PrimeCell General Purpose Input/Output.  
Type: CMSDK\_GPIO.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.GPIO02**

ARM PrimeCell General Purpose Input/Output.  
Type: CMSDK\_GPIO.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.GPIO03**

ARM PrimeCell General Purpose Input/Output.  
Type: CMSDK\_GPIO.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.GPIO\_connection\_test**

Type: GPIO\_Connection\_Test.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.GPIO\_connection\_test.GPIO00\_port\_trans**

Type: GPIO\_Port\_Transfer.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.GPIO\_connection\_test.GPIO1\_port\_test**

Type: GPIO1\_Connection\_Test.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.PSRAM**

RAM device, can be dynamic or static ram.  
Type: RAMDevice.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.PSRAM\_M7**

RAM device, can be dynamic or static ram.  
Type: RAMDevice.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.UART0**

ARM CMSDK UART Module.  
Type: CMSDK\_UART.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.UART0.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: ClockDivider.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.UART1**

ARM CMSDK UART Module.  
Type: CMSDK\_UART.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.UART1.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.UART2**

ARM CMSDK UART Module.

Type: [cmsdk\\_UART](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.UART2.clk\_divider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.VGA\_interface**

VGA display interface between main bus and visualisation.

Type: [MPS2\\_VGA](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.ahb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.ahb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.apb\_ppc\_iotss\_expansion0**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.apb\_ppc\_iotss\_expansion1**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.apb\_ppc\_iotss\_expansion2**

IoT Subsystem Peripheral Protection Controller.

Type: [IoTSS\\_PeripheralProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.clock50Hz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.cmsdk\_sysctrl**

Cortex-M Simple System Control.

Type: CMSDK\_SysCtrl.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.cmsdk\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.cpu\_wait\_or\_gate\_0**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.cpu\_wait\_or\_gate\_1**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dbgen\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma0**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma0.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma0.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma0.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma0.timer.thread.event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma0\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma0\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma1**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma1.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma1.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma1.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma1.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma1\_idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma1\_securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma2**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma2.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus

transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma2.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma2.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma2.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma2\_idau\_labeller**

Type: LabellerIdauSecurity.

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma2\_securitymodifier**

Type: SecurityModifier.

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma3**

ARM PrimeCell DMA Controller(PL080/081).

Type: [PL080\\_DMAC](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma3.timer**

A ClockTimerThread(64) is a drop-in replacement for a ClockTimer(64) component. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma3.timer.timer**

A ClockTimerThread64 is a drop-in replacement for ClockTimer64. The main difference to the ClockTimer component is that the ClockTimerThread runs the signal() callback from a proper scheduler thread. This mean that the signal() function may directly or indirectly invoke wait() functions to wait for time or events. This is not allowed for the ClockTimer component which does not use a thread. Components which issue bus transactions from within the timer signal() callback must use ClockTimerThread(64) rather than ClockTimer(64).

Type: [ClockTimerThread64](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma3.timer.timer.thread**

A SchedulerThread instance represents a co-routine thread in the simulation.

Type: [SchedulerThread](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma3.timer.timer.thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma3.idau\_labeller**

Type: LabellerIdauSecurity.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.dma3.securitymodifier**

Type: SecurityModifier.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.exclusive\_monitor\_psram**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.exclusive\_monitor\_psram\_iotss**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.exclusive\_monitor\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.exclusive\_monitor\_zbtsram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.exclusive\_monitor\_zbtsram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBusExclusiveSquasher](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.fpga\_sysctrl**

FPGA SysCtrl timers LEDs and switches.

Type: [FPGA\\_SysCtrl](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.fpga\_sysctrl.callBack100HzCounter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.fpga\_sysctrl.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.gpio\_0\_or\_2**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.gpio\_1\_or\_3**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.hostbridge**

Host Socket Interface Component.

Type: [HostBridge](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mem\_switch\_extra\_psram\_iotss**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mem\_switch\_extra\_psram\_mps2**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mpc\_iotss\_ssram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mpc\_iotss\_ssram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mpc\_iotss\_ssram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mpc\_iotss\_ssram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mps2\_audio**

MPS2 Audio.

Type: MPS2\_Audio.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mps2\_cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mps2\_cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mps2\_cmsdk\_dualtimer.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mps2\_exclusive\_monitor\_zbtsram1**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mps2\_exclusive\_monitor\_zbtsram2**

Global exclusive monitor.

Type: [PVBusExclusiveMonitor](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mps2\_lcd**

MPS2 LCD I2C interface.

Type: MPS2\_LCD.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mps2\_mpc\_iotss\_ssram1**

IoT Subsystem Memory Protection Controller.

Type: IoTSS\_MemoryProtectionController.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mps2\_mpc\_iotss\_ssram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mps2\_secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: MPS2\_SecureCtrl.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mps2\_timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mps2\_timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mps2\_timer0.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mps2\_timer1**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mps2\_timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mps2\_timer1.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.mps2\_visualisation**

Display window for MPS2 using Visualisation library.

Type: MPS2\_Visualisation.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.niden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.p1022\_ssp\_mps2**

ARM PrimeCell Synchronous Serial Port(PL022).

Type: PL022\_SSP\_MPS2.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.p1022\_ssp\_mps2.prescaler**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.platform\_bus\_switch**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.platform\_switch\_dma0**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.platform\_switch\_dma1**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.signal\_router**

Signal router.

Type: [SignalRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.smsc\_91c111**

SMSC 91C111 ethernet controller.

Type: [SMS\\_C\\_91C111](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.spiden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.spniden\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200**

SSE-200 subsystem.

Type: [sse200](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.acg\_cpu0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.acg\_cpu1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.acg\_sram0**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.acg\_sram1**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.acg\_sram2**

IoT Subsystem Access Control Gate.

Type: [IoTSS\\_AccessControlGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.acg\_sram3**

IoT Subsystem Access Control Gate.

Type: IoTSS\_AccessControlGate.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem0**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.apb\_ppc\_iotss\_subsystem1**

IoT Subsystem Peripheral Protection Controller.

Type: IoTSS\_PeripheralProtectionController.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.clock32kHz**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.clockdivider**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.cmsdk\_dualtimer**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.cmsdk\_dualtimer.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.cmsdk\_dualtimer.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.cmsdk\_dualtimer.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.cordio\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.cpu0core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.cpu0dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.cpu1core\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.cpu1dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.crypto\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.dbg\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram0**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram1**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram2**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.exclusive\_monitor\_iotss\_internal\_sram3**

Global exclusive monitor.

Type: [PVBUSExclusiveMonitor](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.exclusive\_squasher**

Squashes the exclusive attribute on bus transactions.

Type: [PVBUSExclusiveSquasher](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.idau\_labeller**

Type: [LabellerIdauSecurity](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.iotss\_cpuidentity**

IoT Subsystem CPU\_IDENTITY registers.

Type: `IoTSS_CPUIdentity`.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.iotss\_internal\_sram0**

RAM device, can be dynamic or static ram.

Type: `RAMDevice`.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.iotss\_internal\_sram1**

RAM device, can be dynamic or static ram.

Type: `RAMDevice`.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.iotss\_internal\_sram2**

RAM device, can be dynamic or static ram.

Type: `RAMDevice`.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.iotss\_internal\_sram3**

RAM device, can be dynamic or static ram.

Type: `RAMDevice`.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.iotss\_systemcontrol**

IoT Subsystem System Control registers.

Type: `IoTSS_SystemControl`.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.iotss\_systeminfo**

IoT Subsystem System Information registers.

Type: `IoTSS_SystemInfo`.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.mem\_switch\_internal\_sram**

Allow transactions to be routed arbitrarily.

Type: `PVBusRouter`.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.mem\_switch\_internal\_sram\_mpc**

Allow transactions to be routed arbitrarily.

Type: `PVBusRouter`.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.mem\_switch\_ppu**

Allow transactions to be routed arbitrarily.

Type: `PVBusRouter`.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.mhu0**

IoT Subsystem Message Handling Unit.

Type: `IoTSS_MessageHandlingUnit`.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.mhu1**

IoT Subsystem Message Handling Unit.

Type: `IoTSS_MessageHandlingUnit`.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0**

IoT Subsystem Memory Protection Controller.

Type: `IoTSS_MemoryProtectionController`.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram0.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: `SchedulerThreadEvent`.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram1.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram2.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3**

IoT Subsystem Memory Protection Controller.

Type: [IoTSS\\_MemoryProtectionController](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.mpc\_iotss\_internal\_sram3.gating\_disabled\_thread\_event**

A SchedulerThreadEvent instance is an auto-reset boolean condition variable other threads can wait on.

Type: [SchedulerThreadEvent](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.nmi\_or\_gate**

Or Gate.

Type: [OrGate](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.nonsecure\_watchdog**

ARM Watchdog Module.

Type: [CMSDK\\_Watchdog](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.ram0\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.ram1\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.ram2\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.ram3\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.s32k\_timer**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.s32k\_timer.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.s32k\_timer.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.s32k\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.secure\_control\_register\_block**

MPS2 Secure Control Register Block.

Type: MPS2\_SecureCtrl.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.secure\_watchdog**

ARM Watchdog Module.

Type: CMSDK\_Watchdog.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.signal\_router**

Signal router.

Type: signalRouter.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.sys\_ppu**

ARM Power Policy Unit (PPU) architectural model.

Type: [PPUv0](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.timer0**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.timer0.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.timer0.counter**

Internal component used by SP804 Timer module.

Type: CounterModule.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.timer1**

ARM Timer Module.

Type: CMSDK\_Timer.

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.timer1.clk\_div**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.sse200.timer1.counter**

Internal component used by SP804 Timer module.

Type: [CounterModule](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.ssram1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.ssram2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.stub0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.stub1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.stub\_i2c1**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.stub\_i2s**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.stub\_spi0**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.stub\_spi2**

RAM device, can be dynamic or static ram.

Type: [RAMDevice](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualtimer**

Type: [svos\\_DualTimer](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0**

ARM Dual-Timer Module.

Type: [CMSDK\\_DualTimer](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualtimer.svos\_dualtimer0.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer0.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer1.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new

ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer2.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3**

ARM Dual-Timer Module.

Type: CMSDK\_DualTimer.

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div0**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.clk\_div1**

A ClockDivider is a library component that takes a ClockSignal on its input port (which could come from the output of a MasterClock, or from another ClockDivider), and generates a new ClockSignal on its output port, representing a clock frequency that is related to the input clock by the ratio of the multiply and divide parameters.

Type: [ClockDivider](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter0**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.svos\_dualltimer.svos\_dualltimer3.counter1**

Internal component used by SP804 Timer module.

Type: CounterModule.

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.switch\_PSRAM\_M7**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

#### **FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.switch\_svos\_dualltimer**

Allow transactions to be routed arbitrarily.

Type: [PVBusRouter](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.telnetterminal0**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.telnetterminal1**

Telnet terminal interface.

Type: [TelnetTerminal1](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.telnetterminal2**

Telnet terminal interface.

Type: [TelnetTerminal](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.touchscreen\_interface**

MPS2 Touch Screen.

Type: [MPS2\\_TouchScreen](#).

**FVP\_MPS2\_SSE\_200\_Cortex\_M55.fvp\_mps2.uart\_overflows\_or\_gate**

Or Gate.

Type: [OrGate](#).