Added the adr instruction
All checks were successful
Central(Architecture) Docs Build / Build Documentation (push) Successful in 22s

This commit is contained in:
Elyan 2024-11-11 16:57:14 +01:00
parent 56e0c65cab
commit 48bdcb9f66
2 changed files with 50 additions and 0 deletions

View File

@ -32,11 +32,16 @@ include::instructions-operands-encoding.adoc[]
|SVC
|<<SVCINSTR>>
|ADR
|<<ADRINSTR>>
|===
<<<
include::instructions/nop.adoc[]
<<<
include::instructions/svc.adoc[]
<<<
include::instructions/adr.adoc[]
<<<
==== Memory-Related Instructions

View File

@ -0,0 +1,45 @@
[id=ADRINSTR]
===== ADR : Address from PC-relative offset
[wavedrom, ,svg]
....
{reg: [
{bits: 7, name: 0x1d, type: 8, attr: '0x1d'},
{bits: 4, name: 'off[3:0]', type: 5},
{bits: 5, name: 'dst', type: 2},
{bits: 16, name: 'off[19:4]', type: 5}
], config: {label: {right: 'ADRI'}}}
....
Description::
Constructs an absolute address from a given *pc*-relative offset and stores it in a given register.
Sets the `dst` register to the value of `pc + off`.
Encoding:: C-Type
Assembler syntax::
+
[source]
----
adr <dst>, <off>
----
+
Where:
[horizontal]
dst::: Destination register.
off:::
Immediate offset.
Must be in the range -524288..524287.
Examples::
+
[source]
----
adr r0, -48 <1>
adr r1, 0x1234 <2>
----
<1> Sets r0 to `pc - 48`.
<2> Sets r1 to `pc + 0x1234`.
Privileged instruction:: No.
Updates program state flags:: No.
Exceptions::
None.