7
|
1 " Vim syntax file
|
1121
|
2 " Language: Microsoft Macro Assembler (80x86)
|
|
3 " Orig Author: Rob Brady <robb@datatone.com>
|
|
4 " Maintainer: Wu Yongwei <wuyongwei@gmail.com>
|
5487
|
5 " Last Change: $Date: 2013/11/13 11:49:24 $
|
|
6 " $Revision: 1.48 $
|
7
|
7
|
5487
|
8 " Quit when a syntax file was already loaded
|
|
9 if exists("b:current_syntax")
|
7
|
10 finish
|
|
11 endif
|
|
12
|
3312
|
13 let s:cpo_save = &cpo
|
|
14 set cpo&vim
|
|
15
|
7
|
16 syn case ignore
|
|
17
|
|
18
|
1121
|
19 syn match masmIdentifier "[@a-z_$?][@a-z0-9_$?]*"
|
|
20 syn match masmLabel "^\s*[@a-z_$?][@a-z0-9_$?]*:"he=e-1
|
7
|
21
|
1121
|
22 syn match masmDecimal "[-+]\?\d\+[dt]\?"
|
|
23 syn match masmBinary "[-+]\?[0-1]\+[by]" "put this before hex or 0bfh dies!
|
|
24 syn match masmOctal "[-+]\?[0-7]\+[oq]"
|
|
25 syn match masmHexadecimal "[-+]\?[0-9]\x*h"
|
|
26 syn match masmFloatRaw "[-+]\?[0-9]\x*r"
|
|
27 syn match masmFloat "[-+]\?\d\+\.\(\d*\(E[-+]\?\d\+\)\?\)\?"
|
7
|
28
|
1121
|
29 syn match masmComment ";.*" contains=@Spell
|
|
30 syn region masmComment start=+COMMENT\s*\z(\S\)+ end=+\z1.*+ contains=@Spell
|
|
31 syn region masmString start=+'+ end=+'+ oneline contains=@Spell
|
|
32 syn region masmString start=+"+ end=+"+ oneline contains=@Spell
|
7
|
33
|
1121
|
34 syn region masmTitleArea start=+\<TITLE\s+lc=5 start=+\<SUBTITLE\s+lc=8 start=+\<SUBTTL\s+lc=6 end=+$+ end=+;+me=e-1 contains=masmTitle
|
|
35 syn region masmTextArea start=+\<NAME\s+lc=4 start=+\<INCLUDE\s+lc=7 start=+\<INCLUDELIB\s+lc=10 end=+$+ end=+;+me=e-1 contains=masmText
|
1199
|
36 syn match masmTitle "[^\t ;]\([^;]*[^\t ;]\)\?" contained contains=@Spell
|
1121
|
37 syn match masmText "[^\t ;]\([^;]*[^\t ;]\)\?" contained
|
|
38
|
|
39 syn region masmOptionOpt start=+\<OPTION\s+lc=6 end=+$+ end=+;+me=e-1 contains=masmOption
|
1199
|
40 syn region masmContextOpt start=+\<PUSHCONTEXT\s+lc=11 start=+\<POPCONTEXT\s+lc=10 end=+$+ end=+;+me=e-1 contains=masmOption
|
1121
|
41 syn region masmModelOpt start=+\.MODEL\s+lc=6 end=+$+ end=+;+me=e-1 contains=masmOption,masmType
|
|
42 syn region masmSegmentOpt start=+\<SEGMENT\s+lc=7 end=+$+ end=+;+me=e-1 contains=masmOption,masmString
|
|
43 syn region masmProcOpt start=+\<PROC\s+lc=4 end=+$+ end=+;+me=e-1 contains=masmOption,masmType,masmRegister,masmIdentifier
|
1199
|
44 syn region masmAssumeOpt start=+\<ASSUME\s+lc=6 end=+$+ end=+;+me=e-1 contains=masmOption,masmOperator,masmType,masmRegister,masmIdentifier
|
1121
|
45 syn region masmExpression start=+\.IF\s+lc=3 start=+\.WHILE\s+lc=6 start=+\.UNTIL\s+lc=6 start=+\<IF\s+lc=2 start=+\<IF2\s+lc=3 start=+\<ELSEIF\s+lc=6 start=+\<ELSEIF2\s+lc=7 start=+\<REPEAT\s+lc=6 start=+\<WHILE\s+lc=5 end=+$+ end=+;+me=e-1 contains=masmType,masmOperator,masmRegister,masmIdentifier,masmDecimal,masmBinary,masmHexadecimal,masmFloatRaw,masmString
|
7
|
46
|
1121
|
47 syn keyword masmOption TINY SMALL COMPACT MEDIUM LARGE HUGE contained
|
|
48 syn keyword masmOption NEARSTACK FARSTACK contained
|
|
49 syn keyword masmOption PUBLIC PRIVATE STACK COMMON MEMORY AT contained
|
|
50 syn keyword masmOption BYTE WORD DWORD PARA PAGE contained
|
|
51 syn keyword masmOption USE16 USE32 FLAT contained
|
|
52 syn keyword masmOption INFO READ WRITE EXECUTE SHARED contained
|
|
53 syn keyword masmOption NOPAGE NOCACHE DISCARD contained
|
|
54 syn keyword masmOption READONLY USES FRAME contained
|
|
55 syn keyword masmOption CASEMAP DOTNAME NODOTNAME EMULATOR contained
|
|
56 syn keyword masmOption NOEMULATOR EPILOGUE EXPR16 EXPR32 contained
|
|
57 syn keyword masmOption LANGUAGE LJMP NOLJMP M510 NOM510 contained
|
|
58 syn keyword masmOption NOKEYWORD NOSIGNEXTEND OFFSET contained
|
|
59 syn keyword masmOption OLDMACROS NOOLDMACROS OLDSTRUCTS contained
|
|
60 syn keyword masmOption NOOLDSTRUCTS PROC PROLOGUE READONLY contained
|
|
61 syn keyword masmOption NOREADONLY SCOPED NOSCOPED SEGMENT contained
|
|
62 syn keyword masmOption SETIF2 contained
|
1199
|
63 syn keyword masmOption ABS ALL ASSUMES CPU ERROR EXPORT contained
|
|
64 syn keyword masmOption FORCEFRAME LISTING LOADDS NONE contained
|
|
65 syn keyword masmOption NONUNIQUE NOTHING OS_DOS RADIX REQ contained
|
1121
|
66 syn keyword masmType STDCALL SYSCALL C BASIC FORTRAN PASCAL
|
|
67 syn keyword masmType PTR NEAR FAR NEAR16 FAR16 NEAR32 FAR32
|
|
68 syn keyword masmType REAL4 REAL8 REAL10 BYTE SBYTE TBYTE
|
|
69 syn keyword masmType WORD DWORD QWORD FWORD SWORD SDWORD
|
|
70 syn keyword masmOperator AND NOT OR SHL SHR XOR MOD DUP
|
|
71 syn keyword masmOperator EQ GE GT LE LT NE
|
|
72 syn keyword masmOperator LROFFSET SEG LENGTH LENGTHOF SIZE SIZEOF
|
|
73 syn keyword masmOperator CODEPTR DATAPTR FAR NEAR SHORT THIS TYPE
|
|
74 syn keyword masmOperator HIGH HIGHWORD LOW LOWWORD OPATTR MASK WIDTH
|
|
75 syn match masmOperator "OFFSET\(\sFLAT:\)\?"
|
|
76 syn match masmOperator ".TYPE\>"
|
|
77 syn match masmOperator "CARRY?"
|
|
78 syn match masmOperator "OVERFLOW?"
|
|
79 syn match masmOperator "PARITY?"
|
|
80 syn match masmOperator "SIGN?"
|
|
81 syn match masmOperator "ZERO?"
|
|
82 syn keyword masmDirective ALIAS ASSUME CATSTR COMM DB DD DF DOSSEG DQ DT
|
|
83 syn keyword masmDirective DW ECHO ELSE ELSEIF ELSEIF1 ELSEIF2 ELSEIFB
|
|
84 syn keyword masmDirective ELSEIFDEF ELSEIFDIF ELSEIFDIFI ELSEIFE
|
|
85 syn keyword masmDirective ELSEIFIDN ELSEIFIDNI ELSEIFNB ELSEIFNDEF END
|
|
86 syn keyword masmDirective ENDIF ENDM ENDP ENDS EQU EVEN EXITM EXTERN
|
|
87 syn keyword masmDirective EXTERNDEF EXTRN FOR FORC GOTO GROUP IF IF1 IF2
|
|
88 syn keyword masmDirective IFB IFDEF IFDIF IFDIFI IFE IFIDN IFIDNI IFNB
|
|
89 syn keyword masmDirective IFNDEF INCLUDE INCLUDELIB INSTR INVOKE IRP
|
|
90 syn keyword masmDirective IRPC LABEL LOCAL MACRO NAME OPTION ORG PAGE
|
|
91 syn keyword masmDirective POPCONTEXT PROC PROTO PUBLIC PURGE PUSHCONTEXT
|
|
92 syn keyword masmDirective RECORD REPEAT REPT SEGMENT SIZESTR STRUC
|
|
93 syn keyword masmDirective STRUCT SUBSTR SUBTITLE SUBTTL TEXTEQU TITLE
|
|
94 syn keyword masmDirective TYPEDEF UNION WHILE
|
|
95 syn match masmDirective "\.8086\>"
|
|
96 syn match masmDirective "\.8087\>"
|
|
97 syn match masmDirective "\.NO87\>"
|
|
98 syn match masmDirective "\.186\>"
|
|
99 syn match masmDirective "\.286\>"
|
|
100 syn match masmDirective "\.286C\>"
|
|
101 syn match masmDirective "\.286P\>"
|
|
102 syn match masmDirective "\.287\>"
|
|
103 syn match masmDirective "\.386\>"
|
|
104 syn match masmDirective "\.386C\>"
|
|
105 syn match masmDirective "\.386P\>"
|
|
106 syn match masmDirective "\.387\>"
|
|
107 syn match masmDirective "\.486\>"
|
|
108 syn match masmDirective "\.486P\>"
|
|
109 syn match masmDirective "\.586\>"
|
|
110 syn match masmDirective "\.586P\>"
|
|
111 syn match masmDirective "\.686\>"
|
|
112 syn match masmDirective "\.686P\>"
|
|
113 syn match masmDirective "\.K3D\>"
|
|
114 syn match masmDirective "\.MMX\>"
|
|
115 syn match masmDirective "\.XMM\>"
|
|
116 syn match masmDirective "\.ALPHA\>"
|
|
117 syn match masmDirective "\.DOSSEG\>"
|
|
118 syn match masmDirective "\.SEQ\>"
|
|
119 syn match masmDirective "\.CODE\>"
|
|
120 syn match masmDirective "\.CONST\>"
|
|
121 syn match masmDirective "\.DATA\>"
|
|
122 syn match masmDirective "\.DATA?"
|
|
123 syn match masmDirective "\.EXIT\>"
|
|
124 syn match masmDirective "\.FARDATA\>"
|
|
125 syn match masmDirective "\.FARDATA?"
|
|
126 syn match masmDirective "\.MODEL\>"
|
|
127 syn match masmDirective "\.STACK\>"
|
|
128 syn match masmDirective "\.STARTUP\>"
|
|
129 syn match masmDirective "\.IF\>"
|
|
130 syn match masmDirective "\.ELSE\>"
|
|
131 syn match masmDirective "\.ELSEIF\>"
|
|
132 syn match masmDirective "\.ENDIF\>"
|
|
133 syn match masmDirective "\.REPEAT\>"
|
|
134 syn match masmDirective "\.UNTIL\>"
|
|
135 syn match masmDirective "\.UNTILCXZ\>"
|
|
136 syn match masmDirective "\.WHILE\>"
|
|
137 syn match masmDirective "\.ENDW\>"
|
|
138 syn match masmDirective "\.BREAK\>"
|
|
139 syn match masmDirective "\.CONTINUE\>"
|
|
140 syn match masmDirective "\.ERR\>"
|
|
141 syn match masmDirective "\.ERR1\>"
|
|
142 syn match masmDirective "\.ERR2\>"
|
|
143 syn match masmDirective "\.ERRB\>"
|
|
144 syn match masmDirective "\.ERRDEF\>"
|
|
145 syn match masmDirective "\.ERRDIF\>"
|
|
146 syn match masmDirective "\.ERRDIFI\>"
|
|
147 syn match masmDirective "\.ERRE\>"
|
|
148 syn match masmDirective "\.ERRIDN\>"
|
|
149 syn match masmDirective "\.ERRIDNI\>"
|
|
150 syn match masmDirective "\.ERRNB\>"
|
|
151 syn match masmDirective "\.ERRNDEF\>"
|
|
152 syn match masmDirective "\.ERRNZ\>"
|
|
153 syn match masmDirective "\.LALL\>"
|
|
154 syn match masmDirective "\.SALL\>"
|
|
155 syn match masmDirective "\.XALL\>"
|
|
156 syn match masmDirective "\.LFCOND\>"
|
|
157 syn match masmDirective "\.SFCOND\>"
|
|
158 syn match masmDirective "\.TFCOND\>"
|
|
159 syn match masmDirective "\.CREF\>"
|
|
160 syn match masmDirective "\.NOCREF\>"
|
|
161 syn match masmDirective "\.XCREF\>"
|
|
162 syn match masmDirective "\.LIST\>"
|
|
163 syn match masmDirective "\.NOLIST\>"
|
|
164 syn match masmDirective "\.XLIST\>"
|
|
165 syn match masmDirective "\.LISTALL\>"
|
|
166 syn match masmDirective "\.LISTIF\>"
|
|
167 syn match masmDirective "\.NOLISTIF\>"
|
|
168 syn match masmDirective "\.LISTMACRO\>"
|
|
169 syn match masmDirective "\.NOLISTMACRO\>"
|
|
170 syn match masmDirective "\.LISTMACROALL\>"
|
|
171 syn match masmDirective "\.FPO\>"
|
|
172 syn match masmDirective "\.RADIX\>"
|
|
173 syn match masmDirective "\.SAFESEH\>"
|
|
174 syn match masmDirective "%OUT\>"
|
|
175 syn match masmDirective "ALIGN\>"
|
|
176 syn match masmOption "ALIGN([0-9]\+)"
|
7
|
177
|
|
178 syn keyword masmRegister AX BX CX DX SI DI BP SP
|
1121
|
179 syn keyword masmRegister CS DS SS ES FS GS
|
7
|
180 syn keyword masmRegister AH BH CH DH AL BL CL DL
|
|
181 syn keyword masmRegister EAX EBX ECX EDX ESI EDI EBP ESP
|
1121
|
182 syn keyword masmRegister CR0 CR2 CR3 CR4
|
|
183 syn keyword masmRegister DR0 DR1 DR2 DR3 DR6 DR7
|
|
184 syn keyword masmRegister TR3 TR4 TR5 TR6 TR7
|
|
185 syn match masmRegister "ST([0-7])"
|
7
|
186
|
3312
|
187 " x86-64 registers
|
|
188 syn keyword masmRegister RAX RBX RCX RDX RSI RDI RBP RSP
|
|
189 syn keyword masmRegister R8 R9 R10 R11 R12 R13 R14 R15
|
|
190 syn keyword masmRegister R8D R9D R10D R11D R12D R13D R14D R15D
|
|
191 syn keyword masmRegister R8W R9W R10W R11W R12W R13W R14W R15W
|
|
192 syn keyword masmRegister R8B R9B R10B R11B R12B R13B R14B R15B
|
7
|
193
|
5487
|
194 " SSE/AVX registers
|
|
195 syn match masmRegister "\(X\|Y\)MM[0-9]\>"
|
|
196 syn match masmRegister "\(X\|Y\)MM1[0-5]\>"
|
|
197
|
1121
|
198 " Instruction prefixes
|
|
199 syn keyword masmOpcode LOCK REP REPE REPNE REPNZ REPZ
|
|
200
|
|
201 " 8086/8088 opcodes
|
|
202 syn keyword masmOpcode AAA AAD AAM AAS ADC ADD AND CALL CBW CLC CLD
|
|
203 syn keyword masmOpcode CLI CMC CMP CMPS CMPSB CMPSW CWD DAA DAS DEC
|
|
204 syn keyword masmOpcode DIV ESC HLT IDIV IMUL IN INC INT INTO IRET
|
|
205 syn keyword masmOpcode JCXZ JMP LAHF LDS LEA LES LODS LODSB LODSW
|
|
206 syn keyword masmOpcode LOOP LOOPE LOOPEW LOOPNE LOOPNEW LOOPNZ
|
|
207 syn keyword masmOpcode LOOPNZW LOOPW LOOPZ LOOPZW MOV MOVS MOVSB
|
|
208 syn keyword masmOpcode MOVSW MUL NEG NOP NOT OR OUT POP POPF PUSH
|
|
209 syn keyword masmOpcode PUSHF RCL RCR RET RETF RETN ROL ROR SAHF SAL
|
|
210 syn keyword masmOpcode SAR SBB SCAS SCASB SCASW SHL SHR STC STD STI
|
|
211 syn keyword masmOpcode STOS STOSB STOSW SUB TEST WAIT XCHG XLAT XLATB
|
|
212 syn keyword masmOpcode XOR
|
|
213 syn match masmOpcode "J\(P[EO]\|\(N\?\([ABGL]E\?\|[CEOPSZ]\)\)\)\>"
|
7
|
214
|
1121
|
215 " 80186 opcodes
|
|
216 syn keyword masmOpcode BOUND ENTER INS INSB INSW LEAVE OUTS OUTSB
|
|
217 syn keyword masmOpcode OUTSW POPA PUSHA PUSHW
|
|
218
|
|
219 " 80286 opcodes
|
|
220 syn keyword masmOpcode ARPL LAR LSL SGDT SIDT SLDT SMSW STR VERR VERW
|
|
221
|
|
222 " 80286/80386 privileged opcodes
|
|
223 syn keyword masmOpcode CLTS LGDT LIDT LLDT LMSW LTR
|
|
224
|
|
225 " 80386 opcodes
|
|
226 syn keyword masmOpcode BSF BSR BT BTC BTR BTS CDQ CMPSD CWDE INSD
|
|
227 syn keyword masmOpcode IRETD IRETDF IRETF JECXZ LFS LGS LODSD LOOPD
|
|
228 syn keyword masmOpcode LOOPED LOOPNED LOOPNZD LOOPZD LSS MOVSD MOVSX
|
|
229 syn keyword masmOpcode MOVZX OUTSD POPAD POPFD PUSHAD PUSHD PUSHFD
|
|
230 syn keyword masmOpcode SCASD SHLD SHRD STOSD
|
|
231 syn match masmOpcode "SET\(P[EO]\|\(N\?\([ABGL]E\?\|[CEOPSZ]\)\)\)\>"
|
|
232
|
|
233 " 80486 opcodes
|
|
234 syn keyword masmOpcode BSWAP CMPXCHG INVD INVLPG WBINVD XADD
|
|
235
|
|
236 " Floating-point opcodes as of 487
|
7
|
237 syn keyword masmOpFloat F2XM1 FABS FADD FADDP FBLD FBSTP FCHS FCLEX
|
|
238 syn keyword masmOpFloat FNCLEX FCOM FCOMP FCOMPP FCOS FDECSTP FDISI
|
|
239 syn keyword masmOpFloat FNDISI FDIV FDIVP FDIVR FDIVRP FENI FNENI
|
|
240 syn keyword masmOpFloat FFREE FIADD FICOM FICOMP FIDIV FIDIVR FILD
|
|
241 syn keyword masmOpFloat FIMUL FINCSTP FINIT FNINIT FIST FISTP FISUB
|
|
242 syn keyword masmOpFloat FISUBR FLD FLDCW FLDENV FLDLG2 FLDLN2 FLDL2E
|
|
243 syn keyword masmOpFloat FLDL2T FLDPI FLDZ FLD1 FMUL FMULP FNOP FPATAN
|
1121
|
244 syn keyword masmOpFloat FPREM FPREM1 FPTAN FRNDINT FRSTOR FSAVE FNSAVE
|
|
245 syn keyword masmOpFloat FSCALE FSETPM FSIN FSINCOS FSQRT FST FSTCW
|
|
246 syn keyword masmOpFloat FNSTCW FSTENV FNSTENV FSTP FSTSW FNSTSW FSUB
|
|
247 syn keyword masmOpFloat FSUBP FSUBR FSUBRP FTST FUCOM FUCOMP FUCOMPP
|
|
248 syn keyword masmOpFloat FWAIT FXAM FXCH FXTRACT FYL2X FYL2XP1
|
|
249
|
|
250 " Floating-point opcodes in Pentium and later processors
|
|
251 syn keyword masmOpFloat FCMOVE FCMOVNE FCMOVB FCMOVBE FCMOVNB FCMOVNBE
|
|
252 syn keyword masmOpFloat FCMOVU FCMOVNU FCOMI FUCOMI FCOMIP FUCOMIP
|
|
253 syn keyword masmOpFloat FXSAVE FXRSTOR
|
|
254
|
|
255 " MMX opcodes (Pentium w/ MMX, Pentium II, and later)
|
|
256 syn keyword masmOpcode MOVD MOVQ PACKSSWB PACKSSDW PACKUSWB
|
|
257 syn keyword masmOpcode PUNPCKHBW PUNPCKHWD PUNPCKHDQ
|
|
258 syn keyword masmOpcode PUNPCKLBW PUNPCKLWD PUNPCKLDQ
|
|
259 syn keyword masmOpcode PADDB PADDW PADDD PADDSB PADDSW PADDUSB PADDUSW
|
|
260 syn keyword masmOpcode PSUBB PSUBW PSUBD PSUBSB PSUBSW PSUBUSB PSUBUSW
|
|
261 syn keyword masmOpcode PMULHW PMULLW PMADDWD
|
|
262 syn keyword masmOpcode PCMPEQB PCMPEQW PCMPEQD PCMPGTB PCMPGTW PCMPGTD
|
|
263 syn keyword masmOpcode PAND PANDN POR PXOR
|
|
264 syn keyword masmOpcode PSLLW PSLLD PSLLQ PSRLW PSRLD PSRLQ PSRAW PSRAD
|
|
265 syn keyword masmOpcode EMMS
|
|
266
|
|
267 " SSE opcodes (Pentium III and later)
|
|
268 syn keyword masmOpcode MOVAPS MOVUPS MOVHPS MOVHLPS MOVLPS MOVLHPS
|
|
269 syn keyword masmOpcode MOVMSKPS MOVSS
|
|
270 syn keyword masmOpcode ADDPS ADDSS SUBPS SUBSS MULPS MULSS DIVPS DIVSS
|
|
271 syn keyword masmOpcode RCPPS RCPSS SQRTPS SQRTSS RSQRTPS RSQRTSS
|
|
272 syn keyword masmOpcode MAXPS MAXSS MINPS MINSS
|
|
273 syn keyword masmOpcode CMPPS CMPSS COMISS UCOMISS
|
|
274 syn keyword masmOpcode ANDPS ANDNPS ORPS XORPS
|
|
275 syn keyword masmOpcode SHUFPS UNPCKHPS UNPCKLPS
|
|
276 syn keyword masmOpcode CVTPI2PS CVTSI2SS CVTPS2PI CVTTPS2PI
|
|
277 syn keyword masmOpcode CVTSS2SI CVTTSS2SI
|
|
278 syn keyword masmOpcode LDMXCSR STMXCSR
|
|
279 syn keyword masmOpcode PAVGB PAVGW PEXTRW PINSRW PMAXUB PMAXSW
|
|
280 syn keyword masmOpcode PMINUB PMINSW PMOVMSKB PMULHUW PSADBW PSHUFW
|
|
281 syn keyword masmOpcode MASKMOVQ MOVNTQ MOVNTPS SFENCE
|
|
282 syn keyword masmOpcode PREFETCHT0 PREFETCHT1 PREFETCHT2 PREFETCHNTA
|
|
283
|
|
284 " SSE2 opcodes (Pentium 4 and later)
|
|
285 syn keyword masmOpcode MOVAPD MOVUPD MOVHPD MOVLPD MOVMSKPD MOVSD
|
|
286 syn keyword masmOpcode ADDPD ADDSD SUBPD SUBSD MULPD MULSD DIVPD DIVSD
|
|
287 syn keyword masmOpcode SQRTPD SQRTSD MAXPD MAXSD MINPD MINSD
|
|
288 syn keyword masmOpcode ANDPD ANDNPD ORPD XORPD
|
|
289 syn keyword masmOpcode CMPPD CMPSD COMISD UCOMISD
|
|
290 syn keyword masmOpcode SHUFPD UNPCKHPD UNPCKLPD
|
|
291 syn keyword masmOpcode CVTPD2PI CVTTPD2PI CVTPI2PD CVTPD2DQ
|
|
292 syn keyword masmOpcode CVTTPD2DQ CVTDQ2PD CVTPS2PD CVTPD2PS
|
|
293 syn keyword masmOpcode CVTSS2SD CVTSD2SS CVTSD2SI CVTTSD2SI CVTSI2SD
|
|
294 syn keyword masmOpcode CVTDQ2PS CVTPS2DQ CVTTPS2DQ
|
|
295 syn keyword masmOpcode MOVDQA MOVDQU MOVQ2DQ MOVDQ2Q PMULUDQ
|
|
296 syn keyword masmOpcode PADDQ PSUBQ PSHUFLW PSHUFHW PSHUFD
|
|
297 syn keyword masmOpcode PSLLDQ PSRLDQ PUNPCKHQDQ PUNPCKLQDQ
|
|
298 syn keyword masmOpcode CLFLUSH LFENCE MFENCE PAUSE MASKMOVDQU
|
|
299 syn keyword masmOpcode MOVNTPD MOVNTDQ MOVNTI
|
|
300
|
|
301 " SSE3 opcodes (Pentium 4 w/ Hyper-Threading and later)
|
|
302 syn keyword masmOpcode FISTTP LDDQU ADDSUBPS ADDSUBPD
|
|
303 syn keyword masmOpcode HADDPS HSUBPS HADDPD HSUBPD
|
|
304 syn keyword masmOpcode MOVSHDUP MOVSLDUP MOVDDUP MONITOR MWAIT
|
|
305
|
5487
|
306 " SSSE3 opcodes (Core and later)
|
|
307 syn keyword masmOpcode PSIGNB PSIGNW PSIGND PABSB PABSW PABSD
|
|
308 syn keyword masmOpcode PALIGNR PSHUFB PMULHRSW PMADDUBSW
|
|
309 syn keyword masmOpcode PHSUBW PHSUBD PHSUBSW PHADDW PHADDD PHADDSW
|
|
310
|
|
311 " SSE 4.1 opcodes (Penryn and later)
|
|
312 syn keyword masmOpcode MPSADBW PHMINPOSUW PMULDQ PMULLD DPPS DPPD
|
|
313 syn keyword masmOpcode BLENDPS BLENDPD BLENDVPS BLENDVPD
|
|
314 syn keyword masmOpcode PBLENDVB PBLENDW
|
|
315 syn keyword masmOpcode PMINSB PMAXSB PMINSD PMAXSD
|
|
316 syn keyword masmOpcode PMINUW PMAXUW PMINUD PMAXUD
|
|
317 syn keyword masmOpcode ROUNDPS ROUNDSS ROUNDPD ROUNDSD
|
|
318 syn keyword masmOpcode INSERTPS PINSRB PINSRD PINSRQ
|
|
319 syn keyword masmOpcode EXTRACTPS PEXTRB PEXTRD PEXTRQ
|
|
320 syn keyword masmOpcode PMOVSXBW PMOVZXBW PMOVSXBD PMOVZXBD
|
|
321 syn keyword masmOpcode PMOVSXBQ PMOVZXBQ PMOVSXWD PMOVZXWD
|
|
322 syn keyword masmOpcode PMOVSXWQ PMOVZXWQ PMOVSXDQ PMOVZXDQ
|
|
323 syn keyword masmOpcode PTEST PCMPEQQ PACKUSDW MOVNTDQA
|
|
324
|
|
325 " SSE 4.2 opcodes (Nehalem and later)
|
|
326 syn keyword masmOpcode PCMPESTRI PCMPESTRM PCMPISTRI PCMPISTRM PCMPGTQ
|
|
327 syn keyword masmOpcode CRC32 POPCNT LZCNT
|
|
328
|
|
329 " AES-NI (Westmere (2010) and later)
|
|
330 syn keyword masmOpcode AESENC AESENCLAST AESDEC AESDECLAST
|
|
331 syn keyword masmOpcode AESKEYGENASSIST AESIMC PCLMULQDQ
|
|
332
|
|
333 " AVX (Sandy Bridge (2011) and later)
|
|
334 syn keyword masmOpcode VBROADCASTSS VBROADCASTSD VBROADCASTF128
|
|
335 syn keyword masmOpcode VINSERTF128 VEXTRACTF128 VMASKMOVPS VMASKMOVPD
|
|
336 syn keyword masmOpcode VPERMILPS VPERMILPD VPERM2F128
|
|
337 syn keyword masmOpcode VZEROALL VZEROUPPER
|
|
338
|
1121
|
339 " Other opcodes in Pentium and later processors
|
|
340 syn keyword masmOpcode CMPXCHG8B CPUID UD2
|
|
341 syn keyword masmOpcode RSM RDMSR WRMSR RDPMC RDTSC SYSENTER SYSEXIT
|
|
342 syn match masmOpcode "CMOV\(P[EO]\|\(N\?\([ABGL]E\?\|[CEOPSZ]\)\)\)\>"
|
|
343
|
7
|
344
|
5487
|
345 " The default highlighting
|
|
346 hi def link masmLabel PreProc
|
|
347 hi def link masmComment Comment
|
|
348 hi def link masmDirective Statement
|
|
349 hi def link masmType Type
|
|
350 hi def link masmOperator Type
|
|
351 hi def link masmOption Special
|
|
352 hi def link masmRegister Special
|
|
353 hi def link masmString String
|
|
354 hi def link masmText String
|
|
355 hi def link masmTitle Title
|
|
356 hi def link masmOpcode Statement
|
|
357 hi def link masmOpFloat Statement
|
7
|
358
|
5487
|
359 hi def link masmHexadecimal Number
|
|
360 hi def link masmDecimal Number
|
|
361 hi def link masmOctal Number
|
|
362 hi def link masmBinary Number
|
|
363 hi def link masmFloatRaw Number
|
|
364 hi def link masmFloat Number
|
7
|
365
|
5487
|
366 hi def link masmIdentifier Identifier
|
7
|
367
|
5487
|
368 syntax sync minlines=50
|
7
|
369
|
|
370 let b:current_syntax = "masm"
|
|
371
|
3312
|
372 let &cpo = s:cpo_save
|
|
373 unlet s:cpo_save
|
|
374
|
7
|
375 " vim: ts=8
|