ebook img

ARM Generic Interrupt Controller Architecture Specification PDF

154 Pages·2008·0.94 MB·English
by  
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview ARM Generic Interrupt Controller Architecture Specification

ARM Generic Interrupt Controller ® Architecture version 1.0 Architecture Specification Copyright ©2008 ARM Limited. All rights reserved. ARM IHI 0048A ARM Generic Interrupt Controller Copyright ©2008 ARM Limited. All rights reserved. Release Information The following changes have been made to this document. Change History Date Issue Confidentiality Change 23 September 2008 A Non-Confidential Unrestricted Access First release for version 1.0 Proprietary Notice Words and logos marked with ® or ™ are registered trademarks or trademarks of ARM Limited in the EU and other countries, except as otherwise stated below in this proprietary notice. Other brands and names mentioned herein may be the trademarks of their respective owners. The product described in this document is subject to continuous developments and improvements. All particulars of the product and its use contained in this document are given by ARM in good faith. Neither the whole nor any part of the information contained in, or the product described in, this document may be adapted or reproduced in any material form except with the prior written permission of the copyright holder. 1. Subject to the provisions of Clauses 2 and 3, ARM hereby grants to you a perpetual, non-exclusive, non-transferable, royalty free, worldwide licence to use and copy the ARM Generic Interrupt Controller (GIC) Architecture Specification (“Specification”) for the purpose of developing, having developed, manufacturing, having manufactured, offering to sell, selling, supplying or otherwise distributing products which comply with the Specification and which contain at least one processor core which has either been (i) developed by or for ARM or (ii) developed under licence from ARM. 2. THE ARM GIC ARCHITECTURE SPECIFICATION IS PROVIDED “AS IS” WITH NO WARRANTIES EXPRESS, IMPLIED OR STATUTORY, INCLUDING BUT NOT LIMITED TO ANY WARRANTY OF SATISFACTORY QUALITY, NONINFRINGEMENT OR FITNESS FOR A PARTICULAR PURPOSE. 3. No licence, express, implied or otherwise, is granted to you, under the provisions of Clause 1, to use the ARM tradename in connection with the ARM GIC Architecture Specification or any products based thereon. Nothing in Clause 1 shall be construed as authority for you to make any representations on behalf of ARM in respect of the ARM GIC Architecture Specification. Where the term ARM is used it means “ARM or any of its subsidiaries as appropriate”. Copyright © 2008 ARM Limited 110 Fulbourn Road Cambridge, England CB1 9NJ Restricted Rights Legend: Use, duplication or disclosure by the United States Government is subject to the restrictions set forth in DFARS 252.227-7013 (c)(1)(ii) and FAR 52.227-19. This document is Non-Confidential. The right to use, copy and disclose this document is subject to the licence set out above. Unrestricted Access is an ARM internal classification. ii Copyright ©2008 ARM Limited. All rights reserved. ARM IHI 0048A Non-Confidential Unrestricted Access Contents ARM Generic Interrupt Controller Architecture Specification Preface About this specification ......................................................................... vi Conventions ........................................................................................ viii Further reading ..................................................................................... ix Feedback ............................................................................................... x Chapter 1 Introduction 1.1 About the Generic Interrupt Controller architecture ........................... 1-2 1.2 Security Extensions support .............................................................. 1-3 1.3 Terminology ....................................................................................... 1-4 Chapter 2 GIC Partitioning 2.1 About GIC partitioning ........................................................................ 2-2 2.2 The Distributor ................................................................................... 2-4 2.3 CPU interfaces ................................................................................... 2-6 Chapter 3 Interrupt Handling and Prioritization 3.1 About interrupt handling and prioritization .......................................... 3-2 3.2 General handling of interrupts ............................................................ 3-5 3.3 Interrupt prioritization ....................................................................... 3-12 ARM IHI 0048A Copyright ©2008 ARM Limited. All rights reserved. iii Unrestricted Access Non-Confidential Contents 3.4 The effect of the Security Extensions on interrupt handling ............. 3-15 3.5 The effect of the Security Extensions on interrupt prioritization ....... 3-18 3.6 Pseudocode details of interrupt handling and prioritization ............. 3-25 Chapter 4 Programmers Model 4.1 About the programmers model .......................................................... 4-2 4.2 Effect of the Security Extensions on the programmers model ........... 4-7 4.3 Distributor register descriptions ....................................................... 4-11 4.4 CPU interface register descriptions ................................................. 4-46 Appendix A Pseudocode Index A.1 Index of pseudocode functions .......................................................... A-2 Appendix B Software Examples for the GIC B.1 Use of identification registers ............................................................. B-2 B.2 Initialization after reset or power on ................................................... B-3 B.3 Processor response to an initial interrupt ........................................... B-6 B.4 Preemptive processing ...................................................................... B-9 B.5 Generating a software interrupt ....................................................... B-12 B.6 Changing a CPU interface interrupt priority mask ............................ B-13 B.7 Changing the priority of an interrupt ................................................. B-14 B.8 Changing the processor targets of an interrupt ................................ B-15 B.9 Disabling a peripheral interrupt ........................................................ B-16 B.10 Changing the security configuration of an interrupt ......................... B-17 B.11 Disabling a CPU interface on the GIC ............................................. B-19 B.12 Message passing between processors ............................................ B-20 B.13 Example of using the binary point .................................................... B-21 Appendix C Register Shortform Names C.1 Register name aliases ....................................................................... C-2 C.2 Index of architectural shortform names .............................................. C-4 Glossary iv Copyright ©2008 ARM Limited. All rights reserved. ARM IHI 0048A Non-Confidential Unrestricted Access Preface This preface summarizes the contents of this specification and lists the conventions it uses. It contains the following sections: (cid:129) About this specification on pagevi (cid:129) Conventions on pageviii (cid:129) Further reading on pageix (cid:129) Feedback on pagex. ARM IHI 0048A Copyright ©2008 ARM Limited. All rights reserved. v Unrestricted Access Non-Confidential Preface About this specification This is version 1.0 of the Architecture Specification for the ARM Generic Interrupt Controller (GIC). Throughout this document, references to the GIC or a GIC refer to a device that implements this GIC architecture. Unless the context makes it clear that a reference is to an IMPLEMENTATION DEFINED feature of the device, these references describe the requirements of this specification. Intended audience The specification is written for users that want to design, implement, or program the GIC in a range of ARM-compliant implementations from simple uniprocessor implementations to complex multiprocessor systems. The specification assumes that users have some experience of ARM products. It does not assume experience of the GIC. Using this specification This specification is organized into the following chapters: Chapter1 Introduction Read this for an overview of the GIC, and information about the terminology used in this document. Chapter2 GIC Partitioning Read this for a description of the major interfaces and components of the GIC. The chapter also describes how they operate. Chapter3 Interrupt Handling and Prioritization Read this for a description of the requirements for interrupt handling, and the interrupt priority scheme for a GIC. Chapter4 Programmers Model Read this for a description of the Distributor and CPU interface registers. AppendixA Pseudocode Index Read this for an index to the pseudocode functions defined in this specification. AppendixB Software Examples for the GIC Read this for a description of non-architectural, non-prescriptive, methods of using the GIC, and of how the GIC manages interrupts. AppendixC Register Shortform Names Read this for a description of relationship between the architectural shortform names of the registers described in this specification and their legacy shortform aliases, and for an alphabetic index of the architectural shortform names. vi Copyright ©2008 ARM Limited. All rights reserved. ARM IHI 0048A Non-Confidential Unrestricted Access Preface Glossary Read the Glossary for definitions of terms used in this document. ARM IHI 0048A Copyright ©2008 ARM Limited. All rights reserved. vii Unrestricted Access Non-Confidential Preface Conventions The following sections describe conventions that this book can use: (cid:129) General typographic conventions (cid:129) Signals (cid:129) Numbers (cid:129) Pseudocode descriptions. General typographic conventions monospace Used for assembler syntax descriptions, pseudocode, and source code examples. Also used in the main text for instruction mnemonics and for references to other items appearing in assembler syntax descriptions, pseudocode, and source code examples. italic Highlights important notes, introduces special terminology, and denotes internal cross-references and citations. bold Denotes signal names and is used for terms in descriptive lists, where appropriate. SMALL CAPITALS Used for a few terms that have specific technical meanings, that are included in the Glossary. Signals The signal conventions are: Signal level The level of an asserted signal depends on whether the signal is active-HIGH or active-LOW. Asserted means: (cid:129) HIGH for active-HIGH signals (cid:129) LOW for active-LOW signals. Lower-case n At the start or end of a signal name denotes an active-LOW signal. Numbers Numbers are normally written in decimal. Binary numbers are preceded by 0b, and hexadecimal numbers by 0x and written in a monospace font. Pseudocode descriptions This specification uses a form of pseudocode to provide precise descriptions of the specified functionality. This pseudocode is written in a monspace font, and follows the conventions described in the ARM Architecture Reference Manual, ARMv7-A and ARMv7-R edition. viii Copyright ©2008 ARM Limited. All rights reserved. ARM IHI 0048A Non-Confidential Unrestricted Access Preface Further reading This section lists publications by ARM and by third parties. See http://infocenter.arm.com/ for access to ARM documentation. ARM publications This specification contains information that is specific to the GIC. See the following documents for other relevant information: (cid:129) ARM Architecture Reference Manual, ARMv7-A and ARMv7-R edition (ARM DDI 0406). External publications This section lists relevant documents published by third parties: (cid:129) JEP106M, Standard Manufacture’s Identification Code, JEDEC Solid State Technology Association. ARM IHI 0048A Copyright ©2008 ARM Limited. All rights reserved. ix Unrestricted Access Non-Confidential Preface Feedback ARM welcomes feedback on this documentation. Feedback on this specification If you have any comments or suggestions about this documentation, contact your supplier and give: (cid:129) the document title (cid:129) the document number (cid:129) an explanation with as much information as you can provide. ARM also welcomes general suggestions for additions and improvements. x Copyright ©2008 ARM Limited. All rights reserved. ARM IHI 0048A Non-Confidential Unrestricted Access

Description:
F or a processor that complies with the ARM architecture: † The value of the I or F bit in the CPSR determin es whether the processor responds to the signalled
See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.