blob: 85e457106d8bd25c7b6de8356f5fa9baa9862caf [file] [log] [blame]
Bram Moolenaar071d4272004-06-13 20:20:40 +00001" Vim syntax file
Bram Moolenaar9964e462007-05-05 17:54:07 +00002" Language: Microsoft Macro Assembler (80x86)
3" Orig Author: Rob Brady <robb@datatone.com>
4" Maintainer: Wu Yongwei <wuyongwei@gmail.com>
Wu Yongweie7833e72023-09-11 00:27:31 +08005" Last Change: 2023-09-09 20:48:26 +0800
Bram Moolenaar071d4272004-06-13 20:20:40 +00006
Bram Moolenaar4b60a6c2013-11-14 05:48:46 +01007" Quit when a syntax file was already loaded
8if exists("b:current_syntax")
Bram Moolenaar071d4272004-06-13 20:20:40 +00009 finish
10endif
11
Bram Moolenaarb8ff1fb2012-02-04 21:59:01 +010012let s:cpo_save = &cpo
13set cpo&vim
14
Bram Moolenaar47e13952020-05-12 22:49:12 +020015syn iskeyword @,48-57,_,36,60,62,63,@-@
Bram Moolenaar2cfb4a22020-05-07 18:56:00 +020016
Bram Moolenaar071d4272004-06-13 20:20:40 +000017syn case ignore
18
19
Bram Moolenaar2cfb4a22020-05-07 18:56:00 +020020syn match masmIdentifier "[@a-z_$?][@a-z0-9_$?<>]*"
Bram Moolenaar9964e462007-05-05 17:54:07 +000021syn match masmLabel "^\s*[@a-z_$?][@a-z0-9_$?]*:"he=e-1
Bram Moolenaar071d4272004-06-13 20:20:40 +000022
Bram Moolenaar9964e462007-05-05 17:54:07 +000023syn match masmDecimal "[-+]\?\d\+[dt]\?"
24syn match masmBinary "[-+]\?[0-1]\+[by]" "put this before hex or 0bfh dies!
25syn match masmOctal "[-+]\?[0-7]\+[oq]"
26syn match masmHexadecimal "[-+]\?[0-9]\x*h"
27syn match masmFloatRaw "[-+]\?[0-9]\x*r"
28syn match masmFloat "[-+]\?\d\+\.\(\d*\(E[-+]\?\d\+\)\?\)\?"
Bram Moolenaar071d4272004-06-13 20:20:40 +000029
Bram Moolenaar9964e462007-05-05 17:54:07 +000030syn match masmComment ";.*" contains=@Spell
31syn region masmComment start=+COMMENT\s*\z(\S\)+ end=+\z1.*+ contains=@Spell
32syn region masmString start=+'+ end=+'+ oneline contains=@Spell
33syn region masmString start=+"+ end=+"+ oneline contains=@Spell
Bram Moolenaar071d4272004-06-13 20:20:40 +000034
Bram Moolenaar9964e462007-05-05 17:54:07 +000035syn region masmTitleArea start=+\<TITLE\s+lc=5 start=+\<SUBTITLE\s+lc=8 start=+\<SUBTTL\s+lc=6 end=+$+ end=+;+me=e-1 contains=masmTitle
36syn region masmTextArea start=+\<NAME\s+lc=4 start=+\<INCLUDE\s+lc=7 start=+\<INCLUDELIB\s+lc=10 end=+$+ end=+;+me=e-1 contains=masmText
Bram Moolenaarff1d0d42007-05-10 17:24:16 +000037syn match masmTitle "[^\t ;]\([^;]*[^\t ;]\)\?" contained contains=@Spell
Bram Moolenaar9964e462007-05-05 17:54:07 +000038syn match masmText "[^\t ;]\([^;]*[^\t ;]\)\?" contained
Bram Moolenaar071d4272004-06-13 20:20:40 +000039
Bram Moolenaar9964e462007-05-05 17:54:07 +000040syn region masmOptionOpt start=+\<OPTION\s+lc=6 end=+$+ end=+;+me=e-1 contains=masmOption
Bram Moolenaarff1d0d42007-05-10 17:24:16 +000041syn region masmContextOpt start=+\<PUSHCONTEXT\s+lc=11 start=+\<POPCONTEXT\s+lc=10 end=+$+ end=+;+me=e-1 contains=masmOption
Bram Moolenaar9964e462007-05-05 17:54:07 +000042syn region masmModelOpt start=+\.MODEL\s+lc=6 end=+$+ end=+;+me=e-1 contains=masmOption,masmType
43syn region masmSegmentOpt start=+\<SEGMENT\s+lc=7 end=+$+ end=+;+me=e-1 contains=masmOption,masmString
44syn region masmProcOpt start=+\<PROC\s+lc=4 end=+$+ end=+;+me=e-1 contains=masmOption,masmType,masmRegister,masmIdentifier
Bram Moolenaarff1d0d42007-05-10 17:24:16 +000045syn region masmAssumeOpt start=+\<ASSUME\s+lc=6 end=+$+ end=+;+me=e-1 contains=masmOption,masmOperator,masmType,masmRegister,masmIdentifier
Bram Moolenaar9964e462007-05-05 17:54:07 +000046syn 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
47
48syn keyword masmOption TINY SMALL COMPACT MEDIUM LARGE HUGE contained
49syn keyword masmOption NEARSTACK FARSTACK contained
50syn keyword masmOption PUBLIC PRIVATE STACK COMMON MEMORY AT contained
51syn keyword masmOption BYTE WORD DWORD PARA PAGE contained
52syn keyword masmOption USE16 USE32 FLAT contained
53syn keyword masmOption INFO READ WRITE EXECUTE SHARED contained
54syn keyword masmOption NOPAGE NOCACHE DISCARD contained
55syn keyword masmOption READONLY USES FRAME contained
56syn keyword masmOption CASEMAP DOTNAME NODOTNAME EMULATOR contained
57syn keyword masmOption NOEMULATOR EPILOGUE EXPR16 EXPR32 contained
58syn keyword masmOption LANGUAGE LJMP NOLJMP M510 NOM510 contained
59syn keyword masmOption NOKEYWORD NOSIGNEXTEND OFFSET contained
60syn keyword masmOption OLDMACROS NOOLDMACROS OLDSTRUCTS contained
61syn keyword masmOption NOOLDSTRUCTS PROC PROLOGUE READONLY contained
62syn keyword masmOption NOREADONLY SCOPED NOSCOPED SEGMENT contained
63syn keyword masmOption SETIF2 contained
Bram Moolenaarff1d0d42007-05-10 17:24:16 +000064syn keyword masmOption ABS ALL ASSUMES CPU ERROR EXPORT contained
65syn keyword masmOption FORCEFRAME LISTING LOADDS NONE contained
66syn keyword masmOption NONUNIQUE NOTHING OS_DOS RADIX REQ contained
Bram Moolenaar9964e462007-05-05 17:54:07 +000067syn keyword masmType STDCALL SYSCALL C BASIC FORTRAN PASCAL
68syn keyword masmType PTR NEAR FAR NEAR16 FAR16 NEAR32 FAR32
69syn keyword masmType REAL4 REAL8 REAL10 BYTE SBYTE TBYTE
70syn keyword masmType WORD DWORD QWORD FWORD SWORD SDWORD
Bram Moolenaarce001a32022-04-27 15:25:03 +010071syn keyword masmType SQWORD OWORD MMWORD XMMWORD YMMWORD
Bram Moolenaar9964e462007-05-05 17:54:07 +000072syn keyword masmOperator AND NOT OR SHL SHR XOR MOD DUP
73syn keyword masmOperator EQ GE GT LE LT NE
74syn keyword masmOperator LROFFSET SEG LENGTH LENGTHOF SIZE SIZEOF
75syn keyword masmOperator CODEPTR DATAPTR FAR NEAR SHORT THIS TYPE
76syn keyword masmOperator HIGH HIGHWORD LOW LOWWORD OPATTR MASK WIDTH
77syn match masmOperator "OFFSET\(\sFLAT:\)\?"
78syn match masmOperator ".TYPE\>"
79syn match masmOperator "CARRY?"
80syn match masmOperator "OVERFLOW?"
81syn match masmOperator "PARITY?"
82syn match masmOperator "SIGN?"
83syn match masmOperator "ZERO?"
84syn keyword masmDirective ALIAS ASSUME CATSTR COMM DB DD DF DOSSEG DQ DT
85syn keyword masmDirective DW ECHO ELSE ELSEIF ELSEIF1 ELSEIF2 ELSEIFB
86syn keyword masmDirective ELSEIFDEF ELSEIFDIF ELSEIFDIFI ELSEIFE
87syn keyword masmDirective ELSEIFIDN ELSEIFIDNI ELSEIFNB ELSEIFNDEF END
88syn keyword masmDirective ENDIF ENDM ENDP ENDS EQU EVEN EXITM EXTERN
89syn keyword masmDirective EXTERNDEF EXTRN FOR FORC GOTO GROUP IF IF1 IF2
90syn keyword masmDirective IFB IFDEF IFDIF IFDIFI IFE IFIDN IFIDNI IFNB
91syn keyword masmDirective IFNDEF INCLUDE INCLUDELIB INSTR INVOKE IRP
92syn keyword masmDirective IRPC LABEL LOCAL MACRO NAME OPTION ORG PAGE
93syn keyword masmDirective POPCONTEXT PROC PROTO PUBLIC PURGE PUSHCONTEXT
94syn keyword masmDirective RECORD REPEAT REPT SEGMENT SIZESTR STRUC
95syn keyword masmDirective STRUCT SUBSTR SUBTITLE SUBTTL TEXTEQU TITLE
96syn keyword masmDirective TYPEDEF UNION WHILE
97syn match masmDirective "\.8086\>"
98syn match masmDirective "\.8087\>"
99syn match masmDirective "\.NO87\>"
100syn match masmDirective "\.186\>"
101syn match masmDirective "\.286\>"
102syn match masmDirective "\.286C\>"
103syn match masmDirective "\.286P\>"
104syn match masmDirective "\.287\>"
105syn match masmDirective "\.386\>"
106syn match masmDirective "\.386C\>"
107syn match masmDirective "\.386P\>"
108syn match masmDirective "\.387\>"
109syn match masmDirective "\.486\>"
110syn match masmDirective "\.486P\>"
111syn match masmDirective "\.586\>"
112syn match masmDirective "\.586P\>"
113syn match masmDirective "\.686\>"
114syn match masmDirective "\.686P\>"
115syn match masmDirective "\.K3D\>"
116syn match masmDirective "\.MMX\>"
117syn match masmDirective "\.XMM\>"
118syn match masmDirective "\.ALPHA\>"
119syn match masmDirective "\.DOSSEG\>"
120syn match masmDirective "\.SEQ\>"
121syn match masmDirective "\.CODE\>"
122syn match masmDirective "\.CONST\>"
123syn match masmDirective "\.DATA\>"
124syn match masmDirective "\.DATA?"
125syn match masmDirective "\.EXIT\>"
126syn match masmDirective "\.FARDATA\>"
127syn match masmDirective "\.FARDATA?"
128syn match masmDirective "\.MODEL\>"
129syn match masmDirective "\.STACK\>"
130syn match masmDirective "\.STARTUP\>"
131syn match masmDirective "\.IF\>"
132syn match masmDirective "\.ELSE\>"
133syn match masmDirective "\.ELSEIF\>"
134syn match masmDirective "\.ENDIF\>"
135syn match masmDirective "\.REPEAT\>"
136syn match masmDirective "\.UNTIL\>"
137syn match masmDirective "\.UNTILCXZ\>"
138syn match masmDirective "\.WHILE\>"
139syn match masmDirective "\.ENDW\>"
140syn match masmDirective "\.BREAK\>"
141syn match masmDirective "\.CONTINUE\>"
142syn match masmDirective "\.ERR\>"
143syn match masmDirective "\.ERR1\>"
144syn match masmDirective "\.ERR2\>"
145syn match masmDirective "\.ERRB\>"
146syn match masmDirective "\.ERRDEF\>"
147syn match masmDirective "\.ERRDIF\>"
148syn match masmDirective "\.ERRDIFI\>"
149syn match masmDirective "\.ERRE\>"
150syn match masmDirective "\.ERRIDN\>"
151syn match masmDirective "\.ERRIDNI\>"
152syn match masmDirective "\.ERRNB\>"
153syn match masmDirective "\.ERRNDEF\>"
154syn match masmDirective "\.ERRNZ\>"
155syn match masmDirective "\.LALL\>"
156syn match masmDirective "\.SALL\>"
157syn match masmDirective "\.XALL\>"
158syn match masmDirective "\.LFCOND\>"
159syn match masmDirective "\.SFCOND\>"
160syn match masmDirective "\.TFCOND\>"
161syn match masmDirective "\.CREF\>"
162syn match masmDirective "\.NOCREF\>"
163syn match masmDirective "\.XCREF\>"
164syn match masmDirective "\.LIST\>"
165syn match masmDirective "\.NOLIST\>"
166syn match masmDirective "\.XLIST\>"
167syn match masmDirective "\.LISTALL\>"
168syn match masmDirective "\.LISTIF\>"
169syn match masmDirective "\.NOLISTIF\>"
170syn match masmDirective "\.LISTMACRO\>"
171syn match masmDirective "\.NOLISTMACRO\>"
172syn match masmDirective "\.LISTMACROALL\>"
173syn match masmDirective "\.FPO\>"
174syn match masmDirective "\.RADIX\>"
175syn match masmDirective "\.SAFESEH\>"
176syn match masmDirective "%OUT\>"
177syn match masmDirective "ALIGN\>"
178syn match masmOption "ALIGN([0-9]\+)"
Bram Moolenaar071d4272004-06-13 20:20:40 +0000179
180syn keyword masmRegister AX BX CX DX SI DI BP SP
Bram Moolenaar9964e462007-05-05 17:54:07 +0000181syn keyword masmRegister CS DS SS ES FS GS
Bram Moolenaar071d4272004-06-13 20:20:40 +0000182syn keyword masmRegister AH BH CH DH AL BL CL DL
183syn keyword masmRegister EAX EBX ECX EDX ESI EDI EBP ESP
Bram Moolenaar9964e462007-05-05 17:54:07 +0000184syn keyword masmRegister CR0 CR2 CR3 CR4
185syn keyword masmRegister DR0 DR1 DR2 DR3 DR6 DR7
186syn keyword masmRegister TR3 TR4 TR5 TR6 TR7
187syn match masmRegister "ST([0-7])"
Bram Moolenaar071d4272004-06-13 20:20:40 +0000188
Bram Moolenaarb8ff1fb2012-02-04 21:59:01 +0100189" x86-64 registers
190syn keyword masmRegister RAX RBX RCX RDX RSI RDI RBP RSP
191syn keyword masmRegister R8 R9 R10 R11 R12 R13 R14 R15
192syn keyword masmRegister R8D R9D R10D R11D R12D R13D R14D R15D
193syn keyword masmRegister R8W R9W R10W R11W R12W R13W R14W R15W
194syn keyword masmRegister R8B R9B R10B R11B R12B R13B R14B R15B
Bram Moolenaar071d4272004-06-13 20:20:40 +0000195
Bram Moolenaar4b60a6c2013-11-14 05:48:46 +0100196" SSE/AVX registers
Wu Yongweie7833e72023-09-11 00:27:31 +0800197syn match masmRegister "\(X\|Y\|Z\)MM[12]\?[0-9]\>"
198syn match masmRegister "\(X\|Y\|Z\)MM3[01]\>"
Bram Moolenaar4b60a6c2013-11-14 05:48:46 +0100199
Bram Moolenaar9964e462007-05-05 17:54:07 +0000200" Instruction prefixes
201syn keyword masmOpcode LOCK REP REPE REPNE REPNZ REPZ
Bram Moolenaar071d4272004-06-13 20:20:40 +0000202
Bram Moolenaar9964e462007-05-05 17:54:07 +0000203" 8086/8088 opcodes
204syn keyword masmOpcode AAA AAD AAM AAS ADC ADD AND CALL CBW CLC CLD
205syn keyword masmOpcode CLI CMC CMP CMPS CMPSB CMPSW CWD DAA DAS DEC
206syn keyword masmOpcode DIV ESC HLT IDIV IMUL IN INC INT INTO IRET
207syn keyword masmOpcode JCXZ JMP LAHF LDS LEA LES LODS LODSB LODSW
208syn keyword masmOpcode LOOP LOOPE LOOPEW LOOPNE LOOPNEW LOOPNZ
209syn keyword masmOpcode LOOPNZW LOOPW LOOPZ LOOPZW MOV MOVS MOVSB
210syn keyword masmOpcode MOVSW MUL NEG NOP NOT OR OUT POP POPF PUSH
211syn keyword masmOpcode PUSHF RCL RCR RET RETF RETN ROL ROR SAHF SAL
212syn keyword masmOpcode SAR SBB SCAS SCASB SCASW SHL SHR STC STD STI
213syn keyword masmOpcode STOS STOSB STOSW SUB TEST WAIT XCHG XLAT XLATB
214syn keyword masmOpcode XOR
215syn match masmOpcode "J\(P[EO]\|\(N\?\([ABGL]E\?\|[CEOPSZ]\)\)\)\>"
216
217" 80186 opcodes
218syn keyword masmOpcode BOUND ENTER INS INSB INSW LEAVE OUTS OUTSB
219syn keyword masmOpcode OUTSW POPA PUSHA PUSHW
220
221" 80286 opcodes
222syn keyword masmOpcode ARPL LAR LSL SGDT SIDT SLDT SMSW STR VERR VERW
223
224" 80286/80386 privileged opcodes
225syn keyword masmOpcode CLTS LGDT LIDT LLDT LMSW LTR
226
227" 80386 opcodes
228syn keyword masmOpcode BSF BSR BT BTC BTR BTS CDQ CMPSD CWDE INSD
229syn keyword masmOpcode IRETD IRETDF IRETF JECXZ LFS LGS LODSD LOOPD
230syn keyword masmOpcode LOOPED LOOPNED LOOPNZD LOOPZD LSS MOVSD MOVSX
231syn keyword masmOpcode MOVZX OUTSD POPAD POPFD PUSHAD PUSHD PUSHFD
232syn keyword masmOpcode SCASD SHLD SHRD STOSD
233syn match masmOpcode "SET\(P[EO]\|\(N\?\([ABGL]E\?\|[CEOPSZ]\)\)\)\>"
234
235" 80486 opcodes
236syn keyword masmOpcode BSWAP CMPXCHG INVD INVLPG WBINVD XADD
237
238" Floating-point opcodes as of 487
Bram Moolenaar071d4272004-06-13 20:20:40 +0000239syn keyword masmOpFloat F2XM1 FABS FADD FADDP FBLD FBSTP FCHS FCLEX
240syn keyword masmOpFloat FNCLEX FCOM FCOMP FCOMPP FCOS FDECSTP FDISI
241syn keyword masmOpFloat FNDISI FDIV FDIVP FDIVR FDIVRP FENI FNENI
242syn keyword masmOpFloat FFREE FIADD FICOM FICOMP FIDIV FIDIVR FILD
243syn keyword masmOpFloat FIMUL FINCSTP FINIT FNINIT FIST FISTP FISUB
244syn keyword masmOpFloat FISUBR FLD FLDCW FLDENV FLDLG2 FLDLN2 FLDL2E
245syn keyword masmOpFloat FLDL2T FLDPI FLDZ FLD1 FMUL FMULP FNOP FPATAN
Bram Moolenaar9964e462007-05-05 17:54:07 +0000246syn keyword masmOpFloat FPREM FPREM1 FPTAN FRNDINT FRSTOR FSAVE FNSAVE
247syn keyword masmOpFloat FSCALE FSETPM FSIN FSINCOS FSQRT FST FSTCW
248syn keyword masmOpFloat FNSTCW FSTENV FNSTENV FSTP FSTSW FNSTSW FSUB
249syn keyword masmOpFloat FSUBP FSUBR FSUBRP FTST FUCOM FUCOMP FUCOMPP
250syn keyword masmOpFloat FWAIT FXAM FXCH FXTRACT FYL2X FYL2XP1
251
252" Floating-point opcodes in Pentium and later processors
253syn keyword masmOpFloat FCMOVE FCMOVNE FCMOVB FCMOVBE FCMOVNB FCMOVNBE
254syn keyword masmOpFloat FCMOVU FCMOVNU FCOMI FUCOMI FCOMIP FUCOMIP
255syn keyword masmOpFloat FXSAVE FXRSTOR
256
257" MMX opcodes (Pentium w/ MMX, Pentium II, and later)
258syn keyword masmOpcode MOVD MOVQ PACKSSWB PACKSSDW PACKUSWB
259syn keyword masmOpcode PUNPCKHBW PUNPCKHWD PUNPCKHDQ
260syn keyword masmOpcode PUNPCKLBW PUNPCKLWD PUNPCKLDQ
261syn keyword masmOpcode PADDB PADDW PADDD PADDSB PADDSW PADDUSB PADDUSW
262syn keyword masmOpcode PSUBB PSUBW PSUBD PSUBSB PSUBSW PSUBUSB PSUBUSW
263syn keyword masmOpcode PMULHW PMULLW PMADDWD
264syn keyword masmOpcode PCMPEQB PCMPEQW PCMPEQD PCMPGTB PCMPGTW PCMPGTD
265syn keyword masmOpcode PAND PANDN POR PXOR
266syn keyword masmOpcode PSLLW PSLLD PSLLQ PSRLW PSRLD PSRLQ PSRAW PSRAD
267syn keyword masmOpcode EMMS
268
269" SSE opcodes (Pentium III and later)
270syn keyword masmOpcode MOVAPS MOVUPS MOVHPS MOVHLPS MOVLPS MOVLHPS
271syn keyword masmOpcode MOVMSKPS MOVSS
272syn keyword masmOpcode ADDPS ADDSS SUBPS SUBSS MULPS MULSS DIVPS DIVSS
273syn keyword masmOpcode RCPPS RCPSS SQRTPS SQRTSS RSQRTPS RSQRTSS
274syn keyword masmOpcode MAXPS MAXSS MINPS MINSS
275syn keyword masmOpcode CMPPS CMPSS COMISS UCOMISS
276syn keyword masmOpcode ANDPS ANDNPS ORPS XORPS
277syn keyword masmOpcode SHUFPS UNPCKHPS UNPCKLPS
278syn keyword masmOpcode CVTPI2PS CVTSI2SS CVTPS2PI CVTTPS2PI
279syn keyword masmOpcode CVTSS2SI CVTTSS2SI
280syn keyword masmOpcode LDMXCSR STMXCSR
281syn keyword masmOpcode PAVGB PAVGW PEXTRW PINSRW PMAXUB PMAXSW
282syn keyword masmOpcode PMINUB PMINSW PMOVMSKB PMULHUW PSADBW PSHUFW
283syn keyword masmOpcode MASKMOVQ MOVNTQ MOVNTPS SFENCE
284syn keyword masmOpcode PREFETCHT0 PREFETCHT1 PREFETCHT2 PREFETCHNTA
285
286" SSE2 opcodes (Pentium 4 and later)
287syn keyword masmOpcode MOVAPD MOVUPD MOVHPD MOVLPD MOVMSKPD MOVSD
288syn keyword masmOpcode ADDPD ADDSD SUBPD SUBSD MULPD MULSD DIVPD DIVSD
289syn keyword masmOpcode SQRTPD SQRTSD MAXPD MAXSD MINPD MINSD
290syn keyword masmOpcode ANDPD ANDNPD ORPD XORPD
291syn keyword masmOpcode CMPPD CMPSD COMISD UCOMISD
292syn keyword masmOpcode SHUFPD UNPCKHPD UNPCKLPD
293syn keyword masmOpcode CVTPD2PI CVTTPD2PI CVTPI2PD CVTPD2DQ
294syn keyword masmOpcode CVTTPD2DQ CVTDQ2PD CVTPS2PD CVTPD2PS
295syn keyword masmOpcode CVTSS2SD CVTSD2SS CVTSD2SI CVTTSD2SI CVTSI2SD
296syn keyword masmOpcode CVTDQ2PS CVTPS2DQ CVTTPS2DQ
297syn keyword masmOpcode MOVDQA MOVDQU MOVQ2DQ MOVDQ2Q PMULUDQ
298syn keyword masmOpcode PADDQ PSUBQ PSHUFLW PSHUFHW PSHUFD
299syn keyword masmOpcode PSLLDQ PSRLDQ PUNPCKHQDQ PUNPCKLQDQ
300syn keyword masmOpcode CLFLUSH LFENCE MFENCE PAUSE MASKMOVDQU
301syn keyword masmOpcode MOVNTPD MOVNTDQ MOVNTI
302
303" SSE3 opcodes (Pentium 4 w/ Hyper-Threading and later)
304syn keyword masmOpcode FISTTP LDDQU ADDSUBPS ADDSUBPD
305syn keyword masmOpcode HADDPS HSUBPS HADDPD HSUBPD
306syn keyword masmOpcode MOVSHDUP MOVSLDUP MOVDDUP MONITOR MWAIT
307
Bram Moolenaar4b60a6c2013-11-14 05:48:46 +0100308" SSSE3 opcodes (Core and later)
309syn keyword masmOpcode PSIGNB PSIGNW PSIGND PABSB PABSW PABSD
310syn keyword masmOpcode PALIGNR PSHUFB PMULHRSW PMADDUBSW
311syn keyword masmOpcode PHSUBW PHSUBD PHSUBSW PHADDW PHADDD PHADDSW
312
313" SSE 4.1 opcodes (Penryn and later)
314syn keyword masmOpcode MPSADBW PHMINPOSUW PMULDQ PMULLD DPPS DPPD
315syn keyword masmOpcode BLENDPS BLENDPD BLENDVPS BLENDVPD
316syn keyword masmOpcode PBLENDVB PBLENDW
317syn keyword masmOpcode PMINSB PMAXSB PMINSD PMAXSD
318syn keyword masmOpcode PMINUW PMAXUW PMINUD PMAXUD
319syn keyword masmOpcode ROUNDPS ROUNDSS ROUNDPD ROUNDSD
320syn keyword masmOpcode INSERTPS PINSRB PINSRD PINSRQ
321syn keyword masmOpcode EXTRACTPS PEXTRB PEXTRD PEXTRQ
322syn keyword masmOpcode PMOVSXBW PMOVZXBW PMOVSXBD PMOVZXBD
323syn keyword masmOpcode PMOVSXBQ PMOVZXBQ PMOVSXWD PMOVZXWD
324syn keyword masmOpcode PMOVSXWQ PMOVZXWQ PMOVSXDQ PMOVZXDQ
325syn keyword masmOpcode PTEST PCMPEQQ PACKUSDW MOVNTDQA
326
327" SSE 4.2 opcodes (Nehalem and later)
328syn keyword masmOpcode PCMPESTRI PCMPESTRM PCMPISTRI PCMPISTRM PCMPGTQ
329syn keyword masmOpcode CRC32 POPCNT LZCNT
330
331" AES-NI (Westmere (2010) and later)
332syn keyword masmOpcode AESENC AESENCLAST AESDEC AESDECLAST
333syn keyword masmOpcode AESKEYGENASSIST AESIMC PCLMULQDQ
334
335" AVX (Sandy Bridge (2011) and later)
336syn keyword masmOpcode VBROADCASTSS VBROADCASTSD VBROADCASTF128
337syn keyword masmOpcode VINSERTF128 VEXTRACTF128 VMASKMOVPS VMASKMOVPD
338syn keyword masmOpcode VPERMILPS VPERMILPD VPERM2F128
339syn keyword masmOpcode VZEROALL VZEROUPPER
340
Wu Yongweie7833e72023-09-11 00:27:31 +0800341" AVX-2 (Haswell and later)
342syn keyword masmOpcode VPBROADCASTB VPBROADCASTW VPBROADCASTD
343syn keyword masmOpcode VPBROADCASTQ VBROADCASTI128
344syn keyword masmOpcode VINSERTI128 VEXTRACTI128
345syn keyword masmOpcode VGATHERDPD VGATHERQPD VGATHERDPS VGATHERQPS
346syn keyword masmOpcode VPGATHERDD VPGATHERDQ VPGATHERQD VPGATHERQQ
347syn keyword masmOpcode VPMASKMOVD VPMASKMOVQ
348syn keyword masmOpcode PERMPS VPERMD VPERMPD VPERMQ VPERM2I128
349syn keyword masmOpcode VPBLENDD VPSLLVD VPSLLVQ VPSRLVD VPSRLVQ
350syn keyword masmOpcode VPSRAVD
351
352" AVX-512 (Knights Landing/Skylake-X and later)
353syn keyword masmOpcode KAND KANDN KMOV KUNPCK KNOT KOR KORTEST
354syn keyword masmOpcode KSHIFTL KSHIFTR KXNOR KXOR KADD KTEST
355syn keyword masmOpcode VBLENDMPD VBLENDMPS
356syn keyword masmOpcode VPBLENDMD VPBLENDMQ VPBLENDMB VPBLENDMW
357syn keyword masmOpcode VPCMPD VPCMPUD VPCMPQ VPCMPUQ
358syn keyword masmOpcode VPCMPB VPCMPUB VPCMPW VPCMPUW
359syn keyword masmOpcode VPTESTMD VPTESTMQ VPTESTNMD VPTESTNMQ
360syn keyword masmOpcode VPTESTMB VPTESTMW VPTESTNMB VPTESTNMW
361syn keyword masmOpcode VCOMPRESSPD VCOMPRESSPS VPCOMPRESSD VPCOMPRESSQ
362syn keyword masmOpcode VEXPANDPD VEXPANDPS VPEXPANDD VPEXPANDQ
363syn keyword masmOpcode VPERMB VPERMW VPERMT2B VPERMT2W VPERMI2PD
364syn keyword masmOpcode VPERMI2PS VPERMI2D VPERMI2Q VPERMI2B VPERMI2W
365syn keyword masmOpcode VPERMT2PS VPERMT2PD VPERMT2D VPERMT2Q
366syn keyword masmOpcode VSHUFF32x4 VSHUFF64x2 VSHUFI32x4 VSHUFI64x2
367syn keyword masmOpcode VPMULTISHIFTQB VPTERNLOGD VPTERNLOGQ
368syn keyword masmOpcode VPMOVQD VPMOVSQD VPMOVUSQD VPMOVQW VPMOVSQW
369syn keyword masmOpcode VPMOVUSQW VPMOVQB VPMOVSQB VPMOVUSQB VPMOVDW
370syn keyword masmOpcode VPMOVSDW VPMOVUSDW VPMOVDB VPMOVSDB VPMOVUSDB
371syn keyword masmOpcode VPMOVWB VPMOVSWB VPMOVUSWB
372syn keyword masmOpcode VCVTPS2UDQ VCVTPD2UDQ VCVTTPS2UDQ VCVTTPD2UDQ
373syn keyword masmOpcode VCVTSS2USI VCVTSD2USI VCVTTSS2USI VCVTTSD2USI
374syn keyword masmOpcode VCVTPS2QQ VCVTPD2QQ VCVTPS2UQQ VCVTPD2UQQ
375syn keyword masmOpcode VCVTTPS2QQ VCVTTPD2QQ VCVTTPS2UQQ VCVTTPD2UQQ
376syn keyword masmOpcode VCVTUDQ2PS VCVTUDQ2PD VCVTUSI2PS VCVTUSI2PD
377syn keyword masmOpcode VCVTUSI2SD VCVTUSI2SS VCVTUQQ2PS VCVTUQQ2PD
378syn keyword masmOpcode VCVTQQ2PD VCVTQQ2PS VGETEXPPD
379syn keyword masmOpcode VGETEXPPS VGETEXPSD VGETEXPSS
380syn keyword masmOpcode VGETMANTPD VGETMANTPS VGETMANTSD VGETMANTSS
381syn keyword masmOpcode VFIXUPIMMPD VFIXUPIMMPS VFIXUPIMMSD VFIXUPIMMSS
382syn keyword masmOpcode VRCP14PD VRCP14PS VRCP14SD VRCP14SS
383syn keyword masmOpcode VRNDSCALEPS VRNDSCALEPD VRNDSCALESS VRNDSCALESD
384syn keyword masmOpcode VRSQRT14PD VRSQRT14PS VRSQRT14SD VRSQRT14SS
385syn keyword masmOpcode VSCALEFPS VSCALEFPD VSCALEFSS VSCALEFSD
386syn keyword masmOpcode VBROADCASTI32X2 VBROADCASTI32X4 VBROADCASTI32X8
387syn keyword masmOpcode VBROADCASTI64X2 VBROADCASTI64X4
388syn keyword masmOpcode VALIGND VALIGNQ VDBPSADBW VPABSQ VPMAXSQ
389syn keyword masmOpcode VPMAXUQ VPMINSQ VPMINUQ VPROLD VPROLVD VPROLQ
390syn keyword masmOpcode VPROLVQ VPRORD VPRORVD VPRORQ VPRORVQ
391syn keyword masmOpcode VPSCATTERDD VPSCATTERDQ VPSCATTERQD VPSCATTERQQ
392syn keyword masmOpcode VSCATTERDPS VSCATTERDPD VSCATTERQPS VSCATTERQPD
393syn keyword masmOpcode VPCONFLICTD VPCONFLICTQ VPLZCNTD VPLZCNTQ
394syn keyword masmOpcode VPBROADCASTMB2Q VPBROADCASTMW2D
395syn keyword masmOpcode VEXP2PD VEXP2PS
396syn keyword masmOpcode VRCP28PD VRCP28PS VRCP28SD VRCP28SS
397syn keyword masmOpcode VRSQRT28PD VRSQRT28PS VRSQRT28SD VRSQRT28SS
398syn keyword masmOpcode VGATHERPF0DPS VGATHERPF0QPS VGATHERPF0DPD
399syn keyword masmOpcode VGATHERPF0QPD VGATHERPF1DPS VGATHERPF1QPS
400syn keyword masmOpcode VGATHERPF1DPD VGATHERPF1QPD VSCATTERPF0DPS
401syn keyword masmOpcode VSCATTERPF0QPS VSCATTERPF0DPD VSCATTERPF0QPD
402syn keyword masmOpcode VSCATTERPF1DPS VSCATTERPF1QPS VSCATTERPF1DPD
403syn keyword masmOpcode VSCATTERPF1QPD
404syn keyword masmOpcode V4FMADDPS V4FMADDSS V4FNMADDPS V4FNMADDSS
405syn keyword masmOpcode VP4DPWSSD VP4DPWSSDS
406syn keyword masmOpcode VFPCLASSPS VFPCLASSPD VFPCLASSSS VFPCLASSSD
407syn keyword masmOpcode VRANGEPS VRANGEPD VRANGESS VRANGESD
408syn keyword masmOpcode VREDUCEPS VREDUCEPD VREDUCESS VREDUCESD
409syn keyword masmOpcode VPMOVM2D VPMOVM2Q VPMOVM2B VPMOVM2W VPMOVD2M
410syn keyword masmOpcode VPMOVQ2M VPMOVB2M VPMOVW2M VPMULLQ
411syn keyword masmOpcode VPCOMPRESSB VPCOMPRESSW VPEXPANDB VPEXPANDW
412syn keyword masmOpcode VPSHLD VPSHLDV VPSHRD VPSHRDV
413syn keyword masmOpcode VPDPBUSD VPDPBUSDS VPDPWSSD VPDPWSSDS
414syn keyword masmOpcode VPMADD52LUQ VPMADD52HUQ
415syn keyword masmOpcode VPOPCNTD VPOPCNTQ VPOPCNTB VPOPCNTW
416syn keyword masmOpcode VPSHUFBITQMB VP2INTERSECTD VP2INTERSECTQ
417syn keyword masmOpcode VGF2P8AFFINEINVQB VGF2P8AFFINEQB
418syn keyword masmOpcode VGF2P8MULB VPCLMULQDQ
419syn keyword masmOpcode VAESDEC VAESDECLAST VAESENC VAESENCLAST
420syn keyword masmOpcode VCVTNE2PS2BF16 VCVTNEPS2BF16 VDPBF16PS
421syn keyword masmOpcode VADDPH VADDSH VSUBPH VSUBSH VMULPH VMULSH
422syn keyword masmOpcode VDIVPH VDIVSH VSQRTPH VSQRTSH
423syn keyword masmOpcode VFMADD132PH VFMADD213PH VFMADD231PH
424syn keyword masmOpcode VFMADD132SH VFMADD213SH VFMADD231SH
425syn keyword masmOpcode VFNMADD132PH VFNMADD213PH VFNMADD231PH
426syn keyword masmOpcode VFNMADD132SH VFNMADD213SH VFNMADD231SH
427syn keyword masmOpcode VFMSUB132PH VFMSUB213PH VFMSUB231PH
428syn keyword masmOpcode VFMSUB132SH VFMSUB213SH VFMSUB231SH
429syn keyword masmOpcode VFNMSUB132PH VFNMSUB213PH VFNMSUB231PH
430syn keyword masmOpcode VFNMSUB132SH VFNMSUB213SH VFNMSUB231SH
431syn keyword masmOpcode VFMADDSUB132PH VFMADDSUB213PH VFMADDSUB231PH
432syn keyword masmOpcode VFMSUBADD132PH VFMSUBADD213PH VFMSUBADD231PH
433syn keyword masmOpcode VREDUCEPH VREDUCESH VRNDSCALEPH VRNDSCALESH
434syn keyword masmOpcode VSCALEFPH VSCALEFSH VFMULCPH VFMULCSH VFCMULCPH
435syn keyword masmOpcode VFCMULCSH VFMADDCPH VFMADDCSH VFCMADDCPH
436syn keyword masmOpcode VFCMADDCSH VRCPPH VRCPSH VRSQRTPH VRSQRTSH
437syn keyword masmOpcode VCMPPH VCMPSH VCOMISH VUCOMISH VMAXPH VMAXSH
438syn keyword masmOpcode VMINPH VMINSH VFPCLASSPH VFPCLASSSH
439syn keyword masmOpcode VCVTW2PH VCVTUW2PH VCVTDQ2PH VCVTUDQ2PH
440syn keyword masmOpcode VCVTQQ2PH VCVTUQQ2PH VCVTPS2PHX VCVTPD2PH
441syn keyword masmOpcode VCVTSI2SH VCVTUSI2SH VCVTSS2SH VCVTSD2SH
442syn keyword masmOpcode VCVTPH2W VCVTTPH2W VCVTPH2UW VCVTTPH2UW
443syn keyword masmOpcode VCVTPH2DQ VCVTTPH2DQ VCVTPH2UDQ VCVTTPH2UDQ
444syn keyword masmOpcode VCVTPH2QQ VCVTTPH2QQ VCVTPH2UQQ VCVTTPH2UQQ
445syn keyword masmOpcode VCVTPH2PSX VCVTPH2PD VCVTSH2SI VCVTTSH2SI
446syn keyword masmOpcode VCVTSH2USI VCVTTSH2USI VCVTSH2SS VCVTSH2SD
447syn keyword masmOpcode VGETEXPPH VGETEXPSH VGETMANTPH VGETMANTSH
448syn keyword masmOpcode VMOVSH VMOVW VADDPD VADDPS VADDSD VADDSS
449syn keyword masmOpcode VANDPD VANDPS VANDNPD VANDNPS
450syn keyword masmOpcode VCMPPD VCMPPS VCMPSD VCMPSS
451syn keyword masmOpcode VCOMISD VCOMISS VDIVPD VDIVPS VDIVSD VDIVSS
452syn keyword masmOpcode VCVTDQ2PD VCVTDQ2PS VCVTPD2DQ VCVTPD2PS
453syn keyword masmOpcode VCVTPH2PS VCVTPS2PH VCVTPS2DQ VCVTPS2PD
454syn keyword masmOpcode VCVTSD2SI VCVTSD2SS VCVTSI2SD VCVTSI2SS
455syn keyword masmOpcode VCVTSS2SD VCVTSS2SI VCVTTPD2DQ VCVTTPS2DQ
456syn keyword masmOpcode VCVTTSD2SI VCVTTSS2SI VMAXPD VMAXPS
457syn keyword masmOpcode VMAXSD VMAXSS VMINPD VMINPS VMINSD VMINSS
458syn keyword masmOpcode VMOVAPD VMOVAPS VMOVD VMOVQ VMOVDDUP
459syn keyword masmOpcode VMOVHLPS VMOVHPD VMOVHPS VMOVLHPS VMOVLPD
460syn keyword masmOpcode VMOVLPS VMOVNTDQA VMOVNTDQ VMOVNTPD VMOVNTPS
461syn keyword masmOpcode VMOVSD VMOVSHDUP VMOVSLDUP VMOVSS VMOVUPD
462syn keyword masmOpcode VMOVUPS VMOVDQA32 VMOVDQA64 VMOVDQU8
463syn keyword masmOpcode VMOVDQU16 VMOVDQU32 VMOVDQU64 VMULPD VMULPS
464syn keyword masmOpcode VMULSD VMULSS VORPD VORPS VSQRTPD VSQRTPS
465syn keyword masmOpcode VSQRTSD VSQRTSS VSUBPD VSUBPS VSUBSD VSUBSS
466syn keyword masmOpcode VUCOMISD VUCOMISS VUNPCKHPD VUNPCKHPS VUNPCKLPD
467syn keyword masmOpcode VUNPCKLPS VXORPD VXORPS VEXTRACTPS VINSERTPS
468syn keyword masmOpcode VPEXTRB VPEXTRW VPEXTRD VPEXTRQ VPINSRB VPINSRW
469syn keyword masmOpcode VPINSRD VPINSRQ VPACKSSWB VPACKSSDW VPACKUSDW
470syn keyword masmOpcode VPACKUSWB VPADDB VPADDW VPADDD VPADDQ VPADDSB
471syn keyword masmOpcode VPADDSW VPADDUSB VPADDUSW VPANDD VPANDQ VPANDND
472syn keyword masmOpcode VPANDNQ VPAVGB VPAVGW VPCMPEQB VPCMPEQW
473syn keyword masmOpcode VPCMPEQD VPCMPEQQ VPCMPGTB VPCMPGTW VPCMPGTD
474syn keyword masmOpcode VPCMPGTQ VPMAXSB VPMAXSW VPMAXSD VPMAXSQ
475syn keyword masmOpcode VPMAXUB VPMAXUW VPMAXUD VPMAXUQ VPMINSB VPMINSW
476syn keyword masmOpcode VPMINSD VPMINSQ VPMINUB VPMINUW VPMINUD VPMINUQ
477syn keyword masmOpcode VPMOVSXBW VPMOVSXBD VPMOVSXBQ VPMOVSXWD
478syn keyword masmOpcode VPMOVSXWQ VPMOVSXDQ VPMOVZXBW VPMOVZXBD
479syn keyword masmOpcode VPMOVZXBQ VPMOVZXWD VPMOVZXWQ VPMOVZXDQ VPMULDQ
480syn keyword masmOpcode VPMULUDQ VPMULHRSW VPMULHUW VPMULHW VPMULLD
481syn keyword masmOpcode VPMULLQ VPMULLW VPORD VPORQ VPSUBB VPSUBW
482syn keyword masmOpcode VPSUBD VPSUBQ VPSUBSB VPSUBSW VPSUBUSB VPSUBUSW
483syn keyword masmOpcode VPUNPCKHBW VPUNPCKHWD VPUNPCKHDQ VPUNPCKHQDQ
484syn keyword masmOpcode VPUNPCKLBW VPUNPCKLWD VPUNPCKLDQ VPUNPCKLQDQ
485syn keyword masmOpcode VPXORD VPXORQ VPSADBW VPSHUFB VPSHUFHW VPSHUFLW
486syn keyword masmOpcode VPSHUFD VPSLLDQ VPSLLW VPSLLD VPSLLQ VPSRAW
487syn keyword masmOpcode VPSRAD VPSRAQ VPSRLDQ VPSRLW VPSRLD VPSRLQ
488syn keyword masmOpcode VPSLLVW VPSRLVW VPSHUFPD VPSHUFPS VEXTRACTF32X4
489syn keyword masmOpcode VEXTRACTF64X2 VEXTRACTF32X8 VEXTRACTF64X4
490syn keyword masmOpcode VEXTRACTI32X4 VEXTRACTI64X2 VEXTRACTI32X8
491syn keyword masmOpcode VEXTRACTI64X4 VINSERTF32x4 VINSERTF64X2
492syn keyword masmOpcode VINSERTF32X8 VINSERTF64x4 VINSERTI32X4
493syn keyword masmOpcode VINSERTI64X2 VINSERTI32X8 VINSERTI64X4
494syn keyword masmOpcode VPABSB VPABSW VPABSD VPABSQ VPALIGNR
495syn keyword masmOpcode VPMADDUBSW VPMADDWD
496syn keyword masmOpcode VFMADD132PD VFMADD213PD VFMADD231PD
497syn keyword masmOpcode VFMADD132PS VFMADD213PS VFMADD231PS
498syn keyword masmOpcode VFMADD132SD VFMADD213SD VFMADD231SD
499syn keyword masmOpcode VFMADD132SS VFMADD213SS VFMADD231SS
500syn keyword masmOpcode VFMADDSUB132PD VFMADDSUB213PD VFMADDSUB231PD
501syn keyword masmOpcode VFMADDSUB132PS VFMADDSUB213PS VFMADDSUB231PS
502syn keyword masmOpcode VFMSUBADD132PD VFMSUBADD213PD VFMSUBADD231PD
503syn keyword masmOpcode VFMSUBADD132PS VFMSUBADD213PS VFMSUBADD231PS
504syn keyword masmOpcode VFMSUB132PD VFMSUB213PD VFMSUB231PD
505syn keyword masmOpcode VFMSUB132PS VFMSUB213PS VFMSUB231PS
506syn keyword masmOpcode VFMSUB132SD VFMSUB213SD VFMSUB231SD
507syn keyword masmOpcode VFMSUB132SS VFMSUB213SS VFMSUB231SS
508syn keyword masmOpcode VFNMADD132PD VFNMADD213PD VFNMADD231PD
509syn keyword masmOpcode VFNMADD132PS VFNMADD213PS VFNMADD231PS
510syn keyword masmOpcode VFNMADD132SD VFNMADD213SD VFNMADD231SD
511syn keyword masmOpcode VFNMADD132SS VFNMADD213SS VFNMADD231SS
512syn keyword masmOpcode VFNMSUB132PD VFNMSUB213PD VFNMSUB231PD
513syn keyword masmOpcode VFNMSUB132PS VFNMSUB213PS VFNMSUB231PS
514syn keyword masmOpcode VFNMSUB132SD VFNMSUB213SD VFNMSUB231SD
515syn keyword masmOpcode VFNMSUB132SS VFNMSUB213SS VFNMSUB231SS
516syn keyword masmOpcode VPSRAVW VPSRAVQ
517
Bram Moolenaar9964e462007-05-05 17:54:07 +0000518" Other opcodes in Pentium and later processors
519syn keyword masmOpcode CMPXCHG8B CPUID UD2
520syn keyword masmOpcode RSM RDMSR WRMSR RDPMC RDTSC SYSENTER SYSEXIT
521syn match masmOpcode "CMOV\(P[EO]\|\(N\?\([ABGL]E\?\|[CEOPSZ]\)\)\)\>"
522
Wu Yongweie7833e72023-09-11 00:27:31 +0800523" Not really used by MASM, but useful for viewing GCC-generated assembly code
524" in Intel syntax
525syn match masmHexadecimal "[-+]\?0[Xx]\x*"
526syn keyword masmOpcode MOVABS
Bram Moolenaar071d4272004-06-13 20:20:40 +0000527
Bram Moolenaar4b60a6c2013-11-14 05:48:46 +0100528" The default highlighting
529hi def link masmLabel PreProc
530hi def link masmComment Comment
531hi def link masmDirective Statement
532hi def link masmType Type
533hi def link masmOperator Type
534hi def link masmOption Special
535hi def link masmRegister Special
536hi def link masmString String
537hi def link masmText String
538hi def link masmTitle Title
539hi def link masmOpcode Statement
540hi def link masmOpFloat Statement
Bram Moolenaar071d4272004-06-13 20:20:40 +0000541
Bram Moolenaar4b60a6c2013-11-14 05:48:46 +0100542hi def link masmHexadecimal Number
543hi def link masmDecimal Number
544hi def link masmOctal Number
545hi def link masmBinary Number
546hi def link masmFloatRaw Number
547hi def link masmFloat Number
Bram Moolenaar071d4272004-06-13 20:20:40 +0000548
Bram Moolenaar4b60a6c2013-11-14 05:48:46 +0100549hi def link masmIdentifier Identifier
Bram Moolenaar071d4272004-06-13 20:20:40 +0000550
Bram Moolenaar4b60a6c2013-11-14 05:48:46 +0100551syntax sync minlines=50
Bram Moolenaar071d4272004-06-13 20:20:40 +0000552
553let b:current_syntax = "masm"
554
Bram Moolenaarb8ff1fb2012-02-04 21:59:01 +0100555let &cpo = s:cpo_save
556unlet s:cpo_save
557
Bram Moolenaar071d4272004-06-13 20:20:40 +0000558" vim: ts=8