X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=src%2Fmisc%2Fbochs-2.2.6-big-endian.patch;h=420f69b5d5ed3052d1435f4f1ca9cb3ac6aa76fa;hb=4053c61636a5ee545c8130bcedea12d77b85de4c;hp=be95dae5a2c9895a4e2914a5f4292cb70d3f34a9;hpb=c756825357f433537caec55ac12cf0104be3a6f4;p=pintos-anon diff --git a/src/misc/bochs-2.2.6-big-endian.patch b/src/misc/bochs-2.2.6-big-endian.patch index be95dae..420f69b 100644 --- a/src/misc/bochs-2.2.6-big-endian.patch +++ b/src/misc/bochs-2.2.6-big-endian.patch @@ -1,63 +1,63 @@ diff -urp bochs-2.2.6/gdbstub.cc bochs-2.2.6.orig/gdbstub.cc ---- bochs-2.2.6/gdbstub.cc 2006-04-03 13:47:39.000000000 -0700 -+++ bochs-2.2.6.orig/gdbstub.cc 2006-01-17 09:15:29.000000000 -0800 -@@ -672,36 +672,35 @@ static void debug_loop(void) +--- bochs-2.2.6.orig/gdbstub.cc 2006-01-17 09:15:29.000000000 -0800 ++++ bochs-2.2.6/gdbstub.cc 2006-04-03 13:47:39.000000000 -0700 +@@ -672,35 +672,36 @@ case 'g': #if !BX_SUPPORT_X86_64 -- WriteHostDWordToLittleEndian(registers + 0, EAX); -- WriteHostDWordToLittleEndian(registers + 1, ECX); -- WriteHostDWordToLittleEndian(registers + 2, EDX); -- WriteHostDWordToLittleEndian(registers + 3, EBX); -- WriteHostDWordToLittleEndian(registers + 4, ESP); -- WriteHostDWordToLittleEndian(registers + 5, EBP); -- WriteHostDWordToLittleEndian(registers + 6, ESI); -- WriteHostDWordToLittleEndian(registers + 7, EDI); -+ registers[0] = EAX; -+ registers[1] = ECX; -+ registers[2] = EDX; -+ registers[3] = EBX; -+ registers[4] = ESP; -+ registers[5] = EBP; -+ registers[6] = ESI; -+ registers[7] = EDI; +- registers[0] = EAX; +- registers[1] = ECX; +- registers[2] = EDX; +- registers[3] = EBX; +- registers[4] = ESP; +- registers[5] = EBP; +- registers[6] = ESI; +- registers[7] = EDI; ++ WriteHostDWordToLittleEndian(registers + 0, EAX); ++ WriteHostDWordToLittleEndian(registers + 1, ECX); ++ WriteHostDWordToLittleEndian(registers + 2, EDX); ++ WriteHostDWordToLittleEndian(registers + 3, EBX); ++ WriteHostDWordToLittleEndian(registers + 4, ESP); ++ WriteHostDWordToLittleEndian(registers + 5, EBP); ++ WriteHostDWordToLittleEndian(registers + 6, ESI); ++ WriteHostDWordToLittleEndian(registers + 7, EDI); if (last_stop_reason == GDBSTUB_EXECUTION_BREAKPOINT) { -- WriteHostDWordToLittleEndian(registers + 8, EIP + 1); -+ registers[8] = EIP + 1; +- registers[8] = EIP + 1; ++ WriteHostDWordToLittleEndian(registers + 8, EIP + 1); } else { -- WriteHostDWordToLittleEndian(registers + 8, EIP); -+ registers[8] = EIP; +- registers[8] = EIP; ++ WriteHostDWordToLittleEndian(registers + 8, EIP); } -- WriteHostDWordToLittleEndian(registers + 9, -- BX_CPU_THIS_PTR read_eflags()); -- WriteHostDWordToLittleEndian(registers + 10, -- BX_CPU_THIS_PTR sregs[BX_SEG_REG_CS].selector.value); -- WriteHostDWordToLittleEndian(registers + 11, -- BX_CPU_THIS_PTR sregs[BX_SEG_REG_SS].selector.value); -- WriteHostDWordToLittleEndian(registers + 12, -- BX_CPU_THIS_PTR sregs[BX_SEG_REG_DS].selector.value); -- WriteHostDWordToLittleEndian(registers + 13, -- BX_CPU_THIS_PTR sregs[BX_SEG_REG_ES].selector.value); -- WriteHostDWordToLittleEndian(registers + 14, -- BX_CPU_THIS_PTR sregs[BX_SEG_REG_FS].selector.value); -- WriteHostDWordToLittleEndian(registers + 15, -- BX_CPU_THIS_PTR sregs[BX_SEG_REG_GS].selector.value); -+ registers[9] = BX_CPU_THIS_PTR read_eflags(); -+ registers[10] = -+ BX_CPU_THIS_PTR sregs[BX_SEG_REG_CS].selector.value; -+ registers[11] = -+ BX_CPU_THIS_PTR sregs[BX_SEG_REG_SS].selector.value; -+ registers[12] = -+ BX_CPU_THIS_PTR sregs[BX_SEG_REG_DS].selector.value; -+ registers[13] = -+ BX_CPU_THIS_PTR sregs[BX_SEG_REG_ES].selector.value; -+ registers[14] = -+ BX_CPU_THIS_PTR sregs[BX_SEG_REG_FS].selector.value; -+ registers[15] = -+ BX_CPU_THIS_PTR sregs[BX_SEG_REG_GS].selector.value; +- registers[9] = BX_CPU_THIS_PTR read_eflags(); +- registers[10] = +- BX_CPU_THIS_PTR sregs[BX_SEG_REG_CS].selector.value; +- registers[11] = +- BX_CPU_THIS_PTR sregs[BX_SEG_REG_SS].selector.value; +- registers[12] = +- BX_CPU_THIS_PTR sregs[BX_SEG_REG_DS].selector.value; +- registers[13] = +- BX_CPU_THIS_PTR sregs[BX_SEG_REG_ES].selector.value; +- registers[14] = +- BX_CPU_THIS_PTR sregs[BX_SEG_REG_FS].selector.value; +- registers[15] = +- BX_CPU_THIS_PTR sregs[BX_SEG_REG_GS].selector.value; ++ WriteHostDWordToLittleEndian(registers + 9, ++ BX_CPU_THIS_PTR read_eflags()); ++ WriteHostDWordToLittleEndian(registers + 10, ++ BX_CPU_THIS_PTR sregs[BX_SEG_REG_CS].selector.value); ++ WriteHostDWordToLittleEndian(registers + 11, ++ BX_CPU_THIS_PTR sregs[BX_SEG_REG_SS].selector.value); ++ WriteHostDWordToLittleEndian(registers + 12, ++ BX_CPU_THIS_PTR sregs[BX_SEG_REG_DS].selector.value); ++ WriteHostDWordToLittleEndian(registers + 13, ++ BX_CPU_THIS_PTR sregs[BX_SEG_REG_ES].selector.value); ++ WriteHostDWordToLittleEndian(registers + 14, ++ BX_CPU_THIS_PTR sregs[BX_SEG_REG_FS].selector.value); ++ WriteHostDWordToLittleEndian(registers + 15, ++ BX_CPU_THIS_PTR sregs[BX_SEG_REG_GS].selector.value); mem2hex((char *)registers, obuf, NUMREGSBYTES); #else #define PUTREG(buf, val, len) do { \