Compare commits

..

No commits in common. "a3237826645c4114b76eba6ba9907ccc8bfc9ee0" and "505bc620a4e5a0b8d344faef2eea40fdbd865ad7" have entirely different histories.

11 changed files with 57 additions and 62 deletions

View file

@ -1,20 +0,0 @@
package Programs;
import hatelace.*;
import hatelace.instructions.*;
public class Factorial extends Program {
public Factorial() {
Address n = new Address(0),
fac = new Address(1);
add(new Copy(new IntWord(5), n));
add(new Copy(new IntWord(1), fac));
add(new JumpEq(6, n, new IntWord(1)));
add(new Mul(fac, n, fac));
add(new Add(n, new IntWord(-1), n));
add(new Jump(2));
add(new Print(fac));
add(new Halt());
}
}

View file

@ -15,7 +15,7 @@ public class Computer {
public void run() { public void run() {
// Note that the instructions themselves are responsible for incrementing the PC // Note that the instructions themselves are responsible for incrementing the PC
for(ProgramCounter PC = new ProgramCounter(); PC.getPC() < this.program.size() && !PC.halted() && PC.getSysTicks() < 100; ) { for(ProgramCounter PC = new ProgramCounter(); PC.getPC() < this.program.size() && !PC.halted() && PC.getSysTicks() < 100; ) {
program.get(PC.getPC()).execute(this.memory, PC); program.getInstructions()[PC.getPC()].execute(this.memory, PC);
} }
} }
} }

View file

@ -1,6 +1,6 @@
package hatelace; package hatelace;
import Programs.Factorial; import hatelace.instructions.*;
public class Main { public class Main {
public static void main(String[] args) { public static void main(String[] args) {
@ -8,15 +8,26 @@ public class Main {
Memory memory = new IntMemory(64); // 64 words of memory Memory memory = new IntMemory(64); // 64 words of memory
Computer computer = new Computer(memory); Computer computer = new Computer(memory);
Program program = new Factorial();
Address n = new Address(0), fac = new Address(1);
Program program = new Program(new Instruction[] {
new Copy(new IntWord(5), n),
new Copy(new IntWord(1), fac),
new JumpEq(6, n, new IntWord(1)),
new Mul(fac, n, fac),
new Add(n, new IntWord(-1), n),
new Jump(2),
new Print(fac),
new Halt()
});
computer.load(program); computer.load(program);
computer.run(); computer.run();
memory.dump(); memory.dump();
// Print the program // Print the program
System.out.println("Program:"); System.out.println("Program:");
for (Instruction instruction : program) { for (Instruction instruction : program.getInstructions()) {
System.out.println(instruction); System.out.println(instruction);
} }

View file

@ -1,6 +1,17 @@
package hatelace; package hatelace;
import java.util.ArrayList; public class Program {
private Instruction[] instructions;
// This is simply an intermediate class to comply with the specified API requirements. public Program(Instruction[] instructions) {
public abstract class Program extends ArrayList<Instruction> {} this.instructions = instructions;
}
public Instruction[] getInstructions() {
return this.instructions;
}
public int size() {
return this.instructions.length;
}
}

View file

@ -3,19 +3,18 @@ package hatelace.instructions;
import hatelace.*; import hatelace.*;
public class Add extends Instruction { public class Add extends Instruction {
private Address src; private Address op1;
private Word imm; private Word op2;
private Address dest; private Address dest;
/** Add immediate value to memory address. */ public Add(Address op1, Word op2, Address dest) {
public Add(Address src, Word imm, Address dest) { this.op1 = op1;
this.src = src; this.op2 = op2;
this.imm = imm;
this.dest = dest; this.dest = dest;
} }
public void execute(Memory memory, ProgramCounter PC) { public void execute(Memory memory, ProgramCounter PC) {
memory.write(this.dest, memory.read(this.src).add(this.imm)); memory.write(this.dest, memory.read(this.op1).add(this.op2));
PC.incPC(); PC.incPC();
} }
@ -24,6 +23,6 @@ public class Add extends Instruction {
} }
protected Object[] operands() { protected Object[] operands() {
return new Object[] { this.src, this.imm, this.dest }; return new Object[] { this.op1, this.op2, this.dest };
} }
} }

View file

@ -3,17 +3,16 @@ package hatelace.instructions;
import hatelace.*; import hatelace.*;
public class Copy extends Instruction { public class Copy extends Instruction {
private Word imm; private Word word;
private Address dest; private Address address;
/** Copy immediate value to memory address. */ public Copy(Word word, Address address) {
public Copy(Word imm, Address dest) { this.word = word;
this.imm = imm; this.address = address;
this.dest = dest;
} }
public void execute(Memory memory, ProgramCounter PC) { public void execute(Memory memory, ProgramCounter PC) {
memory.write(this.dest, this.imm); memory.write(this.address, this.word);
PC.incPC(); PC.incPC();
} }
@ -22,6 +21,6 @@ public class Copy extends Instruction {
} }
protected Object[] operands() { protected Object[] operands() {
return new Object[] {this.imm, this.dest}; return new Object[] {this.word, this.address};
} }
} }

View file

@ -3,7 +3,6 @@ package hatelace.instructions;
import hatelace.*; import hatelace.*;
public class Halt extends Instruction { public class Halt extends Instruction {
/** Halts the CPU */
public Halt(){}; public Halt(){};
public void execute(Memory memory, ProgramCounter PC) { public void execute(Memory memory, ProgramCounter PC) {

View file

@ -5,7 +5,6 @@ import hatelace.*;
public class Jump extends Instruction { public class Jump extends Instruction {
private int index; private int index;
/** Unconditional jump, non-relative */
public Jump(int index) { public Jump(int index) {
this.index = index; this.index = index;
} }

View file

@ -4,18 +4,17 @@ import hatelace.*;
public class JumpEq extends Instruction { public class JumpEq extends Instruction {
private int index; private int index;
private Address src; private Address address;
private Word imm; private Word value;
/** Conditional jump */ public JumpEq(int index, Address address, Word value) {
public JumpEq(int index, Address src, Word imm) {
this.index = index; this.index = index;
this.src = src; this.address = address;
this.imm = imm; this.value = value;
} }
public void execute(Memory memory, ProgramCounter PC) { public void execute(Memory memory, ProgramCounter PC) {
if (this.imm.equals(memory.read(this.src))) { if (this.value.equals(memory.read(this.address))) {
PC.setPC(this.index); PC.setPC(this.index);
} else { } else {
PC.incPC(); PC.incPC();
@ -27,6 +26,6 @@ public class JumpEq extends Instruction {
} }
protected Object[] operands() { protected Object[] operands() {
return new Object[] {this.index, this.src, this.imm}; return new Object[] {this.index, this.address, this.value};
} }
} }

View file

@ -3,19 +3,18 @@ package hatelace.instructions;
import hatelace.*; import hatelace.*;
public class Mul extends Instruction { public class Mul extends Instruction {
private Address src1; private Address op1;
private Address src2; private Address op2;
private Address dest; private Address dest;
/** Multiply contents of two addresses and store the result in a third memory address. */ public Mul(Address op1, Address op2, Address dest) {
public Mul(Address src1, Address src2, Address dest) { this.op1 = op1;
this.src1 = src1; this.op2 = op2;
this.src2 = src2;
this.dest = dest; this.dest = dest;
} }
public void execute(Memory memory, ProgramCounter PC) { public void execute(Memory memory, ProgramCounter PC) {
memory.write(this.dest, memory.read(this.src1).multiply(memory.read(this.src2))); memory.write(this.dest, memory.read(this.op1).multiply(memory.read(this.op2)));
PC.incPC(); PC.incPC();
} }
@ -24,6 +23,6 @@ public class Mul extends Instruction {
} }
protected Object[] operands() { protected Object[] operands() {
return new Object[] { this.src1, this.src2, this.dest }; return new Object[] {this.op1, this.op2, this.dest};
} }
} }

View file

@ -5,7 +5,6 @@ import hatelace.*;
public class Print extends Instruction { public class Print extends Instruction {
private Address address; private Address address;
/** Print content of memory address */
public Print(Address address) { public Print(Address address) {
this.address = address; this.address = address;
} }