|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object scale.backend.Assembler scale.backend.trips2.Trips2Assembler
public final class Trips2Assembler
This class generates Trips assembly language from a list of Trips instructions.
$Id: Trips2Assembler.java,v 1.44 2007-10-31 23:47:51 bmaher Exp $
Copyright 2007 by the
Scale Compiler Group,
Department of Computer Science
University of Massachusetts,
Amherst MA. 01003, USA
All Rights Reserved.
Field Summary | |
---|---|
static boolean |
useConsecutiveLabels
|
Fields inherited from class scale.backend.Assembler |
---|
gen, hex, oneItemPerLine, repsAllowedInAL, source |
Constructor Summary | |
---|---|
Trips2Assembler(Generator gen,
java.lang.String source)
|
Method Summary | |
---|---|
void |
assemble(Emit emit,
SpaceAllocation[] dataAreas)
Generate assembly code for the data areas. |
void |
assembleComment(java.lang.String comment,
Emit emit)
Insert the assembler representation of the comment into the output stream. |
long |
assembleData(Emit emit,
SpaceAllocation sa,
long location)
Called for each allocation in a named area. |
void |
assembleDataAreaHeader(Emit emit,
int kind)
Generate assembler directives for the start of a data area. |
void |
assembleEpilog(Emit emit)
Called at the very end of generating assembly code. |
void |
assembleLabel(Label label,
Emit emit)
Generate a label in the assembly output. |
java.lang.String |
assemblePredicateRegister(int reg)
Convert a predicate register number into its assembly language form. |
void |
assembleProlog(Emit emit)
Called at the very beginning of generating assembly code. |
java.lang.String |
assembleRegister(int reg)
Convert a register number into its assembly language form. |
protected long |
genData(Emit emit,
int dt,
Label lab,
int reps,
boolean aligned)
Generate the data representation for address of the label. |
protected void |
genDirective(Emit emit,
int dt)
Generate the assembly directive required for the type. |
protected int |
getDirectiveSize(int dt)
Return the number of addressable units required for one value of the specified type. |
java.lang.String |
getLabelString(Label label)
Return the String representing the label. |
Methods inherited from class scale.backend.Assembler |
---|
assembleDataBegin, assembleDataEnd, assembleInstructions, genAsciiText, genBytes, genData, genData, genData, genData, genData, genData, genData, genData, genData, genData, genZeroFill, getDisplayString, getName, getSourceLanguage, getSpaceAllocation, isFortran |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
public static boolean useConsecutiveLabels
Constructor Detail |
---|
public Trips2Assembler(Generator gen, java.lang.String source)
gen
- is the instruction generator used to generate the
instructions.source
- specifies the source programMethod Detail |
---|
public void assemble(Emit emit, SpaceAllocation[] dataAreas)
assemble
in class Assembler
public void assembleProlog(Emit emit)
assembleProlog
in class Assembler
public void assembleEpilog(Emit emit)
assembleEpilog
in class Assembler
public java.lang.String getLabelString(Label label)
getLabelString
in class Assembler
public void assembleLabel(Label label, Emit emit)
assembleLabel
in class Assembler
public void assembleComment(java.lang.String comment, Emit emit)
assembleComment
in class Assembler
public java.lang.String assembleRegister(int reg)
assembleRegister
in class Assembler
public java.lang.String assemblePredicateRegister(int reg)
public void assembleDataAreaHeader(Emit emit, int kind)
assembleDataAreaHeader
in class Assembler
kind
- specifies the area kindemit
- is the output sinkprotected void genDirective(Emit emit, int dt)
genDirective
in class Assembler
dt
- - the data typeemit
- specifies where to put the directive.SpaceAllocation
protected int getDirectiveSize(int dt)
getDirectiveSize
in class Assembler
dt
- - the data typeSpaceAllocation
public long assembleData(Emit emit, SpaceAllocation sa, long location)
Assembler
assembleData
in class Assembler
emit
- is the output sinksa
- is the data spacelocation
- is the current locationprotected long genData(Emit emit, int dt, Label lab, int reps, boolean aligned)
genData
in class Assembler
emit
- specifies where to generate the datadt
- specifies the data typelab
- is the labelreps
- specifies how many times to generate the representationaligned
- specifies whether the data will be aligned
SpaceAllocation
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |