fix local labels, binary, register groups
This commit is contained in:
parent
3d23f83716
commit
6445d61998
@ -44,20 +44,23 @@ if version >= 508 || !exists("did_arm_syntax_inits")
|
|||||||
HiLink armRelative armOperator
|
HiLink armRelative armOperator
|
||||||
|
|
||||||
" Link to standard syn groups so the 'colorschemes' work
|
" Link to standard syn groups so the 'colorschemes' work
|
||||||
HiLink armOperator Operator
|
|
||||||
HiLink armNumber Number
|
|
||||||
HiLink armComment Comment
|
HiLink armComment Comment
|
||||||
|
|
||||||
|
HiLink armOperator Operator
|
||||||
|
HiLink armNumber Constant
|
||||||
|
|
||||||
HiLink armString String
|
HiLink armString String
|
||||||
|
|
||||||
HiLink armIdentifier Label
|
HiLink armIdentifier Function
|
||||||
HiLink armLabel Label
|
HiLink armLabel Function
|
||||||
HiLink gasDirective PreProc
|
|
||||||
HiLink armDirective PreProc
|
HiLink gasDirective Preproc
|
||||||
|
HiLink armDirective Preproc
|
||||||
HiLink armCPreProc Identifier
|
HiLink armCPreProc Identifier
|
||||||
|
|
||||||
HiLink armRegister Type
|
HiLink armRegister Type
|
||||||
HiLink armv6Register Type
|
HiLink armv6Register Type
|
||||||
HiLink armv6Instructions Function
|
HiLink armv6Instructions Keyword
|
||||||
|
|
||||||
HiLink armTodo Todo
|
HiLink armTodo Todo
|
||||||
delcommand HiLink
|
delcommand HiLink
|
||||||
|
@ -32,19 +32,22 @@ if version >= 508 || !exists("did_armv4_syntax_inits")
|
|||||||
HiLink armRelative armOperator
|
HiLink armRelative armOperator
|
||||||
|
|
||||||
" Link to standard syn groups so the 'colorschemes' work
|
" Link to standard syn groups so the 'colorschemes' work
|
||||||
HiLink armOperator Operator
|
|
||||||
HiLink armNumber Number
|
|
||||||
HiLink armComment Comment
|
HiLink armComment Comment
|
||||||
|
|
||||||
|
HiLink armOperator Operator
|
||||||
|
HiLink armNumber Constant
|
||||||
|
|
||||||
HiLink armString String
|
HiLink armString String
|
||||||
|
|
||||||
HiLink armIdentifier Label
|
HiLink armIdentifier Function
|
||||||
HiLink armLabel Label
|
HiLink armLabel Function
|
||||||
HiLink gasDirective PreProc
|
|
||||||
HiLink armDirective PreProc
|
HiLink gasDirective Preproc
|
||||||
|
HiLink armDirective Preproc
|
||||||
HiLink armCPreProc Identifier
|
HiLink armCPreProc Identifier
|
||||||
|
|
||||||
HiLink armRegister Type
|
HiLink armRegister Type
|
||||||
HiLink armv4Instructions Function
|
HiLink armv4Instructions Keyword
|
||||||
|
|
||||||
HiLink armTodo Todo
|
HiLink armTodo Todo
|
||||||
delcommand HiLink
|
delcommand HiLink
|
||||||
|
@ -33,19 +33,22 @@ if version >= 508 || !exists("did_armv5_syntax_inits")
|
|||||||
HiLink armRelative armOperator
|
HiLink armRelative armOperator
|
||||||
|
|
||||||
" Link to standard syn groups so the 'colorschemes' work
|
" Link to standard syn groups so the 'colorschemes' work
|
||||||
HiLink armOperator Operator
|
|
||||||
HiLink armNumber Number
|
|
||||||
HiLink armComment Comment
|
HiLink armComment Comment
|
||||||
|
|
||||||
|
HiLink armOperator Operator
|
||||||
|
HiLink armNumber Constant
|
||||||
|
|
||||||
HiLink armString String
|
HiLink armString String
|
||||||
|
|
||||||
HiLink armIdentifier Label
|
HiLink armIdentifier Function
|
||||||
HiLink armLabel Label
|
HiLink armLabel Function
|
||||||
HiLink gasDirective PreProc
|
|
||||||
HiLink armDirective PreProc
|
HiLink gasDirective Preproc
|
||||||
|
HiLink armDirective Preproc
|
||||||
HiLink armCPreProc Identifier
|
HiLink armCPreProc Identifier
|
||||||
|
|
||||||
HiLink armRegister Type
|
HiLink armRegister Type
|
||||||
HiLink armv5Instructions Function
|
HiLink armv5Instructions Keyword
|
||||||
|
|
||||||
HiLink armTodo Todo
|
HiLink armTodo Todo
|
||||||
delcommand HiLink
|
delcommand HiLink
|
||||||
|
@ -5,12 +5,10 @@ syn match armNumericOp "[+-/*%<>=&|^!]"
|
|||||||
|
|
||||||
" hex
|
" hex
|
||||||
syn match armNumber "[#\$]\?0x\x\+\>"
|
syn match armNumber "[#\$]\?0x\x\+\>"
|
||||||
syn match armNumber "[#\$]\?\d\x*h\>"
|
|
||||||
" dec
|
" dec
|
||||||
syn match armNumber "[#\$]\?\d\+\>"
|
syn match armNumber "[#\$]\?\d\+\>"
|
||||||
" bin
|
" bin
|
||||||
syn match armNumber "[#\$]\?0b[01]\+\>"
|
syn match armNumber "[#\$]\?0b[01]\+\>"
|
||||||
syn match armNumber "[#\$]\?[01]\+b\>"
|
|
||||||
" floats
|
" floats
|
||||||
syn match armNumber "\d*\.\d\+\>"
|
syn match armNumber "\d*\.\d\+\>"
|
||||||
|
|
||||||
@ -26,16 +24,17 @@ syn region armString start="'" skip=+\\'+ end="'\|$"
|
|||||||
" Assembler identifiers/labels/directives
|
" Assembler identifiers/labels/directives
|
||||||
syn match armIdentifier "\<\h\w*\>"
|
syn match armIdentifier "\<\h\w*\>"
|
||||||
syn match armLabel "\<\h\w*:"
|
syn match armLabel "\<\h\w*:"
|
||||||
syn match armLabel "\<\d\{1,3\}[:fb]"
|
syn match armLabel "\<\d\{1,3\}[:fb]\>"
|
||||||
syn match armCPreProc "^\s*#\(include\|define\|undef\|if\|ifdef\|ifndef\|elif\|else\|endif\|error\|pragma\)\>"
|
syn match armCPreProc "^\s*#\s*\(include\|define\|undef\|if\|ifdef\|ifndef\|elif\|else\|endif\|error\|pragma\)\>"
|
||||||
|
|
||||||
so <sfile>:p:h/gas_directives.vim
|
so <sfile>:p:h/gas_directives.vim
|
||||||
so <sfile>:p:h/arm_directives.vim
|
so <sfile>:p:h/arm_directives.vim
|
||||||
|
|
||||||
" Registers
|
" Registers
|
||||||
syn keyword armRegister R0 R1 R2 R3 R4 R5 R6 R7 R8
|
syn match armRegister "R\%(1[0-5]\|[0-9]\)"
|
||||||
syn keyword armRegister R9 R10 R11 R12 R13 R14 R15 FP SP LR PC SPSR CPSR CPSR_c CPSR_cxsf BP
|
syn keyword armRegister FP SP LR PC SPSR CPSR CPSR_c CPSR_cxsf BP
|
||||||
syn keyword armRegister A1 A2 A3 A4 V1 V2 V3 V4 V5 V6 V7 V8
|
syn match armRegister "A[1-3]"
|
||||||
|
syn match armRegister "V[1-8]"
|
||||||
|
|
||||||
" Conditional field to avoid repetition
|
" Conditional field to avoid repetition
|
||||||
let armCond = '\%(AL\|CC\|CS\|EQ\|GE\|GT\|HI\|HS\|LE\|LO\|LS\|LT\|MI\|NE\|PL\|VC\|VS\)\?'
|
let armCond = '\%(AL\|CC\|CS\|EQ\|GE\|GT\|HI\|HS\|LE\|LO\|LS\|LT\|MI\|NE\|PL\|VC\|VS\)\?'
|
||||||
|
@ -2,14 +2,8 @@
|
|||||||
so <sfile>:p:h/armv5_base_syntax.vim
|
so <sfile>:p:h/armv5_base_syntax.vim
|
||||||
|
|
||||||
" VFP/NEON registers
|
" VFP/NEON registers
|
||||||
let i = 0
|
syn match armv6Register "[SD]\%(3[01]\|[12]\?[0-9]\)"
|
||||||
while i < 32
|
syn match armv6Register "Q\%(1[0-5]\|[0-9]\)"
|
||||||
exe 'syn match armv6Register "S' . i . '\>"'
|
|
||||||
exe 'syn match armv6Register "D' . i . '\>"'
|
|
||||||
let i = i + 1
|
|
||||||
endwhile
|
|
||||||
|
|
||||||
syn keyword armv6Register Q0 Q1 Q2 Q3 Q4 Q5 Q6 Q7 Q8 Q9 Q10 Q11 Q12 Q13 Q14 Q15
|
|
||||||
|
|
||||||
"
|
"
|
||||||
" ARMv6 instructions
|
" ARMv6 instructions
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
|
|
||||||
adc r1, r15, R14
|
adc r1, r15, R14
|
||||||
add A1, v1, V8
|
add A1, v1, V8
|
||||||
|
sub r5, #0xFeeDB4c
|
||||||
smull r0, r1,R2
|
smull r0, r1,R2
|
||||||
smull r0, r1,R2
|
smull r0, r1,R2
|
||||||
|
|
||||||
@ -16,5 +17,6 @@ blx 0002f
|
|||||||
smlalBt r1,r15
|
smlalBt r1,r15
|
||||||
SMLawTb V8, v3
|
SMLawTb V8, v3
|
||||||
SMLALtb A1, a4
|
SMLALtb A1, a4
|
||||||
|
1.0f 0.f .1f
|
||||||
|
|
||||||
@ vim:ft=armv4
|
@ vim:ft=armv4
|
||||||
|
@ -1,10 +1,17 @@
|
|||||||
adc r0, r1
|
adc r0, r1
|
||||||
add R1, R2
|
add R1, R2
|
||||||
|
0:
|
||||||
|
sub r14, 0b1110110
|
||||||
|
1:
|
||||||
and R2,r3
|
and R2,r3
|
||||||
bic r3 , r4
|
bic r3 , r4
|
||||||
eor r4,r5
|
eor r4,r5
|
||||||
mla r5,R6
|
mla r5,R6
|
||||||
mov R6,R7
|
mov R6,R7
|
||||||
|
b 001b
|
||||||
|
|
||||||
|
push {r0, r1, r2-r9}
|
||||||
|
pop {r1-r14}
|
||||||
|
|
||||||
FSHTOS
|
FSHTOS
|
||||||
|
|
||||||
@ -15,8 +22,16 @@ fcmpezs
|
|||||||
fcmpzs
|
fcmpzs
|
||||||
fdivs
|
fdivs
|
||||||
|
|
||||||
vmul Q15, Q16, d31, s31, s32, d32
|
|
||||||
vdiv
|
vdiv
|
||||||
vsqrt
|
vsqrt
|
||||||
|
|
||||||
|
.float 3.14159
|
||||||
|
|
||||||
|
@ illegal
|
||||||
|
blx 0002f
|
||||||
|
1.0f 0.f .1f
|
||||||
|
vmul Q15, Q16, d31, s31, s32, d32
|
||||||
|
vmull q01, q09, q14, q16
|
||||||
|
push {q0-q14}
|
||||||
|
pop {s3-s32}
|
||||||
@ vim:ft=arm
|
@ vim:ft=arm
|
||||||
|
Loading…
x
Reference in New Issue
Block a user