Gabe Black
|
8813168b5a
|
X86: Do a merge for the zero extension microop.
|
2009-02-25 10:20:10 -08:00 |
|
Gabe Black
|
28a35a6adb
|
X86: Add microops for reading/writing debug registers.
|
2009-02-25 10:20:01 -08:00 |
|
Gabe Black
|
cb4141f6e6
|
X86: Check src1 for illegal values since that's the index we actually use.
|
2009-02-25 10:19:47 -08:00 |
|
Gabe Black
|
06ff83e1b9
|
X86: Implement a basic prefetch instruction.
|
2009-02-25 10:19:22 -08:00 |
|
Gabe Black
|
5f0428ef9f
|
X86: Use the right portion of a register for stores.
|
2009-02-25 10:19:14 -08:00 |
|
Gabe Black
|
dc53ca89f6
|
X86: Add a flag to force memory accesses to happen at CPL 0.
|
2009-02-25 10:18:22 -08:00 |
|
Gabe Black
|
fcad6e3b13
|
X86: Add a wrattr microop.
|
2009-02-25 10:17:38 -08:00 |
|
Gabe Black
|
08f3a126d5
|
X86: Fix segment limit checking.
|
2009-02-25 10:17:08 -08:00 |
|
Gabe Black
|
2f31643db5
|
X86: Add a check to chks to verify a task state segment descriptor.
|
2009-02-25 10:17:02 -08:00 |
|
Gabe Black
|
7b1cb74ac3
|
X86: Add a check to chks which raises #GP(selector) if selector is NULL or not in the GDT.
|
2009-02-25 10:16:54 -08:00 |
|
Gabe Black
|
1b336a8fe7
|
X86: Make the stupd microop not update registers in initiateAcc.
|
2009-02-25 10:15:56 -08:00 |
|
Gabe Black
|
a1aba01a02
|
CPU: Get rid of translate... functions from various interface classes.
|
2009-02-25 10:15:34 -08:00 |
|
Nathan Binkert
|
e1798d063e
|
Quell g++ 4.3 warning about operator ambiguity
|
2009-02-06 20:55:50 -08:00 |
|
Gabe Black
|
923a14dde7
|
X86: Make the fault classes handle error codes better.
|
2009-02-01 17:08:32 -08:00 |
|
Gabe Black
|
9b4d1e0f9a
|
X86: Distinguish between hardware and software interrupts/exceptions
|
2009-02-01 17:07:18 -08:00 |
|
Gabe Black
|
6b53b8387e
|
X86: Make the chks microop check for the right int descriptor type.
|
2009-02-01 17:05:37 -08:00 |
|
Gabe Black
|
115b1a7ed3
|
X86: Autogenerate macroop generateDisassemble function.
|
2009-01-06 22:55:27 -08:00 |
|
Gabe Black
|
8c15518f30
|
X86: Fix completeAcc get call.
|
2008-11-09 21:55:43 -08:00 |
|
Gabe Black
|
3c4567f2a6
|
X86: Set the delayed commit flag in x86 microops appropriately.
|
2008-10-12 23:29:10 -07:00 |
|
Gabe Black
|
a2e0d539d8
|
X86: Add wrval/rdval microops for reading significant miscregs.
|
2008-10-12 22:55:55 -07:00 |
|
Gabe Black
|
f813a4be49
|
X86: Make sure register microops set fault rather than returning one.
|
2008-10-12 22:24:06 -07:00 |
|
Gabe Black
|
961b40cdb5
|
X86: Implement an wrdh microop which loads bases/offsets from 16 byte descriptors.
|
2008-10-12 22:16:53 -07:00 |
|
Gabe Black
|
6b46e5204d
|
X86: Implement the chks check of interrupt gate target code segments.
|
2008-10-12 20:38:22 -07:00 |
|
Gabe Black
|
30feb90c1c
|
X86: Add a check type for interrupt gates.
|
2008-10-12 20:33:37 -07:00 |
|
Gabe Black
|
15f5bb3055
|
X86: Fix chks checking the submode for stack segments.
|
2008-10-12 20:29:52 -07:00 |
|
Gabe Black
|
9e1fe2050a
|
X86: Let segment manipulation microops be conditional.
|
2008-10-12 20:25:06 -07:00 |
|
Gabe Black
|
223fc41c07
|
X86: Fix the rdbase microop
|
2008-10-12 20:07:46 -07:00 |
|
Gabe Black
|
cefb768131
|
X86: Create a handy way to access labels from the ROM in microcode.
|
2008-10-12 17:52:51 -07:00 |
|
Gabe Black
|
e5f8092467
|
X86: Make X86's microcode ROM actually do something.
|
2008-10-12 17:48:44 -07:00 |
|
Gabe Black
|
6fd4eff68f
|
X86: Create an eret microop which returns from ROM to combinational decoding.
|
2008-10-12 15:53:04 -07:00 |
|
Gabe Black
|
4aa18aa800
|
X86: Make Br never report itself as the last microop.
|
2008-10-12 15:43:35 -07:00 |
|
Gabe Black
|
77c0e1d110
|
X86: Create a SeqOp class of microops and make Br one of them.
|
2008-10-12 15:33:17 -07:00 |
|
Gabe Black
|
e1b306fa53
|
X86: Fix the debugging microops. The debug functions can't handle a string object format.
|
2008-10-09 00:05:39 -07:00 |
|
Gabe Black
|
4f4ff17578
|
X86: Make the disassembly for halt conform with the other microops.
|
2008-06-12 00:58:27 -04:00 |
|
Gabe Black
|
66f54a6037
|
X86: Change how segment loading is performed.
|
2008-06-12 00:52:12 -04:00 |
|
Gabe Black
|
d4e7c7edd3
|
X86: Keep handy values like the operating mode in one register.
|
2008-06-12 00:50:25 -04:00 |
|
Gabe Black
|
fa7c81c6df
|
X86: Change what the microop chks does.
Instead of computing the segment descriptor address, this now checks if a
selector value/descriptor are legal for a particular purpose.
|
2008-06-12 00:50:10 -04:00 |
|
Gabe Black
|
6bd9cf3594
|
X86: Add a microop to read a segments attribute register.
|
2008-06-12 00:50:05 -04:00 |
|
Gabe Black
|
e0c20386ac
|
X86: Add microops and supporting code to manipulate the whole rflags register.
|
2008-06-12 00:49:50 -04:00 |
|
Gabe Black
|
2bb8933f78
|
X86: Add microops which panic, fatal, warn, and warn_once.
|
2008-06-12 00:49:25 -04:00 |
|
Gabe Black
|
bbc1f394ff
|
X86: Truncate descriptors to 16 bits.
|
2008-06-12 00:49:16 -04:00 |
|
Gabe Black
|
8501a90f59
|
X86: Add in some support for the tsc register.
|
2008-06-12 00:39:10 -04:00 |
|
Gabe Black
|
98d2ca403e
|
X86: Implement the INVLPG instruction and the TIA microop.
--HG--
extra : convert_revision : 31db1ee082f6c3ca5443cba1eb335e408661ead2
|
2008-02-26 23:39:22 -05:00 |
|
Gabe Black
|
988c6f227a
|
X86: Implement mov from control register.
--HG--
extra : convert_revision : c8280f0686a3ae6d5c405327540ad15a3a5531f9
|
2007-12-01 23:06:03 -08:00 |
|
Gabe Black
|
fe833dd2c3
|
X86: First crack at far returns. This is grossly approximate.
--HG--
extra : convert_revision : 23da0338af1f7663ae5ddf2289fb45dd32f37c42
|
2007-12-01 23:05:01 -08:00 |
|
Gabe Black
|
dc6f960171
|
X86: Reorganize segmentation and implement segment selector movs.
--HG--
extra : convert_revision : 553c3ffeda1f5312cf02493f602e7d4ba2fe66e8
|
2007-12-01 23:03:39 -08:00 |
|
Gabe Black
|
a548067b01
|
X86: Make the "fault" microop predicated.
--HG--
extra : convert_revision : ded34133afcd6af1f55b8991b82bad45258069d3
|
2007-12-01 23:01:56 -08:00 |
|
Gabe Black
|
62c79ca637
|
X86: Implement the lgdt instruction.
--HG--
extra : convert_revision : d1698a82df3c57cc9bbf8d5d190f271bfc7cb2e4
|
2007-12-01 23:01:17 -08:00 |
|
Gabe Black
|
4e3ff42762
|
X86: Implement wrbase and wrlimit for loading pseudo descriptors.
--HG--
extra : convert_revision : fe03c4aed95ef12773e80cdb3d9cff68a2b20f02
|
2007-12-01 23:00:58 -08:00 |
|
Gabe Black
|
5772e3cada
|
X86: Make microcode use presegmentation RIPs and the rest of m5 use post segmentation RIPS.
--HG--
extra : convert_revision : d8cda7c8b9a2afb8a9d601b6d61529a96c5f87fe
|
2007-11-13 01:31:43 -08:00 |
|