Web based MIPS assembler and emulator

encoders.js 1.4KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. const utils = require('./utils.js')
  2. const regmap = [
  3. 'zero', 'at', 'v0', 'v1', 'a0', 'a1', 'a2', 't0', 't1', 't2', 't3', 't4', 't5',
  4. 't6', 't7', 's0', 's1', 's2', 's3', 's4', 's5', 's6', 's7', 't8', 't9', 'k0',
  5. 'k1', 'gp', 'sp', 's8', 'ra' ]
  6. const getReg = (id) => {
  7. if (id.startsWith('$')) {
  8. id = id.slice(1)
  9. }
  10. if ((isNaN(id) === false && +id >= 0 && +id <= 31) || (id = regmap.indexOf(id)) > -1) {
  11. return id
  12. } else {
  13. utils.error("Invalid register: " + id)
  14. }
  15. }
  16. const encoders = {
  17. 'LUI': (rt, immediate) => {
  18. let encoded = '001111'
  19. encoded = encoded + '0'.repeat(5)
  20. encoded = encoded + utils.dec2binu(getReg(rt), 5)
  21. encoded = encoded + utils.hex2bin(immediate, 16)
  22. return '0x' + utils.bin2hex(encoded, 8)
  23. },
  24. 'ORI': (rt, rs, immediate) => {
  25. let encoded = '001101'
  26. encoded = encoded + utils.dec2binu(getReg(rs), 5)
  27. encoded = encoded + utils.dec2binu(getReg(rt), 5)
  28. encoded = encoded + utils.hex2bin(immediate, 16)
  29. return '0x' + utils.bin2hex(encoded, 8)
  30. },
  31. 'SW': (rt, offsetBase) => {
  32. const [offset, base] = utils.splitOffsetBase(offsetBase)
  33. let encoded = '101011'
  34. encoded = encoded + utils.dec2binu(getReg(base), 5)
  35. encoded = encoded + utils.dec2binu(getReg(rt), 5)
  36. encoded = encoded + utils.int16_2bin(offset, 16)
  37. console.log(encoded)
  38. return '0x' + utils.bin2hex(encoded, 8)
  39. }
  40. }
  41. module.exports = encoders