<?xml version="1.0" ?><?xml-stylesheet type="text/xsl" encoding="UTF-8" href="iform.xsl" version="1.0"?><!DOCTYPE instructionsection  PUBLIC '-//ARM//DTD instructionsection //EN'  'iform-p.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. --><instructionsection id="LDRD_l" title="LDRD (literal) -- AArch32" type="instruction">
  <docvars>
    <docvar key="address-form" value="literal"/>
    <docvar key="instr-class" value="general"/>
    <docvar key="mnemonic" value="LDRD"/>
  </docvars>
  <heading>LDRD (literal)</heading>
  <desc>
    <brief>
      <para>Load Register Dual (literal)</para>
    </brief>
    <authored>
      <para>Load Register Dual (literal) calculates an address from the PC value
and an immediate offset, loads two words from memory, and writes
them to two registers. For information about memory accesses see
<xref linkend="ARMARM_Chddjfjf">Memory accesses</xref>.</para>
    </authored>
    <encodingnotes>
      <para>For more information about the <arm-defined-word>CONSTRAINED UNPREDICTABLE</arm-defined-word> behavior of this instruction, see <xref linkend="ARMARM_CJAEGDJC">Architectural Constraints on UNPREDICTABLE behaviors</xref>.</para>
      <para>Related encodings: <xref linkend="ARMARM_T32.encoding_index.dstd">Load/Store dual, Load/Store-Exclusive, Load-Acquire/Store-Release, table branch</xref>.</para>
    </encodingnotes>
    <syntaxnotes>
      <para>The alternative syntax permits the addition or subtraction of the offset and the immediate offset to be specified separately, including permitting a subtraction of 0 that cannot be specified using the normal syntax. For more information, see <xref linkend="ARMARM_BABGCIBA">Use of labels in UAL instruction syntax</xref>.</para>
    </syntaxnotes>
  </desc>
  <operationalnotes>
    <operationalnote>
      <operationalnote_content>
        <para>This instruction is a data-independent-time instruction as described in <xref linkend="ARMARM_BEIIDCEG">About the DIT bit</xref>.</para>
      </operationalnote_content>
    </operationalnote>
  </operationalnotes>
  <alias_list howmany="0"/>
  <classes>
    <classesintro count="2">
      <txt>It has encodings from the following instruction sets:</txt>
      <txt> A32 (</txt>
      <a href="#iclass_a1">A1</a>
      <txt>)</txt>
      <txt> and </txt>
      <txt> T32 (</txt>
      <a href="#iclass_t1">T1</a>
      <txt>)</txt>
      <txt>.</txt>
    </classesintro>
    <iclass name="A1" oneof="2" id="iclass_a1" no_encodings="1" isa="A32">
      <docvars>
        <docvar key="address-form" value="literal"/>
        <docvar key="armarmheading" value="A1"/>
        <docvar key="instr-class" value="general"/>
        <docvar key="isa" value="A32"/>
        <docvar key="mnemonic" value="LDRD"/>
      </docvars>
      <iclassintro count="1"/>
      <regdiagram form="32" psname="A32.dp.xldst.ldstximm.LDRD_l_A1" tworows="1">
        <box hibit="31" width="4" name="cond" usename="1" settings="4" constraint="!= 1111">
          <c colspan="4">!= 1111</c>
        </box>
        <box hibit="27" width="2" settings="2">
          <c>0</c>
          <c>0</c>
        </box>
        <box hibit="25" width="1" settings="1">
          <c>0</c>
        </box>
        <box hibit="24" name="P" usename="1" settings="1" psbits="x">
          <c>(1)</c>
        </box>
        <box hibit="23" width="1" name="U" usename="1">
          <c colspan="1"/>
        </box>
        <box hibit="22" width="1" settings="1">
          <c>1</c>
        </box>
        <box hibit="21" name="W" usename="1" settings="1" psbits="x">
          <c>(0)</c>
        </box>
        <box hibit="20" name="o1" usename="1" settings="1" psbits="x">
          <c>0</c>
        </box>
        <box hibit="19" width="4" name="Rn" usename="1" settings="4" psbits="xxxx">
          <c>1</c>
          <c>1</c>
          <c>1</c>
          <c>1</c>
        </box>
        <box hibit="15" width="4" name="Rt" usename="1">
          <c colspan="4"/>
        </box>
        <box hibit="11" width="4" name="imm4H" usename="1">
          <c colspan="4"/>
        </box>
        <box hibit="7" width="1" settings="1">
          <c>1</c>
        </box>
        <box hibit="6" width="2" name="op2" usename="1" settings="2" psbits="xx">
          <c>1</c>
          <c>0</c>
        </box>
        <box hibit="4" width="1" settings="1">
          <c>1</c>
        </box>
        <box hibit="3" width="4" name="imm4L" usename="1">
          <c colspan="4"/>
        </box>
      </regdiagram>
      <encoding name="LDRD_l_A1" oneofinclass="1" oneof="2" label="">
        <docvars>
          <docvar key="address-form" value="literal"/>
          <docvar key="armarmheading" value="A1"/>
          <docvar key="instr-class" value="general"/>
          <docvar key="isa" value="A32"/>
          <docvar key="mnemonic" value="LDRD"/>
        </docvars>
        <asmtemplate comment="Normal form"><text>LDRD{</text><a hover="See x[Standard assembler syntax fields](Babbefhf)." link="c__5">&lt;c&gt;</a><text>}{</text><a hover="See x[Standard assembler syntax fields](Babbefhf)." link="qw_option">&lt;q&gt;</a><text>}  </text><a hover="For the &quot;A1&quot; variant: is the first general-purpose register to be transferred, encoded in the &quot;Rt&quot; field. This register must be even-numbered and not R14." link="Rt__3">&lt;Rt&gt;</a><text>, </text><a hover="For the &quot;A1&quot; variant: is the second general-purpose register to be transferred. This register must be &lt;R(t+1)&gt;." link="Rt2__2">&lt;Rt2&gt;</a><text>, </text><a hover="For the &quot;A1&quot; variant: the label of the literal data item that is to be loaded into &lt;Rt&gt;. The assembler calculates the required value of the offset from the Align(PC, 4) value of the instruction to this label. Any value in the range -255 to 255 is permitted." link="imm4H_imm4L">&lt;label&gt;</a></asmtemplate>
        <asmtemplate comment="Alternative form"><text>LDRD{</text><a hover="See x[Standard assembler syntax fields](Babbefhf)." link="c__5">&lt;c&gt;</a><text>}{</text><a hover="See x[Standard assembler syntax fields](Babbefhf)." link="qw_option">&lt;q&gt;</a><text>}  </text><a hover="For the &quot;A1&quot; variant: is the first general-purpose register to be transferred, encoded in the &quot;Rt&quot; field. This register must be even-numbered and not R14." link="Rt__3">&lt;Rt&gt;</a><text>, </text><a hover="For the &quot;A1&quot; variant: is the second general-purpose register to be transferred. This register must be &lt;R(t+1)&gt;." link="Rt2__2">&lt;Rt2&gt;</a><text>, [PC, #{</text><a hover="Specifies the offset is added to or subtracted from the base register, defaulting to + if omitted and " link="plus_or_minus_option">+/-</a><text>}</text><a hover="For the &quot;A1&quot; variant: is the 8-bit unsigned immediate byte offset, in the range 0 to 255, defaulting to 0 if omitted, and encoded in the &quot;imm4H:imm4L&quot; field." link="imm4H_imm4L__2">&lt;imm&gt;</a><text>]</text></asmtemplate>
      </encoding>
      <ps_section howmany="1">
        <ps name="A32.dp.xldst.ldstximm.LDRD_l_A1" sections="1" secttype="noheading">
          <pstext mayhavelinks="1" section="Decode" rep_section="decode">if Rt[0] == '1' then UnpredictableProcedure(); end;
let t : integer = UInt(Rt);
let t2 : integer = t + 1;
let imm32 : bits(32) = ZeroExtend{}(imm4H::imm4L);
let add : boolean = (U == '1');
if t2 == 15 then UnpredictableProcedure(); end;</pstext></ps>
      </ps_section>
      <constrained_unpredictables encoding="A1" ps_block="Decode">
        <cu_case>
          <cu_cause>
            <pstext mayhavelinks="1">Rt&lt;0&gt; == '1'</pstext></cu_cause>
          <cu_type constraint="Constraint_UNDEF"/>
          <cu_type constraint="Constraint_NOP"/>
          <cu_type constraint="Constraint_ADDITIONAL_DECODE">
            <cu_type_variable name="pseudocode" value="t&lt;0&gt; = '0';"/>
          </cu_type>
          <cu_type constraint="Constraint_ADDITIONAL_DECODE">
            <cu_type_variable name="pseudocode" value="t2 = t;"/>
          </cu_type>
          <cu_type>
            <cu_type_text>The instruction executes as described, with no change to its behavior and no additional side-effects. This does not apply when Rt == '1111'.</cu_type_text>
          </cu_type>
        </cu_case>
        <cu_case>
          <cu_cause>
            <pstext mayhavelinks="1">P == '0' || W == '1'</pstext></cu_cause>
          <cu_type constraint="Constraint_UNDEF"/>
          <cu_type constraint="Constraint_NOP"/>
          <cu_type>
            <cu_type_text>The instruction executes as if P == 1 and W == 0.'</cu_type_text>
          </cu_type>
        </cu_case>
      </constrained_unpredictables>
    </iclass>
    <iclass name="T1" oneof="2" id="iclass_t1" no_encodings="1" isa="T32">
      <docvars>
        <docvar key="address-form" value="literal"/>
        <docvar key="armarmheading" value="T1"/>
        <docvar key="instr-class" value="general"/>
        <docvar key="isa" value="T32"/>
        <docvar key="mnemonic" value="LDRD"/>
      </docvars>
      <iclassintro count="1"/>
      <regdiagram form="16x2" psname="T32.w.dstd.lddlit.LDRD_l_T1" tworows="1">
        <box hibit="31" width="3" settings="3">
          <c>1</c>
          <c>1</c>
          <c>1</c>
        </box>
        <box hibit="28" width="4" settings="4">
          <c>0</c>
          <c>1</c>
          <c>0</c>
          <c>0</c>
        </box>
        <box hibit="24" width="1" name="P" usename="1">
          <c colspan="1"/>
        </box>
        <box hibit="23" width="1" name="U" usename="1">
          <c colspan="1"/>
        </box>
        <box hibit="22" width="1" settings="1">
          <c>1</c>
        </box>
        <box hibit="21" width="1" name="W" usename="1">
          <c colspan="1"/>
        </box>
        <box hibit="20" name="L" usename="1" settings="1" psbits="x">
          <c>1</c>
        </box>
        <box hibit="19" width="4" settings="4">
          <c>1</c>
          <c>1</c>
          <c>1</c>
          <c>1</c>
        </box>
        <box hibit="15" width="4" name="Rt" usename="1">
          <c colspan="4"/>
        </box>
        <box hibit="11" width="4" name="Rt2" usename="1">
          <c colspan="4"/>
        </box>
        <box hibit="7" width="8" name="imm8" usename="1">
          <c colspan="8"/>
        </box>
      </regdiagram>
      <encoding name="LDRD_l_T1" oneofinclass="1" oneof="2" label="" bitdiffs="!(P == 0 &amp;&amp; W == 0)">
        <docvars>
          <docvar key="address-form" value="literal"/>
          <docvar key="armarmheading" value="T1"/>
          <docvar key="instr-class" value="general"/>
          <docvar key="isa" value="T32"/>
          <docvar key="mnemonic" value="LDRD"/>
        </docvars>
        <asmtemplate comment="Normal form"><text>LDRD{</text><a hover="See x[Standard assembler syntax fields](Babbefhf)." link="c__5">&lt;c&gt;</a><text>}{</text><a hover="See x[Standard assembler syntax fields](Babbefhf)." link="qw_option">&lt;q&gt;</a><text>}  </text><a hover="For the &quot;T1&quot; variant: is the first general-purpose register to be transferred, encoded in the &quot;Rt&quot; field." link="Rt__19">&lt;Rt&gt;</a><text>, </text><a hover="For the &quot;T1&quot; variant: is the second general-purpose register to be transferred, encoded in the &quot;Rt2&quot; field." link="Rt2__7">&lt;Rt2&gt;</a><text>, </text><a hover="For the &quot;T1&quot; variant: the label of the literal data item that is to be loaded into &lt;Rt&gt;. The assembler calculates the required value of the offset from the Align(PC, 4) value of the instruction to this label. Permitted values of the offset are multiples of 4 in the range -1020 to 1020." link="label__11">&lt;label&gt;</a></asmtemplate>
        <asmtemplate comment="Alternative form"><text>LDRD{</text><a hover="See x[Standard assembler syntax fields](Babbefhf)." link="c__5">&lt;c&gt;</a><text>}{</text><a hover="See x[Standard assembler syntax fields](Babbefhf)." link="qw_option">&lt;q&gt;</a><text>}  </text><a hover="For the &quot;T1&quot; variant: is the first general-purpose register to be transferred, encoded in the &quot;Rt&quot; field." link="Rt__19">&lt;Rt&gt;</a><text>, </text><a hover="For the &quot;T1&quot; variant: is the second general-purpose register to be transferred, encoded in the &quot;Rt2&quot; field." link="Rt2__7">&lt;Rt2&gt;</a><text>, [PC, #{</text><a hover="Specifies the offset is added to or subtracted from the base register, defaulting to + if omitted and " link="plus_or_minus_option">+/-</a><text>}</text><a hover="For the &quot;T1&quot; variant: is the optional 8-bit unsigned immediate byte offset, in the range 0 to 255, defaulting to 0 and encoded in the &quot;imm8&quot; field." link="imm__130">&lt;imm&gt;</a><text>]</text></asmtemplate>
      </encoding>
      <ps_section howmany="1">
        <ps name="T32.w.dstd.lddlit.LDRD_l_T1" sections="1" secttype="noheading">
          <pstext mayhavelinks="1" section="Decode" rep_section="decode">if P == '0' &amp;&amp; W == '0' then See(&quot;Related encodings&quot;); end;
let t : integer = UInt(Rt);
let t2 : integer = UInt(Rt2);
let imm32 : bits(32) = ZeroExtend{}(imm8::'00');
let add : boolean = (U == '1');
// Armv8-A removes UNPREDICTABLE for R13
if t == 15 || t2 == 15 || t == t2 then UnpredictableProcedure(); end;
if W == '1' then UnpredictableProcedure(); end;</pstext></ps>
      </ps_section>
      <constrained_unpredictables encoding="T1" ps_block="Decode">
        <cu_case>
          <cu_cause>
            <pstext mayhavelinks="1">t == t2</pstext></cu_cause>
          <cu_type constraint="Constraint_UNDEF"/>
          <cu_type constraint="Constraint_NOP"/>
          <cu_type constraint="Constraint_LDUNKNOWN"/>
        </cu_case>
        <cu_case>
          <cu_cause>
            <pstext mayhavelinks="1">W == '1'</pstext></cu_cause>
          <cu_type constraint="Constraint_UNDEF"/>
          <cu_type constraint="Constraint_NOP"/>
          <cu_type constraint="Constraint_WBSUPPRESS"/>
          <cu_type>
            <cu_type_text>The instruction uses post-indexed addressing when P == '0' and uses pre-indexed addressing otherwise. The instruction is handled as described in <xref linkend="CEGHJGEF">Using R15</xref>.</cu_type_text>
          </cu_type>
        </cu_case>
      </constrained_unpredictables>
    </iclass>
  </classes>
  <explanations scope="all">
    <explanation enclist="LDRD_l_A1, A1B_LDRD_l_A1, LDRD_l_T1, T1B_LDRD_l_T1" symboldefcount="1">
      <symbol link="c__5">&lt;c&gt;</symbol>
      <account encodedin="cond">
        <intro>
          <para>See <xref linkend="Babbefhf">Standard assembler syntax fields</xref>.</para>
        </intro>
      </account>
    </explanation>
    <explanation enclist="LDRD_l_A1, A1B_LDRD_l_A1, LDRD_l_T1, T1B_LDRD_l_T1" symboldefcount="1">
      <symbol link="qw_option">&lt;q&gt;</symbol>
      <account encodedin="">
        <intro>
          <para>See <xref linkend="Babbefhf">Standard assembler syntax fields</xref>.</para>
        </intro>
      </account>
    </explanation>
    <explanation enclist="LDRD_l_A1, A1B_LDRD_l_A1" symboldefcount="1">
      <symbol link="Rt__3">&lt;Rt&gt;</symbol>
      <account encodedin="Rt">
        <intro>
          <para>For the &quot;A1&quot; variant: is the first general-purpose register to be transferred, encoded in the &quot;Rt&quot; field. This register must be even-numbered and not R14.</para>
        </intro>
      </account>
    </explanation>
    <explanation enclist="LDRD_l_T1, T1B_LDRD_l_T1" symboldefcount="2">
      <symbol link="Rt__19">&lt;Rt&gt;</symbol>
      <account encodedin="Rt">
        <intro>
          <para>For the &quot;T1&quot; variant: is the first general-purpose register to be transferred, encoded in the &quot;Rt&quot; field.</para>
        </intro>
      </account>
    </explanation>
    <explanation enclist="LDRD_l_A1, A1B_LDRD_l_A1" symboldefcount="1">
      <symbol link="Rt2__2">&lt;Rt2&gt;</symbol>
      <account encodedin="Rt">
        <intro>
          <para>For the &quot;A1&quot; variant: is the second general-purpose register to be transferred. This register must be <syntax>&lt;R(t+1)&gt;</syntax>.</para>
        </intro>
      </account>
    </explanation>
    <explanation enclist="LDRD_l_T1, T1B_LDRD_l_T1" symboldefcount="2">
      <symbol link="Rt2__7">&lt;Rt2&gt;</symbol>
      <account encodedin="Rt2">
        <intro>
          <para>For the &quot;T1&quot; variant: is the second general-purpose register to be transferred, encoded in the &quot;Rt2&quot; field.</para>
        </intro>
      </account>
    </explanation>
    <explanation enclist="LDRD_l_A1" symboldefcount="1">
      <symbol link="imm4H_imm4L">&lt;label&gt;</symbol>
      <account encodedin="(imm4H :: imm4L)">
        <intro>
          <para>For the &quot;A1&quot; variant: the label of the literal data item that is to be loaded into <syntax>&lt;Rt&gt;</syntax>. The assembler calculates the required value of the offset from the <function>Align(PC, 4)</function> value of the instruction to this label. Any value in the range -255 to 255 is permitted.
If the offset is zero or positive, <field>imm32</field> is equal to the offset and <field>add</field> == <enumvalue>TRUE</enumvalue>, encoded as U == 1. If the offset is negative, <field>imm32</field> is equal to minus the offset and <field>add</field> == <enumvalue>FALSE</enumvalue>, encoded as U == 0.</para>
        </intro>
      </account>
    </explanation>
    <explanation enclist="LDRD_l_T1" symboldefcount="2">
      <symbol link="label__11">&lt;label&gt;</symbol>
      <account encodedin="imm8">
        <intro>
          <para>For the &quot;T1&quot; variant: the label of the literal data item that is to be loaded into <syntax>&lt;Rt&gt;</syntax>. The assembler calculates the required value of the offset from the <function>Align(PC, 4)</function> value of the instruction to this label. Permitted values of the offset are multiples of 4 in the range -1020 to 1020.</para>
          <para>If the offset is zero or positive, <field>imm32</field> is equal to the offset and <field>add</field> == <enumvalue>TRUE</enumvalue>, encoded as U == 1.</para>
          <para>If the offset is negative, <field>imm32</field> is equal to minus the offset and <field>add</field> == <enumvalue>FALSE</enumvalue>, encoded as U == 0.</para>
        </intro>
      </account>
    </explanation>
    <explanation enclist="A1B_LDRD_l_A1, T1B_LDRD_l_T1" symboldefcount="1">
      <symbol link="plus_or_minus_option">+/-</symbol>
      <definition encodedin="U">
        <intro>Specifies the offset is added to or subtracted from the base register, defaulting to + if omitted and </intro>
        <table class="valuetable">
          <tgroup cols="2">
            <thead>
              <row>
                <entry class="bitfield">U</entry>
                <entry class="symbol">+/-</entry>
              </row>
            </thead>
            <tbody>
              <row>
                <entry class="bitfield">0</entry>
                <entry class="symbol">-</entry>
              </row>
              <row>
                <entry class="bitfield">1</entry>
                <entry class="symbol">+</entry>
              </row>
            </tbody>
          </tgroup>
        </table>
      </definition>
    </explanation>
    <explanation enclist="A1B_LDRD_l_A1" symboldefcount="1">
      <symbol link="imm4H_imm4L__2">&lt;imm&gt;</symbol>
      <account encodedin="(imm4H :: imm4L)">
        <intro>
          <para>For the &quot;A1&quot; variant: is the 8-bit unsigned immediate byte offset, in the range 0 to 255, defaulting to 0 if omitted, and encoded in the &quot;imm4H:imm4L&quot; field.</para>
        </intro>
      </account>
    </explanation>
    <explanation enclist="T1B_LDRD_l_T1" symboldefcount="2">
      <symbol link="imm__130">&lt;imm&gt;</symbol>
      <account encodedin="imm8">
        <intro>
          <para>For the &quot;T1&quot; variant: is the optional 8-bit unsigned immediate byte offset, in the range 0 to 255, defaulting to 0 and encoded in the &quot;imm8&quot; field.</para>
        </intro>
      </account>
    </explanation>
  </explanations>
  <ps_section howmany="1">
    <ps name="A32.dp.xldst.ldstximm.LDRD_l_A1" sections="1" secttype="Operation">
      <pstext mayhavelinks="1" section="Execute" rep_section="execute">if <a link="func_ConditionPassed_0" file="shared_pseudocode.xml">ConditionPassed</a>() then
    EncodingSpecificOperations();
    let address : bits(32) = (if add then (AlignDownSize(<a link="func_PC32_0" file="shared_pseudocode.xml">PC32</a>(),4) + imm32)
                                     else (AlignDownSize(<a link="func_PC32_0" file="shared_pseudocode.xml">PC32</a>(),4) - imm32));
    if IsAlignedSize(address, 8) then
        let data : bits(64) = <a link="accessor_MemA_2" file="shared_pseudocode.xml">MemA</a>{64}(address);
        if <a link="func_BigEndian_1" file="shared_pseudocode.xml">BigEndian</a>(<a link="enum_AccessType_GPR" file="shared_pseudocode.xml">AccessType_GPR</a>) then
            <a link="accessor_R_1" file="shared_pseudocode.xml">R</a>(t)  = data[63:32];
            <a link="accessor_R_1" file="shared_pseudocode.xml">R</a>(t2) = data[31:0];
        else
            <a link="accessor_R_1" file="shared_pseudocode.xml">R</a>(t)  = data[31:0];
            <a link="accessor_R_1" file="shared_pseudocode.xml">R</a>(t2) = data[63:32];
        end;
    else
        let data1 : bits(32) = <a link="accessor_MemA_2" file="shared_pseudocode.xml">MemA</a>{32}(address);
        let data2 : bits(32) = <a link="accessor_MemA_2" file="shared_pseudocode.xml">MemA</a>{32}(address+4);
        <a link="accessor_R_1" file="shared_pseudocode.xml">R</a>(t)  = data1;
        <a link="accessor_R_1" file="shared_pseudocode.xml">R</a>(t2) = data2;
    end;
end;</pstext></ps>
  </ps_section>
  <timestamp>2026-03-26 20:27:25</timestamp>
  <commit_id>2026-03_rel</commit_id>
</instructionsection>