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.
110 lines
4.3 KiB
110 lines
4.3 KiB
4 weeks ago
|
/*
|
||
|
Language: MIPS Assembly
|
||
|
Author: Nebuleon Fumika <nebuleon.fumika@gmail.com>
|
||
|
Description: MIPS Assembly (up to MIPS32R2)
|
||
|
Website: https://en.wikipedia.org/wiki/MIPS_architecture
|
||
|
Category: assembler
|
||
|
*/
|
||
|
|
||
|
function mipsasm(hljs) {
|
||
|
// local labels: %?[FB]?[AT]?\d{1,2}\w+
|
||
|
return {
|
||
|
name: 'MIPS Assembly',
|
||
|
case_insensitive: true,
|
||
|
aliases: [ 'mips' ],
|
||
|
keywords: {
|
||
|
$pattern: '\\.?' + hljs.IDENT_RE,
|
||
|
meta:
|
||
|
// GNU preprocs
|
||
|
'.2byte .4byte .align .ascii .asciz .balign .byte .code .data .else .end .endif .endm .endr .equ .err .exitm .extern .global .hword .if .ifdef .ifndef .include .irp .long .macro .rept .req .section .set .skip .space .text .word .ltorg ',
|
||
|
built_in:
|
||
|
'$0 $1 $2 $3 $4 $5 $6 $7 $8 $9 $10 $11 $12 $13 $14 $15 ' + // integer registers
|
||
|
'$16 $17 $18 $19 $20 $21 $22 $23 $24 $25 $26 $27 $28 $29 $30 $31 ' + // integer registers
|
||
|
'zero at v0 v1 a0 a1 a2 a3 a4 a5 a6 a7 ' + // integer register aliases
|
||
|
't0 t1 t2 t3 t4 t5 t6 t7 t8 t9 s0 s1 s2 s3 s4 s5 s6 s7 s8 ' + // integer register aliases
|
||
|
'k0 k1 gp sp fp ra ' + // integer register aliases
|
||
|
'$f0 $f1 $f2 $f2 $f4 $f5 $f6 $f7 $f8 $f9 $f10 $f11 $f12 $f13 $f14 $f15 ' + // floating-point registers
|
||
|
'$f16 $f17 $f18 $f19 $f20 $f21 $f22 $f23 $f24 $f25 $f26 $f27 $f28 $f29 $f30 $f31 ' + // floating-point registers
|
||
|
'Context Random EntryLo0 EntryLo1 Context PageMask Wired EntryHi ' + // Coprocessor 0 registers
|
||
|
'HWREna BadVAddr Count Compare SR IntCtl SRSCtl SRSMap Cause EPC PRId ' + // Coprocessor 0 registers
|
||
|
'EBase Config Config1 Config2 Config3 LLAddr Debug DEPC DESAVE CacheErr ' + // Coprocessor 0 registers
|
||
|
'ECC ErrorEPC TagLo DataLo TagHi DataHi WatchLo WatchHi PerfCtl PerfCnt ' // Coprocessor 0 registers
|
||
|
},
|
||
|
contains: [
|
||
|
{
|
||
|
className: 'keyword',
|
||
|
begin: '\\b(' + // mnemonics
|
||
|
// 32-bit integer instructions
|
||
|
'addi?u?|andi?|b(al)?|beql?|bgez(al)?l?|bgtzl?|blezl?|bltz(al)?l?|' +
|
||
|
'bnel?|cl[oz]|divu?|ext|ins|j(al)?|jalr(\\.hb)?|jr(\\.hb)?|lbu?|lhu?|' +
|
||
|
'll|lui|lw[lr]?|maddu?|mfhi|mflo|movn|movz|move|msubu?|mthi|mtlo|mul|' +
|
||
|
'multu?|nop|nor|ori?|rotrv?|sb|sc|se[bh]|sh|sllv?|slti?u?|srav?|' +
|
||
|
'srlv?|subu?|sw[lr]?|xori?|wsbh|' +
|
||
|
// floating-point instructions
|
||
|
'abs\\.[sd]|add\\.[sd]|alnv.ps|bc1[ft]l?|' +
|
||
|
'c\\.(s?f|un|u?eq|[ou]lt|[ou]le|ngle?|seq|l[et]|ng[et])\\.[sd]|' +
|
||
|
'(ceil|floor|round|trunc)\\.[lw]\\.[sd]|cfc1|cvt\\.d\\.[lsw]|' +
|
||
|
'cvt\\.l\\.[dsw]|cvt\\.ps\\.s|cvt\\.s\\.[dlw]|cvt\\.s\\.p[lu]|cvt\\.w\\.[dls]|' +
|
||
|
'div\\.[ds]|ldx?c1|luxc1|lwx?c1|madd\\.[sd]|mfc1|mov[fntz]?\\.[ds]|' +
|
||
|
'msub\\.[sd]|mth?c1|mul\\.[ds]|neg\\.[ds]|nmadd\\.[ds]|nmsub\\.[ds]|' +
|
||
|
'p[lu][lu]\\.ps|recip\\.fmt|r?sqrt\\.[ds]|sdx?c1|sub\\.[ds]|suxc1|' +
|
||
|
'swx?c1|' +
|
||
|
// system control instructions
|
||
|
'break|cache|d?eret|[de]i|ehb|mfc0|mtc0|pause|prefx?|rdhwr|' +
|
||
|
'rdpgpr|sdbbp|ssnop|synci?|syscall|teqi?|tgei?u?|tlb(p|r|w[ir])|' +
|
||
|
'tlti?u?|tnei?|wait|wrpgpr' +
|
||
|
')',
|
||
|
end: '\\s'
|
||
|
},
|
||
|
// lines ending with ; or # aren't really comments, probably auto-detect fail
|
||
|
hljs.COMMENT('[;#](?!\\s*$)', '$'),
|
||
|
hljs.C_BLOCK_COMMENT_MODE,
|
||
|
hljs.QUOTE_STRING_MODE,
|
||
|
{
|
||
|
className: 'string',
|
||
|
begin: '\'',
|
||
|
end: '[^\\\\]\'',
|
||
|
relevance: 0
|
||
|
},
|
||
|
{
|
||
|
className: 'title',
|
||
|
begin: '\\|',
|
||
|
end: '\\|',
|
||
|
illegal: '\\n',
|
||
|
relevance: 0
|
||
|
},
|
||
|
{
|
||
|
className: 'number',
|
||
|
variants: [
|
||
|
{ // hex
|
||
|
begin: '0x[0-9a-f]+'
|
||
|
},
|
||
|
{ // bare number
|
||
|
begin: '\\b-?\\d+'
|
||
|
}
|
||
|
],
|
||
|
relevance: 0
|
||
|
},
|
||
|
{
|
||
|
className: 'symbol',
|
||
|
variants: [
|
||
|
{ // GNU MIPS syntax
|
||
|
begin: '^\\s*[a-z_\\.\\$][a-z0-9_\\.\\$]+:'
|
||
|
},
|
||
|
{ // numbered local labels
|
||
|
begin: '^\\s*[0-9]+:'
|
||
|
},
|
||
|
{ // number local label reference (backwards, forwards)
|
||
|
begin: '[0-9]+[bf]'
|
||
|
}
|
||
|
],
|
||
|
relevance: 0
|
||
|
}
|
||
|
],
|
||
|
// forward slashes are not allowed
|
||
|
illegal: /\//
|
||
|
};
|
||
|
}
|
||
|
|
||
|
module.exports = mipsasm;
|