[PATCH] D108319: [doc][GlobalISel]Improving generic opcodes for memory operations
PoojaYadav via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Sat Aug 28 08:02:50 PDT 2021
pooja2299 updated this revision to Diff 369262.
pooja2299 added a comment.
replaced GEP with G_PTR_ADD
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D108319/new/
https://reviews.llvm.org/D108319
Files:
llvm/docs/GlobalISel/GenericOpcode.rst
Index: llvm/docs/GlobalISel/GenericOpcode.rst
===================================================================
--- llvm/docs/GlobalISel/GenericOpcode.rst
+++ llvm/docs/GlobalISel/GenericOpcode.rst
@@ -657,6 +657,12 @@
operands. If the result size is larger than the memory size, the
high bits are undefined, sign-extended, or zero-extended respectively.
+.. code-block:: none
+
+ %load:_(s64) = G_LOAD %ptr(p0) :: (load (s32)) ; High 32 bits are undefined.
+ %load:_(s64) = G_SEXTLOAD %ptr(p0) :: (load (s32)) ; High 32 bits are sign-extended.
+ %load:_(s64) = G_ZEXTLOAD %ptr(p0) :: (load (s32)) ; High 32 bits are zero-extended.
+
Only G_LOAD is valid if the result is a vector type. If the result is larger
than the memory size, the high elements are undefined (i.e. this is not a
per-element, vector anyextload)
@@ -664,9 +670,15 @@
G_INDEXED_LOAD
^^^^^^^^^^^^^^
-Generic indexed load. Combines a GEP with a load. $newaddr is set to $base + $offset.
+Generic indexed load opcode combines a G_PTR_ADD with a load.
+
+.. code-block:: none
+
+ $val, $addr = G_INDEXED_LOAD $base, $offset, 1 (IsPre)
+
+$addr is set to $base + $offset.
If $am is 0 (post-indexed), then the value is loaded from $base; if $am is 1 (pre-indexed)
-then the value is loaded from $newaddr.
+then the value is loaded from $addr.
G_INDEXED_SEXTLOAD
^^^^^^^^^^^^^^^^^^
@@ -692,6 +704,10 @@
Combines a store with a GEP. See description of G_INDEXED_LOAD for indexing behaviour.
+.. code:: none
+
+ $addr = G_INDEXED_STORE $val, $base, $offset
+
G_ATOMIC_CMPXCHG_WITH_SUCCESS
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D108319.369262.patch
Type: text/x-patch
Size: 1618 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20210828/ebef2263/attachment.bin>
More information about the llvm-commits
mailing list