You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
81 lines
2.9 KiB
81 lines
2.9 KiB
/*
|
|
Language: AVR Assembly
|
|
Author: Vladimir Ermakov <vooon341@gmail.com>
|
|
Category: assembler
|
|
Website: https://www.microchip.com/webdoc/avrassembler/avrassembler.wb_instruction_list.html
|
|
*/
|
|
|
|
/** @type LanguageFn */
|
|
function avrasm(hljs) {
|
|
return {
|
|
name: 'AVR Assembly',
|
|
case_insensitive: true,
|
|
keywords: {
|
|
$pattern: '\\.?' + hljs.IDENT_RE,
|
|
keyword:
|
|
/* mnemonic */
|
|
'adc add adiw and andi asr bclr bld brbc brbs brcc brcs break breq brge brhc brhs ' +
|
|
'brid brie brlo brlt brmi brne brpl brsh brtc brts brvc brvs bset bst call cbi cbr ' +
|
|
'clc clh cli cln clr cls clt clv clz com cp cpc cpi cpse dec eicall eijmp elpm eor ' +
|
|
'fmul fmuls fmulsu icall ijmp in inc jmp ld ldd ldi lds lpm lsl lsr mov movw mul ' +
|
|
'muls mulsu neg nop or ori out pop push rcall ret reti rjmp rol ror sbc sbr sbrc sbrs ' +
|
|
'sec seh sbi sbci sbic sbis sbiw sei sen ser ses set sev sez sleep spm st std sts sub ' +
|
|
'subi swap tst wdr',
|
|
built_in:
|
|
/* general purpose registers */
|
|
'r0 r1 r2 r3 r4 r5 r6 r7 r8 r9 r10 r11 r12 r13 r14 r15 r16 r17 r18 r19 r20 r21 r22 ' +
|
|
'r23 r24 r25 r26 r27 r28 r29 r30 r31 x|0 xh xl y|0 yh yl z|0 zh zl ' +
|
|
/* IO Registers (ATMega128) */
|
|
'ucsr1c udr1 ucsr1a ucsr1b ubrr1l ubrr1h ucsr0c ubrr0h tccr3c tccr3a tccr3b tcnt3h ' +
|
|
'tcnt3l ocr3ah ocr3al ocr3bh ocr3bl ocr3ch ocr3cl icr3h icr3l etimsk etifr tccr1c ' +
|
|
'ocr1ch ocr1cl twcr twdr twar twsr twbr osccal xmcra xmcrb eicra spmcsr spmcr portg ' +
|
|
'ddrg ping portf ddrf sreg sph spl xdiv rampz eicrb eimsk gimsk gicr eifr gifr timsk ' +
|
|
'tifr mcucr mcucsr tccr0 tcnt0 ocr0 assr tccr1a tccr1b tcnt1h tcnt1l ocr1ah ocr1al ' +
|
|
'ocr1bh ocr1bl icr1h icr1l tccr2 tcnt2 ocr2 ocdr wdtcr sfior eearh eearl eedr eecr ' +
|
|
'porta ddra pina portb ddrb pinb portc ddrc pinc portd ddrd pind spdr spsr spcr udr0 ' +
|
|
'ucsr0a ucsr0b ubrr0l acsr admux adcsr adch adcl porte ddre pine pinf',
|
|
meta:
|
|
'.byte .cseg .db .def .device .dseg .dw .endmacro .equ .eseg .exit .include .list ' +
|
|
'.listmac .macro .nolist .org .set'
|
|
},
|
|
contains: [
|
|
hljs.C_BLOCK_COMMENT_MODE,
|
|
hljs.COMMENT(
|
|
';',
|
|
'$',
|
|
{
|
|
relevance: 0
|
|
}
|
|
),
|
|
hljs.C_NUMBER_MODE, // 0x..., decimal, float
|
|
hljs.BINARY_NUMBER_MODE, // 0b...
|
|
{
|
|
className: 'number',
|
|
begin: '\\b(\\$[a-zA-Z0-9]+|0o[0-7]+)' // $..., 0o...
|
|
},
|
|
hljs.QUOTE_STRING_MODE,
|
|
{
|
|
className: 'string',
|
|
begin: '\'',
|
|
end: '[^\\\\]\'',
|
|
illegal: '[^\\\\][^\']'
|
|
},
|
|
{
|
|
className: 'symbol',
|
|
begin: '^[A-Za-z0-9_.$]+:'
|
|
},
|
|
{
|
|
className: 'meta',
|
|
begin: '#',
|
|
end: '$'
|
|
},
|
|
{ // substitution within a macro
|
|
className: 'subst',
|
|
begin: '@[0-9]+'
|
|
}
|
|
]
|
|
};
|
|
}
|
|
|
|
module.exports = avrasm;
|