diff options
| author | bd <bdunaisky@umass.edu> | 2025-04-01 02:12:15 +0000 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-04-01 02:12:15 +0000 | 
| commit | 6f536bd1bd1abab307c79d688c993e930cf7c250 (patch) | |
| tree | 6132673f5aa85f2488d6f7de77fb33538b7320d3 /src/sim/id.cc | |
| parent | 44cb9d396b909c84ef7ad3338e0a12cfcc082748 (diff) | |
| parent | 574212dafcf1c4bdb7d5e6aaa577b74345988d67 (diff) | |
Merge pull request #45 from bdunahu/dev-sid
MEM WB stage
Diffstat (limited to 'src/sim/id.cc')
| -rw-r--r-- | src/sim/id.cc | 13 | 
1 files changed, 9 insertions, 4 deletions
| diff --git a/src/sim/id.cc b/src/sim/id.cc index edf74e2..0b75b64 100644 --- a/src/sim/id.cc +++ b/src/sim/id.cc @@ -46,38 +46,43 @@ void ID::advance_helper()  {  	signed int s1, s2, s3;  	Mnemonic m; +	Type t;  	// it may be good to ensure we are not doing  	// work that has already been done -	if (this->curr_instr) { +	if (this->curr_instr && this->curr_instr->get_mnemonic() == NONE) {  		s1 = curr_instr->get_instr_bits(); -		get_instr_fields(s1, s2, s3, m); +		get_instr_fields(s1, s2, s3, m ,t);  		if (this->status == OK) {  			curr_instr->set_s1(s1);  			curr_instr->set_s2(s2);  			curr_instr->set_s3(s3);  			curr_instr->set_mnemonic(m); +			curr_instr->set_type(t);  		}  	}  } -void ID::get_instr_fields( -	signed int &s1, signed int &s2, signed int &s3, Mnemonic &m) +void ID::get_instr_fields(signed int &s1, signed int &s2, signed int &s3, Mnemonic &m, Type &t)  {  	unsigned int type;  	this->split_instr(s1, type, m);  	switch (type) {  	case 0b00: +		t = R;  		this->decode_R_type(s1, s2, s3);  		break;  	case 0b01: +		t = I;  		this->decode_I_type(s1, s2, s3);  		break;  	case 0b10: +		t = J;  		this->decode_J_type(s1, s2);  		break;  	case 0b11: +		t = INV;  		this->status = OK;  	}  } | 
