/*******************************************************************************
* openDLX - A DLX/MIPS processor simulator.
* Copyright (C) 2013 The openDLX project, University of Augsburg, Germany
* Project URL: <https://sourceforge.net/projects/opendlx>
* Development branch: <https://github.com/smetzlaff/openDLX>
*
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program, see <LICENSE>. If not, see
* <http://www.gnu.org/licenses/>.
******************************************************************************/
package openDLX;
import org.apache.log4j.Logger;
import openDLX.datatypes.*;
public class BranchControl
{
private static Logger logger = Logger.getLogger("EXECUTE/BCTRL");
public boolean checkBranch(Instruction inst, uint32 A, uint32 B)
{
boolean jump = false;
switch(inst.getBranchCondition())
{
case BEQ:
if(A.getValue() == B.getValue())
{
jump = true;
}
break;
case BNE:
if(A.getValue() != B.getValue())
{
jump = true;
}
break;
case BGEZ:
if(A.getValue() >= 0)
{
jump = true;
}
case BGTZ:
if(A.getValue() > 0)
{
jump = true;
}
break;
case BLEZ:
if(A.getValue() <= 0)
{
jump = true;
}
break;
case BLTZ:
if(A.getValue() < 0)
{
jump = true;
}
break;
case UNCOND:
jump = true;
break;
default:
jump = false;
}
if(inst.getBranch())
{
logger.debug("A: " + A.getValueAsHexString() + " " + inst.getBranchCondition() + " B: " + B.getValueAsHexString() + " jump: " + jump);
}
return jump;
}
}