X-Git-Url: http://git.megacz.com/?p=nestedvm.git;a=blobdiff_plain;f=src%2Forg%2Fibex%2Fnestedvm%2FInterpreter.java;fp=src%2Forg%2Fibex%2Fnestedvm%2FInterpreter.java;h=e39ecfa6083a008de2117b161ae3f50261ef75c5;hp=b6b34240aa28e534df2c6ae7f314dccce8225dd3;hb=d17f981238451c360a30bd631ca8a4bc95762a33;hpb=814947ec0bf8e8cad840df9f21320a9ce9ffd1ac diff --git a/src/org/ibex/nestedvm/Interpreter.java b/src/org/ibex/nestedvm/Interpreter.java index b6b3424..e39ecfa 100644 --- a/src/org/ibex/nestedvm/Interpreter.java +++ b/src/org/ibex/nestedvm/Interpreter.java @@ -470,9 +470,10 @@ public class Interpreter extends UnixRuntime implements Cloneable { } catch(RuntimeException e) { tmp = memRead(addr&~3); } - switch(addr&2) { + switch(addr&3) { case 0: tmp = (tmp>>>16)&0xffff; break; case 2: tmp = (tmp>>> 0)&0xffff; break; + default: throw new ReadFaultException(addr); } if((tmp&0x8000)!=0) tmp |= 0xffff0000; // sign extend r[rt] = tmp; @@ -523,9 +524,10 @@ public class Interpreter extends UnixRuntime implements Cloneable { } catch(RuntimeException e) { tmp = memRead(addr&~3); } - switch(addr&2) { + switch(addr&3) { case 0: r[rt] = (tmp>>>16)&0xffff; break; case 2: r[rt] = (tmp>>> 0)&0xffff; break; + default: throw new ReadFaultException(addr); } break; } @@ -571,9 +573,10 @@ public class Interpreter extends UnixRuntime implements Cloneable { } catch(RuntimeException e) { tmp = memRead(addr&~3); } - switch(addr&2) { + switch(addr&3) { case 0: tmp = (tmp&0x0000ffff) | ((r[rt]&0xffff)<<16); break; case 2: tmp = (tmp&0xffff0000) | ((r[rt]&0xffff)<< 0); break; + default: throw new WriteFaultException(addr); } try { writePages[addr>>>pageShift][(addr>>>2)&(PAGE_WORDS-1)] = tmp;