Gabe Black [Wed, 2 Jun 2010 17:58:07 +0000 (12:58 -0500)]
ARM: Decode the rbit instruction.
Gabe Black [Wed, 2 Jun 2010 17:58:07 +0000 (12:58 -0500)]
ARM: Implement the rbit instruction.
Gabe Black [Wed, 2 Jun 2010 17:58:07 +0000 (12:58 -0500)]
ARM: Decode the nop instruction.
Gabe Black [Wed, 2 Jun 2010 17:58:07 +0000 (12:58 -0500)]
ARM: Implement nop.
Gabe Black [Wed, 2 Jun 2010 17:58:07 +0000 (12:58 -0500)]
ARM: Decode the ldrex instruction.
Gabe Black [Wed, 2 Jun 2010 17:58:07 +0000 (12:58 -0500)]
ARM: Rearrange the load/store double/exclusive, table branch thumb decoding.
Gabe Black [Wed, 2 Jun 2010 17:58:07 +0000 (12:58 -0500)]
ARM: Implement the ldrex instruction.
Gabe Black [Wed, 2 Jun 2010 17:58:07 +0000 (12:58 -0500)]
ARM: Decode the usad8 and usada8 instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:07 +0000 (12:58 -0500)]
ARM: Implement the usad8 and usada8 instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:07 +0000 (12:58 -0500)]
ARM: Add a base class to support usada8.
Gabe Black [Wed, 2 Jun 2010 17:58:07 +0000 (12:58 -0500)]
ARM: Decode the sel instruction.
Gabe Black [Wed, 2 Jun 2010 17:58:07 +0000 (12:58 -0500)]
ARM: Implement the sel instruction.
Gabe Black [Wed, 2 Jun 2010 17:58:07 +0000 (12:58 -0500)]
ARM: Add a base class for the sel instruction.
Gabe Black [Wed, 2 Jun 2010 17:58:07 +0000 (12:58 -0500)]
ARM: Decode pkh instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:07 +0000 (12:58 -0500)]
ARM: Implement the pkh instruction.
Gabe Black [Wed, 2 Jun 2010 17:58:07 +0000 (12:58 -0500)]
ARM: Decode the sign/zero extend instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:07 +0000 (12:58 -0500)]
ARM: Implement zero/sign extend instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:07 +0000 (12:58 -0500)]
ARM: Add a base class for extend and add instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:07 +0000 (12:58 -0500)]
ARM: Generalize the saturation instruction bases for use in other instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:07 +0000 (12:58 -0500)]
ARM: Decode the 8/16 bit signed/unsigned add/subtract half instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:06 +0000 (12:58 -0500)]
ARM: Implement the 8/16 bit signed/unsigned add/subtract half instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:06 +0000 (12:58 -0500)]
ARM: Fix signed most significant multiply instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:06 +0000 (12:58 -0500)]
ARM: Fix multiply overflow flag setting.
Gabe Black [Wed, 2 Jun 2010 17:58:06 +0000 (12:58 -0500)]
ARM: Decode the saturation instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:06 +0000 (12:58 -0500)]
ARM: Implement the saturation instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:06 +0000 (12:58 -0500)]
ARM: Implement base classes for the saturation instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:06 +0000 (12:58 -0500)]
ARM: Decode the signed add/subtract and subtract/add instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:06 +0000 (12:58 -0500)]
ARM: Implement signed add/subtract and subtract/add.
Gabe Black [Wed, 2 Jun 2010 17:58:06 +0000 (12:58 -0500)]
ARM: Decode the unsigned 8 and 16 bit add and subtract instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:06 +0000 (12:58 -0500)]
ARM: Implement the unsigned 8 bit and 16 bit vector adds and subtracts.
Gabe Black [Wed, 2 Jun 2010 17:58:06 +0000 (12:58 -0500)]
ARM: Decode the unsigned saturating instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:06 +0000 (12:58 -0500)]
ARM: Implement the unsigned saturating instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:06 +0000 (12:58 -0500)]
ARM: Decode the ssub instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:06 +0000 (12:58 -0500)]
ARM: Implement the ssub instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:06 +0000 (12:58 -0500)]
ARM: Decode the SADD8 and SADD16 instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:06 +0000 (12:58 -0500)]
ARM: Implement the SADD8 and SADD16 instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:06 +0000 (12:58 -0500)]
ARM: Support instructions that set the GE bits when they write the condition codes.
Gabe Black [Wed, 2 Jun 2010 17:58:06 +0000 (12:58 -0500)]
ARM: Decode 32 bit thumb data processing register instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:06 +0000 (12:58 -0500)]
ARM: Decode the 16 bit thumb versions of the REV* instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:05 +0000 (12:58 -0500)]
ARM: Decode the ARM version of the REV* instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:05 +0000 (12:58 -0500)]
ARM: Pull decoding of ARM pack, unpack, saturate and reverse instructions into a format.
Gabe Black [Wed, 2 Jun 2010 17:58:05 +0000 (12:58 -0500)]
ARM: Implement the REV* instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:05 +0000 (12:58 -0500)]
ARM: Add base classes suitable for the REV* instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:05 +0000 (12:58 -0500)]
ARM: Make LDM that loads the PC perform an interworking branch.
Gabe Black [Wed, 2 Jun 2010 17:58:05 +0000 (12:58 -0500)]
ARM: Decode the swp and swpb instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:05 +0000 (12:58 -0500)]
ARM: Implement the swp and swpb instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:05 +0000 (12:58 -0500)]
ARM: Decode MRS and MSR for thumb.
Gabe Black [Wed, 2 Jun 2010 17:58:05 +0000 (12:58 -0500)]
ARM: Replace the versions of MRS and MSR in the ARM decoder with the new ones.
Gabe Black [Wed, 2 Jun 2010 17:58:05 +0000 (12:58 -0500)]
ARM: Define versions of MSR and MRS outside the decoder.
Gabe Black [Wed, 2 Jun 2010 17:58:05 +0000 (12:58 -0500)]
ARM: Hook up the push/pop versions of stm/ldm in thumb.
Gabe Black [Wed, 2 Jun 2010 17:58:05 +0000 (12:58 -0500)]
ARM: Hook SVC into the thumb decoder.
Gabe Black [Wed, 2 Jun 2010 17:58:05 +0000 (12:58 -0500)]
ARM: Implement SVC (was SWI) outside of the decoder.
Gabe Black [Wed, 2 Jun 2010 17:58:05 +0000 (12:58 -0500)]
ARM: Update the stats for the new syscall behavior.
Gabe Black [Wed, 2 Jun 2010 17:58:05 +0000 (12:58 -0500)]
ARM: Trigger system calls from the SupervisorCall invoke method.
This simplifies the decoder slightly, and makes the system call mechanism
very slightly more realistic.
Gabe Black [Wed, 2 Jun 2010 17:58:05 +0000 (12:58 -0500)]
ARM: Fix multiply operations.
These fixes were provided by Ali and fix the saturation condition code and
various multiply instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:05 +0000 (12:58 -0500)]
ARM: Decode the scalar saturating add/subtract instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:05 +0000 (12:58 -0500)]
ARM: Decode the parallel add and subtract instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:05 +0000 (12:58 -0500)]
ARM: Implement signed saturating add and/or subtract instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:05 +0000 (12:58 -0500)]
ARM: Implemented prefetch instructions/decoding (pli, pld, pldw).
Gabe Black [Wed, 2 Jun 2010 17:58:04 +0000 (12:58 -0500)]
ARM: Decode unconditional ARM instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:04 +0000 (12:58 -0500)]
ARM: Make sure ldm exception return writes back its base in the right mode.
This change moves the writeback of load multiple instructions to the beginning
of the macroop. That way, the MicroLdrRetUop that changes the mode will
necessarily happen later, ensuring the writeback happens in the original mode.
The actual value in the base register if it also shows up in the register list
is undefined, so it's fine if it gets clobbered by one of the loads. For
stores where the base register is the lowest numbered in the register list,
the original value should be written back. That means stores can't write back
at the beginning, but the mode changing problem doesn't affect them so they
can continue to write back at the end.
Gabe Black [Wed, 2 Jun 2010 17:58:04 +0000 (12:58 -0500)]
ARM: Rework how unrecognized/unimplemented instructions are handled.
Instead of panic immediately when these instructions are executed, an
UndefinedInstruction fault is returned. In FS mode (not currently
implemented), this is the fault that should, to my knowledge, be triggered in
these situations and should be handled using the normal architected
mechanisms. In SE mode, the fault causes a panic when it's invoked that gives
the same information as the instruction did. When/if support for speculative
execution of ARM is supported, this will allow a mispeculated and unrecognized
and/or unimplemented instruction from causing a panic. Only once the
instruction is going to be committed will the fault be invoked, triggering the
panic.
Gabe Black [Wed, 2 Jun 2010 17:58:04 +0000 (12:58 -0500)]
ARM: Add support for "SUBS PC, LR and related instructions".
Gabe Black [Wed, 2 Jun 2010 17:58:04 +0000 (12:58 -0500)]
ARM: Make ldrs into the PC and ldm exception return do interworking branches.
Gabe Black [Wed, 2 Jun 2010 17:58:04 +0000 (12:58 -0500)]
ARM: Align the PC when using it as the base for a load.
Gabe Black [Wed, 2 Jun 2010 17:58:04 +0000 (12:58 -0500)]
ARM: Implement ADR as separate from ADD.
Gabe Black [Wed, 2 Jun 2010 17:58:04 +0000 (12:58 -0500)]
ARM: Add support for interworking branch ALU instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:04 +0000 (12:58 -0500)]
ARM: Fix when the flag bits are updated for thumb.
Gabe Black [Wed, 2 Jun 2010 17:58:04 +0000 (12:58 -0500)]
ARM: Don't rely on undefined behavior to get arithmetic right shift.
Shifting to the right of a signed value when the MSB is one is technically
undefined behavior, even though in my experience it's done the "right thing"
and sign extended the value. This replaces the arithmetic right shift code in
ARM that uses that coincidence with some code that relies on bit math.
Gabe Black [Wed, 2 Jun 2010 17:58:04 +0000 (12:58 -0500)]
ARM: Restrict the shift amount from a register to 8 bits.
The shift amount when taken from a register is supposed to be truncated to an
8 bit value.
Gabe Black [Wed, 2 Jun 2010 17:58:04 +0000 (12:58 -0500)]
ARM: Update the stats now that VFP load/store multiple is implemented.
Gabe Black [Wed, 2 Jun 2010 17:58:04 +0000 (12:58 -0500)]
ARM: Define the VFP load/store multiple instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:04 +0000 (12:58 -0500)]
ARM: Decode the VFP load/store multiple instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:04 +0000 (12:58 -0500)]
ARM: Fix the constant describing the number of floating point registers.
Gabe Black [Wed, 2 Jun 2010 17:58:04 +0000 (12:58 -0500)]
ARM: Add templates for VFP load/store multiple instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:04 +0000 (12:58 -0500)]
ARM: Add base classes for VFP load/store multiple.
Gabe Black [Wed, 2 Jun 2010 17:58:04 +0000 (12:58 -0500)]
ARM: Add floating point load/store microops.
Gabe Black [Wed, 2 Jun 2010 17:58:04 +0000 (12:58 -0500)]
ARM: Add an fp version of one of the microop indexed registers.
Gabe Black [Wed, 2 Jun 2010 17:58:04 +0000 (12:58 -0500)]
ARM: Move the mmap region to where Linux actually has it.
Gabe Black [Wed, 2 Jun 2010 17:58:03 +0000 (12:58 -0500)]
ARM: Eliminate the unused rhi and rlo operands.
Gabe Black [Wed, 2 Jun 2010 17:58:03 +0000 (12:58 -0500)]
ARM: Move the macro mem constructor out of the isa desc.
This code doesn't use the parser at all, and moving it out reduces the
conceptual complexity of that code.
Gabe Black [Wed, 2 Jun 2010 17:58:03 +0000 (12:58 -0500)]
ARM: Make macroops panic if executed directly.
The macroop should never be executed, only it's microops will.
Ali Saidi [Wed, 2 Jun 2010 17:58:03 +0000 (12:58 -0500)]
ARM: GCC < 4.3 has some issues with attribute no return on some functions. Fix so it works for older gccs.
Gabe Black [Wed, 2 Jun 2010 17:58:03 +0000 (12:58 -0500)]
ARM: Split out the "basic" templates and format.
--HG--
rename : src/arch/arm/isa/formats/basic.isa => src/arch/arm/isa/templates/basic.isa
Gabe Black [Wed, 2 Jun 2010 17:58:03 +0000 (12:58 -0500)]
ARM: Remove unnecessary cruft from includes.isa.
Gabe Black [Wed, 2 Jun 2010 17:58:03 +0000 (12:58 -0500)]
ARM: Move the inst2string function out of the isa_desc.
Delete the now empty formats/util.isa.
Gabe Black [Wed, 2 Jun 2010 17:58:03 +0000 (12:58 -0500)]
ARM: Get rid of the unused ArmGenericCodeSubs.
Gabe Black [Wed, 2 Jun 2010 17:58:03 +0000 (12:58 -0500)]
ARM: Make the predecoder print out the ExtMachInst it gathered when traced.
Gabe Black [Wed, 2 Jun 2010 17:58:03 +0000 (12:58 -0500)]
ARM: Remove special naming for the new version of multiply.
Gabe Black [Wed, 2 Jun 2010 17:58:03 +0000 (12:58 -0500)]
ARM: Hook the new multiply instructions into all the decoders.
Gabe Black [Wed, 2 Jun 2010 17:58:03 +0000 (12:58 -0500)]
ARM: Implement all integer multiply instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:03 +0000 (12:58 -0500)]
ARM: Add templates for multiply instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:03 +0000 (12:58 -0500)]
ARM: Add base classes for multiply instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:03 +0000 (12:58 -0500)]
ARM: Decode plain binary immediate thumb data processing instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:03 +0000 (12:58 -0500)]
ARM: Define a new "movt" data processing instruction.
Gabe Black [Wed, 2 Jun 2010 17:58:03 +0000 (12:58 -0500)]
ARM: Hook the new branch instructions into the 32 bit thumb decoder.
Gabe Black [Wed, 2 Jun 2010 17:58:03 +0000 (12:58 -0500)]
ARM: Hook the new branch instructions into the 16 bit thumb decoder.
Gabe Black [Wed, 2 Jun 2010 17:58:03 +0000 (12:58 -0500)]
ARM: Eliminate the old style branch instructions.
Gabe Black [Wed, 2 Jun 2010 17:58:02 +0000 (12:58 -0500)]
ARM: Hook the new branch instructions into the ARM decoder.
Gabe Black [Wed, 2 Jun 2010 17:58:02 +0000 (12:58 -0500)]
ARM: Implement branch instructions external to the decoder.