[nasm:master] x86/insns.dat: non-vector instructions from ISE 319433-046 2022-09
nasm-bot for H. Peter Anvin
hpa at zytor.com
Sat Nov 12 13:18:04 PST 2022
Commit-ID: 2b01ddf2ec0278e9db4bfb7c2be80db051189f2c
Gitweb: http://repo.or.cz/w/nasm.git?a=commitdiff;h=2b01ddf2ec0278e9db4bfb7c2be80db051189f2c
Author: H. Peter Anvin <hpa at zytor.com>
AuthorDate: Sat, 12 Nov 2022 13:15:03 -0800
Committer: H. Peter Anvin <hpa at zytor.com>
CommitDate: Sat, 12 Nov 2022 13:15:03 -0800
x86/insns.dat: non-vector instructions from ISE 319433-046 2022-09
Additional nonvector instructions from the Intel Instruction Set
Extensions document 319433-046 September 2022.
Signed-off-by: H. Peter Anvin <hpa at zytor.com>
---
x86/iflags.ph | 4 ++++
x86/insns.dat | 35 +++++++++++++++++++++++++++++++----
2 files changed, 35 insertions(+), 4 deletions(-)
diff --git a/x86/iflags.ph b/x86/iflags.ph
index 1306ed6b..a2c35c11 100644
--- a/x86/iflags.ph
+++ b/x86/iflags.ph
@@ -100,6 +100,10 @@ if_("AMXINT8", "AMX 8-bit integer multiplication");
if_("FRED", "Flexible Return and Exception Delivery (FRED)");
if_("RAOINT", "Remote atomic operations (RAO-INT)");
if_("UINTR", "User interrupts");
+if_("CMPCCXADD", "CMPccXADD instructions");
+if_("PREFETCHI", "PREFETCHI0 and PREFETCHI1");
+if_("WRMSRNS", "WRMSRNS");
+if_("MSRLIST", "RDMSRLIST and WRMSRLIST");
# Put these last to minimize their relevance
if_("OBSOLETE", "Instruction removed from architecture");
diff --git a/x86/insns.dat b/x86/insns.dat
index 0f40f995..75ae9e36 100644
--- a/x86/insns.dat
+++ b/x86/insns.dat
@@ -1636,10 +1636,12 @@ XRSTORS64 mem [m: o64 np 0f c7 /3] LONG,FUTURE
; These instructions are not SSE-specific; they are
;# Generic memory operations
; and work even if CR4.OSFXFR == 0
-PREFETCHNTA mem8 [m: 0f 18 /0] KATMAI
-PREFETCHT0 mem8 [m: 0f 18 /1] KATMAI
-PREFETCHT1 mem8 [m: 0f 18 /2] KATMAI
-PREFETCHT2 mem8 [m: 0f 18 /3] KATMAI
+PREFETCHNTA mem8 [m: 0f 18 /0] KATMAI,SB
+PREFETCHT0 mem8 [m: 0f 18 /1] KATMAI,SB
+PREFETCHT1 mem8 [m: 0f 18 /2] KATMAI,SB
+PREFETCHT2 mem8 [m: 0f 18 /3] KATMAI,SB
+PREFETCHIT0 mem8 [m: 0f 18 /7] FUTURE,PREFETCHI,SB
+PREFETCHIT1 mem8 [m: 0f 18 /6] FUTURE,PREFETCHI,SB
SFENCE void [ np 0f ae f8] KATMAI
;# New MMX instructions introduced in Katmai
@@ -6305,6 +6307,31 @@ VSUBPH zmmreg|mask|z,zmmreg*,zmmrm512|b16|er [rvm:fv: evex.nds.512.np.map5.w0 5
VSUBSH xmmreg|mask|z,xmmreg*,xmmrm16|er [rvm:t1s: evex.nds.lig.f3.map5.w0 5c /r] AVX512FP16,FUTURE
VUCOMISH xmmreg,xmmrm16|sae [rm:t1s: evex.lig.np.map5.w0 2e /r] AVX512FP16,FUTURE
+;# RAO-INT weakly ordered atomic operations
+AADD mem32,reg32 [mr: norexw np 0f 38 fc /r ] RAOINT,FUTURE,SD
+AADD mem64,reg64 [mr: o64 np 0f 38 fc /r ] RAOINT,FUTURE,SQ,LONG
+AAND mem32,reg32 [mr: norexw 66 0f 38 fc /r ] RAOINT,FUTURE,SD
+AAND mem64,reg64 [mr: o64 66 0f 38 fc /r ] RAOINT,FUTURE,SQ,LONG
+AXOR mem32,reg32 [mr: norexw f3 0f 38 fc /r ] RAOINT,FUTURE,SD
+AXOR mem64,reg64 [mr: o64 f3 0f 38 fc /r ] RAOINT,FUTURE,SQ,LONG
+
+;# User interrupts
+CLUI void [ f3 0f 01 ee ] UINTR,FUTURE,LONG
+SENDUIPI reg64 [m: o64nw f3 0f c7 /6 ] UINTR,FUTURE,LONG
+STUI void [ f3 0f 01 ef ] UINTR,FUTURE,LONG
+TESTUI void [ f3 0f 01 ed ] UINTR,FUTURE,LONG
+UIRET void [ f3 0f 01 ec ] UINTR,FUTURE,LONG
+
+
+;# Compare, exchange and add conditional
+CMPccXADD mem32,reg32,reg32 [mrv: vex.128.66.0f38.w0 e0+c /r] CMPCCXADD,FUTURE,LONG,SD
+CMPccXADD mem64,reg64,reg64 [mrv: vex.128.66.0f38.w1 e0+c /r] CMPCCXADD,FUTURE,LONG,SQ
+
+;# WRMSRNS and MSRLIST instructions
+WRMSRNS void [ np 0f 01 c6 ] WRMSRNS,FUTURE,PRIV,LONG
+RDMSRLIST void [ f2 0f 01 c6 ] MSRLIST,FUTURE,PRIV,LONG
+WRMSRLIST void [ f3 0f 01 c6 ] MSRLIST,FUTURE,PRIV,LONG
+
;# Systematic names for the hinting nop instructions
; These should be last in the file
HINT_NOP0 rm16 [m: o16 0f 18 /0] P6,UNDOC
More information about the Nasm-commits
mailing list