Age | Commit message (Collapse) | Author | |
---|---|---|---|
2009-04-19 | X86: Implement a locking version of AND. | Gabe Black | |
2009-04-19 | X86: Implement a locking version of SBB. | Gabe Black | |
2009-04-19 | X86: Implement a locking version of ADC. | Gabe Black | |
2009-04-19 | X86: Implement a locking version of OR. | Gabe Black | |
2009-04-19 | X86: Implement a locking version of ADD. | Gabe Black | |
2009-04-19 | X86: Implement the stul microop. | Gabe Black | |
This microop does a store and unlocks the requested address. The RISC86 microop ISA doesn't seem to have an equivalent to this, so I'm guessing that the store following an ldstl is automatically unlocking. We don't do it this way for performance reasons since the behavior is the same. | |||
2009-04-19 | X86: Implement the ldstl microop. | Gabe Black | |
This microop does a load, checks that a store would succeed, and locks the requested address. | |||
2009-04-19 | CPUs: Make the atomic CPU support locked memory accesses. | Gabe Black | |
2009-04-19 | Memory: Add a LOCKED flag back in for x86 style locking. | Gabe Black | |
2009-04-19 | Memory: Rename LOCKED for load locked store conditional to LLSC. | Gabe Black | |
2009-04-19 | SE mode: Make keeping track of the number of syscalls less hacky. | Gabe Black | |
2009-04-19 | X86: Mask the PIC at startup to avoid a glitch which causes an NMI. | Gabe Black | |
2009-04-19 | X86: Actually handle 16 bit mode modrm. | Gabe Black | |
2009-04-19 | X86: Make the TEST instruction set all the flags it's supposed to. | Gabe Black | |
2009-04-19 | X86: Implement broadcast IPIs. | Gabe Black | |
2009-04-19 | X86: Fix the ordering of the vendor string reported by CPUID. | Gabe Black | |
2009-04-19 | X86: Keep track of what the initial count value was in the LAPIC timer. | Gabe Black | |
2009-04-19 | X86: Only recognize the first startup IPI after INIT or reset. | Gabe Black | |
2009-04-19 | X86: Use recvResponse to implement the idle bit in the Local APIC ICR. | Gabe Black | |
2009-04-19 | X86: Add a function which gets called when an interrupt message has been ↵ | Gabe Black | |
delivered. | |||
2009-04-19 | X86: Fix the flags for interrupt response messages. | Gabe Black | |
2009-04-19 | X86: Explicitly use the right width in a few places that need a 64 bit value. | Gabe Black | |
2009-04-19 | X86: Keep track of the pioAddr for the local APIC. | Gabe Black | |
2009-04-19 | X86: Implement far jmp. | Gabe Black | |
2009-04-19 | X86: Some segment selectors can be used when "NULL". | Gabe Black | |
2009-04-19 | X86: Fix a bug in the chks microop where it ignored that it found a fault. | Gabe Black | |
2009-04-19 | X86: Make the interrupt entering microcode record the value to use, not ↵ | Gabe Black | |
actually use it. | |||
2009-04-19 | X86: LEA calculates an address before segmentation. | Gabe Black | |
2009-04-19 | X86: Implement the save machine status word instruction (SMSW). | Gabe Black | |
2009-04-19 | X86: Implement the load machine status word instruction (LMSW). | Gabe Black | |
2009-04-19 | X86: Only use %eax to select a function and look like we support sse2. | Gabe Black | |
2009-04-19 | X86: Fix the mov to segment selector in real mode instruction microcode. | Gabe Black | |
2009-04-19 | X86: The startup IPI delivery mode is not reserved. | Gabe Black | |
2009-04-19 | X86: Implement the STARTUP IPI. | Gabe Black | |
2009-04-19 | X86: Implement the INIT IPI. | Gabe Black | |
2009-04-19 | X86: Fix the halt microop. | Gabe Black | |
2009-04-19 | X86: Start implementing the interrupt command register in the local APIC. | Gabe Black | |
2009-04-19 | X86: Make code that sends an interrupt from the IO APIC available for IPIs. | Gabe Black | |
2009-04-19 | CPU: If the simple CPU is already idle, just return from suspendContext, ↵ | Gabe Black | |
don't assert. | |||
2009-04-19 | X86: Condense the startupCPU code. | Gabe Black | |
2009-04-19 | X86: Set the local APIC ID to something meaningful. | Gabe Black | |
2009-04-19 | X86: Don't pretend to be an AMD CPU any more. We're not good enough at it. | Gabe Black | |
2009-04-18 | mips-tlb-fix: check for alignment faults.\nMIPS was never updated to use ↵ | Korey Sewell | |
TLBS correcty in SE mode. The error was forwarding translations directly to pageTable. The TLB should check for alignment faults at bare minimum here but in the long run we should be using TLBs in SE mode for MIPS. | |||
2009-04-18 | mips-syscall: mark with correct flag. \nMIPS was using wrong serialization ↵ | Korey Sewell | |
flag on syscall instructions allowing O3 to handle SE mode syscalls incorrectly and speculate on instructions after a syscall | |||
2009-04-18 | o3-delay-slot-bpred: fix decode stage handling of uncdtl. branches.\n decode ↵ | Korey Sewell | |
stage was not setting the predicted PC correctly or passing that information back to fetch correctly | |||
2009-04-18 | mips-shadowsets: fix calcuations. \n Remove Shadowsets from Int & Arch. Reg ↵ | Korey Sewell | |
Calculations | |||
2009-04-17 | o3, inorder: fix FS bug due to initializing ThreadState to Halted. | Steve Reinhardt | |
For some reason o3 FS init() only called initCPU if the thread state was Suspended, which was no longer the case. There's no apparent reason to check, so I whacked the test completely rather than changing the check to Halted. The inorder init() was also updated to be symmetric, though the previous code was just a fancy no-op. | |||
2009-04-15 | o3: handle fetch with no active threads correctly. | Steve Reinhardt | |
This situation can arise now on the first fetch cycle after the last active thread is halted. It seems easy enough to deal with when it happens rather than trying to avoid it. | |||
2009-04-15 | o3: fix {read,set}ArchFloatReg* functions. | Steve Reinhardt | |
Register indices were not being calculated properly. | |||
2009-04-15 | ThreadState: initialize status to Halted in constructor. | Steve Reinhardt | |
This provides a common initial status for all threads independent of CPU model (unlike the prior situation where CPUs initialized threads to inconsistent states). This mostly matters for SE mode; in FS mode, ISA-specific startupCPU() methods generally handle boot-time initialization of thread contexts (since the right thing to do is ISA-dependent). |