Andrew Waterman [Sun, 24 Apr 2011 23:35:13 +0000 (16:35 -0700)]
[xcc,sim,opcodes] added more RVC instructions
Andrew Waterman [Sun, 24 Apr 2011 04:31:50 +0000 (21:31 -0700)]
[sim] fixed divw/remw crashing simulator
Andrew Waterman [Tue, 19 Apr 2011 05:55:28 +0000 (22:55 -0700)]
[xcc,sim] rv64 'w' instruction semantics changed
they no longer require their inputs to be canonicalized 32b values, so
this speeds up mixed int/long code sequences.
Andrew Waterman [Tue, 19 Apr 2011 02:28:51 +0000 (19:28 -0700)]
[xcc,sim,opcodes] added rvc conditional branches
Andrew Waterman [Sun, 17 Apr 2011 02:44:52 +0000 (19:44 -0700)]
[sim] removed undefined behavior for non-canonical inputs
Andrew Waterman [Sun, 17 Apr 2011 02:44:16 +0000 (19:44 -0700)]
[sim] added "str" debug command
it prints the c string starting at the specified memory address.
Andrew Waterman [Fri, 15 Apr 2011 22:33:39 +0000 (15:33 -0700)]
[sim] fixed jalr immediate bug
Andrew Waterman [Fri, 15 Apr 2011 21:32:54 +0000 (14:32 -0700)]
[sim] added icache simulator (disabled by default)
Andrew Waterman [Wed, 13 Apr 2011 01:27:26 +0000 (18:27 -0700)]
[xcc,pk,sim] added privileged cflush instruction
Andrew Waterman [Wed, 13 Apr 2011 01:22:07 +0000 (18:22 -0700)]
[xcc,sim] fixed RM field
Andrew Waterman [Tue, 12 Apr 2011 08:42:55 +0000 (01:42 -0700)]
[xcc,sim] rvc loads and stores
Andrew Waterman [Tue, 12 Apr 2011 08:42:20 +0000 (01:42 -0700)]
[sim,pk] fixed minor pk bugs and trap codes
Andrew Waterman [Tue, 12 Apr 2011 00:10:16 +0000 (17:10 -0700)]
[sim] fixed FSR exception field bug
Andrew Waterman [Tue, 12 Apr 2011 00:09:50 +0000 (17:09 -0700)]
[xcc,sim,opcodes] more rvc instructions and bug fixes
Yunsup Lee [Sun, 10 Apr 2011 03:18:04 +0000 (20:18 -0700)]
[sim] add disable option for vector
Yunsup Lee [Sun, 10 Apr 2011 03:15:22 +0000 (20:15 -0700)]
[sim] set SR_EV for uts
Yunsup Lee [Sun, 10 Apr 2011 02:45:10 +0000 (19:45 -0700)]
[sim] add vector traps to vector instructions
Yunsup Lee [Sun, 10 Apr 2011 02:35:14 +0000 (19:35 -0700)]
[sim] add vt stuff
Andrew Waterman [Sun, 10 Apr 2011 03:03:07 +0000 (20:03 -0700)]
[xcc, sim] added rvc insn c.li; misc fixes
Andrew Waterman [Sun, 10 Apr 2011 00:50:12 +0000 (17:50 -0700)]
[sim,pk] reorganized status register
Andrew Waterman [Sun, 10 Apr 2011 00:37:42 +0000 (17:37 -0700)]
[xcc,pk,sim,opcodes] added first RVC instruction
Andrew Waterman [Fri, 8 Apr 2011 23:34:35 +0000 (16:34 -0700)]
[sim] fixed multiply-high in rv32
Andrew Waterman [Thu, 7 Apr 2011 22:41:00 +0000 (15:41 -0700)]
[pk,sim] fixed parse-opcodes bug
was causing spurious illegal instruction traps
Yunsup Lee [Thu, 7 Apr 2011 05:44:57 +0000 (22:44 -0700)]
[opcodes,pk,sim,xcc] fix utidx - add rd
Yunsup Lee [Tue, 5 Apr 2011 07:50:52 +0000 (00:50 -0700)]
[opcodes,pk,sim,xcc] fix vector mem instruction format, add vector seg mem instructions
Yunsup Lee [Mon, 4 Apr 2011 08:50:56 +0000 (01:50 -0700)]
[opcodes,pk,sim,xcc] add leftover vector instructions (vf, etc.)
Yunsup Lee [Mon, 4 Apr 2011 08:16:10 +0000 (01:16 -0700)]
[opcodes,pk,sim,xcc] add vector mem instructions
Yunsup Lee [Mon, 4 Apr 2011 07:08:18 +0000 (00:08 -0700)]
[opcodes,pk,sim,xcc] add stop,utidx instructions
Yunsup Lee [Mon, 4 Apr 2011 06:54:56 +0000 (23:54 -0700)]
[opcodes,pk,sim,xcc] add fence instructions for vector unit
Andrew Waterman [Wed, 30 Mar 2011 10:37:32 +0000 (03:37 -0700)]
[xcc] fixed bug in amo{maxu,minu}.w
Andrew Waterman [Sat, 26 Mar 2011 02:02:37 +0000 (19:02 -0700)]
[opcodes] minor opcode changes
Andrew Waterman [Sat, 26 Mar 2011 00:44:06 +0000 (17:44 -0700)]
[sim,pk,xcc,opcodes] removed fminmag/fmaxmag
Andrew Waterman [Fri, 25 Mar 2011 23:43:38 +0000 (16:43 -0700)]
[xcc,pk,opcodes,sim] updated encoding/insn names
Andrew Waterman [Fri, 18 Mar 2011 00:19:31 +0000 (17:19 -0700)]
[sim] LWU now illegal in RV32
Andrew Waterman [Tue, 1 Mar 2011 21:12:31 +0000 (13:12 -0800)]
[xcc,sim] branches are pc-relative (not pc+4) again
Andrew Waterman [Tue, 15 Feb 2011 07:44:13 +0000 (23:44 -0800)]
[xcc,opcodes,pk,sim] krste's re-renaming spree
Andrew Waterman [Tue, 15 Feb 2011 05:17:49 +0000 (21:17 -0800)]
[xcc,sim,opcodes] removed mtflh/mffl/mffh
in rv32 these will be replaced with loads and stores.
Andrew Waterman [Sat, 5 Feb 2011 00:09:47 +0000 (16:09 -0800)]
[sim,pk] added interrupt-pending field to cause reg
Andrew Waterman [Wed, 2 Feb 2011 09:52:36 +0000 (01:52 -0800)]
[sim,xcc,opcodes] added back mtflh.d
Andrew Waterman [Wed, 2 Feb 2011 09:31:07 +0000 (01:31 -0800)]
[opcodes,pk,sim,xcc] synci now bombs whole icache
Andrew Waterman [Wed, 2 Feb 2011 07:22:54 +0000 (23:22 -0800)]
[xcc,opcodes,pk,sim] cleanup to FP ISA
- Added 5th rounding mode
- Removed MFCR/MTCR in favor of MFFSR/MTFSR (it was the only CR...)
- merged MTF.D with MTFLH.D; operation depends on RV32/RV64 mode
- made MFFL.D and MFFH.D illegal in RV64
Andrew Waterman [Wed, 2 Feb 2011 02:57:37 +0000 (18:57 -0800)]
[sim] added nearest/ties to max magnitude rounding mode
Andrew Waterman [Thu, 27 Jan 2011 02:05:11 +0000 (18:05 -0800)]
[sim] changed divide-by-0 semantics
now it always gives -1, no matter the signedness.
Andrew Waterman [Wed, 26 Jan 2011 06:56:38 +0000 (22:56 -0800)]
[sim,opcodes] add mulhsu instruction
Andrew Waterman [Wed, 26 Jan 2011 06:51:24 +0000 (22:51 -0800)]
[opcodes,pk,sim,xcc] great renumbering of 2011, part deux
Andrew Waterman [Fri, 21 Jan 2011 04:37:22 +0000 (20:37 -0800)]
[sim, pk, xcc, opcodes] great instruction renaming of 2011
Andrew Waterman [Wed, 19 Jan 2011 01:51:52 +0000 (17:51 -0800)]
[opcodes, sim, xcc] made *w insns illegal in RV32
now generic variants behave differently in RV32 and RV64.
Andrew Waterman [Mon, 17 Jan 2011 09:13:50 +0000 (01:13 -0800)]
[opcodes, pk, sim, xcc] removed nor, normalized macros to addi
Andrew Waterman [Wed, 12 Jan 2011 03:02:20 +0000 (19:02 -0800)]
[sim] fix jalr bug
Yunsup Lee [Tue, 4 Jan 2011 03:12:24 +0000 (19:12 -0800)]
[opcodes,pk,sim,xcc] flip fields to favor little endian
Andrew Waterman [Mon, 27 Dec 2010 23:34:05 +0000 (15:34 -0800)]
[sim] fixed some compiler warnings
Andrew Waterman [Mon, 27 Dec 2010 22:28:45 +0000 (14:28 -0800)]
[sim] cleaned up handling of link register
Andrew Waterman [Thu, 11 Nov 2010 23:49:21 +0000 (15:49 -0800)]
[sim] handle integer division overflow
Behavior is now same as GCC's optimizer. Previously, we just crashed :)
Andrew Waterman [Tue, 9 Nov 2010 23:31:00 +0000 (15:31 -0800)]
[opcodes, pk, sim, xcc] Tweaked FP encoding
Andrew Waterman [Sun, 7 Nov 2010 00:44:56 +0000 (17:44 -0700)]
[opcodes] generate latex and verilog correctly
Andrew Waterman [Fri, 5 Nov 2010 23:46:36 +0000 (16:46 -0700)]
[pk] various PK cleanups/speedups
Andrew Waterman [Fri, 5 Nov 2010 21:06:12 +0000 (14:06 -0700)]
[xcc, sim, pk, opcodes] new instruction encoding!
Andrew Waterman [Tue, 2 Nov 2010 23:00:37 +0000 (16:00 -0700)]
[xcc, sim, pk] link register is now x1
Andrew Waterman [Tue, 2 Nov 2010 19:19:52 +0000 (12:19 -0700)]
[opcodes, pk, sim, xcc] made jumps shorter and PC-relative
Andrew Waterman [Tue, 26 Oct 2010 22:04:05 +0000 (15:04 -0700)]
[sim] removed unnecessary trap in mfcr instruction
Andrew Waterman [Tue, 26 Oct 2010 20:46:15 +0000 (13:46 -0700)]
[sim,xcc] fixed minor bugs related to tp/cr29
Yunsup Lee [Tue, 26 Oct 2010 09:20:44 +0000 (02:20 -0700)]
[pk,sim,xcc] get rid of at register, introduce tp register
Andrew Waterman [Tue, 26 Oct 2010 02:41:39 +0000 (19:41 -0700)]
[sim,xcc,pk,opcodes] static rounding modes for FP insns
Now, you can either use the RM in the FSR or specify it in the insn.
(Except for FP->int; no dynamic for that.)
Andrew Waterman [Sat, 16 Oct 2010 00:51:37 +0000 (17:51 -0700)]
[pk, sim] added FPU emulation support to proxy kernel
Andrew Waterman [Fri, 15 Oct 2010 23:17:53 +0000 (16:17 -0700)]
[sim] made softfloat files C instead of C++
Andrew Waterman [Tue, 12 Oct 2010 00:16:00 +0000 (17:16 -0700)]
[sim] added writeback tracing
Andrew Waterman [Thu, 7 Oct 2010 07:55:14 +0000 (00:55 -0700)]
[xcc] modified opcodes for better FP decode mapping
Andrew Waterman [Wed, 6 Oct 2010 02:21:55 +0000 (19:21 -0700)]
[opcodes] added code field back to syscall/break
Andrew Waterman [Wed, 6 Oct 2010 00:35:22 +0000 (17:35 -0700)]
[xcc] removed CEXC field from FSR
Andrew Waterman [Tue, 5 Oct 2010 22:08:18 +0000 (15:08 -0700)]
[xcc,sim] eliminated vectored traps
now, the evec register holds the address that all traps vector to,
and the cause register is set with the trap number.
Andrew Waterman [Sun, 3 Oct 2010 00:45:29 +0000 (17:45 -0700)]
[sim, xcc] changed cvt/trunc to use GPRs for int args
this way, we don't have to futz with storing integers in recoded
floating-point registers. too bad we lose some decoupling.
Andrew Waterman [Sun, 3 Oct 2010 00:19:42 +0000 (17:19 -0700)]
[xcc, sim] mff now uses rs2 for data
this is symmetric with fp stores, so we only need one decoding pipe
Andrew Waterman [Wed, 29 Sep 2010 00:17:04 +0000 (17:17 -0700)]
[opcodes, sim, xcc] added mffl.d instruction
...to be used instead of mff.s when doing int -> DP FP moves on a 32-bit cpu
Andrew Waterman [Thu, 23 Sep 2010 20:00:01 +0000 (13:00 -0700)]
[xcc, sim] eliminated zero-extended immediates
This is a big commit because it involved rewriting gcc's algorithm for
generating constants.
Andrew Waterman [Wed, 22 Sep 2010 21:02:28 +0000 (14:02 -0700)]
[sim] fixed bug in which shift operands were reversed
Andrew Waterman [Tue, 21 Sep 2010 02:01:40 +0000 (19:01 -0700)]
[xcc, sim] changed instruction format so imm12 subs for rs2
Andrew Waterman [Tue, 14 Sep 2010 01:00:08 +0000 (18:00 -0700)]
[xcc, sim] replaced ble/bleu with bge/bgeu
This will simplify control logic (since every branch has a logical inverse)
Andrew Waterman [Mon, 13 Sep 2010 02:13:48 +0000 (19:13 -0700)]
[sim] renamed sllv to sll (same for other shifts)
Andrew Waterman [Mon, 13 Sep 2010 01:23:36 +0000 (18:23 -0700)]
[xcc, sim] moved shamt field and renamed shifts
Andrew Waterman [Mon, 13 Sep 2010 00:03:47 +0000 (17:03 -0700)]
[xcc, sim] branches now are next-PC-based, not PC-based
Andrew Waterman [Sat, 11 Sep 2010 22:56:12 +0000 (15:56 -0700)]
[xcc] fixed broken 32-bit FP ABI
Andrew Waterman [Sat, 11 Sep 2010 04:13:55 +0000 (21:13 -0700)]
[sim, xcc] Added mffh.d/mtflh.d; fixed FP ABI for 32-bit
Andrew Waterman [Sat, 11 Sep 2010 04:02:38 +0000 (21:02 -0700)]
[sim, pk] cleaned up exception vectors and FP exc flags
Yunsup Lee [Sat, 11 Sep 2010 01:08:52 +0000 (18:08 -0700)]
[opcodes,xcc,sim] mffh.d,mtfh.d added (broken commit)
Yunsup Lee [Fri, 10 Sep 2010 06:21:11 +0000 (23:21 -0700)]
[opcodes,sim,xcc] move opcodes for 3 source instructions
Andrew Waterman [Fri, 10 Sep 2010 00:50:10 +0000 (17:50 -0700)]
Revert "[xcc, sim] added slei/sleui in lieu of slti/sltiu"
This reverts commit
bf5406d4df625678bc6ec20ce1d48541541dba54.
We found a clever way to efficiently implement slti/sltiu despite the
reversed operands. The trick is because of the following fact:
(a < b) === !(b <= a) === !(b-1 < a)
So just turn off the carry-in when doing the subtraction for the comparison.
Andrew Waterman [Thu, 9 Sep 2010 22:41:59 +0000 (15:41 -0700)]
Merge branch 'master' of /project/eecs/parlab/git/projects/riscv
Conflicts:
sim/riscv/insns/mtpcr.h
sim/riscv/processor.cc
Andrew Waterman [Thu, 9 Sep 2010 22:39:40 +0000 (15:39 -0700)]
[pk, sim] added interrupt support to sim; added timer interrupt
Yunsup Lee [Wed, 8 Sep 2010 22:58:39 +0000 (15:58 -0700)]
[sim] add while to interactive_until
Yunsup Lee [Wed, 8 Sep 2010 21:17:12 +0000 (14:17 -0700)]
[sim] change applink for tohost/fromhost (forgot one file)
Yunsup Lee [Wed, 8 Sep 2010 21:16:13 +0000 (14:16 -0700)]
[sim] change applink for tohost/fromhost
Andrew Waterman [Tue, 7 Sep 2010 23:04:57 +0000 (16:04 -0700)]
[xcc, sim] added slei/sleui in lieu of slti/sltiu
Rationale was that since we have the datapath for rc = (ra < rb),
it's straightforward to also add rc = !(imm < rb) = (rb <= imm).
Yunsup Lee [Tue, 7 Sep 2010 07:30:20 +0000 (00:30 -0700)]
[sim] yet another fix stdint.h __STDC_LIMIT_MACROS problem
Yunsup Lee [Tue, 7 Sep 2010 07:28:19 +0000 (00:28 -0700)]
[sim] fix stdint.h __STDC_LIMIT_MACROS problem
Andrew Waterman [Tue, 7 Sep 2010 07:19:19 +0000 (00:19 -0700)]
[sim, xcc] branches now have 2-byte-aligned displacements
This will facilitate 16-bit instructions later on
Andrew Waterman [Tue, 7 Sep 2010 05:48:37 +0000 (22:48 -0700)]
[sim, xcc] added PCRs to replace k0 and k1
Andrew Waterman [Tue, 7 Sep 2010 05:22:09 +0000 (22:22 -0700)]
[sim, xcc] bthread threading model exposed; insn encoding cleaned up
Andrew Waterman [Tue, 7 Sep 2010 00:06:50 +0000 (17:06 -0700)]
[sim] fixed bug in msub.d; added ability to print FPRs in debug mode
Andrew Waterman [Mon, 6 Sep 2010 23:04:52 +0000 (16:04 -0700)]
[sim] added atomic memory operations
Andrew Waterman [Tue, 24 Aug 2010 10:13:02 +0000 (03:13 -0700)]
[xcc] argc/argv work for 32b programs
Some patch-up code runs as soon as the 32b version of crt1 begins running
that massages the pointers accordingly.