123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 |
- function mipsasm(hljs) {
-
- return {
- name: 'MIPS Assembly',
- case_insensitive: true,
- aliases: [ 'mips' ],
- keywords: {
- $pattern: '\\.?' + hljs.IDENT_RE,
- meta:
-
- '.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 ' +
- '$16 $17 $18 $19 $20 $21 $22 $23 $24 $25 $26 $27 $28 $29 $30 $31 ' +
- 'zero at v0 v1 a0 a1 a2 a3 a4 a5 a6 a7 ' +
- 't0 t1 t2 t3 t4 t5 t6 t7 t8 t9 s0 s1 s2 s3 s4 s5 s6 s7 s8 ' +
- 'k0 k1 gp sp fp ra ' +
- '$f0 $f1 $f2 $f2 $f4 $f5 $f6 $f7 $f8 $f9 $f10 $f11 $f12 $f13 $f14 $f15 ' +
- '$f16 $f17 $f18 $f19 $f20 $f21 $f22 $f23 $f24 $f25 $f26 $f27 $f28 $f29 $f30 $f31 ' +
- 'Context Random EntryLo0 EntryLo1 Context PageMask Wired EntryHi ' +
- 'HWREna BadVAddr Count Compare SR IntCtl SRSCtl SRSMap Cause EPC PRId ' +
- 'EBase Config Config1 Config2 Config3 LLAddr Debug DEPC DESAVE CacheErr ' +
- 'ECC ErrorEPC TagLo DataLo TagHi DataHi WatchLo WatchHi PerfCtl PerfCnt '
- },
- contains: [
- {
- className: 'keyword',
- begin: '\\b(' +
-
- '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|' +
-
- '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|' +
-
- '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'
- },
-
- 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: [
- {
- begin: '0x[0-9a-f]+'
- },
- {
- begin: '\\b-?\\d+'
- }
- ],
- relevance: 0
- },
- {
- className: 'symbol',
- variants: [
- {
- begin: '^\\s*[a-z_\\.\\$][a-z0-9_\\.\\$]+:'
- },
- {
- begin: '^\\s*[0-9]+:'
- },
- {
- begin: '[0-9]+[bf]'
- }
- ],
- relevance: 0
- }
- ],
-
- illegal: /\//
- };
- }
- module.exports = mipsasm;
|