<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE register_page SYSTEM "registers.dtd">
<!-- Copyright (c) 2010-2026 Arm Limited or its affiliates. All rights reserved. -->
<!-- This document is Non-Confidential. This document may only be used and distributed in accordance with the terms of the agreement entered into by Arm and the party that Arm delivered this document to. -->
<!--The data contained in this document is preliminary and subject to change or correction following further review. -->
<?xml-stylesheet href="one_register.xsl" type="text/xsl" ?>







<register_page>
  <registers>
  
    <register execution_state="AArch64" is_register="True" is_internal="True" is_stub_entry="False">
      <reg_short_name>FAR_EL3</reg_short_name>
        
        <reg_long_name>Fault Address Register (EL3)</reg_long_name>



      
            <reg_condition otherwise="UNDEFINED">when EL3 is implemented and FEAT_AA64 is implemented</reg_condition>
      




          <reg_reset_value></reg_reset_value>

      <reg_mappings>
        




      </reg_mappings>

        <reg_purpose>
          
    
      <purpose_text>
        <para>Holds the faulting Virtual Address for all synchronous Instruction Abort exceptions, Data Abort exceptions and PC alignment fault exceptions that are taken to EL3.</para>
      </purpose_text>

        </reg_purpose>

      <reg_groups>
            <reg_group>Exception</reg_group>
      </reg_groups>
      
      
        
      <reg_attributes>
          
    
      <attributes_text>
        <para>FAR_EL3 is a 64-bit register.</para>
      </attributes_text>

      </reg_attributes>
      <reg_fieldsets>
        






<fields id="fieldset_0" length="64">
  <text_before_fields/>
  <field id="fieldset_0-63_0" has_partial_fieldset="False" is_linked_to_partial_fieldset="False" is_access_restriction_possible="False" is_variable_length="False" is_constant_value="False" is_partial_field="False" is_conditional_field_name="False">
    <field_name>VA</field_name>
    <field_shortdesc>Faulting Virtual Address for synchronous exceptions taken to EL3</field_shortdesc>
    <field_msb>63</field_msb>
    <field_lsb>0</field_lsb>
    <rel_range>63:0</rel_range>
    <field_description order="before"><para>Faulting Virtual Address for synchronous exceptions taken to EL3. Exceptions that set the FAR_EL3 are Instruction Aborts (EC <hexnumber>0x20</hexnumber> or <hexnumber>0x21</hexnumber>), Data Aborts (EC <hexnumber>0x24</hexnumber> or <hexnumber>0x25</hexnumber>), and PC alignment faults (EC <hexnumber>0x22</hexnumber>). <register_link state="AArch64" id="AArch64-esr_el3.xml">ESR_EL3</register_link>.EC holds the EC syndrome value for the exception.</para>
<para>For a synchronous External abort:</para>
<list type="unordered">
<listitem><content>If the VA that generated the abort was from an address range for which Address tagging is enabled for the translation regime in use when the abort was generated, then bits[63:56] of FAR_EL3 are <arm-defined-word>UNKNOWN</arm-defined-word>.</content>
</listitem><listitem><content>If the VA that generated the abort was from an address range for which Address tagging is disabled and Logical Address Tagging is enabled for the translation regime in use when the abort was generated, then bits[59:56] of FAR_EL3 are <arm-defined-word>UNKNOWN</arm-defined-word>.</content>
</listitem></list>
<para>For a synchronous External abort other than a synchronous External abort on a translation table walk, this field is valid only if <register_link state="AArch64" id="AArch64-esr_el3.xml">ESR_EL3</register_link>.FnV is 0, and FAR_EL3 is <arm-defined-word>UNKNOWN</arm-defined-word> if <register_link state="AArch64" id="AArch64-esr_el3.xml">ESR_EL3</register_link>.FnV is 1.</para>
<para>On an exception due to a Tag Check Fault caused by a data cache maintenance or other DC instruction, the address held in FAR_EL3 is <arm-defined-word>IMPLEMENTATION DEFINED</arm-defined-word> as one of the following:</para>
<list type="unordered">
<listitem><content>The lowest address that gave rise to the fault.</content>
</listitem><listitem><content>The address specified in the register argument of the instruction as generated by MMU faults caused by <register_link id="AArch64-dc-zva.xml" state="AArch64">DC ZVA</register_link>.</content>
</listitem></list>
<para>If a memory fault that sets FAR_EL3 is generated from an STZGM instruction, the address held in FAR_EL3 is <arm-defined-word>IMPLEMENTATION DEFINED</arm-defined-word> as one of the following:</para>
<list type="unordered">
<listitem><content>The lowest address that gave rise to the fault.</content>
</listitem><listitem><content>The address specified in the register argument.</content>
</listitem></list>
<para>If a memory fault that sets FAR_EL3, other than a Tag Check Fault, is generated from a data cache maintenance or other DC instruction, this field holds the address specified in the register argument of the instruction.</para>
<para>If the exception that updates FAR_EL3 is taken from an Exception level using AArch32, the top 32 bits are all zero, unless both of the following apply, in which case the top 32 bits of FAR_ELx are <hexnumber>0x00000001</hexnumber>:</para>
<list type="unordered">
<listitem><content>The faulting address was generated by a load or store instruction that sequentially incremented from address <hexnumber>0xFFFFFFFF</hexnumber>. Such a load or store instruction is <arm-defined-word>CONSTRAINED UNPREDICTABLE</arm-defined-word>.</content>
</listitem><listitem><content>The implementation treats such incrementing as setting bit[32] of the virtual address to 1.</content>
</listitem></list>
<para>When the PE sets <register_link state="AArch64" id="AArch64-esr_el3.xml">ESR_EL3</register_link>.{ISV,FnP} to {0,1} on taking a Data Abort exception, the PE sets FAR_EL3 to any address within the naturally-aligned fault granule that contains the virtual address of the memory access that generated the Data Abort exception.</para>
<para>The naturally-aligned fault granule is one of:</para>
<list type="unordered">
<listitem><content>When <register_link state="AArch64" id="AArch64-esr_el3.xml">ESR_EL3</register_link>.DFSC is <binarynumber>0b010001</binarynumber>, indicating a Synchronous Tag Check fault, it is a 16-byte tag granule.</content>
</listitem><listitem><content>When <register_link state="AArch64" id="AArch64-esr_el3.xml">ESR_EL3</register_link>.DFSC is <binarynumber>0b11010x</binarynumber>, indicating an <arm-defined-word>IMPLEMENTATION DEFINED</arm-defined-word> fault, it is an <arm-defined-word>IMPLEMENTATION DEFINED</arm-defined-word> granule.</content>
</listitem><listitem><content>Otherwise, it is the smallest implemented translation granule.</content>
</listitem></list>
<para>When <xref linkend="#FEAT_MOPS">FEAT_MOPS</xref> is implemented, the value in FAR_EL3 on a synchronous exception from any of the Memory Copy and Memory Set instructions is determined as follows:</para>
<list type="unordered">
<listitem><content>
<para>For an MMU fault reported as a Data Abort or as a Granule Protection Check Exception, the value is within the address range of the relevant translation granule, aligned to the size of the relevant translation granule of the address that generated the Data Abort. Bits[(n-1):0] of the value are <arm-defined-word>UNKNOWN</arm-defined-word>, where 2<sup>n</sup> is the relevant translation granule size in bytes. For the purpose of calculating the relevant translation granule, if the MMU is disabled for a stage of translation, then the current translation granule size is equal to 2<sup>64</sup> for stage 1, and the PARange for stage 2. The relevant translation granule is:</para>
<list type="unordered">
<listitem><content>
<para>For MMU faults generated at stage 1, the current stage 1 translation granule.</para>
</content>
</listitem><listitem><content>
<para>For MMU faults generated at stage 2, the smaller of the current stage 1 translation granule and the current stage 2 translation granule.</para>
</content>
</listitem><listitem><content>
<para>If FEAT_RME is implemented, for a GPC fault, the smallest of the current stage 1 translation granule, the current stage 2 translation granule and the configured granule size in <register_link state="AArch64" id="AArch64-gpccr_el3.xml">GPCCR_EL3</register_link>.PGS.</para>
</content>
</listitem></list>
</content>
</listitem><listitem><content>
<para>For a Data Abort generated by a Tag Check Fault, the value is any address that caused a Tag Check Fault within the block size of the load or store.</para>
</content>
</listitem><listitem><content>
<para>Otherwise, the value is the lowest address in the block size of the load or store.</para>
</content>
</listitem></list>
<para>For a Data Abort exception, if address tagging is enabled for the address accessed by the data access that caused the exception, then this field includes the tag. For more information about address tagging, see <xref linkend="#MDSec.Address_tagging">'Address tagging'</xref>.</para>
<para>For a synchronous Tag Check Fault:</para>
<list type="unordered">
<listitem><content>If FEAT_MTE_TAGGED_FAR is implemented or Address tagging is disabled for the translation regime in use when the abort was generated, all bits of FAR_EL3 are not <arm-defined-word>UNKNOWN</arm-defined-word>.</content>
</listitem><listitem><content>If FEAT_MTE_TAGGED_FAR is not implemented and Address tagging is enabled for the translation regime in use when the abort was generated, bits[63:60] of FAR_EL3 are <arm-defined-word>UNKNOWN</arm-defined-word>.</content>
</listitem></list>
<para>Execution at EL2, EL1, and EL0 makes FAR_EL3 become <arm-defined-word>UNKNOWN</arm-defined-word>.</para>
<note><para>The address held in this register is an address accessed by the instruction fetch or data access that caused the exception that actually gave rise to the instruction or Data Abort. It is the lowest address that gave rise to the fault that is reported. Where different faults from different addresses arise from the same instruction, such as for an instruction that loads or stores an unaligned address that crosses a page boundary, the architecture does not prioritize which fault is reported.</para></note><para>For all other exceptions taken to EL3, FAR_EL3 is <arm-defined-word>UNKNOWN</arm-defined-word>.</para>
<para>FAR_EL3 is made <arm-defined-word>UNKNOWN</arm-defined-word> on an exception return from EL3.</para></field_description>
    <field_resets>
      <field_reset reset_type="Warm">
        <field_reset_standard_text>AU</field_reset_standard_text>
      </field_reset>
    </field_resets>
  </field>
  <text_after_fields/>
</fields>




<reg_fieldset length="64">
  <fieldat id="fieldset_0-63_0" msb="63" lsb="0"/>
</reg_fieldset>


      </reg_fieldsets>

      <access_mechanisms>
          






    
        
        <access_mechanism accessor="MRS FAR_EL3" type="SystemAccessor">
            <encoding>
            <access_instruction>MRS &lt;Xt&gt;, FAR_EL3</access_instruction>
                
                <enc n="op0" v="0b11"/>
                
                <enc n="op1" v="0b110"/>
                
                <enc n="CRn" v="0b0110"/>
                
                <enc n="CRm" v="0b0000"/>
                
                <enc n="op2" v="0b000"/>
            </encoding>
            <access_permission>
                <ps name="MRS" sections="1" secttype="access_permission">
                <pstext>
if !(HaveEL(EL3) &amp;&amp; IsFeatureImplemented(FEAT_AA64)) then
    Undefined();
elsif PSTATE.EL == EL0 then
    Undefined();
elsif PSTATE.EL == EL1 then
    Undefined();
elsif PSTATE.EL == EL2 then
    Undefined();
elsif PSTATE.EL == EL3 then
    X{64}(t) = FAR_EL3();
end;
                </pstext>
                </ps>
            </access_permission>
        </access_mechanism>
    
        
        <access_mechanism accessor="MSRregister FAR_EL3" type="SystemAccessor">
            <encoding>
            <access_instruction>MSR FAR_EL3, &lt;Xt&gt;</access_instruction>
                
                <enc n="op0" v="0b11"/>
                
                <enc n="op1" v="0b110"/>
                
                <enc n="CRn" v="0b0110"/>
                
                <enc n="CRm" v="0b0000"/>
                
                <enc n="op2" v="0b000"/>
            </encoding>
            <access_permission>
                <ps name="MSRregister" sections="1" secttype="access_permission">
                <pstext>
if !(HaveEL(EL3) &amp;&amp; IsFeatureImplemented(FEAT_AA64)) then
    Undefined();
elsif PSTATE.EL == EL0 then
    Undefined();
elsif PSTATE.EL == EL1 then
    Undefined();
elsif PSTATE.EL == EL2 then
    Undefined();
elsif PSTATE.EL == EL3 then
    FAR_EL3() = X{64}(t);
end;
                </pstext>
                </ps>
            </access_permission>
        </access_mechanism>

      </access_mechanisms>

      <arch_variants>
      </arch_variants>
  </register>
</registers>
<timestamp>2026-03-26 20:27:25</timestamp>
<commit_id>2026-03_rel</commit_id>
</register_page>