Merge branch 'GP-5975_emteere_RISCV_Upgrade' into Ghidra_12.0

This commit is contained in:
ghidra1
2025-11-07 15:30:09 -05:00
56 changed files with 4475 additions and 2181 deletions

View File

@@ -34,7 +34,6 @@ import ghidra.trace.database.memory.DBTraceMemoryManager;
import ghidra.trace.database.memory.DBTraceMemorySpace;
import ghidra.util.MathUtilities;
import ghidra.util.exception.CancelledException;
import ghidra.util.exception.NotFoundException;
import ghidra.util.task.TaskMonitor;
/**
@@ -305,31 +304,31 @@ public class DBTraceGuestPlatformMappedMemory implements Memory {
@Override
public void moveBlock(MemoryBlock block, Address newStartAddr, TaskMonitor monitor)
throws LockException, MemoryBlockException, MemoryConflictException,
AddressOverflowException, NotFoundException {
AddressOverflowException {
throw new UnsupportedOperationException();
}
@Override
public void split(MemoryBlock block, Address addr)
throws MemoryBlockException, LockException, NotFoundException {
throws MemoryBlockException, LockException {
throw new UnsupportedOperationException();
}
@Override
public MemoryBlock join(MemoryBlock blockOne, MemoryBlock blockTwo)
throws LockException, MemoryBlockException, NotFoundException {
throws LockException, MemoryBlockException {
throw new UnsupportedOperationException();
}
@Override
public MemoryBlock convertToInitialized(MemoryBlock uninitializedBlock, byte initialValue)
throws LockException, MemoryBlockException, NotFoundException {
throws LockException, MemoryBlockException {
throw new UnsupportedOperationException();
}
@Override
public MemoryBlock convertToUninitialized(MemoryBlock itializedBlock)
throws MemoryBlockException, NotFoundException, LockException {
throws MemoryBlockException, LockException {
throw new UnsupportedOperationException();
}

View File

@@ -33,7 +33,6 @@ import ghidra.trace.util.MemoryAdapter;
import ghidra.util.LockHold;
import ghidra.util.MathUtilities;
import ghidra.util.exception.CancelledException;
import ghidra.util.exception.NotFoundException;
import ghidra.util.task.TaskMonitor;
public abstract class AbstractDBTraceProgramViewMemory
@@ -206,31 +205,31 @@ public abstract class AbstractDBTraceProgramViewMemory
@Override
public void moveBlock(MemoryBlock block, Address newStartAddr, TaskMonitor monitor)
throws LockException, MemoryBlockException, MemoryConflictException,
AddressOverflowException, NotFoundException {
AddressOverflowException {
throw new UnsupportedOperationException();
}
@Override
public void split(MemoryBlock block, Address addr)
throws MemoryBlockException, LockException, NotFoundException {
throws MemoryBlockException, LockException {
throw new UnsupportedOperationException();
}
@Override
public MemoryBlock join(MemoryBlock blockOne, MemoryBlock blockTwo)
throws LockException, MemoryBlockException, NotFoundException {
throws LockException, MemoryBlockException {
throw new UnsupportedOperationException();
}
@Override
public MemoryBlock convertToInitialized(MemoryBlock uninitializedBlock, byte initialValue)
throws LockException, MemoryBlockException, NotFoundException {
throws LockException, MemoryBlockException {
throw new UnsupportedOperationException();
}
@Override
public MemoryBlock convertToUninitialized(MemoryBlock itializedBlock)
throws MemoryBlockException, NotFoundException, LockException {
throws MemoryBlockException, LockException {
throw new UnsupportedOperationException();
}

View File

@@ -20,7 +20,6 @@ import ghidra.program.model.listing.Program;
import ghidra.program.model.mem.*;
import ghidra.program.util.ProgramTask;
import ghidra.util.Msg;
import ghidra.util.exception.NotFoundException;
import ghidra.util.exception.RollbackException;
import ghidra.util.task.TaskMonitor;
@@ -80,10 +79,6 @@ public class MoveBlockTask extends ProgramTask {
statusMessage = "Insufficient memory to complete operation";
cause = e;
}
catch (NotFoundException e) {
statusMessage = "Memory block not found";
cause = e;
}
catch (MemoryConflictException | MemoryBlockException | IllegalArgumentException e) {
statusMessage = e.getMessage();
cause = e;

View File

@@ -693,7 +693,7 @@ public class GolangSymbolAnalyzer extends AbstractAnalyzer {
memBlk = memory.getBlock(afterFlag);
memBlk.setName(memBlk.getName().replaceFirst("(\\.split)+$", ".part2"));
}
catch (MemoryBlockException | LockException | NotFoundException e) {
catch (MemoryBlockException | LockException e) {
Msg.error(this, "Failed to fixup runtime.writeBarrier flag", e);
}
}

View File

@@ -4,9 +4,9 @@
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*
* http://www.apache.org/licenses/LICENSE-2.0
*
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
@@ -27,7 +27,8 @@ import ghidra.program.model.address.*;
import ghidra.program.model.listing.*;
import ghidra.program.model.mem.*;
import ghidra.util.Msg;
import ghidra.util.exception.*;
import ghidra.util.exception.DuplicateNameException;
import ghidra.util.exception.RollbackException;
/**
* Helper class to make changes to memory blocks.
@@ -270,10 +271,6 @@ class MemoryMapManager {
msg = e.getMessage();
return false;
}
catch (NotFoundException e) {
msg = e.getMessage();
return false;
}
catch (LockException e) {
msg = e.getMessage();
return false;

View File

@@ -4,9 +4,9 @@
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*
* http://www.apache.org/licenses/LICENSE-2.0
*
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
@@ -43,6 +43,7 @@ import ghidra.framework.Application;
import ghidra.framework.main.ApplicationLevelPlugin;
import ghidra.framework.plugintool.*;
import ghidra.framework.plugintool.util.PluginStatus;
import ghidra.program.database.ProgramDB;
import ghidra.program.model.address.AddressSpace;
import ghidra.program.model.lang.*;
import ghidra.program.model.listing.IncompatibleLanguageException;
@@ -50,6 +51,7 @@ import ghidra.program.util.*;
import ghidra.util.Msg;
import ghidra.util.exception.AssertException;
import ghidra.util.filechooser.ExtensionFileFilter;
import ghidra.util.task.TaskMonitor;
import ghidra.util.xml.GenericXMLOutputter;
//@formatter:off
@@ -395,8 +397,7 @@ public class GenerateOldLanguagePlugin extends Plugin implements ApplicationLeve
Register oldCtx = oldLang.getContextBaseRegister();
Register newCtx = newLang.getContextBaseRegister();
boolean contextWarning = false;
if (oldCtx != Register.NO_CONTEXT &&
defaultTrans.isValueTranslationRequired(oldCtx)) {
if (oldCtx != Register.NO_CONTEXT && defaultTrans.isValueTranslationRequired(oldCtx)) {
contextWarning = true;
}
else if (oldCtx == Register.NO_CONTEXT && newCtx != Register.NO_CONTEXT) {

View File

@@ -325,9 +325,8 @@ public abstract class AbstractProgramLoader implements Loader {
prog.setExecutableFormat(executableFormatName);
}
FSRL fsrl = provider.getFSRL();
String md5 = (fsrl != null && fsrl.getMD5() != null)
? fsrl.getMD5()
: computeBinaryMD5(provider);
String md5 =
(fsrl != null && fsrl.getMD5() != null) ? fsrl.getMD5() : computeBinaryMD5(provider);
if (fsrl != null) {
if (fsrl.getMD5() == null) {
fsrl = fsrl.withMD5(md5);
@@ -470,6 +469,19 @@ public abstract class AbstractProgramLoader implements Loader {
return DefaultLanguageService.getLanguageService();
}
private AddressSetView getProcessorDefinedMemoryBlockAddresses(Program program) {
AddressSet blockAddrSet = new AddressSet();
Memory memory = program.getMemory();
Language language = program.getLanguage();
for (MemoryBlockDefinition defaultMemoryBlockDef : language.getDefaultMemoryBlocks()) {
MemoryBlock block = memory.getBlock(defaultMemoryBlockDef.getBlockName());
if (block != null) {
blockAddrSet.add(block.getAddressRange());
}
}
return blockAddrSet;
}
private void applyProcessorLabels(List<Option> options, Program program) {
int id = program.startTransaction("Finalize load");
try {
@@ -482,15 +494,25 @@ public abstract class AbstractProgramLoader implements Loader {
createSymbol(program, reg.getName(), addr, null, false, true, true);
}
}
// optionally create default symbols defined by pspec
if (shouldApplyProcessorLabels(options)) {
boolean anchorSymbols = shouldAnchorSymbols(options);
List<AddressLabelInfo> labels = lang.getDefaultSymbols();
for (AddressLabelInfo info : labels) {
createSymbol(program, info.getLabel(), info.getAddress(), info.getDescription(), info.isEntry(),
info.isPrimary(), anchorSymbols);
// NOTE: pspec defined labels should always be defined if they correspond to a memory
// block defined by the pspec.
boolean applyAllProcessorLabels = shouldApplyProcessorLabels(options);
AddressSetView pspecDefinedBlockSet = getProcessorDefinedMemoryBlockAddresses(program);
boolean anchorSymbols = shouldAnchorSymbols(options);
List<AddressLabelInfo> labels = lang.getDefaultSymbols();
for (AddressLabelInfo info : labels) {
Address addr = info.getAddress();
boolean isRequiredLabel = pspecDefinedBlockSet.contains(addr);
if (isRequiredLabel || applyAllProcessorLabels) {
// NOTE: Required labels contained within a pspec-defined memory block do not
// need to be pinned/anchored
boolean anchor = !isRequiredLabel && anchorSymbols;
createSymbol(program, info.getLabel(), info.getAddress(), info.getDescription(),
info.isEntry(), info.isPrimary(), anchor);
}
}
GhidraProgramUtilities.resetAnalysisFlags(program);
}
finally {

View File

@@ -269,7 +269,7 @@ public class NeLoader extends AbstractOrdinalSupportLoader {
try {
block = program.getMemory().join(block, zeroBlock); // expand
}
catch (MemoryBlockException | LockException | NotFoundException e) {
catch (MemoryBlockException | LockException e) {
throw new IOException(e);
}
}

View File

@@ -23,7 +23,6 @@ import ghidra.program.model.listing.Program;
import ghidra.program.model.mem.*;
import ghidra.util.Msg;
import ghidra.util.SystemUtilities;
import ghidra.util.exception.NotFoundException;
import ghidra.util.task.TaskMonitor;
/**
@@ -297,9 +296,6 @@ public class MemoryDiff {
catch (LockException e) {
Msg.error(this, "Unexpected Exception: " + e.getMessage(), e);
}
catch (NotFoundException e) {
Msg.error(this, "Unexpected Exception: " + e.getMessage(), e);
}
catch (AddressOutOfBoundsException e) {
Msg.error(this, "Unexpected Exception: " + e.getMessage(), e);
}

View File

@@ -879,10 +879,13 @@ public class SymbolicPropogator {
try {
switch (ptype) {
case PcodeOp.COPY:
if (in[0].isAddress() &&
!in[0].getAddress().getAddressSpace().hasMappedRegisters()) {
makeReference(vContext, instruction, Reference.MNEMONIC, in[0],
null, RefType.READ, ptype, true, monitor);
if (in[0].isAddress()) {
AddressSpace addressSpace = in[0].getAddress().getAddressSpace();
// if not address mapped, or no register defined there
if (!addressSpace.hasMappedRegisters() || program.getRegister(in[0]) == null) {
makeReference(vContext, instruction, Reference.MNEMONIC, in[0],
null, RefType.READ, ptype, true, monitor);
}
}
vContext.copy(out, in[0], mustClearAll, evaluator);
break;

View File

@@ -25,7 +25,6 @@ import ghidra.program.model.address.*;
import ghidra.program.model.listing.Program;
import ghidra.program.model.mem.*;
import ghidra.util.exception.CancelledException;
import ghidra.util.exception.NotFoundException;
import ghidra.util.task.TaskMonitor;
public class MyTestMemory extends AddressSet implements Memory {
@@ -153,30 +152,30 @@ public class MyTestMemory extends AddressSet implements Memory {
@Override
public void moveBlock(MemoryBlock block, Address newStartAddr, TaskMonitor monitor)
throws MemoryConflictException, AddressOverflowException, NotFoundException {
throws MemoryConflictException, AddressOverflowException {
throw new UnsupportedOperationException();
}
@Override
public void split(MemoryBlock block, Address addr) throws NotFoundException {
public void split(MemoryBlock block, Address addr) {
throw new UnsupportedOperationException();
}
@Override
public MemoryBlock join(MemoryBlock blockOne, MemoryBlock blockTwo)
throws MemoryBlockException, NotFoundException {
throws MemoryBlockException {
throw new UnsupportedOperationException();
}
@Override
public MemoryBlock convertToInitialized(MemoryBlock uninitializedBlock, byte initialValue)
throws MemoryBlockException, NotFoundException {
throws MemoryBlockException {
throw new UnsupportedOperationException();
}
@Override
public MemoryBlock convertToUninitialized(MemoryBlock initializedBlock)
throws MemoryBlockException, NotFoundException {
throws MemoryBlockException {
throw new UnsupportedOperationException();
}

View File

@@ -44,7 +44,8 @@ import ghidra.program.model.symbol.SourceType;
import ghidra.program.model.symbol.SymbolTable;
import ghidra.program.model.util.CodeUnitInsertionException;
import ghidra.util.Msg;
import ghidra.util.exception.*;
import ghidra.util.exception.CancelledException;
import ghidra.util.exception.InvalidInputException;
import ghidra.util.task.TaskMonitor;
/**
@@ -177,8 +178,7 @@ public class DumpFileLoader extends AbstractProgramWrapperLoader {
DumpAddressObject d = daos.get(address);
try {
MemoryBlockUtils.createInitializedBlock(program, false, d.getRangeName(),
address, fileBytes,
d.getRVA(), // offset into filebytes
address, fileBytes, d.getRVA(), // offset into filebytes
d.getLength(), // size
d.getComment(), // comment
null, // source
@@ -215,7 +215,7 @@ public class DumpFileLoader extends AbstractProgramWrapperLoader {
try {
m = memory.join(m, next);
}
catch (MemoryBlockException | LockException | NotFoundException e) {
catch (MemoryBlockException | LockException e) {
break;
}
deleted.add(next.getStart());
@@ -281,9 +281,8 @@ public class DumpFileLoader extends AbstractProgramWrapperLoader {
symbolTable.createLabel(address, dd.getName(), SourceType.IMPORTED);
}
catch (InvalidInputException e) {
Msg.error(this,
"Error creating label " + dd.getName() + " at address " + address +
": " + e.getMessage());
Msg.error(this, "Error creating label " + dd.getName() + " at address " +
address + ": " + e.getMessage());
}
continue;
}

View File

@@ -0,0 +1,139 @@
/* ###
* IP: GHIDRA
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package ghidra.app.plugin.processors.generic;
import java.util.*;
import ghidra.framework.store.LockException;
import ghidra.program.database.ProgramDB;
import ghidra.program.database.symbol.SymbolManager;
import ghidra.program.model.address.*;
import ghidra.program.model.lang.AddressLabelInfo;
import ghidra.program.model.lang.Language;
import ghidra.program.model.mem.MemoryBlock;
import ghidra.program.model.mem.MemoryBlockException;
import ghidra.program.model.symbol.*;
import ghidra.util.Msg;
import ghidra.util.exception.*;
/**
* {@link LanguageFixupUtil} provides utility method intended for internal language upgrade
* situations.
*/
public class LanguageFixupUtil {
/**
* Apply pspec defined memory blocks and default symbols which are considered safe and
* generally required. Reconciling symbols is limited to those symbols contained within
* processor defined memory blocks which are not within either the default code or data spaces.
* @param programDB target program
*/
public static void applyPSpecFixups(ProgramDB programDB) throws CancelledException {
try {
Language language = programDB.getLanguage();
AddressSpace defaultSpace = language.getDefaultSpace();
AddressSpace defaultDataSpace = language.getDefaultDataSpace();
// Create or fixup processor defined memory blocks
// NOTE: Additional translator capability required if block removal is required which
// would likely remove any IMPORTED symbols contained within its bounds
AddressSet processorDefinedBlockSet = new AddressSet();
// Define address set which identifies processor define blocks which are safe to scrub
// of old imported symbols.
AddressSet processorDefinedSafeBlockSet = new AddressSet();
for (MemoryBlockDefinition defaultMemoryBlockDef : language.getDefaultMemoryBlocks()) {
try {
MemoryBlock block = defaultMemoryBlockDef.fixupBlock(programDB);
AddressRange blockRange = block.getAddressRange();
processorDefinedBlockSet.add(blockRange);
AddressSpace space = block.getStart().getAddressSpace();
if (!space.equals(defaultSpace) && !space.equals(defaultDataSpace)) {
processorDefinedSafeBlockSet.add(blockRange);
}
}
catch (MemoryBlockException e) {
Msg.error(LanguageFixupUtil.class,
"Failed to create or fixup processor defined memory block '" +
defaultMemoryBlockDef.getBlockName() + "': " + e.getMessage());
}
catch (LockException e) {
throw new RuntimeException(e); // upgrades require exclusive access
}
}
HashSet<Symbol> goodSymbols = new HashSet<>();
SymbolManager symbolTable = programDB.getSymbolTable();
for (AddressLabelInfo labelInfo : language.getDefaultSymbols()) {
String name = labelInfo.getLabel();
Address addr = labelInfo.getAddress();
// NOTE: For now we only add symbols which are defined within processor-defined blocks
if (!processorDefinedBlockSet.contains(addr)) {
continue;
}
// Check all symbols within processor-defined blocks
Symbol existingSymbol = null;
for (Symbol s : symbolTable.getGlobalSymbols(name)) {
if (s.getSymbolType() != SymbolType.LABEL) {
continue;
}
if (addr.equals(s.getAddress())) {
existingSymbol = s;
goodSymbols.add(s);
}
else if (s.getSource() == SourceType.IMPORTED) {
s.delete();
}
}
if (existingSymbol == null) {
// Add missing label
try {
Symbol s = symbolTable.createLabel(addr, name, null, SourceType.IMPORTED);
goodSymbols.add(s);
}
catch (InvalidInputException e) {
throw new AssertException(e); // unexpected
}
}
}
// Remove all symbols with processor defined blocks which are no longer defined.
// This is restricted to safe address spaces since loader may have imported other symbols
// which we do not want to delete.
List<Symbol> deleteSet = new ArrayList<>(); // defered delete to avoid iterator resets
for (Symbol s : symbolTable.getSymbols(processorDefinedSafeBlockSet, SymbolType.LABEL,
true)) {
if (s.getSource() == SourceType.IMPORTED && !goodSymbols.contains(s)) {
deleteSet.add(s);
}
}
for (Symbol s : deleteSet) {
s.delete();
}
}
catch (UnsupportedOperationException e) {
// skip
}
}
}

View File

@@ -4,9 +4,9 @@
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*
* http://www.apache.org/licenses/LICENSE-2.0
*
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
@@ -15,11 +15,15 @@
*/
package ghidra.app.plugin.processors.generic;
import java.util.List;
import ghidra.framework.store.LockException;
import ghidra.program.database.ProgramDB;
import ghidra.program.database.mem.ByteMappingScheme;
import ghidra.program.model.address.*;
import ghidra.program.model.listing.Program;
import ghidra.program.model.mem.*;
import ghidra.util.Msg;
import ghidra.util.XmlProgramUtilities;
import ghidra.util.exception.AssertException;
import ghidra.util.exception.CancelledException;
@@ -36,18 +40,22 @@ import ghidra.xml.XmlElement;
*/
public class MemoryBlockDefinition {
private String blockName;
private String addressString;
private int length;
private boolean initialized;
private boolean overlay;
private String bitMappedAddress;
private String byteMappedAddress;
private ByteMappingScheme byteMappingScheme;
private boolean readPermission = true;
private boolean writePermission = true;
private boolean executePermission = false;
private boolean isVolatile = false;
private final String blockName;
private final String addressString;
private final int length;
private final boolean initialized;
private final boolean overlay;
private final String bitMappedAddress;
private final String byteMappedAddress;
private final ByteMappingScheme byteMappingScheme;
private final String mode;
private final boolean readPermission;
private final boolean writePermission;
private final boolean executePermission;
private final boolean isVolatile;
private static final String DEFAULT_MODE = "rw";
/**
* Construct <code>MemoryBlockDefinition</code> using a text-based specified.
@@ -62,7 +70,8 @@ public class MemoryBlockDefinition {
* decimations may be specified using a mapping ratio. When specifying a mapping ratio both
* values must be in the range 1..127 where the right (source-byte count) value must be
* greater-than-or-equal to the left value (e.g., 2:4).
* @param mode block mode as concatenation of the following mode indicator characters:
* @param mode block mode as concatenation of the following mode indicator characters. If null
* the default mode (rw) will be used.
* <pre>
* r - read mode enabled
* w - write mode enabled
@@ -71,18 +80,33 @@ public class MemoryBlockDefinition {
* </pre>
* @param lengthString length of memory block in bytes (required)
* @param initializedString boolean (y | n | true | false) indicating if memory block is
* initialialized or not (must be null for mapped block specification)
* initialialized or not (ignored for mapped block specification)
* @param overlayString boolean (y | n | true | false) indicating if memory block is an overlay
* (false assumed if null).
* @throws XmlAttributeException if parse failure occurs (NOTE: address parsing is not performed)
*/
private MemoryBlockDefinition(String blockName, String addressString, String bitMappedAddress,
String byteMappedAddressRatio, String mode, String lengthString,
String initializedString, String overlayString)
throws XmlAttributeException {
String initializedString, String overlayString) throws XmlAttributeException {
this.mode = mode != null ? mode.toLowerCase() : DEFAULT_MODE;
// Parse specified access mode
readPermission = this.mode.indexOf('r') >= 0;
writePermission = this.mode.indexOf('w') >= 0;
executePermission = this.mode.indexOf('x') >= 0;
isVolatile = this.mode.indexOf('v') >= 0;
if (blockName == null) {
throw new XmlAttributeException("Missing default memory block 'name'");
}
this.blockName = blockName;
if (addressString == null) {
throw new XmlAttributeException("Missing default memory block 'start_address'");
}
this.addressString = addressString;
this.bitMappedAddress = bitMappedAddress;
if (byteMappedAddressRatio != null) {
@@ -98,30 +122,35 @@ public class MemoryBlockDefinition {
}
else {
// 1:1 mapping scheme assumed (null byteMappingScheme)
byteMappingScheme = null;
byteMappedAddress = byteMappedAddressRatio;
}
}
if (mode != null) {
mode = mode.toLowerCase();
readPermission = mode.indexOf('r') >= 0;
writePermission = mode.indexOf('w') >= 0;
executePermission = mode.indexOf('x') >= 0;
isVolatile = mode.indexOf('v') >= 0;
else {
byteMappedAddress = null;
byteMappingScheme = null;
}
// Parse specified length string
int parsedLen = -1;
try {
length = XmlUtilities.parseInt(lengthString);
parsedLen = XmlUtilities.parseInt(lengthString);
}
catch (NumberFormatException e) {
throw new XmlAttributeException(lengthString + " is not a valid integer");
// ignore - length will be checked below
}
if (parsedLen <= 0) {
throw new XmlAttributeException(lengthString + " is not a valid 'length'");
}
length = parsedLen;
if (initializedString != null) {
if (bitMappedAddress != null || byteMappedAddress != null) {
throw new XmlAttributeException(
"mapped block specifications must not specify initialized attribute");
}
initialized = XmlUtilities.parseBoolean(initializedString);
}
initialized = XmlUtilities.parseBoolean(initializedString);
overlay = XmlUtilities.parseBoolean(overlayString);
}
@@ -142,20 +171,164 @@ public class MemoryBlockDefinition {
return addr;
}
/**
* {@return memory block name}
*/
public String getBlockName() {
return blockName;
}
/**
* Create or fixup existing block found within specified program.
* @param program target program
* @return new or adjusted memory block
* @throws LockException if program does not have exclusive access
* @throws MemoryBlockException if failed to create or fixup default memory block
*/
public MemoryBlock fixupBlock(ProgramDB program) throws LockException, MemoryBlockException {
program.checkExclusiveAccess();
Memory memory = program.getMemory();
MemoryBlock block = memory.getBlock(blockName);
if (block == null) {
try {
Msg.info(this, "Adding process-defined memory block: " + blockName);
return createBlock(program);
}
catch (MemoryConflictException | AddressOverflowException | InvalidAddressException e) {
throw new MemoryBlockException("Create block failed", e);
}
}
MemoryBlockType blockType = getBlockType();
List<MemoryBlockSourceInfo> sourceInfos = block.getSourceInfos();
if (!blockType.equals(block.getType()) || overlay != block.isOverlay() ||
sourceInfos.size() != 1) {
throw new MemoryBlockException("Incompatible memory block type");
}
MemoryBlockSourceInfo sourceInfo = sourceInfos.get(0);
Address addr;
Address currentStartAddress;
try {
addr = parseAddress(addressString, program, "block address");
currentStartAddress = block.getStart();
AddressSpace currentAddressSpace = currentStartAddress.getAddressSpace();
if (currentAddressSpace instanceof OverlayAddressSpace overlaySpace) {
if (overlaySpace.getOverlayedSpace().equals(addr.getAddressSpace())) {
throw new MemoryBlockException("Incompatible overlay memory block");
}
// Redefine overlay block start address for comparison use
addr = overlaySpace.getAddressInThisSpaceOnly(addr.getOffset());
}
if (bitMappedAddress != null) {
Address mappedAddr = parseAddress(bitMappedAddress, program, "bit-mapped address");
if (addr.equals(currentStartAddress) &&
mappedAddr.equals(sourceInfo.getMappedRange().get().getMinAddress()) &&
length == block.getSize()) {
return block;
}
// We do not currently support modifying default bit-mapped block
throw new MemoryBlockException("inconsistent bit-mapped block");
}
else if (byteMappedAddress != null) {
Address mappedAddr =
parseAddress(byteMappedAddress, program, "byte-mapped address");
if (addr.equals(currentStartAddress) &&
mappedAddr.equals(sourceInfo.getMappedRange().get().getMinAddress()) &&
length == block.getSize()) {
return block;
}
// We do not currently support modifying default byte-mapped block
throw new MemoryBlockException("inconsistent byte-mapped block");
}
}
catch (InvalidAddressException e) {
throw new MemoryBlockException("failed to process processor block address", e);
}
if (sourceInfo.getFileBytes().isPresent() || sourceInfo.getMappedRange().isPresent()) {
throw new MemoryBlockException("unsupported file or memory-mapped block");
}
if (!addr.equals(currentStartAddress)) {
throw new MemoryBlockException(
"inconsistent block start address: " + addr + " / " + currentStartAddress);
}
try {
if (length > block.getSize()) {
// Expand processor defined memory block
Msg.info(this, "Expanding processor defined memory block from " + block.getSize() +
"-bytes to " + length + "-bytes: " + blockName);
MemoryBlock newBlock = memory.createBlock(block, block.getName() + ".exp",
block.getEnd().next(), length - block.getSize());
MemoryBlock b = memory.join(block, newBlock);
if (!b.getName().equals(blockName)) {
b.setName(blockName); // preserve block name
}
}
else {
Msg.warn(this, "Ignored processor block size reduction: " + blockName);
}
boolean accessAdjusted = false;
if (readPermission != block.isRead()) {
block.setRead(readPermission);
accessAdjusted = true;
}
if (writePermission != block.isWrite()) {
block.setWrite(writePermission);
accessAdjusted = true;
}
if (executePermission != block.isExecute()) {
block.setExecute(executePermission);
accessAdjusted = true;
}
if (isVolatile != block.isVolatile()) {
block.setVolatile(isVolatile);
accessAdjusted = true;
}
if (accessAdjusted) {
Msg.warn(this, "Updated processor block access mode (" + mode + "): " + blockName);
}
}
catch (IllegalArgumentException | MemoryConflictException | AddressOverflowException e) {
throw new MemoryBlockException("block adjustment failed", e);
}
return block;
}
private MemoryBlockType getBlockType() {
if (bitMappedAddress != null) {
return MemoryBlockType.BIT_MAPPED;
}
if (byteMappedAddress != null) {
return MemoryBlockType.BYTE_MAPPED;
}
return MemoryBlockType.DEFAULT;
}
/**
* Create memory block within specified program based upon this block specification.
* @param program target program
* @return newly created memory block
* @throws LockException if program does not have exclusive access required when adding memory blocks.
* @throws MemoryConflictException if this specification conflicts with an existing memory block in program
* @throws AddressOverflowException if memory space constraints are violated by block specification
* @throws InvalidAddressException if address defined by this block specification is invalid
* for the specified program. May also indicate an improperly formatted address attribute.
*/
public void createBlock(Program program) throws LockException, MemoryConflictException,
public MemoryBlock createBlock(Program program) throws LockException, MemoryConflictException,
AddressOverflowException, InvalidAddressException {
if (blockName == null || addressString == null || length <= 0) {
return;
}
Memory mem = program.getMemory();
Address addr = parseAddress(addressString, program, "block address");
@@ -172,9 +345,8 @@ public class MemoryBlockDefinition {
}
else if (initialized) {
try {
block =
mem.createInitializedBlock(blockName, addr, length, (byte) 0,
TaskMonitor.DUMMY, overlay);
block = mem.createInitializedBlock(blockName, addr, length, (byte) 0,
TaskMonitor.DUMMY, overlay);
}
catch (CancelledException e) {
throw new AssertException(e); // unexpected
@@ -187,6 +359,7 @@ public class MemoryBlockDefinition {
block.setWrite(writePermission);
block.setExecute(executePermission);
block.setVolatile(isVolatile);
return block;
}
@Override

View File

@@ -47,6 +47,7 @@ import ghidra.program.model.util.ProcessorSymbolType;
import ghidra.sleigh.grammar.SleighPreprocessor;
import ghidra.sleigh.grammar.SourceFileIndexer;
import ghidra.util.*;
import ghidra.util.exception.InvalidInputException;
import ghidra.util.task.TaskMonitor;
import ghidra.util.xml.SpecXmlUtils;
import ghidra.xml.*;
@@ -787,10 +788,9 @@ public class SleighLanguage implements Language {
AddressLabelInfo info;
try {
info = new AddressLabelInfo(startAddress, rangeSize, labelName, comment,
false,
isEntry, type, isVolatile);
false, isEntry, type, isVolatile);
}
catch (AddressOverflowException e) {
catch (AddressOverflowException | InvalidInputException e) {
throw new XmlParseException("invalid symbol definition: " + labelName,
e);
}
@@ -1242,9 +1242,7 @@ public class SleighLanguage implements Language {
ManualEntry manualEntry = null;
int maxInCommon = -1;
Iterator<Entry<String, ManualEntry>> ii = subMap.entrySet().iterator();
while (ii.hasNext()) {
Entry<String, ManualEntry> mapEntry = ii.next();
for (Entry<String, ManualEntry> mapEntry : subMap.entrySet()) {
String key = mapEntry.getKey();
if (instruction.startsWith(key) && key.length() > maxInCommon) {
manualEntry = mapEntry.getValue();

View File

@@ -22,6 +22,7 @@ import java.util.*;
import org.apache.commons.lang3.StringUtils;
import db.DBHandle;
import ghidra.app.plugin.processors.generic.LanguageFixupUtil;
import ghidra.app.plugin.processors.sleigh.SleighLanguage;
import ghidra.framework.Application;
import ghidra.framework.data.DomainObjectAdapterDB;
@@ -2065,8 +2066,10 @@ public class ProgramDB extends DomainObjectAdapterDB implements Program, ChangeM
newCompilerSpecID = translator.getNewCompilerSpecID(compilerSpecID);
}
Msg.info(this, "Setting language for Program " + getName() + ": " + translator);
Msg.info(this, "Setting compiler spec for Program " + getName() + ": " +
compilerSpecID + " -> " + newCompilerSpecID);
if (!compilerSpecID.equals(newCompilerSpecID)) {
Msg.info(this, "Setting compiler spec for Program " + getName() + ": " +
compilerSpecID + " -> " + newCompilerSpecID);
}
}
else if (!forceRedisassembly && language.getVersion() == languageVersion &&
language.getMinorVersion() == languageMinorVersion) {
@@ -2138,6 +2141,9 @@ public class ProgramDB extends DomainObjectAdapterDB implements Program, ChangeM
translator.fixupInstructions(this, translator.getOldLanguage(), monitor);
}
// apply pspec default markup as defined by translator and pspec
LanguageFixupUtil.applyPSpecFixups(this);
dataMap.put(LANGUAGE_ID, languageID.getIdAsString());
dataMap.put(COMPILER_SPEC_ID, compilerSpecID.getIdAsString());
dataMap.put(LANGUAGE_VERSION, languageVersion + "." + languageMinorVersion);

View File

@@ -941,7 +941,7 @@ public class MemoryMapDB implements Memory, ManagerDB {
@Override
public void moveBlock(MemoryBlock block, Address newStartAddr, TaskMonitor monitor)
throws MemoryBlockException, MemoryConflictException, AddressOverflowException,
NotFoundException, LockException {
LockException {
lock.acquire();
try {
program.checkExclusiveAccess();
@@ -986,8 +986,7 @@ public class MemoryMapDB implements Memory, ManagerDB {
}
@Override
public void split(MemoryBlock block, Address addr)
throws MemoryBlockException, NotFoundException, LockException {
public void split(MemoryBlock block, Address addr) throws MemoryBlockException, LockException {
lock.acquire();
try {
program.checkExclusiveAccess();
@@ -1037,7 +1036,7 @@ public class MemoryMapDB implements Memory, ManagerDB {
@Override
public MemoryBlock join(MemoryBlock blockOne, MemoryBlock blockTwo)
throws MemoryBlockException, NotFoundException, LockException {
throws MemoryBlockException, LockException {
lock.acquire();
try {
// swap if second block is before first block
@@ -1111,7 +1110,7 @@ public class MemoryMapDB implements Memory, ManagerDB {
@Override
public MemoryBlock convertToInitialized(MemoryBlock uninitializedBlock, byte initialValue)
throws MemoryBlockException, NotFoundException, LockException {
throws MemoryBlockException, LockException {
lock.acquire();
try {
checkBlock(uninitializedBlock);
@@ -1149,7 +1148,7 @@ public class MemoryMapDB implements Memory, ManagerDB {
@Override
public MemoryBlock convertToUninitialized(MemoryBlock initializedBlock)
throws MemoryBlockException, NotFoundException, LockException {
throws MemoryBlockException, LockException {
lock.acquire();
try {
program.checkExclusiveAccess();

View File

@@ -4,9 +4,9 @@
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*
* http://www.apache.org/licenses/LICENSE-2.0
*
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
@@ -15,10 +15,12 @@
*/
package ghidra.program.model.data;
import ghidra.program.database.ProgramDB;
import ghidra.program.model.lang.*;
import ghidra.program.model.listing.IncompatibleLanguageException;
import ghidra.program.util.DefaultLanguageService;
import ghidra.program.util.LanguageTranslatorAdapter;
import ghidra.util.task.TaskMonitor;
public class ProgramArchitectureTranslator extends LanguageTranslatorAdapter {
@@ -40,9 +42,8 @@ public class ProgramArchitectureTranslator extends LanguageTranslatorAdapter {
public ProgramArchitectureTranslator(LanguageID oldLanguageId, int oldLanguageVersion,
CompilerSpecID oldCompilerSpecId, Language newLanguage,
CompilerSpecID newCompilerSpecId)
throws LanguageNotFoundException, CompilerSpecNotFoundException,
IncompatibleLanguageException {
CompilerSpecID newCompilerSpecId) throws LanguageNotFoundException,
CompilerSpecNotFoundException, IncompatibleLanguageException {
this(getLanguage(oldLanguageId, oldLanguageVersion), oldCompilerSpecId, newLanguage,
newCompilerSpecId);
}
@@ -65,5 +66,4 @@ public class ProgramArchitectureTranslator extends LanguageTranslatorAdapter {
return newCompilerSpec;
}
}

View File

@@ -17,7 +17,9 @@ package ghidra.program.model.lang;
import ghidra.program.model.address.Address;
import ghidra.program.model.address.AddressOverflowException;
import ghidra.program.model.symbol.SymbolUtilities;
import ghidra.program.model.util.ProcessorSymbolType;
import ghidra.util.exception.InvalidInputException;
/**
* <CODE>AddressLabelInfo</CODE> is a utility class for storing
@@ -35,7 +37,7 @@ public class AddressLabelInfo implements Comparable<AddressLabelInfo> {
private ProcessorSymbolType processorSymbolType;
private int sizeInBytes;
private Boolean isVolatile;
/**
* Constructor for class AddressLabelInfo
*
@@ -47,17 +49,22 @@ public class AddressLabelInfo implements Comparable<AddressLabelInfo> {
* @param isEntry boolean describes if this object is an entry label for the Address 'addr'
* @param type ProcessorSymbolType the type of symbol
* @param isVolatile Boolean describes if the memory at this address is volatile
* @throws AddressOverflowException if sizeInBytes cause an overflow relative to address
* @throws InvalidInputException if an invalid label name is specified
*/
public AddressLabelInfo(Address addr, Integer sizeInBytes, String label, String description, boolean isPrimary,
boolean isEntry, ProcessorSymbolType type, Boolean isVolatile) throws AddressOverflowException {
public AddressLabelInfo(Address addr, Integer sizeInBytes, String label, String description,
boolean isPrimary, boolean isEntry, ProcessorSymbolType type, Boolean isVolatile)
throws AddressOverflowException, InvalidInputException {
SymbolUtilities.validateName(label);
this.addr = addr;
if ( sizeInBytes == null || sizeInBytes <= 0 ) {
if (sizeInBytes == null || sizeInBytes <= 0) {
// Default size in addressable units
this.sizeInBytes = addr.getAddressSpace().getAddressableUnitSize();
} else {
}
else {
this.sizeInBytes = sizeInBytes;
}
this.endAddr = this.addr.addNoWrap(this.sizeInBytes-1);
this.endAddr = this.addr.addNoWrap(this.sizeInBytes - 1);
this.label = label;
this.description = description;
this.isPrimary = isPrimary;
@@ -72,21 +79,21 @@ public class AddressLabelInfo implements Comparable<AddressLabelInfo> {
public final Address getAddress() {
return addr;
}
/**
* @return the object's end address.
*/
public final Address getEndAddress() {
return endAddr;
}
/**
* @return the object's label or alias.
*/
public final String getLabel() {
return label;
}
/**
* @return the object's description if it has one, null otherwise
*/
@@ -101,14 +108,14 @@ public class AddressLabelInfo implements Comparable<AddressLabelInfo> {
public final int getByteSize() {
return sizeInBytes;
}
/**
* @return whether the object is the primary label at the address.
*/
public final boolean isPrimary() {
return isPrimary;
}
/**
* @return whether the object is volatile.
* Boolean.False when the address is explicitly not volatile.

View File

@@ -25,7 +25,6 @@ import ghidra.program.model.address.*;
import ghidra.program.model.listing.Program;
import ghidra.program.model.symbol.OffsetReference;
import ghidra.util.exception.CancelledException;
import ghidra.util.exception.NotFoundException;
import ghidra.util.task.TaskMonitor;
/**
@@ -462,16 +461,14 @@ public interface Memory extends AddressSetView {
* @param newStartAddr new start address for block
* @param monitor task monitor so the move block can be canceled
* @throws LockException if exclusive lock not in place (see haveLock())
* @throws MemoryBlockException if block movement is not permitted
* @throws MemoryConflictException if move would cause
* blocks to overlap.
* @throws MemoryBlockException if block movement is not permitted
* @throws AddressOverflowException if block movement would violate bounds of address space
* @throws NotFoundException if memoryBlock does not exist in
* this memory.
*/
public void moveBlock(MemoryBlock block, Address newStartAddr, TaskMonitor monitor)
throws LockException, MemoryBlockException, MemoryConflictException,
AddressOverflowException, NotFoundException;
AddressOverflowException;
/**
* Split a block at the given addr and create a new block
@@ -479,14 +476,11 @@ public interface Memory extends AddressSetView {
* @param block block to be split into two
* @param addr address (within block) that will be the
* start of new block
* @throws LockException if exclusive lock not in place (see haveLock())
* @throws NotFoundException thrown if block does not exist
* in memory
* @throws MemoryBlockException memory split not permitted
* @throws LockException if exclusive lock not in place (see haveLock())
* @throws AddressOutOfBoundsException thrown if address is not in the block
*/
public void split(MemoryBlock block, Address addr)
throws MemoryBlockException, LockException, NotFoundException;
public void split(MemoryBlock block, Address addr) throws MemoryBlockException, LockException;
/**
* Join the two blocks to create a single memory block.
@@ -499,7 +493,7 @@ public interface Memory extends AddressSetView {
* not contiguous in the address space,
*/
public MemoryBlock join(MemoryBlock blockOne, MemoryBlock blockTwo)
throws LockException, MemoryBlockException, NotFoundException;
throws LockException, MemoryBlockException;
/**
* Convert an existing uninitialized block with an initialized block.
@@ -512,10 +506,20 @@ public interface Memory extends AddressSetView {
* the same.
*/
public MemoryBlock convertToInitialized(MemoryBlock uninitializedBlock, byte initialValue)
throws LockException, MemoryBlockException, NotFoundException;
throws LockException, MemoryBlockException;
public MemoryBlock convertToUninitialized(MemoryBlock itializedBlock)
throws MemoryBlockException, NotFoundException, LockException;
/**
* Convert an existing initialized block with an uninitialized block.
* Block will discard any associated memory bytes and drop source info.
* @param initializedBlock uninitialized block to convert
* @return the converted block
* @throws LockException if exclusive lock not in place (see haveLock())
* @throws MemoryBlockException if there is no block in memory
* at the same address as block or if the block lengths are not
* the same.
*/
public MemoryBlock convertToUninitialized(MemoryBlock initializedBlock)
throws MemoryBlockException, LockException;
/**
* Finds a sequence of contiguous bytes that match the

View File

@@ -1,13 +1,12 @@
/* ###
* IP: GHIDRA
* REVIEWED: YES
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*
* http://www.apache.org/licenses/LICENSE-2.0
*
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
@@ -16,7 +15,6 @@
*/
package ghidra.program.model.mem;
/**
* Exception thrown for memory block-related problems.
*/
@@ -29,11 +27,21 @@ public class MemoryBlockException extends MemoryAccessException {
public MemoryBlockException() {
super();
}
/**
* Constructs a new MemoryBlockException with a detailed message.
* @param msg detailed message
*/
public MemoryBlockException(String msg) {
super(msg);
}
}
public MemoryBlockException(String msg) {
super(msg);
}
/**
* Constructs a new MemoryBlockException with a detailed message.
* @param msg detailed message
* @param cause original cause of this exception
*/
public MemoryBlockException(String msg, Throwable cause) {
super(msg, cause);
}
}

View File

@@ -24,7 +24,6 @@ import ghidra.framework.store.LockException;
import ghidra.program.database.mem.*;
import ghidra.program.model.address.*;
import ghidra.program.model.listing.Program;
import ghidra.util.exception.NotFoundException;
import ghidra.util.task.TaskMonitor;
/**
@@ -241,31 +240,31 @@ public class StubMemory extends AddressSet implements Memory {
@Override
public void moveBlock(MemoryBlock block, Address newStartAddr, TaskMonitor monitor)
throws LockException, MemoryBlockException, MemoryConflictException,
AddressOverflowException, NotFoundException {
AddressOverflowException {
throw new UnsupportedOperationException();
}
@Override
public void split(MemoryBlock block, Address addr)
throws MemoryBlockException, LockException, NotFoundException {
throws MemoryBlockException, LockException {
throw new UnsupportedOperationException();
}
@Override
public MemoryBlock join(MemoryBlock blockOne, MemoryBlock blockTwo)
throws LockException, MemoryBlockException, NotFoundException {
throws LockException, MemoryBlockException {
throw new UnsupportedOperationException();
}
@Override
public MemoryBlock convertToInitialized(MemoryBlock uninitializedBlock, byte initialValue)
throws LockException, MemoryBlockException, NotFoundException {
throws LockException, MemoryBlockException {
throw new UnsupportedOperationException();
}
@Override
public MemoryBlock convertToUninitialized(MemoryBlock initializedBlock)
throws MemoryBlockException, NotFoundException, LockException {
throws MemoryBlockException, LockException {
throw new UnsupportedOperationException();
}

View File

@@ -4,9 +4,9 @@
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*
* http://www.apache.org/licenses/LICENSE-2.0
*
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
@@ -15,6 +15,7 @@
*/
package ghidra.program.util;
import ghidra.program.database.ProgramDB;
import ghidra.program.model.address.Address;
import ghidra.program.model.address.AddressSpace;
import ghidra.program.model.lang.*;
@@ -34,7 +35,7 @@ import ghidra.util.task.TaskMonitor;
* instantiate Language, AddressSpace, AddressFactory or Register objects until isValid() is invoked.
*/
public interface LanguageTranslator extends ExtensionPoint {
/**
* Validate translator to complete initialization and ensure language compatibility.
* This method will be invoked by the LanguageTranslatorFactory before handing out this
@@ -42,7 +43,7 @@ public interface LanguageTranslator extends ExtensionPoint {
* @return true if translator successfully validated
*/
public boolean isValid();
/**
* Returns old language
* @throws IllegalStateException if instance has not been validated
@@ -54,27 +55,27 @@ public interface LanguageTranslator extends ExtensionPoint {
* Returns new language
*/
public Language getNewLanguage();
/**
* Returns old language name
*/
public LanguageID getOldLanguageID();
/**
* Returns new language name
*/
public LanguageID getNewLanguageID();
/**
* Returns old language version
*/
public int getOldVersion();
/**
* Returns new language version
*/
public int getNewVersion();
/**
* Translate BASE address spaces (Overlay spaces are not handled)
* @param oldSpaceName old space name
@@ -92,7 +93,7 @@ public interface LanguageTranslator extends ExtensionPoint {
* @see #getOldRegisterContaining(Address)
*/
public Register getOldRegister(Address oldAddr, int size);
/**
* Get the largest old register which contains the specified oldAddr
* @param oldAddr old register address which may be offcut
@@ -104,14 +105,14 @@ public interface LanguageTranslator extends ExtensionPoint {
* Returns the old processor context register or null if not defined
*/
public Register getOldContextRegister();
/**
* Find new register which corresponds to the specified old register.
* @param oldReg old register
* @return new register or null if corresponding register not found.
*/
public Register getNewRegister(Register oldReg);
/**
* Returns the new processor context register or null if not defined
*/
@@ -150,7 +151,8 @@ public interface LanguageTranslator extends ExtensionPoint {
* @throws CompilerSpecNotFoundException if new compiler spec not found based upon
* translator mappings.
*/
public CompilerSpec getOldCompilerSpec(CompilerSpecID oldCompilerSpecID) throws CompilerSpecNotFoundException;
public CompilerSpec getOldCompilerSpec(CompilerSpecID oldCompilerSpecID)
throws CompilerSpecNotFoundException;
/**
* Invoked after Program language upgrade has completed.
@@ -172,4 +174,5 @@ public interface LanguageTranslator extends ExtensionPoint {
*/
public void fixupInstructions(Program program, Language oldLanguage, TaskMonitor monitor)
throws Exception, CancelledException;
}

View File

@@ -4,9 +4,9 @@
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*
* http://www.apache.org/licenses/LICENSE-2.0
*
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
@@ -225,9 +225,7 @@ public abstract class LanguageTranslatorAdapter implements LanguageTranslator {
protected static AddressSpace findSpaceSameName(AddressSpace oldSpace,
ArrayList<AddressSpace> newSpaces) throws IncompatibleLanguageException {
Iterator<AddressSpace> it = newSpaces.iterator();
while (it.hasNext()) {
AddressSpace space = it.next();
for (AddressSpace space : newSpaces) {
if (space.getName().equals(oldSpace.getName())) {
if (oldSpace.getSize() > space.getSize()) {
throw new IncompatibleLanguageException("Old language space (" +

View File

@@ -4,9 +4,9 @@
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*
* http://www.apache.org/licenses/LICENSE-2.0
*
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
@@ -20,6 +20,7 @@ import java.util.*;
import generic.jar.ResourceFile;
import ghidra.framework.Application;
import ghidra.program.database.ProgramDB;
import ghidra.program.model.address.Address;
import ghidra.program.model.address.AddressSpace;
import ghidra.program.model.lang.*;
@@ -405,10 +406,10 @@ public class LanguageTranslatorFactory {
}
/**
*
* Get language translator
* @param versionTranslatorList sorted list of version translators
* @param version
* @return
* @param version old/from language version
* @return translator from specified version or next greater versionor null if not found
*/
private LanguageTranslator getNextTranslator(List<LanguageTranslator> versionTranslatorList,
int version) {
@@ -561,4 +562,5 @@ class FactoryLanguageTranslator implements LanguageTranslator {
public String toString() {
return t1.toString() + "; " + System.getProperty("line.separator") + t2.toString();
}
}

View File

@@ -289,7 +289,8 @@ class OldLanguage implements Language {
throw new SAXException("Missing required 'spaces' element");
}
if (!registersFound) {
throw new SAXException("Missing required 'registers' element");
// register mapping will not be performed
registerMgr = (new RegisterBuilder()).getRegisterManager();
}
}

View File

@@ -4,9 +4,9 @@
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
*
* http://www.apache.org/licenses/LICENSE-2.0
*
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
@@ -471,9 +471,4 @@ class SimpleLanguageTranslator extends LanguageTranslatorAdapter {
contextSettings.put(name, val);
}
public CompilerSpec getCompilerSpec() {
// TODO Auto-generated method stub
return null;
}
}

View File

@@ -1,15 +1,12 @@
##VERSION: 2.0
Module.manifest||GHIDRA||||END|
README.md||GHIDRA||||END|
data/languages/RV32G.pspec||GHIDRA||||END|
data/languages/RV32GC.pspec||GHIDRA||||END|
data/languages/RV32I.pspec||GHIDRA||||END|
data/languages/RV32IC.pspec||GHIDRA||||END|
data/languages/RV32IMC.pspec||GHIDRA||||END|
data/languages/RV64G.pspec||GHIDRA||||END|
data/languages/RV64GC.pspec||GHIDRA||||END|
data/languages/RV64I.pspec||GHIDRA||||END|
data/languages/RV64IC.pspec||GHIDRA||||END|
data/languages/RV32.pspec||GHIDRA||||END|
data/languages/RV64.pspec||GHIDRA||||END|
data/languages/andestar_v5.instr.sinc||GHIDRA||||END|
data/languages/andestar_v5.ldefs||GHIDRA||||END|
data/languages/andestar_v5.slaspec||GHIDRA||||END|
data/languages/old/riscv_deprecated.ldefs||GHIDRA||||END|
data/languages/riscv.csr.sinc||GHIDRA||||END|
data/languages/riscv.custom.sinc||GHIDRA||||END|
data/languages/riscv.ilp32d.slaspec||GHIDRA||||END|

View File

@@ -0,0 +1,425 @@
<?xml version="1.0" encoding="UTF-8"?>
<processor_spec>
<programcounter register="pc"/>
<context_data>
<context_set space="ram">
<set name="MXL" val="1"/>
</context_set>
</context_data>
<default_memory_blocks>
<memory_block name="csr" start_address="csreg:0x0" length="0x4000" initialized="false"/>
</default_memory_blocks>
<!-- TODO: add include directive and move to shared include -->
<default_symbols>
<symbol name="ustatus" address="csreg:0x000" size="4" description="" />
<symbol name="fflags" address="csreg:0x001" size="4" description="" />
<symbol name="frm" address="csreg:0x002" size="4" description="" />
<symbol name="fcsr" address="csreg:0x003" size="4" description="" />
<symbol name="uie" address="csreg:0x004" size="4" description="" />
<symbol name="utvec" address="csreg:0x005" size="4" description="" />
<symbol name="vstart" address="csreg:0x008" size="4" description="" />
<symbol name="vxsat" address="csreg:0x009" size="4" description="" />
<symbol name="vxrm" address="csreg:0x00a" size="4" description="" />
<symbol name="vcsr" address="csreg:0x00f" size="4" description="" />
<symbol name="uscratch" address="csreg:0x040" size="4" description="" />
<symbol name="uepc" address="next" size="4" description="" />
<symbol name="ucause" address="next" size="4" description="" />
<symbol name="utval" address="next" size="4" description="" />
<symbol name="uip" address="next" size="4" description="" />
<symbol name="sstatus" address="csreg:0x100" size="4" description="" />
<symbol name="sedeleg" address="next" size="4" description="" />
<symbol name="sideleg" address="next" size="4" description="" />
<symbol name="sie" address="next" size="4" description="" />
<symbol name="stvec" address="next" size="4" description="" />
<symbol name="scounteren" address="next" size="4" description="" />
<symbol name="sscratch" address="csreg:0x140" size="4" description="" />
<symbol name="sepc" address="next" size="4" description="" />
<symbol name="scause" address="next" size="4" description="" />
<symbol name="stval" address="next" size="4" description="" />
<symbol name="sip" address="next" size="4" description="" />
<symbol name="satp" address="csreg:0x180" size="4" description="" />
<symbol name="vsstatus" address="csreg:0x200" size="4" description="" />
<symbol name="vsie" address="csreg:0x204" size="4" description="" />
<symbol name="vstvec" address="next" size="4" description="" />
<symbol name="vsscratch" address="csreg:0x240" size="4" description="" />
<symbol name="vsepc" address="next" size="4" description="" />
<symbol name="vscause" address="next" size="4" description="" />
<symbol name="vstval" address="next" size="4" description="" />
<symbol name="vsip" address="next" size="4" description="" />
<symbol name="vsatp" address="csreg:0x280" size="4" description="" />
<symbol name="mstatus" address="csreg:0x300" size="4" description="" />
<symbol name="misa" address="next" size="4" description="" />
<symbol name="medeleg" address="next" size="4" description="" />
<symbol name="mideleg" address="next" size="4" description="" />
<symbol name="mie" address="next" size="4" description="" />
<symbol name="mtvec" address="next" size="4" description="" />
<symbol name="mcounteren" address="next" size="4" description="" />
<symbol name="mstatush" address="csreg:0x310" size="4" description="" />
<symbol name="mcountinhibit" address="csreg:0x320" size="4" description="" />
<symbol name="mhpmevent3" address="csreg:0x323" size="4" description="" />
<symbol name="mhpmevent4" address="csreg:0x324" size="4" description="" />
<symbol name="mhpmevent5" address="csreg:0x325" size="4" description="" />
<symbol name="mhpmevent6" address="csreg:0x326" size="4" description="" />
<symbol name="mhpmevent7" address="csreg:0x327" size="4" description="" />
<symbol name="mhpmevent8" address="csreg:0x328" size="4" description="" />
<symbol name="mhpmevent9" address="csreg:0x329" size="4" description="" />
<symbol name="mhpmevent10" address="csreg:0x32a" size="4" description="" />
<symbol name="mhpmevent11" address="csreg:0x32b" size="4" description="" />
<symbol name="mhpmevent12" address="csreg:0x32c" size="4" description="" />
<symbol name="mhpmevent13" address="csreg:0x32d" size="4" description="" />
<symbol name="mhpmevent14" address="csreg:0x32e" size="4" description="" />
<symbol name="mhpmevent15" address="csreg:0x32f" size="4" description="" />
<symbol name="mhpmevent16" address="csreg:0x330" size="4" description="" />
<symbol name="mhpmevent17" address="next" size="4" description="" />
<symbol name="mhpmevent18" address="next" size="4" description="" />
<symbol name="mhpmevent19" address="next" size="4" description="" />
<symbol name="mhpmevent20" address="next" size="4" description="" />
<symbol name="mhpmevent21" address="next" size="4" description="" />
<symbol name="mhpmevent22" address="next" size="4" description="" />
<symbol name="mhpmevent23" address="next" size="4" description="" />
<symbol name="mhpmevent24" address="csreg:0x338" size="4" description="" />
<symbol name="mhpmevent25" address="next" size="4" description="" />
<symbol name="mhpmevent26" address="next" size="4" description="" />
<symbol name="mhpmevent27" address="next" size="4" description="" />
<symbol name="mhpmevent28" address="next" size="4" description="" />
<symbol name="mhpmevent29" address="next" size="4" description="" />
<symbol name="mhpmevent30" address="next" size="4" description="" />
<symbol name="mhpmevent31" address="next" size="4" description="" />
<symbol name="mscratch" address="csreg:0x340" size="4" description="" />
<symbol name="mepc" address="csreg:0x341" size="4" description="" />
<symbol name="mcause" address="csreg:0x342" size="4" description="" />
<symbol name="mtval" address="csreg:0x343" size="4" description="" />
<symbol name="mip" address="csreg:0x344" size="4" description="" />
<symbol name="mtinst" address="csreg:0x34a" size="4" description="" />
<symbol name="mtval2" address="csreg:0x34b" size="4" description="" />
<symbol name="mbase" address="csreg:0x380" size="4" description="" />
<symbol name="mbound" address="csreg:0x381" size="4" description="" />
<symbol name="mibase" address="csreg:0x382" size="4" description="" />
<symbol name="mibound" address="csreg:0x383" size="4" description="" />
<symbol name="mdbase" address="csreg:0x384" size="4" description="" />
<symbol name="mdbound" address="csreg:0x385" size="4" description="" />
<symbol name="pmpcfg0" address="csreg:0x3a0" size="4" description="" />
<symbol name="pmpcfg1" address="next" size="4" description="" />
<symbol name="pmpcfg2" address="next" size="4" description="" />
<symbol name="pmpcfg3" address="next" size="4" description="" />
<symbol name="pmpcfg4" address="next" size="4" description="" />
<symbol name="pmpcfg5" address="next" size="4" description="" />
<symbol name="pmpcfg6" address="next" size="4" description="" />
<symbol name="pmpcfg7" address="next" size="4" description="" />
<symbol name="pmpcfg8" address="csreg:0x3a8" size="4" description="" />
<symbol name="pmpcfg9" address="next" size="4" description="" />
<symbol name="pmpcfg10" address="next" size="4" description="" />
<symbol name="pmpcfg11" address="next" size="4" description="" />
<symbol name="pmpcfg12" address="next" size="4" description="" />
<symbol name="pmpcfg13" address="next" size="4" description="" />
<symbol name="pmpcfg14" address="next" size="4" description="" />
<symbol name="pmpcfg15" address="next" size="4" description="" />
<symbol name="pmpaddr0" address="csreg:0x3b0" size="4" description="" />
<symbol name="pmpaddr1" address="next" size="4" description="" />
<symbol name="pmpaddr2" address="next" size="4" description="" />
<symbol name="pmpaddr3" address="next" size="4" description="" />
<symbol name="pmpaddr4" address="next" size="4" description="" />
<symbol name="pmpaddr5" address="next" size="4" description="" />
<symbol name="pmpaddr6" address="next" size="4" description="" />
<symbol name="pmpaddr7" address="next" size="4" description="" />
<symbol name="pmpaddr8" address="csreg:0x3b8" size="4" description="" />
<symbol name="pmpaddr9" address="next" size="4" description="" />
<symbol name="pmpaddr10" address="next" size="4" description="" />
<symbol name="pmpaddr11" address="next" size="4" description="" />
<symbol name="pmpaddr12" address="next" size="4" description="" />
<symbol name="pmpaddr13" address="next" size="4" description="" />
<symbol name="pmpaddr14" address="next" size="4" description="" />
<symbol name="pmpaddr15" address="next" size="4" description="" />
<symbol name="pmpaddr16" address="csreg:0x3c0" size="4" description="" />
<symbol name="pmpaddr17" address="next" size="4" description="" />
<symbol name="pmpaddr18" address="next" size="4" description="" />
<symbol name="pmpaddr19" address="next" size="4" description="" />
<symbol name="pmpaddr20" address="next" size="4" description="" />
<symbol name="pmpaddr21" address="next" size="4" description="" />
<symbol name="pmpaddr22" address="next" size="4" description="" />
<symbol name="pmpaddr23" address="next" size="4" description="" />
<symbol name="pmpaddr24" address="csreg:0x3c8" size="4" description="" />
<symbol name="pmpaddr25" address="next" size="4" description="" />
<symbol name="pmpaddr26" address="next" size="4" description="" />
<symbol name="pmpaddr27" address="next" size="4" description="" />
<symbol name="pmpaddr28" address="next" size="4" description="" />
<symbol name="pmpaddr29" address="next" size="4" description="" />
<symbol name="pmpaddr30" address="next" size="4" description="" />
<symbol name="pmpaddr31" address="next" size="4" description="" />
<symbol name="pmpaddr32" address="csreg:0x3d0" size="4" description="" />
<symbol name="pmpaddr33" address="next" size="4" description="" />
<symbol name="pmpaddr34" address="next" size="4" description="" />
<symbol name="pmpaddr35" address="next" size="4" description="" />
<symbol name="pmpaddr36" address="next" size="4" description="" />
<symbol name="pmpaddr37" address="next" size="4" description="" />
<symbol name="pmpaddr38" address="next" size="4" description="" />
<symbol name="pmpaddr39" address="next" size="4" description="" />
<symbol name="pmpaddr40" address="csreg:0x3d8" size="4" description="" />
<symbol name="pmpaddr41" address="next" size="4" description="" />
<symbol name="pmpaddr42" address="next" size="4" description="" />
<symbol name="pmpaddr43" address="next" size="4" description="" />
<symbol name="pmpaddr44" address="next" size="4" description="" />
<symbol name="pmpaddr45" address="next" size="4" description="" />
<symbol name="pmpaddr46" address="next" size="4" description="" />
<symbol name="pmpaddr47" address="next" size="4" description="" />
<symbol name="pmpaddr48" address="csreg:0x3e0" size="4" description="" />
<symbol name="pmpaddr49" address="next" size="4" description="" />
<symbol name="pmpaddr50" address="next" size="4" description="" />
<symbol name="pmpaddr51" address="next" size="4" description="" />
<symbol name="pmpaddr52" address="next" size="4" description="" />
<symbol name="pmpaddr53" address="next" size="4" description="" />
<symbol name="pmpaddr54" address="next" size="4" description="" />
<symbol name="pmpaddr55" address="next" size="4" description="" />
<symbol name="pmpaddr56" address="csreg:0x3e8" size="4" description="" />
<symbol name="pmpaddr57" address="next" size="4" description="" />
<symbol name="pmpaddr58" address="next" size="4" description="" />
<symbol name="pmpaddr59" address="next" size="4" description="" />
<symbol name="pmpaddr60" address="next" size="4" description="" />
<symbol name="pmpaddr61" address="next" size="4" description="" />
<symbol name="pmpaddr62" address="next" size="4" description="" />
<symbol name="pmpaddr63" address="next" size="4" description="" />
<symbol name="scontext" address="csreg:0x5a8" size="4" description="" />
<symbol name="hstatus" address="csreg:0x600" size="4" description="" />
<symbol name="hedeleg" address="csreg:0x602" size="4" description="" />
<symbol name="hideleg" address="csreg:0x603" size="4" description="" />
<symbol name="hie" address="csreg:0x604" size="4" description="" />
<symbol name="htimedelta" address="csreg:0x605" size="4" description="" />
<symbol name="hcounteren" address="csreg:0x606" size="4" description="" />
<symbol name="hgeie" address="csreg:0x607" size="4" description="" />
<symbol name="htimedeltah" address="csreg:0x615" size="4" description="" />
<symbol name="htval" address="csreg:0x643" size="4" description="" />
<symbol name="hip" address="csreg:0x644" size="4" description="" />
<symbol name="hvip" address="csreg:0x645" size="4" description="" />
<symbol name="htinst" address="csreg:0x64a" size="4" description="" />
<symbol name="hgatp" address="csreg:0x680" size="4" description="" />
<symbol name="hcontext" address="csreg:0x6a8" size="4" description="" />
<symbol name="tselect" address="csreg:0x7a0" size="4" description="" />
<symbol name="tdata1" address="csreg:0x7a1" size="4" description="" />
<symbol name="tdata2" address="csreg:0x7a2" size="4" description="" />
<symbol name="tdata3" address="csreg:0x7a3" size="4" description="" />
<symbol name="mcontext" address="csreg:0x7a8" size="4" description="" />
<symbol name="dcsr" address="csreg:0x7b0" size="4" description="" />
<symbol name="dpc" address="csreg:0x7b1" size="4" description="" />
<symbol name="dscratch0" address="csreg:0x7b2" size="4" description="" />
<symbol name="dscratch1" address="csreg:0x7b3" size="4" description="" />
<symbol name="mcycle" address="csreg:0xa00" size="4" description="" />
<symbol name="minstret" address="csreg:0xa02" size="4" description="" />
<symbol name="mhpmcounter3" address="csreg:0xa03" size="4" description="" />
<symbol name="mhpmcounter4" address="next" size="4" description="" />
<symbol name="mhpmcounter5" address="next" size="4" description="" />
<symbol name="mhpmcounter6" address="next" size="4" description="" />
<symbol name="mhpmcounter7" address="next" size="4" description="" />
<symbol name="mhpmcounter8" address="csreg:0xa08" size="4" description="" />
<symbol name="mhpmcounter9" address="next" size="4" description="" />
<symbol name="mhpmcounter10" address="next" size="4" description="" />
<symbol name="mhpmcounter11" address="next" size="4" description="" />
<symbol name="mhpmcounter12" address="next" size="4" description="" />
<symbol name="mhpmcounter13" address="next" size="4" description="" />
<symbol name="mhpmcounter14" address="next" size="4" description="" />
<symbol name="mhpmcounter15" address="next" size="4" description="" />
<symbol name="mhpmcounter16" address="csreg:0xa10" size="4" description="" />
<symbol name="mhpmcounter17" address="next" size="4" description="" />
<symbol name="mhpmcounter18" address="next" size="4" description="" />
<symbol name="mhpmcounter19" address="next" size="4" description="" />
<symbol name="mhpmcounter20" address="next" size="4" description="" />
<symbol name="mhpmcounter21" address="next" size="4" description="" />
<symbol name="mhpmcounter22" address="next" size="4" description="" />
<symbol name="mhpmcounter23" address="next" size="4" description="" />
<symbol name="mhpmcounter24" address="csreg:0xa18" size="4" description="" />
<symbol name="mhpmcounter25" address="next" size="4" description="" />
<symbol name="mhpmcounter26" address="next" size="4" description="" />
<symbol name="mhpmcounter27" address="next" size="4" description="" />
<symbol name="mhpmcounter28" address="next" size="4" description="" />
<symbol name="mhpmcounter29" address="next" size="4" description="" />
<symbol name="mhpmcounter30" address="next" size="4" description="" />
<symbol name="mhpmcounter31" address="next" size="4" description="" />
<symbol name="mcycleh" address="csreg:0xb80" size="4" description="" />
<symbol name="minstreth" address="next" size="4" description="" />
<symbol name="mhpmcounter3h" address="next" size="4" description="" />
<symbol name="mhpmcounter4h" address="next" size="4" description="" />
<symbol name="mhpmcounter5h" address="next" size="4" description="" />
<symbol name="mhpmcounter6h" address="next" size="4" description="" />
<symbol name="mhpmcounter7h" address="next" size="4" description="" />
<symbol name="mhpmcounter8h" address="csreg:0xb88" size="4" description="" />
<symbol name="mhpmcounter9h" address="next" size="4" description="" />
<symbol name="mhpmcounter10h" address="next" size="4" description="" />
<symbol name="mhpmcounter11h" address="next" size="4" description="" />
<symbol name="mhpmcounter12h" address="next" size="4" description="" />
<symbol name="mhpmcounter13h" address="next" size="4" description="" />
<symbol name="mhpmcounter14h" address="next" size="4" description="" />
<symbol name="mhpmcounter15h" address="next" size="4" description="" />
<symbol name="mhpmcounter16h" address="csreg:0xb90" size="4" description="" />
<symbol name="mhpmcounter17h" address="next" size="4" description="" />
<symbol name="mhpmcounter18h" address="next" size="4" description="" />
<symbol name="mhpmcounter19h" address="next" size="4" description="" />
<symbol name="mhpmcounter20h" address="next" size="4" description="" />
<symbol name="mhpmcounter21h" address="next" size="4" description="" />
<symbol name="mhpmcounter22h" address="next" size="4" description="" />
<symbol name="mhpmcounter23h" address="next" size="4" description="" />
<symbol name="mhpmcounter24h" address="csreg:0xb98" size="4" description="" />
<symbol name="mhpmcounter25h" address="next" size="4" description="" />
<symbol name="mhpmcounter26h" address="next" size="4" description="" />
<symbol name="mhpmcounter27h" address="next" size="4" description="" />
<symbol name="mhpmcounter28h" address="next" size="4" description="" />
<symbol name="mhpmcounter29h" address="next" size="4" description="" />
<symbol name="mhpmcounter30h" address="next" size="4" description="" />
<symbol name="mhpmcounter31h" address="next" size="4" description="" />
<symbol name="cycle" address="csreg:0xc00" size="4" description="" />
<symbol name="time" address="next" size="4" description="" />
<symbol name="instret" address="next" size="4" description="" />
<symbol name="hpmcounter3" address="next" size="4" description="" />
<symbol name="hpmcounter4" address="next" size="4" description="" />
<symbol name="hpmcounter5" address="next" size="4" description="" />
<symbol name="hpmcounter6" address="next" size="4" description="" />
<symbol name="hpmcounter7" address="next" size="4" description="" />
<symbol name="hpmcounter8" address="csreg:0xc08" size="4" description="" />
<symbol name="hpmcounter9" address="next" size="4" description="" />
<symbol name="hpmcounter10" address="next" size="4" description="" />
<symbol name="hpmcounter11" address="next" size="4" description="" />
<symbol name="hpmcounter12" address="next" size="4" description="" />
<symbol name="hpmcounter13" address="next" size="4" description="" />
<symbol name="hpmcounter14" address="next" size="4" description="" />
<symbol name="hpmcounter15" address="next" size="4" description="" />
<symbol name="hpmcounter16" address="csreg:0xc10" size="4" description="" />
<symbol name="hpmcounter17" address="next" size="4" description="" />
<symbol name="hpmcounter18" address="next" size="4" description="" />
<symbol name="hpmcounter19" address="next" size="4" description="" />
<symbol name="hpmcounter20" address="next" size="4" description="" />
<symbol name="hpmcounter21" address="next" size="4" description="" />
<symbol name="hpmcounter22" address="next" size="4" description="" />
<symbol name="hpmcounter23" address="next" size="4" description="" />
<symbol name="hpmcounter24" address="csreg:0xc18" size="4" description="" />
<symbol name="hpmcounter25" address="next" size="4" description="" />
<symbol name="hpmcounter26" address="next" size="4" description="" />
<symbol name="hpmcounter27" address="next" size="4" description="" />
<symbol name="hpmcounter28" address="next" size="4" description="" />
<symbol name="hpmcounter29" address="next" size="4" description="" />
<symbol name="hpmcounter30" address="next" size="4" description="" />
<symbol name="hpmcounter31" address="next" size="4" description="" />
<symbol name="vl" address="csreg:0xc20" size="4" description="" />
<symbol name="vtype" address="next" size="4" description="" />
<symbol name="vlenb" address="next" size="4" description="" />
<symbol name="cycleh" address="csreg:0xc80" size="4" description="" />
<symbol name="timeh" address="next" size="4" description="" />
<symbol name="instreth" address="next" size="4" description="" />
<symbol name="hpmcounter3h" address="next" size="4" description="" />
<symbol name="hpmcounter4h" address="next" size="4" description="" />
<symbol name="hpmcounter5h" address="next" size="4" description="" />
<symbol name="hpmcounter6h" address="next" size="4" description="" />
<symbol name="hpmcounter7h" address="next" size="4" description="" />
<symbol name="hpmcounter8h" address="csreg:0xc88" size="4" description="" />
<symbol name="hpmcounter9h" address="next" size="4" description="" />
<symbol name="hpmcounter10h" address="next" size="4" description="" />
<symbol name="hpmcounter11h" address="next" size="4" description="" />
<symbol name="hpmcounter12h" address="next" size="4" description="" />
<symbol name="hpmcounter13h" address="next" size="4" description="" />
<symbol name="hpmcounter14h" address="next" size="4" description="" />
<symbol name="hpmcounter15h" address="next" size="4" description="" />
<symbol name="hpmcounter16h" address="csreg:0xc90" size="4" description="" />
<symbol name="hpmcounter17h" address="next" size="4" description="" />
<symbol name="hpmcounter18h" address="next" size="4" description="" />
<symbol name="hpmcounter19h" address="next" size="4" description="" />
<symbol name="hpmcounter20h" address="next" size="4" description="" />
<symbol name="hpmcounter21h" address="next" size="4" description="" />
<symbol name="hpmcounter22h" address="next" size="4" description="" />
<symbol name="hpmcounter23h" address="next" size="4" description="" />
<symbol name="hpmcounter24h" address="csreg:0xc98" size="4" description="" />
<symbol name="hpmcounter25h" address="next" size="4" description="" />
<symbol name="hpmcounter26h" address="next" size="4" description="" />
<symbol name="hpmcounter27h" address="next" size="4" description="" />
<symbol name="hpmcounter28h" address="next" size="4" description="" />
<symbol name="hpmcounter29h" address="next" size="4" description="" />
<symbol name="hpmcounter30h" address="next" size="4" description="" />
<symbol name="hpmcounter31h" address="next" size="4" description="" />
<symbol name="hgeip" address="csreg:0xe12" size="4" description="" />
<symbol name="mvendorid" address="csreg:0xf11" size="4" description="" />
<symbol name="marchid" address="csreg:0xf12" size="4" description="" />
<symbol name="mimpid" address="csreg:0xf13" size="4" description="" />
<symbol name="mhartid" address="csreg:0xf14" size="4" description="" />
</default_symbols>
</processor_spec>

View File

@@ -1,19 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<processor_spec>
<programcounter register="pc"/>
<context_data>
<context_set space="ram">
<set name="MXL" val="1"/>
<set name="RVA" val="1"/>
<set name="RVD" val="1"/>
<set name="RVF" val="1"/>
<set name="RVH" val="1"/>
<set name="RVI" val="1"/>
<set name="RVM" val="1"/>
<set name="RVQ" val="1"/>
<set name="RVS" val="1"/>
<set name="RVU" val="1"/>
</context_set>
</context_data>
</processor_spec>

View File

@@ -1,20 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<processor_spec>
<programcounter register="pc"/>
<context_data>
<context_set space="ram">
<set name="MXL" val="1"/>
<set name="RVA" val="1"/>
<set name="RVC" val="1"/>
<set name="RVD" val="1"/>
<set name="RVF" val="1"/>
<set name="RVH" val="1"/>
<set name="RVI" val="1"/>
<set name="RVM" val="1"/>
<set name="RVQ" val="1"/>
<set name="RVS" val="1"/>
<set name="RVU" val="1"/>
</context_set>
</context_data>
</processor_spec>

View File

@@ -1,14 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<processor_spec>
<programcounter register="pc"/>
<context_data>
<context_set space="ram">
<set name="MXL" val="1"/>
<set name="RVH" val="1"/>
<set name="RVI" val="1"/>
<set name="RVS" val="1"/>
<set name="RVU" val="1"/>
</context_set>
</context_data>
</processor_spec>

View File

@@ -1,15 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<processor_spec>
<programcounter register="pc"/>
<context_data>
<context_set space="ram">
<set name="MXL" val="1"/>
<set name="RVC" val="1"/>
<set name="RVH" val="1"/>
<set name="RVI" val="1"/>
<set name="RVS" val="1"/>
<set name="RVU" val="1"/>
</context_set>
</context_data>
</processor_spec>

View File

@@ -1,16 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<processor_spec>
<programcounter register="pc"/>
<context_data>
<context_set space="ram">
<set name="MXL" val="1"/>
<set name="RVC" val="1"/>
<set name="RVH" val="1"/>
<set name="RVI" val="1"/>
<set name="RVM" val="1"/>
<set name="RVS" val="1"/>
<set name="RVU" val="1"/>
</context_set>
</context_data>
</processor_spec>

View File

@@ -0,0 +1,425 @@
<?xml version="1.0" encoding="UTF-8"?>
<processor_spec>
<programcounter register="pc"/>
<context_data>
<context_set space="ram">
<set name="MXL" val="2"/>
</context_set>
</context_data>
<default_memory_blocks>
<memory_block name="csr" start_address="csreg:0x0" length="0x8000" initialized="false"/>
</default_memory_blocks>
<!-- TODO: add include directive and move to shared include -->
<default_symbols>
<symbol name="ustatus" address="csreg:0x000" size="8" description="" />
<symbol name="fflags" address="csreg:0x001" size="8" description="" />
<symbol name="frm" address="csreg:0x002" size="8" description="" />
<symbol name="fcsr" address="csreg:0x003" size="8" description="" />
<symbol name="uie" address="csreg:0x004" size="8" description="" />
<symbol name="utvec" address="csreg:0x005" size="8" description="" />
<symbol name="vstart" address="csreg:0x008" size="8" description="" />
<symbol name="vxsat" address="csreg:0x009" size="8" description="" />
<symbol name="vxrm" address="csreg:0x00a" size="8" description="" />
<symbol name="vcsr" address="csreg:0x00f" size="8" description="" />
<symbol name="uscratch" address="csreg:0x040" size="8" description="" />
<symbol name="uepc" address="next" size="8" description="" />
<symbol name="ucause" address="next" size="8" description="" />
<symbol name="utval" address="next" size="8" description="" />
<symbol name="uip" address="next" size="8" description="" />
<symbol name="sstatus" address="csreg:0x100" size="8" description="" />
<symbol name="sedeleg" address="next" size="8" description="" />
<symbol name="sideleg" address="next" size="8" description="" />
<symbol name="sie" address="next" size="8" description="" />
<symbol name="stvec" address="next" size="8" description="" />
<symbol name="scounteren" address="next" size="8" description="" />
<symbol name="sscratch" address="csreg:0x140" size="8" description="" />
<symbol name="sepc" address="next" size="8" description="" />
<symbol name="scause" address="next" size="8" description="" />
<symbol name="stval" address="next" size="8" description="" />
<symbol name="sip" address="next" size="8" description="" />
<symbol name="satp" address="csreg:0x180" size="8" description="" />
<symbol name="vsstatus" address="csreg:0x200" size="8" description="" />
<symbol name="vsie" address="csreg:0x204" size="8" description="" />
<symbol name="vstvec" address="next" size="8" description="" />
<symbol name="vsscratch" address="csreg:0x240" size="8" description="" />
<symbol name="vsepc" address="next" size="8" description="" />
<symbol name="vscause" address="next" size="8" description="" />
<symbol name="vstval" address="next" size="8" description="" />
<symbol name="vsip" address="next" size="8" description="" />
<symbol name="vsatp" address="csreg:0x280" size="8" description="" />
<symbol name="mstatus" address="csreg:0x300" size="8" description="" />
<symbol name="misa" address="next" size="8" description="" />
<symbol name="medeleg" address="next" size="8" description="" />
<symbol name="mideleg" address="next" size="8" description="" />
<symbol name="mie" address="next" size="8" description="" />
<symbol name="mtvec" address="next" size="8" description="" />
<symbol name="mcounteren" address="next" size="8" description="" />
<symbol name="mstatush" address="csreg:0x310" size="8" description="" />
<symbol name="mcountinhibit" address="csreg:0x320" size="8" description="" />
<symbol name="mhpmevent3" address="csreg:0x323" size="8" description="" />
<symbol name="mhpmevent4" address="csreg:0x324" size="8" description="" />
<symbol name="mhpmevent5" address="csreg:0x325" size="8" description="" />
<symbol name="mhpmevent6" address="csreg:0x326" size="8" description="" />
<symbol name="mhpmevent7" address="csreg:0x327" size="8" description="" />
<symbol name="mhpmevent8" address="csreg:0x328" size="8" description="" />
<symbol name="mhpmevent9" address="csreg:0x329" size="8" description="" />
<symbol name="mhpmevent10" address="csreg:0x32a" size="8" description="" />
<symbol name="mhpmevent11" address="csreg:0x32b" size="8" description="" />
<symbol name="mhpmevent12" address="csreg:0x32c" size="8" description="" />
<symbol name="mhpmevent13" address="csreg:0x32d" size="8" description="" />
<symbol name="mhpmevent14" address="csreg:0x32e" size="8" description="" />
<symbol name="mhpmevent15" address="csreg:0x32f" size="8" description="" />
<symbol name="mhpmevent16" address="csreg:0x330" size="8" description="" />
<symbol name="mhpmevent17" address="next" size="8" description="" />
<symbol name="mhpmevent18" address="next" size="8" description="" />
<symbol name="mhpmevent19" address="next" size="8" description="" />
<symbol name="mhpmevent20" address="next" size="8" description="" />
<symbol name="mhpmevent21" address="next" size="8" description="" />
<symbol name="mhpmevent22" address="next" size="8" description="" />
<symbol name="mhpmevent23" address="next" size="8" description="" />
<symbol name="mhpmevent24" address="csreg:0x338" size="8" description="" />
<symbol name="mhpmevent25" address="next" size="8" description="" />
<symbol name="mhpmevent26" address="next" size="8" description="" />
<symbol name="mhpmevent27" address="next" size="8" description="" />
<symbol name="mhpmevent28" address="next" size="8" description="" />
<symbol name="mhpmevent29" address="next" size="8" description="" />
<symbol name="mhpmevent30" address="next" size="8" description="" />
<symbol name="mhpmevent31" address="next" size="8" description="" />
<symbol name="mscratch" address="csreg:0x340" size="8" description="" />
<symbol name="mepc" address="csreg:0x341" size="8" description="" />
<symbol name="mcause" address="csreg:0x342" size="8" description="" />
<symbol name="mtval" address="csreg:0x343" size="8" description="" />
<symbol name="mip" address="csreg:0x344" size="8" description="" />
<symbol name="mtinst" address="csreg:0x34a" size="8" description="" />
<symbol name="mtval2" address="csreg:0x34b" size="8" description="" />
<symbol name="mbase" address="csreg:0x380" size="8" description="" />
<symbol name="mbound" address="csreg:0x381" size="8" description="" />
<symbol name="mibase" address="csreg:0x382" size="8" description="" />
<symbol name="mibound" address="csreg:0x383" size="8" description="" />
<symbol name="mdbase" address="csreg:0x384" size="8" description="" />
<symbol name="mdbound" address="csreg:0x385" size="8" description="" />
<symbol name="pmpcfg0" address="csreg:0x3a0" size="8" description="" />
<symbol name="pmpcfg1" address="next" size="8" description="" />
<symbol name="pmpcfg2" address="next" size="8" description="" />
<symbol name="pmpcfg3" address="next" size="8" description="" />
<symbol name="pmpcfg4" address="next" size="8" description="" />
<symbol name="pmpcfg5" address="next" size="8" description="" />
<symbol name="pmpcfg6" address="next" size="8" description="" />
<symbol name="pmpcfg7" address="next" size="8" description="" />
<symbol name="pmpcfg8" address="csreg:0x3a8" size="8" description="" />
<symbol name="pmpcfg9" address="next" size="8" description="" />
<symbol name="pmpcfg10" address="next" size="8" description="" />
<symbol name="pmpcfg11" address="next" size="8" description="" />
<symbol name="pmpcfg12" address="next" size="8" description="" />
<symbol name="pmpcfg13" address="next" size="8" description="" />
<symbol name="pmpcfg14" address="next" size="8" description="" />
<symbol name="pmpcfg15" address="next" size="8" description="" />
<symbol name="pmpaddr0" address="csreg:0x3b0" size="8" description="" />
<symbol name="pmpaddr1" address="next" size="8" description="" />
<symbol name="pmpaddr2" address="next" size="8" description="" />
<symbol name="pmpaddr3" address="next" size="8" description="" />
<symbol name="pmpaddr4" address="next" size="8" description="" />
<symbol name="pmpaddr5" address="next" size="8" description="" />
<symbol name="pmpaddr6" address="next" size="8" description="" />
<symbol name="pmpaddr7" address="next" size="8" description="" />
<symbol name="pmpaddr8" address="csreg:0x3b8" size="8" description="" />
<symbol name="pmpaddr9" address="next" size="8" description="" />
<symbol name="pmpaddr10" address="next" size="8" description="" />
<symbol name="pmpaddr11" address="next" size="8" description="" />
<symbol name="pmpaddr12" address="next" size="8" description="" />
<symbol name="pmpaddr13" address="next" size="8" description="" />
<symbol name="pmpaddr14" address="next" size="8" description="" />
<symbol name="pmpaddr15" address="next" size="8" description="" />
<symbol name="pmpaddr16" address="csreg:0x3c0" size="8" description="" />
<symbol name="pmpaddr17" address="next" size="8" description="" />
<symbol name="pmpaddr18" address="next" size="8" description="" />
<symbol name="pmpaddr19" address="next" size="8" description="" />
<symbol name="pmpaddr20" address="next" size="8" description="" />
<symbol name="pmpaddr21" address="next" size="8" description="" />
<symbol name="pmpaddr22" address="next" size="8" description="" />
<symbol name="pmpaddr23" address="next" size="8" description="" />
<symbol name="pmpaddr24" address="csreg:0x3c8" size="8" description="" />
<symbol name="pmpaddr25" address="next" size="8" description="" />
<symbol name="pmpaddr26" address="next" size="8" description="" />
<symbol name="pmpaddr27" address="next" size="8" description="" />
<symbol name="pmpaddr28" address="next" size="8" description="" />
<symbol name="pmpaddr29" address="next" size="8" description="" />
<symbol name="pmpaddr30" address="next" size="8" description="" />
<symbol name="pmpaddr31" address="next" size="8" description="" />
<symbol name="pmpaddr32" address="csreg:0x3d0" size="8" description="" />
<symbol name="pmpaddr33" address="next" size="8" description="" />
<symbol name="pmpaddr34" address="next" size="8" description="" />
<symbol name="pmpaddr35" address="next" size="8" description="" />
<symbol name="pmpaddr36" address="next" size="8" description="" />
<symbol name="pmpaddr37" address="next" size="8" description="" />
<symbol name="pmpaddr38" address="next" size="8" description="" />
<symbol name="pmpaddr39" address="next" size="8" description="" />
<symbol name="pmpaddr40" address="csreg:0x3d8" size="8" description="" />
<symbol name="pmpaddr41" address="next" size="8" description="" />
<symbol name="pmpaddr42" address="next" size="8" description="" />
<symbol name="pmpaddr43" address="next" size="8" description="" />
<symbol name="pmpaddr44" address="next" size="8" description="" />
<symbol name="pmpaddr45" address="next" size="8" description="" />
<symbol name="pmpaddr46" address="next" size="8" description="" />
<symbol name="pmpaddr47" address="next" size="8" description="" />
<symbol name="pmpaddr48" address="csreg:0x3e0" size="8" description="" />
<symbol name="pmpaddr49" address="next" size="8" description="" />
<symbol name="pmpaddr50" address="next" size="8" description="" />
<symbol name="pmpaddr51" address="next" size="8" description="" />
<symbol name="pmpaddr52" address="next" size="8" description="" />
<symbol name="pmpaddr53" address="next" size="8" description="" />
<symbol name="pmpaddr54" address="next" size="8" description="" />
<symbol name="pmpaddr55" address="next" size="8" description="" />
<symbol name="pmpaddr56" address="csreg:0x3e8" size="8" description="" />
<symbol name="pmpaddr57" address="next" size="8" description="" />
<symbol name="pmpaddr58" address="next" size="8" description="" />
<symbol name="pmpaddr59" address="next" size="8" description="" />
<symbol name="pmpaddr60" address="next" size="8" description="" />
<symbol name="pmpaddr61" address="next" size="8" description="" />
<symbol name="pmpaddr62" address="next" size="8" description="" />
<symbol name="pmpaddr63" address="next" size="8" description="" />
<symbol name="scontext" address="csreg:0x5a8" size="8" description="" />
<symbol name="hstatus" address="csreg:0x600" size="8" description="" />
<symbol name="hedeleg" address="csreg:0x602" size="8" description="" />
<symbol name="hideleg" address="csreg:0x603" size="8" description="" />
<symbol name="hie" address="csreg:0x604" size="8" description="" />
<symbol name="htimedelta" address="csreg:0x605" size="8" description="" />
<symbol name="hcounteren" address="csreg:0x606" size="8" description="" />
<symbol name="hgeie" address="csreg:0x607" size="8" description="" />
<symbol name="htimedeltah" address="csreg:0x615" size="8" description="" />
<symbol name="htval" address="csreg:0x643" size="8" description="" />
<symbol name="hip" address="csreg:0x644" size="8" description="" />
<symbol name="hvip" address="csreg:0x645" size="8" description="" />
<symbol name="htinst" address="csreg:0x64a" size="8" description="" />
<symbol name="hgatp" address="csreg:0x680" size="8" description="" />
<symbol name="hcontext" address="csreg:0x6a8" size="8" description="" />
<symbol name="tselect" address="csreg:0x7a0" size="8" description="" />
<symbol name="tdata1" address="csreg:0x7a1" size="8" description="" />
<symbol name="tdata2" address="csreg:0x7a2" size="8" description="" />
<symbol name="tdata3" address="csreg:0x7a3" size="8" description="" />
<symbol name="mcontext" address="csreg:0x7a8" size="8" description="" />
<symbol name="dcsr" address="csreg:0x7b0" size="8" description="" />
<symbol name="dpc" address="csreg:0x7b1" size="8" description="" />
<symbol name="dscratch0" address="csreg:0x7b2" size="8" description="" />
<symbol name="dscratch1" address="csreg:0x7b3" size="8" description="" />
<symbol name="mcycle" address="csreg:0xa00" size="8" description="" />
<symbol name="minstret" address="csreg:0xa02" size="8" description="" />
<symbol name="mhpmcounter3" address="csreg:0xa03" size="8" description="" />
<symbol name="mhpmcounter4" address="next" size="8" description="" />
<symbol name="mhpmcounter5" address="next" size="8" description="" />
<symbol name="mhpmcounter6" address="next" size="8" description="" />
<symbol name="mhpmcounter7" address="next" size="8" description="" />
<symbol name="mhpmcounter8" address="csreg:0xa08" size="8" description="" />
<symbol name="mhpmcounter9" address="next" size="8" description="" />
<symbol name="mhpmcounter10" address="next" size="8" description="" />
<symbol name="mhpmcounter11" address="next" size="8" description="" />
<symbol name="mhpmcounter12" address="next" size="8" description="" />
<symbol name="mhpmcounter13" address="next" size="8" description="" />
<symbol name="mhpmcounter14" address="next" size="8" description="" />
<symbol name="mhpmcounter15" address="next" size="8" description="" />
<symbol name="mhpmcounter16" address="csreg:0xa10" size="8" description="" />
<symbol name="mhpmcounter17" address="next" size="8" description="" />
<symbol name="mhpmcounter18" address="next" size="8" description="" />
<symbol name="mhpmcounter19" address="next" size="8" description="" />
<symbol name="mhpmcounter20" address="next" size="8" description="" />
<symbol name="mhpmcounter21" address="next" size="8" description="" />
<symbol name="mhpmcounter22" address="next" size="8" description="" />
<symbol name="mhpmcounter23" address="next" size="8" description="" />
<symbol name="mhpmcounter24" address="csreg:0xa18" size="8" description="" />
<symbol name="mhpmcounter25" address="next" size="8" description="" />
<symbol name="mhpmcounter26" address="next" size="8" description="" />
<symbol name="mhpmcounter27" address="next" size="8" description="" />
<symbol name="mhpmcounter28" address="next" size="8" description="" />
<symbol name="mhpmcounter29" address="next" size="8" description="" />
<symbol name="mhpmcounter30" address="next" size="8" description="" />
<symbol name="mhpmcounter31" address="next" size="8" description="" />
<symbol name="mcycleh" address="csreg:0xb80" size="8" description="" />
<symbol name="minstreth" address="next" size="8" description="" />
<symbol name="mhpmcounter3h" address="next" size="8" description="" />
<symbol name="mhpmcounter4h" address="next" size="8" description="" />
<symbol name="mhpmcounter5h" address="next" size="8" description="" />
<symbol name="mhpmcounter6h" address="next" size="8" description="" />
<symbol name="mhpmcounter7h" address="next" size="8" description="" />
<symbol name="mhpmcounter8h" address="csreg:0xb88" size="8" description="" />
<symbol name="mhpmcounter9h" address="next" size="8" description="" />
<symbol name="mhpmcounter10h" address="next" size="8" description="" />
<symbol name="mhpmcounter11h" address="next" size="8" description="" />
<symbol name="mhpmcounter12h" address="next" size="8" description="" />
<symbol name="mhpmcounter13h" address="next" size="8" description="" />
<symbol name="mhpmcounter14h" address="next" size="8" description="" />
<symbol name="mhpmcounter15h" address="next" size="8" description="" />
<symbol name="mhpmcounter16h" address="csreg:0xb90" size="8" description="" />
<symbol name="mhpmcounter17h" address="next" size="8" description="" />
<symbol name="mhpmcounter18h" address="next" size="8" description="" />
<symbol name="mhpmcounter19h" address="next" size="8" description="" />
<symbol name="mhpmcounter20h" address="next" size="8" description="" />
<symbol name="mhpmcounter21h" address="next" size="8" description="" />
<symbol name="mhpmcounter22h" address="next" size="8" description="" />
<symbol name="mhpmcounter23h" address="next" size="8" description="" />
<symbol name="mhpmcounter24h" address="csreg:0xb98" size="8" description="" />
<symbol name="mhpmcounter25h" address="next" size="8" description="" />
<symbol name="mhpmcounter26h" address="next" size="8" description="" />
<symbol name="mhpmcounter27h" address="next" size="8" description="" />
<symbol name="mhpmcounter28h" address="next" size="8" description="" />
<symbol name="mhpmcounter29h" address="next" size="8" description="" />
<symbol name="mhpmcounter30h" address="next" size="8" description="" />
<symbol name="mhpmcounter31h" address="next" size="8" description="" />
<symbol name="cycle" address="csreg:0xc00" size="8" description="" />
<symbol name="time" address="next" size="8" description="" />
<symbol name="instret" address="next" size="8" description="" />
<symbol name="hpmcounter3" address="next" size="8" description="" />
<symbol name="hpmcounter4" address="next" size="8" description="" />
<symbol name="hpmcounter5" address="next" size="8" description="" />
<symbol name="hpmcounter6" address="next" size="8" description="" />
<symbol name="hpmcounter7" address="next" size="8" description="" />
<symbol name="hpmcounter8" address="csreg:0xc08" size="8" description="" />
<symbol name="hpmcounter9" address="next" size="8" description="" />
<symbol name="hpmcounter10" address="next" size="8" description="" />
<symbol name="hpmcounter11" address="next" size="8" description="" />
<symbol name="hpmcounter12" address="next" size="8" description="" />
<symbol name="hpmcounter13" address="next" size="8" description="" />
<symbol name="hpmcounter14" address="next" size="8" description="" />
<symbol name="hpmcounter15" address="next" size="8" description="" />
<symbol name="hpmcounter16" address="csreg:0xc10" size="8" description="" />
<symbol name="hpmcounter17" address="next" size="8" description="" />
<symbol name="hpmcounter18" address="next" size="8" description="" />
<symbol name="hpmcounter19" address="next" size="8" description="" />
<symbol name="hpmcounter20" address="next" size="8" description="" />
<symbol name="hpmcounter21" address="next" size="8" description="" />
<symbol name="hpmcounter22" address="next" size="8" description="" />
<symbol name="hpmcounter23" address="next" size="8" description="" />
<symbol name="hpmcounter24" address="csreg:0xc18" size="8" description="" />
<symbol name="hpmcounter25" address="next" size="8" description="" />
<symbol name="hpmcounter26" address="next" size="8" description="" />
<symbol name="hpmcounter27" address="next" size="8" description="" />
<symbol name="hpmcounter28" address="next" size="8" description="" />
<symbol name="hpmcounter29" address="next" size="8" description="" />
<symbol name="hpmcounter30" address="next" size="8" description="" />
<symbol name="hpmcounter31" address="next" size="8" description="" />
<symbol name="vl" address="csreg:0xc20" size="8" description="" />
<symbol name="vtype" address="next" size="8" description="" />
<symbol name="vlenb" address="next" size="8" description="" />
<symbol name="cycleh" address="csreg:0xc80" size="8" description="" />
<symbol name="timeh" address="next" size="8" description="" />
<symbol name="instreth" address="next" size="8" description="" />
<symbol name="hpmcounter3h" address="next" size="8" description="" />
<symbol name="hpmcounter4h" address="next" size="8" description="" />
<symbol name="hpmcounter5h" address="next" size="8" description="" />
<symbol name="hpmcounter6h" address="next" size="8" description="" />
<symbol name="hpmcounter7h" address="next" size="8" description="" />
<symbol name="hpmcounter8h" address="csreg:0xc88" size="8" description="" />
<symbol name="hpmcounter9h" address="next" size="8" description="" />
<symbol name="hpmcounter10h" address="next" size="8" description="" />
<symbol name="hpmcounter11h" address="next" size="8" description="" />
<symbol name="hpmcounter12h" address="next" size="8" description="" />
<symbol name="hpmcounter13h" address="next" size="8" description="" />
<symbol name="hpmcounter14h" address="next" size="8" description="" />
<symbol name="hpmcounter15h" address="next" size="8" description="" />
<symbol name="hpmcounter16h" address="csreg:0xc90" size="8" description="" />
<symbol name="hpmcounter17h" address="next" size="8" description="" />
<symbol name="hpmcounter18h" address="next" size="8" description="" />
<symbol name="hpmcounter19h" address="next" size="8" description="" />
<symbol name="hpmcounter20h" address="next" size="8" description="" />
<symbol name="hpmcounter21h" address="next" size="8" description="" />
<symbol name="hpmcounter22h" address="next" size="8" description="" />
<symbol name="hpmcounter23h" address="next" size="8" description="" />
<symbol name="hpmcounter24h" address="csreg:0xc98" size="8" description="" />
<symbol name="hpmcounter25h" address="next" size="8" description="" />
<symbol name="hpmcounter26h" address="next" size="8" description="" />
<symbol name="hpmcounter27h" address="next" size="8" description="" />
<symbol name="hpmcounter28h" address="next" size="8" description="" />
<symbol name="hpmcounter29h" address="next" size="8" description="" />
<symbol name="hpmcounter30h" address="next" size="8" description="" />
<symbol name="hpmcounter31h" address="next" size="8" description="" />
<symbol name="hgeip" address="csreg:0xe12" size="8" description="" />
<symbol name="mvendorid" address="csreg:0xf11" size="8" description="" />
<symbol name="marchid" address="csreg:0xf12" size="8" description="" />
<symbol name="mimpid" address="csreg:0xf13" size="8" description="" />
<symbol name="mhartid" address="csreg:0xf14" size="8" description="" />
</default_symbols>
</processor_spec>

View File

@@ -1,19 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<processor_spec>
<programcounter register="pc"/>
<context_data>
<context_set space="ram">
<set name="MXL" val="2"/>
<set name="RVA" val="1"/>
<set name="RVD" val="1"/>
<set name="RVF" val="1"/>
<set name="RVH" val="1"/>
<set name="RVI" val="1"/>
<set name="RVM" val="1"/>
<set name="RVQ" val="1"/>
<set name="RVS" val="1"/>
<set name="RVU" val="1"/>
</context_set>
</context_data>
</processor_spec>

View File

@@ -1,20 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<processor_spec>
<programcounter register="pc"/>
<context_data>
<context_set space="ram">
<set name="MXL" val="2"/>
<set name="RVA" val="1"/>
<set name="RVC" val="1"/>
<set name="RVD" val="1"/>
<set name="RVF" val="1"/>
<set name="RVH" val="1"/>
<set name="RVI" val="1"/>
<set name="RVM" val="1"/>
<set name="RVQ" val="1"/>
<set name="RVS" val="1"/>
<set name="RVU" val="1"/>
</context_set>
</context_data>
</processor_spec>

View File

@@ -1,14 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<processor_spec>
<programcounter register="pc"/>
<context_data>
<context_set space="ram">
<set name="MXL" val="2"/>
<set name="RVH" val="1"/>
<set name="RVI" val="1"/>
<set name="RVS" val="1"/>
<set name="RVU" val="1"/>
</context_set>
</context_data>
</processor_spec>

View File

@@ -1,15 +0,0 @@
<?xml version="1.0" encoding="UTF-8"?>
<processor_spec>
<programcounter register="pc"/>
<context_data>
<context_set space="ram">
<set name="MXL" val="2"/>
<set name="RVC" val="1"/>
<set name="RVH" val="1"/>
<set name="RVI" val="1"/>
<set name="RVS" val="1"/>
<set name="RVU" val="1"/>
</context_set>
</context_data>
</processor_spec>

View File

@@ -0,0 +1,607 @@
#
# AndeStar V5 extensions to base RISC-V architecture
#
#
# ExecTable is loaded/overlayed on the memory segment
# That is indexed by the E
define space ExecTable type=ram_space size=2;
@define CUSTOM0 "op0006=0b0001011"
@define CUSTOM1 "op0006=0b0101011"
@define CUSTOM2 "op0006=0b1011011"
@define CUSTOM4 "op0006=0b1010111"
simm18_lb: val is sop3131 & op1516 & op1719 & op2020 & op2130 & op1414 [ val = (sop3131<<17) | (op1516<<15) | (op1719<<12) | (op2020<<11) | (op2130<<1) | op1414; ] {
export *[const]:$(XLEN) val;
}
simm18_lh: val is sop3131 & op1516 & op1719 & op2020 & op2130 [ val = (sop3131<<17) | (op1516<<15) | (op1719<<12) | (op2020<<11) | (op2130<<1); ] {
export *[const]:$(XLEN) val;
}
simm18_lw: val is sop3131 & op1516 & op1719 & op2020 & op2130 [ val = (sop3131<<18) | (op1516<<16) | (op1719<<13) | (op2020<<12) | (op2130<<2); ] {
export *[const]:$(XLEN) val;
}
simm18_ld: val is sop3131 & op1516 & op1719 & op2020 & op2122 & op2330 [ val = (sop3131<<19) | (op2122<<17) | (op1516<<15) | (op1719<<12) | (op2330<<3); ] {
export *[const]:$(XLEN) val;
}
simm18_sb: val is sop3131 & op1516 & op1719 & op0707 & op2530 & op0811 & op1414 [ val = (sop3131<<17) | (op1516<<15) | (op1719<<12) | (op0707<<11) | (op2530<<5) | (op0811<<1) | op1414; ] {
export *[const]:$(XLEN) val;
}
simm18_sh: val is sop3131 & op1516 & op1719 & op0707 & op2530 & op0811 [ val = (sop3131<<17) | (op1516<<15) | (op1719<<12) | (op0707<<11) | (op2530<<5) | (op0811<<1); ] {
export *[const]:$(XLEN) val;
}
simm18_sw: val is sop3131 & op1516 & op1719 & op0707 & op2530 & op0808 & op0911 [ val = (sop3131<<18) | (op0808<<17) | (op1516<<15) | (op1719<<12) | (op0707<<11) | (op2530<<5) | (op0911<<2); ] {
export *[const]:$(XLEN) val;
}
simm18_sd: val is sop3131 & op1516 & op1719 & op0707 & op2530 & op0809 & op1011 [ val = (sop3131<<19) | (op0809<<17) | (op1516<<15) | (op1719<<12) | (op0707<<11) | (op2530<<5) | (op1011<<3); ] {
export *[const]:$(XLEN) val;
}
cimm: "#"^val is op2024 & op0707 [ val = op0707<<5 | op2024; ] {
# Note on 32-bit op0707 must be 0
export *[const]:$(XLEN) val;
}
cimm7: "#"^val is op3030 & op2024 & op0707 [ val = op3030<<6 | op0707<<5 | op2024; ] {
export *[const]:$(XLEN) val;
}
ra_imm10: dest is sop3131 & op2529 & op0811 [ dest = inst_start + (sop3131 << 10 | op2529<<5 | op0811<<1); ] {
export *[ram]:$(XLEN) dest;
}
:addigp rd,simm18_lb is simm18_lb & rd & op1213=1 & $(CUSTOM0)
{
rd = gp + simm18_lb;
}
:bbc rs1,cimm,ra_imm10 is rs1 & cimm & ra_imm10 & op3030=0 & op1214=0b111 & op0707=0 & $(CUSTOM2)
{
tst:1 = (rs1 & (1 << cimm)) == 0;
if (tst) goto ra_imm10;
}
:bbs rs1,cimm,ra_imm10 is rs1 & cimm & ra_imm10 & op3030=1 & op1214=0b111 & op0707=0 & $(CUSTOM2)
{
tst:1 = (rs1 & (1 << cimm)) == 1;
if (tst) goto ra_imm10;
}
:beqc rs1,cimm7,ra_imm10 is rs1 & cimm7 & ra_imm10 & op1214=0b101 & $(CUSTOM2)
{
tst:1 = rs1 == cimm7;
if (tst) goto ra_imm10;
}
:bnec rs1,cimm7,ra_imm10 is rs1 & cimm7 & ra_imm10 & op1214=0b110 & $(CUSTOM2)
{
tst:1 = rs1 != cimm7;
if (tst) goto ra_imm10;
}
msb: "#"^op2631 is op2631 { export *[const]:$(XLEN) op2631; }
lsb: "#"^op2025 is op2025 { export *[const]:$(XLEN) op2025; }
:bfos rd,rs1,msb,lsb is rd & rs1 & op2631=0 & msb & lsb & op1214=0b011 & $(CUSTOM2)
{
# msb==0 Rd[LSB] = sext(Rs1[0])
shift:$(XLEN) = ($(XLEN)*8-1);
val:$(XLEN) = (rs1 & 1 << shift) s>> (shift);
val = val << lsb;
rd = val;
}
:bfos rd,rs1,msb,lsb is rd & rs1 & msb & lsb & (op2025 > op2631) & (op2631 != 0) & op1214=0b011 & $(CUSTOM2)
{
# msb < lsb Rd[LSB:MSB] = sext(Rs1[len-1:0])
len:$(XLEN) = lsb-msb+1;
shift:$(XLEN) = ($(XLEN)*8 - len);
val:$(XLEN) = (rs1 << shift) s>> shift;
val = val << msb;
rd = val;
}
:bfos rd,rs1,msb,lsb is rd & rs1 & msb & lsb & (op2025 <= op2631) & (op2631 != 0) & op1214=0b011 & $(CUSTOM2)
{
# msb >= lsb Rd[len-1:0] = sext(Rs1[MSB:LSB])
len:$(XLEN) = msb-lsb+1;
shift:$(XLEN) = ($(XLEN)*8 - msb - 1);
val:$(XLEN) = (rs1 << shift) s>> ($(XLEN)*8 - len);
rd = val;
}
:bfoz rd,rs1,msb,lsb is rd & rs1 & op2631=0 & msb & lsb & op1214=0b010 & $(CUSTOM2)
{
# msb==0 Rd[LSB] = zext(Rs1[0])
val:$(XLEN) = rs1 & 1;
val = val << lsb;
rd = val;
}
:bfoz rd,rs1,msb,lsb is rd & rs1 & msb & lsb & (op2025 > op2631) & (op2631 != 0) & op1214=0b010 & $(CUSTOM2)
{
# msb < lsb Rd[LSB:MSB] = zext(Rs1[len-1:0])
len:$(XLEN) = lsb-msb+1;
mask:$(XLEN) = ((-1) >> ($(XLEN)*8 -len));
val:$(XLEN) = rs1 & mask;
val = val << msb;
rd = val;
}
:bfoz rd,rs1,msb,lsb is rd & rs1 & msb & lsb & (op2025 <= op2631) & op1214=0b010 & $(CUSTOM2)
{
# msb >= lsb Rd[len-1:0] = zext(Rs1[MSB:LSB])
len:$(XLEN) = msb-lsb+1;
mask:$(XLEN) = ((-1) >> ($(XLEN)*8 -len)) << lsb;
val:$(XLEN) = rs1 & mask;
val = val >> lsb;
rd = val;
}
:lea.h rd,rs1,rs2 is op2531=0b0000101 & rs2 & rs1 & op1214=0 & rd & $(CUSTOM2)
{
local ea:$(XLEN) = rs1 + rs2 * 2;
rd = ea;
}
:lea.w rd,rs1,rs2 is op2531=0b0000110 & rs2 & rs1 & op1214=0 & rd & $(CUSTOM2)
{
local ea:$(XLEN) = rs1 + rs2 * 4;
rd = ea;
}
:lea.d rd,rs1,rs2 is op2531=0b0000111 & rs2 & rs1 & op1214=0 & rd & $(CUSTOM2)
{
local ea:$(XLEN) = rs1 + rs2 * 8;
rd = ea;
}
:lea.b.ze rd,rs1,rs2 is op2531=0b0001000 & rs2 & rs1 & op1214=0 & rd & $(CUSTOM2)
{
local ea:$(XLEN) = rs1 + zext(rs2:4);
rd = ea;
}
:lea.h.ze rd,rs1,rs2 is op2531=0b0001001 & rs2 & rs1 & op1214=0 & rd & $(CUSTOM2)
{
local ea:$(XLEN) = rs1 + zext(rs2:4) * 2;
rd = ea;
}
:lea.w.ze rd,rs1,rs2 is op2531=0b0001010 & rs2 & rs1 & op1214=0 & rd & $(CUSTOM2)
{
local ea:$(XLEN) = rs1 + zext(rs2:4) * 4;
rd = ea;
}
:lea.d.ze rd,rs1,rs2 is op2531=0b0001011 & rs2 & rs1 & op1214=0 & rd & $(CUSTOM2)
{
local ea:$(XLEN) = rs1 + zext(rs2:4) * 8;
rd = ea;
}
:lbgp rd,"["^simm18_lb^"]" is simm18_lb & rd & op1213=0 & $(CUSTOM0)
{
local ea:$(XLEN) = gp + simm18_lb;
rd = sext(*[ram]:1 ea);
}
:lbugp rd,"["^simm18_lb^"]" is simm18_lb & rd & op1213=2 & $(CUSTOM0)
{
local ea:$(XLEN) = gp + simm18_lb;
rd = zext(*[ram]:1 ea);
}
:lhgp rd,"["^simm18_lh^"]" is simm18_lh & rd & op1214=1 & $(CUSTOM1)
{
local ea:$(XLEN) = gp + simm18_lh;
rd = sext(*[ram]:2 ea);
}
:lhugp rd,"["^simm18_lh^"]" is simm18_lh & rd & op1214=5 & $(CUSTOM1)
{
local ea:$(XLEN) = gp + simm18_lh;
rd = zext(*[ram]:2 ea);
}
:lwgp rd,"["^simm18_lw^"]" is simm18_lw & rd & op1214=2 & $(CUSTOM1)
{
local ea:$(XLEN) = gp + simm18_lw;
rd = sext(*[ram]:4 ea);
}
:lwugp rd,"["^simm18_lw^"]" is simm18_lw & rd & op1214=6 & $(CUSTOM1)
{
local ea:$(XLEN) = gp + simm18_lw;
rd = zext(*[ram]:4 ea);
}
:ldgp rd,"["^simm18_ld^"]" is simm18_ld & rd & op1214=3 & $(CUSTOM1)
{
local ea:$(XLEN) = gp + simm18_ld;
rd = *[ram]:8 ea;
}
:sbgp rs2,"["^simm18_sb^"]" is simm18_sb & rs2 & op1213=3 & $(CUSTOM0)
{
local ea:$(XLEN) = gp + simm18_sb;
*[ram]:1 ea = rs2[0,8];
}
:shgp rs2,"["^simm18_sh^"]" is simm18_sh & rs2 & op1214=0 & $(CUSTOM1)
{
local ea:$(XLEN) = gp + simm18_sh;
*[ram]:2 ea = rs2[0,16];
}
:swgp rs2,"["^simm18_sw^"]" is simm18_sw & rs2 & op1214=4 & $(CUSTOM1)
{
local ea:$(XLEN) = gp + simm18_sw;
*[ram]:4 ea = rs2[0,32];
}
:sdgp rs2,"["^simm18_sd^"]" is simm18_sd & rs2 & op1214=7 & $(CUSTOM1)
{
local ea:$(XLEN) = gp + simm18_sd;
*[ram]:8 ea = rs2;
}
:ffb rd,rs1,rs2 is rd & rs1 & rs2 & op2531=0b0010000 & op1214=0 & $(CUSTOM2) {
@if XLEN == "4"
m1:1 = (rs1[0,8] == rs2[0,8]);
m2:1 = (rs1[8,8] == rs2[0,8]);
m3:1 = (rs1[16,8] == rs2[0,8]);
m4:1 = (rs1[24,8] == rs2[0,8]);
rd = -4;
if (m1) goto inst_next;
rd = -3;
if (m2) goto inst_next;
rd = -2;
if (m3) goto inst_next;
rd = -1;
if (m4) goto inst_next;
rd = 0;
# choosery method
# rd = 0 + (zext(m1)*-4) + (zext(m2)*-3) + (zext(m3)*-2) + (zext(m4)*-1);
@else
m1:1 = (rs1[0,8] == rs2[0,8]);
m2:1 = (rs1[8,8] == rs2[0,8]);
m3:1 = (rs1[16,8] == rs2[0,8]);
m4:1 = (rs1[24,8] == rs2[0,8]);
m5:1 = (rs1[32,8] == rs2[0,8]);
m6:1 = (rs1[40,8] == rs2[0,8]);
m7:1 = (rs1[48,8] == rs2[0,8]);
m8:1 = (rs1[56,8] == rs2[0,8]);
rd = -8;
if (m1) goto inst_next;
rd = -7;
if (m2) goto inst_next;
rd = -6;
if (m3) goto inst_next;
rd = -5;
if (m4) goto inst_next;
rd = -4;
if (m5) goto inst_next;
rd = -3;
if (m6) goto inst_next;
rd = -2;
if (m7) goto inst_next;
rd = -1;
if (m8) goto inst_next;
rd = 0;
# choosery method
# rd = 0 + (zext(m1)*-8) + (zext(m2)*-7) + (zext(m3)*-6) + (zext(m4)*-5) + (zext(m5)*-4) + (zext(m6)*-3) + (zext(m7)*-2) + (zext(m8)*-1);
@endif
}
:ffzmism rd,rs1,rs2 is rd & rs1 & rs2 & op2531=0b0010001 & op1214=0 & $(CUSTOM2) {
@if XLEN == "4"
m1:1 = (rs1[0,8]==0) | (rs1[0,8] == rs2[0,8]);
m2:1 = (rs1[8,8]==0) | (rs1[8,8] == rs2[8,8]);
m3:1 = (rs1[16,8]==0) | (rs1[16,8] == rs2[16,8]);
m4:1 = (rs1[24,8]==0) | (rs1[24,8] == rs2[24,8]);
rd = -4;
if (m1) goto inst_next;
rd = -3;
if (m2) goto inst_next;
rd = -2;
if (m3) goto inst_next;
rd = -1;
if (m4) goto inst_next;
rd = 0;
# choosery method
# rd = 0 + (zext(m1)*-4) + (zext(m2)*-3) + (zext(m3)*-2) + (zext(m4)*-1);
@else
m1:1 = (rs1[0,8]==0) | (rs1[0,8] == rs2[0,8]);
m2:1 = (rs1[8,8]==0) | (rs1[8,8] == rs2[8,8]);
m3:1 = (rs1[16,8]==0) | (rs1[16,8] == rs2[16,8]);
m4:1 = (rs1[24,8]==0) | (rs1[24,8] == rs2[24,8]);
m5:1 = (rs1[32,8]==0) | (rs1[32,8] == rs2[32,8]);
m6:1 = (rs1[40,8]==0) | (rs1[40,8] == rs2[40,8]);
m7:1 = (rs1[48,8]==0) | (rs1[48,8] == rs2[48,8]);
m8:1 = (rs1[56,8]==0) | (rs1[56,8] == rs2[56,8]);
rd = -8;
if (m1) goto inst_next;
rd = -7;
if (m2) goto inst_next;
rd = -6;
if (m3) goto inst_next;
rd = -5;
if (m4) goto inst_next;
rd = -4;
if (m5) goto inst_next;
rd = -3;
if (m6) goto inst_next;
rd = -2;
if (m7) goto inst_next;
rd = -1;
if (m8) goto inst_next;
rd = 0;
# choosery method
# rd = 0 + (zext(m1)*-8) + (zext(m2)*-7) + (zext(m3)*-6) + (zext(m4)*-5) + (zext(m5)*-4) + (zext(m6)*-3) + (zext(m7)*-2) + (zext(m8)*-1);
@endif
}
:ffmism rd,rs1,rs2 is rd & rs1 & rs2 & op2531=0b0010010 & op1214=0 & $(CUSTOM2) {
@if XLEN == "4"
m1:1 = (rs1[0,8] != rs2[0,8]);
m2:1 = (rs1[8,8] != rs2[8,8]);
m3:1 = (rs1[16,8] != rs2[16,8]);
m4:1 = (rs1[24,8] != rs2[24,8]);
rd = -4;
if (m1) goto inst_next;
rd = -3;
if (m2) goto inst_next;
rd = -2;
if (m3) goto inst_next;
rd = -1;
if (m4) goto inst_next;
rd = 0;
# choosery method
# rd = 0 + (zext(m1)*-4) + (zext(m2)*-3) + (zext(m3)*-2) + (zext(m4)*-1);
@else
m1:1 = (rs1[0,8] != rs2[0,8]);
m2:1 = (rs1[8,8] != rs2[8,8]);
m3:1 = (rs1[16,8] != rs2[16,8]);
m4:1 = (rs1[24,8] != rs2[24,8]);
m5:1 = (rs1[32,8] != rs2[32,8]);
m6:1 = (rs1[40,8] != rs2[40,8]);
m7:1 = (rs1[48,8] != rs2[48,8]);
m8:1 = (rs1[56,8] != rs2[56,8]);
rd = -8;
if (m1) goto inst_next;
rd = -7;
if (m2) goto inst_next;
rd = -6;
if (m3) goto inst_next;
rd = -5;
if (m4) goto inst_next;
rd = -4;
if (m5) goto inst_next;
rd = -3;
if (m6) goto inst_next;
rd = -2;
if (m7) goto inst_next;
rd = -1;
if (m8) goto inst_next;
rd = 0;
# choosery method
# rd = 0 + (zext(m1)*-8) + (zext(m2)*-7) + (zext(m3)*-6) + (zext(m4)*-5) + (zext(m5)*-4) + (zext(m6)*-3) + (zext(m7)*-2) + (zext(m8)*-1);
@endif
}
:flmism rd,rs1,rs2 is rd & rs1 & rs2 & op2531=0b0010011 & op1214=0 & $(CUSTOM2) {
@if XLEN == "4"
m1:1 = (rs1[0,8] != rs2[0,8]);
m2:1 = (rs1[8,8] != rs2[8,8]);
m3:1 = (rs1[16,8] != rs2[16,8]);
m4:1 = (rs1[24,8] != rs2[24,8]);
rd = -1;
if (m4) goto inst_next;
rd = -2;
if (m3) goto inst_next;
rd = -3;
if (m2) goto inst_next;
rd = -4;
if (m1) goto inst_next;
rd = 0;
# choosery method
# rd = 0 + (zext(m1)*-4) + (zext(m2)*-3) + (zext(m3)*-2) + (zext(m4)*-1);
@else
m1:1 = (rs1[0,8] != rs2[0,8]);
m2:1 = (rs1[8,8] != rs2[8,8]);
m3:1 = (rs1[16,8] != rs2[16,8]);
m4:1 = (rs1[24,8] != rs2[24,8]);
m5:1 = (rs1[32,8] != rs2[32,8]);
m6:1 = (rs1[40,8] != rs2[40,8]);
m7:1 = (rs1[48,8] != rs2[48,8]);
m8:1 = (rs1[56,8] != rs2[56,8]);
rd = -1;
if (m8) goto inst_next;
rd = -2;
if (m7) goto inst_next;
rd = -3;
if (m6) goto inst_next;
rd = -4;
if (m5) goto inst_next;
rd = -5;
if (m4) goto inst_next;
rd = -6;
if (m3) goto inst_next;
rd = -7;
if (m2) goto inst_next;
rd = -8;
if (m1) goto inst_next;
rd = 0;
# choosery method
# rd = 0 + (zext(m1)*-8) + (zext(m2)*-7) + (zext(m3)*-6) + (zext(m4)*-5) + (zext(m5)*-4) + (zext(m6)*-3) + (zext(m7)*-2) + (zext(m8)*-1);
@endif
}
imm11_exec: val is cop1212 & cop1011 & cop0909 & cop0808 & cop0506 & cop0404 & cop0303 & cop0202
[ val = (cop0808<<11)|(cop1212<<10)|(cop0303<<9)|(cop0909<<8)|(cop0506<<6)|(cop0202<<5)|(cop1011<<3)|(cop0404<<2); ] {
export *[ExecTable]:2 val;
}
#
# Code Dense (CoDense) extension
#100 imm[10|4:3|8] imm[11] 0 imm[7:6|2|9|5] 00
:exec.it imm11_exec is ecdv=0 & cop1315=4 & imm11_exec & cop0707=0 & cop0001=0 {
ExecRetAddr = inst_next;
goto imm11_exec;
}
:ex9.it imm11_exec is ecdv=0 & cop1315=4 & imm11_exec & cop0708=0 & cop0001=0 {
ExecRetAddr = inst_next;
goto imm11_exec;
}
#
# alternate version of EXEC.IT when mmsc_cfb.ECDV=1
#
imm11_nexec: val is cop1011 & cop0909 & cop0808 & cop0707 & cop0506 & cop0404 & cop0303 & cop0202
[ val = (cop0808<<11)|(cop0707<<10)|(cop0303<<9)|(cop0909<<8)|(cop0506<<6)|(cop0202<<5)|(cop1011<<3)|(cop0404<<2); ] {
export *[ExecTable]:2 val;
}
# 100 1 imm[4:3|8] imm[11] imm[10] imm[7:6|2|9|5] 00
:nexec.it imm11_nexec is ecdv=1 & cop1315=4 & cop1212=1 & imm11_nexec & cop0001=0 {
ExecRetAddr = inst_next;
goto imm11_nexec;
}
#
# INT4 vector load extension
#
define pcodeop vln8;
:vln8.v vd,(rs1)^vm is vd & rs1 & op2631=0b000001 & vm & op2024=0b00010 & op1214=0b100 & $(CUSTOM2) {
# TODO load 32 4bit values, possibly sext by vm into 32 8-bit vector registers
val:$(VLEN) = *[ram]:$(VLEN) rs1;
vd = vln8(val);
build vm;
}
:vlnu8.v vd,(rs1)^vm is vd & rs1 & op2631=0b000001 & vm & op2024=0b00011 & op1214=0b100 & $(CUSTOM2) {
# TODO load 32 4bit values, possibly zext by vm into 32 8-bit vector registers
val:$(VLEN) = *[ram]:$(VLEN) rs1;
vd = vln8(val);
build vm;
}
#
# bfloat16 conversion extension
#
define pcodeop fcvt.s.bf16;
:fcvt.s.bf16 frd,frs2 is frd & frs2 & op2531=0 & op1519=0b00010 & op1214=0b100 & $(CUSTOM2) {
frd = fcvt.s.bf16(frs2);
}
define pcodeop fcvt.bf16.s;
:fcvt.bf16.s frd,frs2 is frd & frs2 & op2531=0 & op1519=0b00011 & op1214=0b100 & $(CUSTOM2) {
frd = fcvt.bf16.s(frs2);
}
#
# Vector BFloat16 conversion extension
#
define pcodeop vfwcvt.s.bf16;
:vfwcvt.s.bf16 vd,vs2 is vd & vs2 & op2631=0b000000 & op1519=0b00000 & op1214=0b100 & $(CUSTOM2) {
vd = vfwcvt.s.bf16(vs2);
}
define pcodeop vfncvt.bf16.s;
:vfncvt.bf16.s vd,vs2 is vd & vs2 & op2631=0b000000 & op1519=0b00001 & op1214=0b100 & $(CUSTOM2) {
vd = vfncvt.bf16.s(vs2);
}
define pcodeop vfpmadt.vf;
:vfpmadt.vf vd,rs1,vs2^vm is vd & rs1 & vs2 & vm & op2631=0b000010 & op1214=0b100 & $(CUSTOM2) {
vd = vfpmadt.vf(rs1,vs2);
build vm;
}
define pcodeop vfpmadb.vf;
:vfpmadb.vf vd,rs1,vs2^vm is vd & rs1 & vs2 & vm & op2631=0b000011 & op1214=0b100 & $(CUSTOM2) {
vd = vfpmadb.vf(rs1,vs2);
build vm;
}
define pcodeop vd4dots.vv;
:vd4dots.vv vd,vs1,vs2^vm is vd & vs1 & vs2 & vm & op2631=0b000100 & op1214=0b100 & $(CUSTOM2) {
vd = vd4dots.vv(vs1,vs2);
build vm;
}
define pcodeop vd4dotu.vv;
:vd4dotu.vv vd,vs1,vs2^vm is vd & vs1 & vs2 & vm & op2631=0b000111 & op1214=0b100 & $(CUSTOM2) {
vd = vd4dotu.vv(vs1,vs2);
build vm;
}
define pcodeop vd4dotsu.vv;
:vd4dotsu.vv vd,vs1,vs2^vm is vd & vs1 & vs2 & vm & op2631=0b000101 & op1214=0b100 & $(CUSTOM2) {
vd = vd4dotsu.vv(vs1,vs2);
build vm;
}
define pcodeop vle4.v;
:vle4.v vd,(rs1) is vd & rs1 & op2631=0b000001 & op2525=1 & op2024=0b00000 & op1214=0b100 & $(CUSTOM2) {
val:$(VLEN) = *[ram]:$(VLEN) rs1;
vd = vle4.v(val);
}
define pcodeop vfwcvt.f.n.v;
:vfwcvt.f.n.v vd,vs2^vm is vd & vs2 & op2631=0b000000 & vm & op1519=0b00100 & op1214=0b100 & $(CUSTOM2) {
vd = vfwcvt.f.n.v(vs2);
build vm;
}
define pcodeop vfwcvt.f.nu.v;
:vfwcvt.f.nu.v vd,vs2^vm is vd & vs2 & op2631=0b000000 & vm & op1519=0b00101 & op1214=0b100 & $(CUSTOM2) {
vd = vfwcvt.f.nu.v(vs2);
build vm;
}
define pcodeop vfwcvt.f.b.v;
:vfwcvt.f.b.v vd,vs2^vm is vd & vs2 & op2631=0b000000 & vm & op1519=0b00110 & op1214=0b100 & $(CUSTOM2) {
vd = vfwcvt.f.b.v(vs2);
build vm;
}
define pcodeop vfwcvt.f.bu.v;
:vfwcvt.f.bu.v vd,vs2^vm is vd & vs2 & op2631=0b000000 & vm & op1519=0b00111 & op1214=0b100 & $(CUSTOM2) {
vd = vfwcvt.f.bu.v(vs2);
build vm;
}

View File

@@ -0,0 +1,20 @@
<?xml version="1.0" encoding="UTF-8"?>
<language_definitions>
<language processor="RISCV"
endian="little"
size="32"
variant="AndeStar_v5"
version="1.4"
slafile="andestar_v5.sla"
processorspec="RV32.pspec"
id="RISCV:LE:32:AndeStar_v5">
<description>AndeStar v5 RISC-V based 32 little default</description>
<compiler name="gcc" spec="riscv32-fp.cspec" id="gcc"/>
<external_name tool="gnu" name="riscv:rv32"/>
<external_name tool="DWARF.register.mapping.file" name="riscv32.dwarf"/>
<external_name tool="qemu" name="qemu-riscv32"/>
</language>
</language_definitions>

View File

@@ -0,0 +1,36 @@
define endian=little;
@define XLEN 4
@define XLEN2 8
@define FLEN 8
@define CONTEXTLEN 8
@define ADDRSIZE "32"
@define FPSIZE "64"
@include "riscv.reg.sinc"
define context CONTEXT
isExecInstr=(32,32)
phase=(33,33)
ecdv=(34,34)
;
@include "riscv.table.sinc"
# artificial return register
define register offset=0x6000 size=4 [ ExecRetAddr ];
Dest: is epsilon { export *[ram]:1 ExecRetAddr; }
:^instruction is phase=0 & isExecInstr=1 & instruction [ phase=1; ] { build instruction; local dest:$(XLEN) = ExecRetAddr; goto [dest]; }
:^instruction is phase=0 & isExecInstr=0 & instruction [ phase=1; ] { build instruction; }
with : phase=1 {
@include "riscv.instr.sinc"
@include "andestar_v5.instr.sinc"
}

View File

@@ -0,0 +1,150 @@
<?xml version="1.0" encoding="UTF-8"?>
<language_definitions>
<language processor="RISCV"
deprecated="true"
endian="little"
size="64"
variant="RV64I"
version="1.4"
slafile="riscv.lp64d.sla"
processorspec="RV64.pspec"
id="RISCV:LE:64:RV64I">
<description>RISC-V 64 little base</description>
<compiler name="gcc" spec="riscv64.cspec" id="gcc"/>
<external_name tool="DWARF.register.mapping.file" name="riscv64.dwarf"/>
<external_name tool="gnu" name="riscv:rv64"/>
<external_name tool="qemu" name="qemu-riscv64"/>
<external_name tool="qemu_system" name="qemu-system-riscv64"/>
</language>
<language processor="RISCV"
deprecated="true"
endian="little"
size="64"
variant="RV64IC"
version="1.4"
slafile="riscv.lp64d.sla"
processorspec="RV64.pspec"
id="RISCV:LE:64:RV64IC">
<description>RISC-V 64 little base compressed</description>
<compiler name="gcc" spec="riscv64.cspec" id="gcc"/>
<external_name tool="DWARF.register.mapping.file" name="riscv64.dwarf"/>
<external_name tool="gnu" name="riscv:rv64"/>
<external_name tool="qemu" name="qemu-riscv64"/>
<external_name tool="qemu_system" name="qemu-system-riscv64"/>
</language>
<language processor="RISCV"
deprecated="true"
endian="little"
size="64"
variant="RV64G"
version="1.4"
slafile="riscv.lp64d.sla"
processorspec="RV64.pspec"
id="RISCV:LE:64:RV64G">
<description>RISC-V 64 little general purpose</description>
<compiler name="gcc" spec="riscv64-fp.cspec" id="gcc"/>
<external_name tool="DWARF.register.mapping.file" name="riscv64.dwarf"/>
<external_name tool="gnu" name="riscv:rv64"/>
<external_name tool="qemu" name="qemu-riscv64"/>
<external_name tool="qemu_system" name="qemu-system-riscv64"/>
</language>
<language processor="RISCV"
deprecated="true"
endian="little"
size="64"
variant="RV64GC"
version="1.4"
slafile="riscv.lp64d.sla"
processorspec="RV64.pspec"
id="RISCV:LE:64:RV64GC">
<description>RISC-V 64 little general purpose compressed</description>
<compiler name="gcc" spec="riscv64-fp.cspec" id="gcc"/>
<external_name tool="gnu" name="riscv:rv64"/>
<external_name tool="DWARF.register.mapping.file" name="riscv64.dwarf"/>
<external_name tool="qemu" name="qemu-riscv64"/>
<external_name tool="qemu_system" name="qemu-system-riscv64"/>
</language>
<language processor="RISCV"
deprecated="true"
endian="little"
size="32"
variant="RV32I"
version="1.4"
slafile="riscv.ilp32d.sla"
processorspec="RV32.pspec"
id="RISCV:LE:32:RV32I">
<description>RISC-V 32 little base</description>
<compiler name="gcc" spec="riscv32.cspec" id="gcc"/>
<external_name tool="DWARF.register.mapping.file" name="riscv32.dwarf"/>
<external_name tool="gnu" name="riscv:rv32"/>
<external_name tool="qemu" name="qemu-riscv32"/>
<external_name tool="qemu_system" name="qemu-system-riscv32"/>
</language>
<language processor="RISCV"
deprecated="true"
endian="little"
size="32"
variant="RV32IC"
version="1.4"
slafile="riscv.ilp32d.sla"
processorspec="RV32.pspec"
id="RISCV:LE:32:RV32IC">
<description>RISC-V 32 little base compressed</description>
<compiler name="gcc" spec="riscv32.cspec" id="gcc"/>
<external_name tool="DWARF.register.mapping.file" name="riscv32.dwarf"/>
<external_name tool="gnu" name="riscv:rv32"/>
<external_name tool="qemu" name="qemu-riscv32"/>
<external_name tool="qemu_system" name="qemu-system-riscv32"/>
</language>
<language processor="RISCV"
deprecated="true"
endian="little"
size="32"
variant="RV32IMC"
version="1.4"
slafile="riscv.ilp32d.sla"
processorspec="RV32.pspec"
id="RISCV:LE:32:RV32IMC">
<description>RISC-V 32 little base compressed</description>
<compiler name="gcc" spec="riscv32.cspec" id="gcc"/>
<external_name tool="DWARF.register.mapping.file" name="riscv32.dwarf"/>
<external_name tool="gnu" name="riscv:rv32"/>
<external_name tool="qemu" name="qemu-riscv32"/>
<external_name tool="qemu_system" name="qemu-system-riscv32"/>
</language>
<language processor="RISCV"
deprecated="true"
endian="little"
size="32"
variant="RV32G"
version="1.4"
slafile="riscv.ilp32d.sla"
processorspec="RV32.pspec"
id="RISCV:LE:32:RV32G">
<description>RISC-V 32 little general purpose</description>
<compiler name="gcc" spec="riscv32-fp.cspec" id="gcc"/>
<external_name tool="gnu" name="riscv:rv32"/>
<external_name tool="DWARF.register.mapping.file" name="riscv32.dwarf"/>
<external_name tool="qemu" name="qemu-riscv32"/>
<external_name tool="qemu_system" name="qemu-system-riscv32"/>
</language>
<language processor="RISCV"
deprecated="true"
endian="little"
size="32"
variant="RV32GC"
version="1.4"
slafile="riscv.ilp32d.sla"
processorspec="RV32.pspec"
id="RISCV:LE:32:RV32GC">
<description>RISC-V 32 little general purpose compressed</description>
<compiler name="gcc" spec="riscv32-fp.cspec" id="gcc"/>
<external_name tool="gnu" name="riscv:rv32"/>
<external_name tool="DWARF.register.mapping.file" name="riscv32.dwarf"/>
<external_name tool="qemu" name="qemu-riscv32"/>
<external_name tool="qemu_system" name="qemu-system-riscv32"/>
</language>
</language_definitions>

View File

@@ -2,71 +2,109 @@
# csrrc d,E,s 00003073 0000707f SIMPLE (0, 0)
:csrrc rdDst,csr,rs1 is rs1 & csr & rdDst & op0001=0x3 & op0204=0x4 & op0506=0x3 & funct3=0x3 & op1519
:csrc csr,rs1 is rs1 & csr & op0001=0x3 & op0204=0x4 & op0506=0x3 & funct3=0x3 & op0711=0
{
local tmprs1:$(XLEN) = rs1;
local oldcsr:$(XLEN) = csr:$(XLEN);
rdDst = oldcsr;
local tmp:$(XLEN) = op1519;
if (tmp == 0) goto inst_next;
local newcsr:$(XLEN) = oldcsr & ~tmprs1;
csr = newcsr;
}
# csrrc d,E,s 00003073 0000707f SIMPLE (0, 0)
:csrrc rdDst,csr,rs1 is rs1 & csr & rdDst & op0001=0x3 & op0204=0x4 & op0506=0x3 & funct3=0x3 & op0711
{
local tmprs1:$(XLEN) = rs1;
local oldcsr:$(XLEN) = csr:$(XLEN);
local newcsr:$(XLEN) = oldcsr & ~tmprs1;
csr = newcsr;
rdDst = oldcsr;
}
# csrrci d,E,Z 00007073 0000707f SIMPLE (0, 0)
:csrci csr,op1519 is op1519 & op0711=0 & csr & op0001=0x3 & op0204=0x4 & op0506=0x3 & funct3=0x7
{
local oldcsr:$(XLEN) = csr:$(XLEN);
local tmp:$(XLEN) = op1519;
csr = oldcsr & ~tmp;
}
# csrrci d,E,Z 00007073 0000707f SIMPLE (0, 0)
:csrrci rdDst,csr,op1519 is op1519 & csr & rdDst & op0001=0x3 & op0204=0x4 & op0506=0x3 & funct3=0x7
{
local oldcsr:$(XLEN) = csr:$(XLEN);
rdDst = oldcsr;
local tmp:$(XLEN) = op1519;
if (tmp == 0) goto inst_next;
csr = csr & ~tmp;
csr = oldcsr & ~tmp;
rdDst = oldcsr;
}
# csrrs d,E,s 00002073 0000707f SIMPLE (0, 0)
:csrrs rdDst,csr,rs1 is rs1 & csr & rdDst & op0001=0x3 & op0204=0x4 & op0506=0x3 & funct3=0x2 & op1519
:csrr rdDst,csr is csr & rdDst & op0001=0x3 & op0204=0x4 & op0506=0x3 & funct3=0x2 & op1519=0 & op0711
{
local tmprs1 = rs1;
local oldcsr:$(XLEN) = csr:$(XLEN);
rdDst = oldcsr;
local tmp:$(XLEN) = op1519;
if (tmp == 0) goto inst_next;
csr = csr | tmprs1;
rdDst = csr:$(XLEN);
}
# csrrs d,E,s 00002073 0000707f SIMPLE (0, 0)
:csrs csr,rs1 is rs1 & csr & op0001=0x3 & op0204=0x4 & op0506=0x3 & funct3=0x2 & op1519 & op0711=0
{
local oldcsr:$(XLEN) = csr:$(XLEN);
csr = oldcsr | rs1;
}
# csrrs d,E,s 00002073 0000707f SIMPLE (0, 0)
:csrrs rdDst,csr,rs1 is rs1 & csr & rdDst & op0001=0x3 & op0204=0x4 & op0506=0x3 & funct3=0x2 & op1519 & op0711
{
local oldcsr:$(XLEN) = csr:$(XLEN);
csr = oldcsr | rs1;
rdDst = oldcsr;
}
# csrrsi d,E,Z 00006073 0000707f SIMPLE (0, 0)
:csrrsi rdDst,csr,op1519 is op1519 & csr & rdDst & op0001=0x3 & op0204=0x4 & op0506=0x3 & funct3=0x6
:csrsi csr,op1519 is op1519 & csr & op0711=0 & op0001=0x3 & op0204=0x4 & op0506=0x3 & funct3=0x6
{
local oldcsr:$(XLEN) = csr:$(XLEN);
rdDst = oldcsr;
local tmp:$(XLEN) = op1519;
if (tmp == 0) goto inst_next;
csr = csr | tmp;
csr = oldcsr | tmp;
}
# csrrsi d,E,Z 00006073 0000707f SIMPLE (0, 0)
:csrrsi rdDst,csr,op1519 is op1519 & csr & rdDst & op0001=0x3 & op0204=0x4 & op0506=0x3 & funct3=0x6 & op0711
{
local oldcsr:$(XLEN) = csr:$(XLEN);
local tmp:$(XLEN) = op1519;
csr = oldcsr | tmp;
rdDst = oldcsr;
}
# csrw d,E,s 00001073 0000707f SIMPLE (0, 0)
:csrw csr,rs1 is rs1 & csr & op0001=0x3 & op0204=0x4 & op0506=0x3 & funct3=0x1 & r0711=0
{
csr = rs1;
}
# csrrw d,E,s 00001073 0000707f SIMPLE (0, 0)
:csrrw rdDst,csr,rs1 is rs1 & csr & rdDst & op0001=0x3 & op0204=0x4 & op0506=0x3 & funct3=0x1 & op1519
:csrrw rdDst,csr,rs1 is rs1 & csr & rdDst & r0711 & op0001=0x3 & op0204=0x4 & op0506=0x3 & funct3=0x1
{
local tmprs1:$(XLEN) = rs1;
local oldcsr:$(XLEN) = csr:$(XLEN);
local tmp:$(XLEN) = op1519;
csr = tmprs1;
if (tmp == 0) goto inst_next;
rdDst = oldcsr;
}
# csrrwi d,E,Z 00005073 0000707f SIMPLE (0, 0)
:csrwi csr,op1519 is op1519 & csr & op0001=0x3 & op0204=0x4 & op0506=0x3 & funct3=0x5 & r0711=0
{
local val:$(XLEN) = op1519;
csr = val;
}
# csrrwi d,E,Z 00005073 0000707f SIMPLE (0, 0)
:csrrwi rdDst,csr,op1519 is op1519 & csr & rdDst & op0001=0x3 & op0204=0x4 & op0506=0x3 & funct3=0x5
:csrrwi rdDst,csr,op1519 is op1519 & csr & rdDst & op0001=0x3 & op0204=0x4 & op0506=0x3 & funct3=0x5 & r0711
{
local oldcsr:$(XLEN) = csr:$(XLEN);
local tmp:$(XLEN) = op1519;
csr = tmp;
if (tmp == 0) goto inst_next;
local val:$(XLEN) = op1519;
csr = val;
rdDst = oldcsr;
}

View File

@@ -4,8 +4,7 @@ define endian=little;
@define XLEN2 8
@define FLEN 8
@define MXLEN_1 31
@define MXLEN_2 30
@define CONTEXTLEN 4
@define ADDRSIZE "32"
@define FPSIZE "64"
@@ -13,3 +12,6 @@ define endian=little;
@include "riscv.reg.sinc"
@include "riscv.table.sinc"
@include "riscv.instr.sinc"
# include placeholder decode for *some* custom instructions
@include "riscv.custom.sinc"

View File

@@ -27,7 +27,6 @@
@include "riscv.rv64m.sinc"
@include "riscv.rv64b.sinc"
@include "riscv.rv64p.sinc"
@include "riscv.rv64k.sinc"
@if FPSIZE == "32" || FPSIZE == "64" || FPSIZE == "128"
@include "riscv.rv64f.sinc"
@@ -48,8 +47,6 @@
@include "riscv.rvv.sinc"
@include "riscv.zi.sinc"
@include "riscv.custom.sinc"
# todos that may be possible, mostly just artifacts from my
# script to generate the initial SELIGH

View File

@@ -1,164 +1,30 @@
<?xml version="1.0" encoding="UTF-8"?>
<language_definitions>
<language processor="RISCV"
endian="little"
size="64"
variant="default"
version="1.4"
slafile="riscv.lp64d.sla"
processorspec="RV64.pspec"
id="RISCV:LE:64:default">
<description>RISC-V 64 little default</description>
<compiler name="gcc" spec="riscv64-fp.cspec" id="gcc"/>
<external_name tool="DWARF.register.mapping.file" name="riscv64.dwarf"/>
<external_name tool="gnu" name="riscv:rv64"/>
<external_name tool="qemu" name="qemu-riscv64"/>
<external_name tool="qemu_system" name="qemu-system-riscv64"/>
</language>
<language processor="RISCV"
endian="little"
size="64"
variant="RV64I"
version="1.3"
slafile="riscv.lp64d.sla"
processorspec="RV64I.pspec"
id="RISCV:LE:64:RV64I">
<description>RISC-V 64 little base</description>
<compiler name="gcc" spec="riscv64.cspec" id="gcc"/>
<external_name tool="DWARF.register.mapping.file" name="riscv64.dwarf"/>
<external_name tool="gnu" name="riscv:rv64"/>
<external_name tool="qemu" name="qemu-riscv64"/>
<external_name tool="qemu_system" name="qemu-system-riscv64"/>
</language>
<language processor="RISCV"
endian="little"
size="64"
variant="RV64IC"
version="1.3"
slafile="riscv.lp64d.sla"
processorspec="RV64IC.pspec"
id="RISCV:LE:64:RV64IC">
<description>RISC-V 64 little base compressed</description>
<compiler name="gcc" spec="riscv64.cspec" id="gcc"/>
<external_name tool="DWARF.register.mapping.file" name="riscv64.dwarf"/>
<external_name tool="gnu" name="riscv:rv64"/>
<external_name tool="qemu" name="qemu-riscv64"/>
<external_name tool="qemu_system" name="qemu-system-riscv64"/>
</language>
<language processor="RISCV"
endian="little"
size="64"
variant="RV64G"
version="1.3"
slafile="riscv.lp64d.sla"
processorspec="RV64G.pspec"
id="RISCV:LE:64:RV64G">
<description>RISC-V 64 little general purpose</description>
<compiler name="gcc" spec="riscv64-fp.cspec" id="gcc"/>
<external_name tool="DWARF.register.mapping.file" name="riscv64.dwarf"/>
<external_name tool="gnu" name="riscv:rv64"/>
<external_name tool="qemu" name="qemu-riscv64"/>
<external_name tool="qemu_system" name="qemu-system-riscv64"/>
</language>
<language processor="RISCV"
endian="little"
size="64"
variant="RV64GC"
version="1.3"
slafile="riscv.lp64d.sla"
processorspec="RV64GC.pspec"
id="RISCV:LE:64:RV64GC">
<description>RISC-V 64 little general purpose compressed</description>
<compiler name="gcc" spec="riscv64-fp.cspec" id="gcc"/>
<external_name tool="gnu" name="riscv:rv64"/>
<external_name tool="DWARF.register.mapping.file" name="riscv64.dwarf"/>
<external_name tool="qemu" name="qemu-riscv64"/>
<external_name tool="qemu_system" name="qemu-system-riscv64"/>
</language>
<language processor="RISCV"
endian="little"
size="64"
variant="default"
version="1.3"
slafile="riscv.lp64d.sla"
processorspec="RV64GC.pspec"
id="RISCV:LE:64:default">
<description>RISC-V 32 little default</description>
<compiler name="gcc" spec="riscv64-fp.cspec" id="gcc"/>
<external_name tool="DWARF.register.mapping.file" name="riscv64.dwarf"/>
<external_name tool="gnu" name="riscv:rv64"/>
<external_name tool="qemu" name="qemu-riscv64"/>
<external_name tool="qemu_system" name="qemu-system-riscv64"/>
</language>
<language processor="RISCV"
endian="little"
size="32"
variant="RV32I"
version="1.3"
slafile="riscv.ilp32d.sla"
processorspec="RV32I.pspec"
id="RISCV:LE:32:RV32I">
<description>RISC-V 32 little base</description>
<compiler name="gcc" spec="riscv32.cspec" id="gcc"/>
<external_name tool="DWARF.register.mapping.file" name="riscv32.dwarf"/>
<external_name tool="gnu" name="riscv:rv32"/>
<external_name tool="qemu" name="qemu-riscv32"/>
<external_name tool="qemu_system" name="qemu-system-riscv32"/>
</language>
<language processor="RISCV"
endian="little"
size="32"
variant="RV32IC"
version="1.3"
slafile="riscv.ilp32d.sla"
processorspec="RV32IC.pspec"
id="RISCV:LE:32:RV32IC">
<description>RISC-V 32 little base compressed</description>
<compiler name="gcc" spec="riscv32.cspec" id="gcc"/>
<external_name tool="DWARF.register.mapping.file" name="riscv32.dwarf"/>
<external_name tool="gnu" name="riscv:rv32"/>
<external_name tool="qemu" name="qemu-riscv32"/>
<external_name tool="qemu_system" name="qemu-system-riscv32"/>
</language>
<language processor="RISCV"
endian="little"
size="32"
variant="RV32IMC"
version="1.3"
slafile="riscv.ilp32d.sla"
processorspec="RV32IMC.pspec"
id="RISCV:LE:32:RV32IMC">
<description>RISC-V 32 little base compressed</description>
<compiler name="gcc" spec="riscv32.cspec" id="gcc"/>
<external_name tool="DWARF.register.mapping.file" name="riscv32.dwarf"/>
<external_name tool="gnu" name="riscv:rv32"/>
<external_name tool="qemu" name="qemu-riscv32"/>
<external_name tool="qemu_system" name="qemu-system-riscv32"/>
</language>
<language processor="RISCV"
endian="little"
size="32"
variant="RV32G"
version="1.3"
slafile="riscv.ilp32d.sla"
processorspec="RV32G.pspec"
id="RISCV:LE:32:RV32G">
<description>RISC-V 32 little general purpose</description>
<compiler name="gcc" spec="riscv32-fp.cspec" id="gcc"/>
<external_name tool="gnu" name="riscv:rv32"/>
<external_name tool="DWARF.register.mapping.file" name="riscv32.dwarf"/>
<external_name tool="qemu" name="qemu-riscv32"/>
<external_name tool="qemu_system" name="qemu-system-riscv32"/>
</language>
<language processor="RISCV"
endian="little"
size="32"
variant="RV32GC"
version="1.3"
slafile="riscv.ilp32d.sla"
processorspec="RV32GC.pspec"
id="RISCV:LE:32:RV32GC">
<description>RISC-V 32 little general purpose compressed</description>
<compiler name="gcc" spec="riscv32-fp.cspec" id="gcc"/>
<external_name tool="gnu" name="riscv:rv32"/>
<external_name tool="DWARF.register.mapping.file" name="riscv32.dwarf"/>
<external_name tool="qemu" name="qemu-riscv32"/>
<external_name tool="qemu_system" name="qemu-system-riscv32"/>
</language>
<language processor="RISCV"
endian="little"
size="32"
variant="default"
version="1.3"
version="1.4"
slafile="riscv.ilp32d.sla"
processorspec="RV32GC.pspec"
processorspec="RV32.pspec"
id="RISCV:LE:32:default">
<description>RISC-V 32 little default</description>
<compiler name="gcc" spec="riscv32-fp.cspec" id="gcc"/>
@@ -167,5 +33,5 @@
<external_name tool="qemu" name="qemu-riscv32"/>
<external_name tool="qemu_system" name="qemu-system-riscv32"/>
</language>
</language_definitions>

View File

@@ -4,8 +4,7 @@ define endian=little;
@define XLEN2 16
@define FLEN 8
@define MXLEN_1 63
@define MXLEN_2 62
@define CONTEXTLEN 4
@define ADDRSIZE "64"
@define FPSIZE "64"
@@ -13,3 +12,6 @@ define endian=little;
@include "riscv.reg.sinc"
@include "riscv.table.sinc"
@include "riscv.instr.sinc"
@include "riscv.rv64k.sinc" # current encoding is in custom space
@include "riscv.custom.sinc"

File diff suppressed because it is too large Load Diff

View File

@@ -226,9 +226,9 @@
}
# c.lui d,Cu 00006001 0000e003 SIMPLE (0, 0)
:c.lui crd,cbigimm is crd & cbigimm & cop0001=0x1 & cop1315=0x3
:c.lui cd0711NoSp,cbigimm is cd0711NoSp & cbigimm & cop0001=0x1 & cop1315=0x3
{
crd = cbigimm;
cd0711NoSp = cbigimm;
}
# c.lw Ct,Ck(Cs) 00004000 0000e003 DWORD|DREF (0, 4)

File diff suppressed because it is too large Load Diff

View File

@@ -1,3 +1,587 @@
attach variables [ r0711 r1519 r2024 r2731 ]
[ zero ra sp gp tp t0 t1 t2 s0 s1 a0 a1 a2 a3 a4 a5
a6 a7 s2 s3 s4 s5 s6 s7 s8 s9 s10 s11 t3 t4 t5 t6 ];
attach variables [ cd0711NoSp ]
[ zero ra _ gp tp t0 t1 t2 s0 s1 a0 a1 a2 a3 a4 a5
a6 a7 s2 s3 s4 s5 s6 s7 s8 s9 s10 s11 t3 t4 t5 t6 ];
attach variables [ cr0206 cr0711 cd0711 ]
[ zero ra sp gp tp t0 t1 t2 s0 s1 a0 a1 a2 a3 a4 a5
a6 a7 s2 s3 s4 s5 s6 s7 s8 s9 s10 s11 t3 t4 t5 t6 ];
attach variables [ cr0204s cr0709s cd0709s ]
[ s0 s1 a0 a1 a2 a3 a4 a5 ];
attach variables [ fr0711 fr1519 fr2024 fr2731 ]
[ ft0 ft1 ft2 ft3 ft4 ft5 ft6 ft7 fs0 fs1 fa0 fa1 fa2 fa3 fa4 fa5
fa6 fa7 fs2 fs3 fs4 fs5 fs6 fs7 fs8 fs9 fs10 fs11 ft8 ft9 ft10 ft11 ];
attach variables [ cfr0206 cfr0711 ]
[ ft0 ft1 ft2 ft3 ft4 ft5 ft6 ft7 fs0 fs1 fa0 fa1 fa2 fa3 fa4 fa5
fa6 fa7 fs2 fs3 fs4 fs5 fs6 fs7 fs8 fs9 fs10 fs11 ft8 ft9 ft10 ft11 ];
attach variables [ cfr0204s cfr0709s ]
[ fs0 fs1 fa0 fa1 fa2 fa3 fa4 fa5 ];
attach variables [ v0711 v1519 v2024 ]
[ v0 v1 v2 v3 v4 v5 v6 v7 v8 v9 v10 v11 v12 v13 v14 v15
v16 v17 v18 v19 v20 v21 v22 v23 v24 v25 v26 v27 v28 v29 v30 v31 ];
#attach variables [ csr_0 ]
# [ ustatus fflags frm fcsr uie utvec csr006 csr007
# vstart vxsat vxrm csr00b csr00c csr00d csr00e vcsr
# csr010 csr011 csr012 csr013 csr014 csr015 csr016 csr017
# csr018 csr019 csr01a csr01b csr01c csr01d csr01e csr01f
# csr020 csr021 csr022 csr023 csr024 csr025 csr026 csr027
# csr028 csr029 csr02a csr02b csr02c csr02d csr02e csr02f
# csr030 csr031 csr032 csr033 csr034 csr035 csr036 csr037
# csr038 csr039 csr03a csr03b csr03c csr03d csr03e csr03f
# uscratch uepc ucause utval uip csr045 csr046 csr047
# csr048 csr049 csr04a csr04b csr04c csr04d csr04e csr04f
# csr050 csr051 csr052 csr053 csr054 csr055 csr056 csr057
# csr058 csr059 csr05a csr05b csr05c csr05d csr05e csr05f
# csr060 csr061 csr062 csr063 csr064 csr065 csr066 csr067
# csr068 csr069 csr06a csr06b csr06c csr06d csr06e csr06f
# csr070 csr071 csr072 csr073 csr074 csr075 csr076 csr077
# csr078 csr079 csr07a csr07b csr07c csr07d csr07e csr07f
# csr080 csr081 csr082 csr083 csr084 csr085 csr086 csr087
# csr088 csr089 csr08a csr08b csr08c csr08d csr08e csr08f
# csr090 csr091 csr092 csr093 csr094 csr095 csr096 csr097
# csr098 csr099 csr09a csr09b csr09c csr09d csr09e csr09f
# csr0a0 csr0a1 csr0a2 csr0a3 csr0a4 csr0a5 csr0a6 csr0a7
# csr0a8 csr0a9 csr0aa csr0ab csr0ac csr0ad csr0ae csr0af
# csr0b0 csr0b1 csr0b2 csr0b3 csr0b4 csr0b5 csr0b6 csr0b7
# csr0b8 csr0b9 csr0ba csr0bb csr0bc csr0bd csr0be csr0bf
# csr0c0 csr0c1 csr0c2 csr0c3 csr0c4 csr0c5 csr0c6 csr0c7
# csr0c8 csr0c9 csr0ca csr0cb csr0cc csr0cd csr0ce csr0cf
# csr0d0 csr0d1 csr0d2 csr0d3 csr0d4 csr0d5 csr0d6 csr0d7
# csr0d8 csr0d9 csr0da csr0db csr0dc csr0dd csr0de csr0df
# csr0e0 csr0e1 csr0e2 csr0e3 csr0e4 csr0e5 csr0e6 csr0e7
# csr0e8 csr0e9 csr0ea csr0eb csr0ec csr0ed csr0ee csr0ef
# csr0f0 csr0f1 csr0f2 csr0f3 csr0f4 csr0f5 csr0f6 csr0f7
# csr0f8 csr0f9 csr0fa csr0fb csr0fc csr0fd csr0fe csr0ff ];
#attach variables [ csr_1 ]
# [ sstatus csr101 sedeleg sideleg sie stvec scounteren csr107
# csr108 csr109 csr10a csr10b csr10c csr10d csr10e csr10f
# csr110 csr111 csr112 csr113 csr114 csr115 csr116 csr117
# csr118 csr119 csr11a csr11b csr11c csr11d csr11e csr11f
# csr120 csr121 csr122 csr123 csr124 csr125 csr126 csr127
# csr128 csr129 csr12a csr12b csr12c csr12d csr12e csr12f
# csr130 csr131 csr132 csr133 csr134 csr135 csr136 csr137
# csr138 csr139 csr13a csr13b csr13c csr13d csr13e csr13f
# sscratch sepc scause stval sip csr145 csr146 csr147
# csr148 csr149 csr14a csr14b csr14c csr14d csr14e csr14f
# csr150 csr151 csr152 csr153 csr154 csr155 csr156 csr157
# csr158 csr159 csr15a csr15b csr15c csr15d csr15e csr15f
# csr160 csr161 csr162 csr163 csr164 csr165 csr166 csr167
# csr168 csr169 csr16a csr16b csr16c csr16d csr16e csr16f
# csr170 csr171 csr172 csr173 csr174 csr175 csr176 csr177
# csr178 csr179 csr17a csr17b csr17c csr17d csr17e csr17f
# satp csr181 csr182 csr183 csr184 csr185 csr186 csr187
# csr188 csr189 csr18a csr18b csr18c csr18d csr18e csr18f
# csr190 csr191 csr192 csr193 csr194 csr195 csr196 csr197
# csr198 csr199 csr19a csr19b csr19c csr19d csr19e csr19f
# csr1a0 csr1a1 csr1a2 csr1a3 csr1a4 csr1a5 csr1a6 csr1a7
# csr1a8 csr1a9 csr1aa csr1ab csr1ac csr1ad csr1ae csr1af
# csr1b0 csr1b1 csr1b2 csr1b3 csr1b4 csr1b5 csr1b6 csr1b7
# csr1b8 csr1b9 csr1ba csr1bb csr1bc csr1bd csr1be csr1bf
# csr1c0 csr1c1 csr1c2 csr1c3 csr1c4 csr1c5 csr1c6 csr1c7
# csr1c8 csr1c9 csr1ca csr1cb csr1cc csr1cd csr1ce csr1cf
# csr1d0 csr1d1 csr1d2 csr1d3 csr1d4 csr1d5 csr1d6 csr1d7
# csr1d8 csr1d9 csr1da csr1db csr1dc csr1dd csr1de csr1df
# csr1e0 csr1e1 csr1e2 csr1e3 csr1e4 csr1e5 csr1e6 csr1e7
# csr1e8 csr1e9 csr1ea csr1eb csr1ec csr1ed csr1ee csr1ef
# csr1f0 csr1f1 csr1f2 csr1f3 csr1f4 csr1f5 csr1f6 csr1f7
# csr1f8 csr1f9 csr1fa csr1fb csr1fc csr1fd csr1fe csr1ff ];
#attach variables [ csr_2 ]
# [ vsstatus csr201 csr202 csr203 vsie vstvec csr206 csr207
# csr208 csr209 csr20a csr20b csr20c csr20d csr20e csr20f
# csr210 csr211 csr212 csr213 csr214 csr215 csr216 csr217
# csr218 csr219 csr21a csr21b csr21c csr21d csr21e csr21f
# csr220 csr221 csr222 csr223 csr224 csr225 csr226 csr227
# csr228 csr229 csr22a csr22b csr22c csr22d csr22e csr22f
# csr230 csr231 csr232 csr233 csr234 csr235 csr236 csr237
# csr238 csr239 csr23a csr23b csr23c csr23d csr23e csr23f
# vsscratch vsepc vscause vstval vsip csr245 csr246 csr247
# csr248 csr249 csr24a csr24b csr24c csr24d csr24e csr24f
# csr250 csr251 csr252 csr253 csr254 csr255 csr256 csr257
# csr258 csr259 csr25a csr25b csr25c csr25d csr25e csr25f
# csr260 csr261 csr262 csr263 csr264 csr265 csr266 csr267
# csr268 csr269 csr26a csr26b csr26c csr26d csr26e csr26f
# csr270 csr271 csr272 csr273 csr274 csr275 csr276 csr277
# csr278 csr279 csr27a csr27b csr27c csr27d csr27e csr27f
# vsatp csr281 csr282 csr283 csr284 csr285 csr286 csr287
# csr288 csr289 csr28a csr28b csr28c csr28d csr28e csr28f
# csr290 csr291 csr292 csr293 csr294 csr295 csr296 csr297
# csr298 csr299 csr29a csr29b csr29c csr29d csr29e csr29f
# csr2a0 csr2a1 csr2a2 csr2a3 csr2a4 csr2a5 csr2a6 csr2a7
# csr2a8 csr2a9 csr2aa csr2ab csr2ac csr2ad csr2ae csr2af
# csr2b0 csr2b1 csr2b2 csr2b3 csr2b4 csr2b5 csr2b6 csr2b7
# csr2b8 csr2b9 csr2ba csr2bb csr2bc csr2bd csr2be csr2bf
# csr2c0 csr2c1 csr2c2 csr2c3 csr2c4 csr2c5 csr2c6 csr2c7
# csr2c8 csr2c9 csr2ca csr2cb csr2cc csr2cd csr2ce csr2cf
# csr2d0 csr2d1 csr2d2 csr2d3 csr2d4 csr2d5 csr2d6 csr2d7
# csr2d8 csr2d9 csr2da csr2db csr2dc csr2dd csr2de csr2df
# csr2e0 csr2e1 csr2e2 csr2e3 csr2e4 csr2e5 csr2e6 csr2e7
# csr2e8 csr2e9 csr2ea csr2eb csr2ec csr2ed csr2ee csr2ef
# csr2f0 csr2f1 csr2f2 csr2f3 csr2f4 csr2f5 csr2f6 csr2f7
# csr2f8 csr2f9 csr2fa csr2fb csr2fc csr2fd csr2fe csr2ff ];
#attach variables [ csr_3 ]
# [ mstatus misa medeleg mideleg mie mtvec mcounteren csr307
# csr308 csr309 csr30a csr30b csr30c csr30d csr30e csr30f
# mstatush csr311 csr312 csr313 csr314 csr315 csr316 csr317
# csr318 csr319 csr31a csr31b csr31c csr31d csr31e csr31f
# mcountinhibit csr321 csr322 mhpmevent3 mhpmevent4 mhpmevent5 mhpmevent6 mhpmevent7
# mhpmevent8 mhpmevent9 mhpmevent10 mhpmevent11 mhpmevent12 mhpmevent13 mhpmevent14 mhpmevent15
# mhpmevent16 mhpmevent17 mhpmevent18 mhpmevent19 mhpmevent20 mhpmevent21 mhpmevent22 mhpmevent23
# mhpmevent24 mhpmevent25 mhpmevent26 mhpmevent27 mhpmevent28 mhpmevent29 mhpmevent30 mhpmevent31
# mscratch mepc mcause mtval mip csr345 csr346 csr347
# csr348 csr349 mtinst mtval2 csr34c csr34d csr34e csr34f
# csr350 csr351 csr352 csr353 csr354 csr355 csr356 csr357
# csr358 csr359 csr35a csr35b csr35c csr35d csr35e csr35f
# csr360 csr361 csr362 csr363 csr364 csr365 csr366 csr367
# csr368 csr369 csr36a csr36b csr36c csr36d csr36e csr36f
# csr370 csr371 csr372 csr373 csr374 csr375 csr376 csr377
# csr378 csr379 csr37a csr37b csr37c csr37d csr37e csr37f
# mbase mbound mibase mibound mdbase mdbound csr386 csr387
# csr388 csr389 csr38a csr38b csr38c csr38d csr38e csr38f
# csr390 csr391 csr392 csr393 csr394 csr395 csr396 csr397
# csr398 csr399 csr39a csr39b csr39c csr39d csr39e csr39f
# pmpcfg0 pmpcfg1 pmpcfg2 pmpcfg3 pmpcfg4 pmpcfg5 pmpcfg6 pmpcfg7
# pmpcfg8 pmpcfg9 pmpcfg10 pmpcfg11 pmpcfg12 pmpcfg13 pmpcfg14 pmpcfg15
# pmpaddr0 pmpaddr1 pmpaddr2 pmpaddr3 pmpaddr4 pmpaddr5 pmpaddr6 pmpaddr7
# pmpaddr8 pmpaddr9 pmpaddr10 pmpaddr11 pmpaddr12 pmpaddr13 pmpaddr14 pmpaddr15
# pmpaddr16 pmpaddr17 pmpaddr18 pmpaddr19 pmpaddr20 pmpaddr21 pmpaddr22 pmpaddr23
# pmpaddr24 pmpaddr25 pmpaddr26 pmpaddr27 pmpaddr28 pmpaddr29 pmpaddr30 pmpaddr31
# pmpaddr32 pmpaddr33 pmpaddr34 pmpaddr35 pmpaddr36 pmpaddr37 pmpaddr38 pmpaddr39
# pmpaddr40 pmpaddr41 pmpaddr42 pmpaddr43 pmpaddr44 pmpaddr45 pmpaddr46 pmpaddr47
# pmpaddr48 pmpaddr49 pmpaddr50 pmpaddr51 pmpaddr52 pmpaddr53 pmpaddr54 pmpaddr55
# pmpaddr56 pmpaddr57 pmpaddr58 pmpaddr59 pmpaddr60 pmpaddr61 pmpaddr62 pmpaddr63
# csr3f0 csr3f1 csr3f2 csr3f3 csr3f4 csr3f5 csr3f6 csr3f7
# csr3f8 csr3f9 csr3fa csr3fb csr3fc csr3fd csr3fe csr3ff ];
#attach variables [ csr_4 ]
# [ csr400 csr401 csr402 csr403 csr404 csr405 csr406 csr407
# csr408 csr409 csr40a csr40b csr40c csr40d csr40e csr40f
# csr410 csr411 csr412 csr413 csr414 csr415 csr416 csr417
# csr418 csr419 csr41a csr41b csr41c csr41d csr41e csr41f
# csr420 csr421 csr422 csr423 csr424 csr425 csr426 csr427
# csr428 csr429 csr42a csr42b csr42c csr42d csr42e csr42f
# csr430 csr431 csr432 csr433 csr434 csr435 csr436 csr437
# csr438 csr439 csr43a csr43b csr43c csr43d csr43e csr43f
# csr440 csr441 csr442 csr443 csr444 csr445 csr446 csr447
# csr448 csr449 csr44a csr44b csr44c csr44d csr44e csr44f
# csr450 csr451 csr452 csr453 csr454 csr455 csr456 csr457
# csr458 csr459 csr45a csr45b csr45c csr45d csr45e csr45f
# csr460 csr461 csr462 csr463 csr464 csr465 csr466 csr467
# csr468 csr469 csr46a csr46b csr46c csr46d csr46e csr46f
# csr470 csr471 csr472 csr473 csr474 csr475 csr476 csr477
# csr478 csr479 csr47a csr47b csr47c csr47d csr47e csr47f
# csr480 csr481 csr482 csr483 csr484 csr485 csr486 csr487
# csr488 csr489 csr48a csr48b csr48c csr48d csr48e csr48f
# csr490 csr491 csr492 csr493 csr494 csr495 csr496 csr497
# csr498 csr499 csr49a csr49b csr49c csr49d csr49e csr49f
# csr4a0 csr4a1 csr4a2 csr4a3 csr4a4 csr4a5 csr4a6 csr4a7
# csr4a8 csr4a9 csr4aa csr4ab csr4ac csr4ad csr4ae csr4af
# csr4b0 csr4b1 csr4b2 csr4b3 csr4b4 csr4b5 csr4b6 csr4b7
# csr4b8 csr4b9 csr4ba csr4bb csr4bc csr4bd csr4be csr4bf
# csr4c0 csr4c1 csr4c2 csr4c3 csr4c4 csr4c5 csr4c6 csr4c7
# csr4c8 csr4c9 csr4ca csr4cb csr4cc csr4cd csr4ce csr4cf
# csr4d0 csr4d1 csr4d2 csr4d3 csr4d4 csr4d5 csr4d6 csr4d7
# csr4d8 csr4d9 csr4da csr4db csr4dc csr4dd csr4de csr4df
# csr4e0 csr4e1 csr4e2 csr4e3 csr4e4 csr4e5 csr4e6 csr4e7
# csr4e8 csr4e9 csr4ea csr4eb csr4ec csr4ed csr4ee csr4ef
# csr4f0 csr4f1 csr4f2 csr4f3 csr4f4 csr4f5 csr4f6 csr4f7
# csr4f8 csr4f9 csr4fa csr4fb csr4fc csr4fd csr4fe csr4ff ];
#attach variables [ csr_50 ]
# [ csr500 csr501 csr502 csr503 csr504 csr505 csr506 csr507
# csr508 csr509 csr50a csr50b csr50c csr50d csr50e csr50f
# csr510 csr511 csr512 csr513 csr514 csr515 csr516 csr517
# csr518 csr519 csr51a csr51b csr51c csr51d csr51e csr51f
# csr520 csr521 csr522 csr523 csr524 csr525 csr526 csr527
# csr528 csr529 csr52a csr52b csr52c csr52d csr52e csr52f
# csr530 csr531 csr532 csr533 csr534 csr535 csr536 csr537
# csr538 csr539 csr53a csr53b csr53c csr53d csr53e csr53f
# csr540 csr541 csr542 csr543 csr544 csr545 csr546 csr547
# csr548 csr549 csr54a csr54b csr54c csr54d csr54e csr54f
# csr550 csr551 csr552 csr553 csr554 csr555 csr556 csr557
# csr558 csr559 csr55a csr55b csr55c csr55d csr55e csr55f
# csr560 csr561 csr562 csr563 csr564 csr565 csr566 csr567
# csr568 csr569 csr56a csr56b csr56c csr56d csr56e csr56f
# csr570 csr571 csr572 csr573 csr574 csr575 csr576 csr577
# csr578 csr579 csr57a csr57b csr57c csr57d csr57e csr57f ];
#attach variables [ csr_58 ]
# [ csr580 csr581 csr582 csr583 csr584 csr585 csr586 csr587
# csr588 csr589 csr58a csr58b csr58c csr58d csr58e csr58f
# csr590 csr591 csr592 csr593 csr594 csr595 csr596 csr597
# csr598 csr599 csr59a csr59b csr59c csr59d csr59e csr59f
# csr5a0 csr5a1 csr5a2 csr5a3 csr5a4 csr5a5 csr5a6 csr5a7
# scontext csr5a9 csr5aa csr5ab csr5ac csr5ad csr5ae csr5af
# csr5b0 csr5b1 csr5b2 csr5b3 csr5b4 csr5b5 csr5b6 csr5b7
# csr5b8 csr5b9 csr5ba csr5bb csr5bc csr5bd csr5be csr5bf ];
#attach variables [ csr_5C ]
# [ csr5c0 csr5c1 csr5c2 csr5c3 csr5c4 csr5c5 csr5c6 csr5c7
# csr5c8 csr5c9 csr5ca csr5cb csr5cc csr5cd csr5ce csr5cf
# csr5d0 csr5d1 csr5d2 csr5d3 csr5d4 csr5d5 csr5d6 csr5d7
# csr5d8 csr5d9 csr5da csr5db csr5dc csr5dd csr5de csr5df
# csr5e0 csr5e1 csr5e2 csr5e3 csr5e4 csr5e5 csr5e6 csr5e7
# csr5e8 csr5e9 csr5ea csr5eb csr5ec csr5ed csr5ee csr5ef
# csr5f0 csr5f1 csr5f2 csr5f3 csr5f4 csr5f5 csr5f6 csr5f7
# csr5f8 csr5f9 csr5fa csr5fb csr5fc csr5fd csr5fe csr5ff ];
#attach variables [ csr_60 ]
# [ hstatus csr601 hedeleg hideleg hie htimedelta hcounteren hgeie
# csr608 csr609 csr60a csr60b csr60c csr60d csr60e csr60f
# csr610 csr611 csr612 csr613 csr614 htimedeltah csr616 csr617
# csr618 csr619 csr61a csr61b csr61c csr61d csr61e csr61f
# csr620 csr621 csr622 csr623 csr624 csr625 csr626 csr627
# csr628 csr629 csr62a csr62b csr62c csr62d csr62e csr62f
# csr630 csr631 csr632 csr633 csr634 csr635 csr636 csr637
# csr638 csr639 csr63a csr63b csr63c csr63d csr63e csr63f
# csr640 csr641 csr642 htval hip hvip csr646 csr647
# csr648 csr649 htinst csr64b csr64c csr64d csr64e csr64f
# csr650 csr651 csr652 csr653 csr654 csr655 csr656 csr657
# csr658 csr659 csr65a csr65b csr65c csr65d csr65e csr65f
# csr660 csr661 csr662 csr663 csr664 csr665 csr666 csr667
# csr668 csr669 csr66a csr66b csr66c csr66d csr66e csr66f
# csr670 csr671 csr672 csr673 csr674 csr675 csr676 csr677
# csr678 csr679 csr67a csr67b csr67c csr67d csr67e csr67f ];
#attach variables [ csr_68 ]
# [ hgatp csr681 csr682 csr683 csr684 csr685 csr686 csr687
# csr688 csr689 csr68a csr68b csr68c csr68d csr68e csr68f
# csr690 csr691 csr692 csr693 csr694 csr695 csr696 csr697
# csr698 csr699 csr69a csr69b csr69c csr69d csr69e csr69f
# csr6a0 csr6a1 csr6a2 csr6a3 csr6a4 csr6a5 csr6a6 csr6a7
# hcontext csr6a9 csr6aa csr6ab csr6ac csr6ad csr6ae csr6af
# csr6b0 csr6b1 csr6b2 csr6b3 csr6b4 csr6b5 csr6b6 csr6b7
# csr6b8 csr6b9 csr6ba csr6bb csr6bc csr6bd csr6be csr6bf ];
#attach variables [ csr_6C ]
# [ csr6c0 csr6c1 csr6c2 csr6c3 csr6c4 csr6c5 csr6c6 csr6c7
# csr6c8 csr6c9 csr6ca csr6cb csr6cc csr6cd csr6ce csr6cf
# csr6d0 csr6d1 csr6d2 csr6d3 csr6d4 csr6d5 csr6d6 csr6d7
# csr6d8 csr6d9 csr6da csr6db csr6dc csr6dd csr6de csr6df
# csr6e0 csr6e1 csr6e2 csr6e3 csr6e4 csr6e5 csr6e6 csr6e7
# csr6e8 csr6e9 csr6ea csr6eb csr6ec csr6ed csr6ee csr6ef
# csr6f0 csr6f1 csr6f2 csr6f3 csr6f4 csr6f5 csr6f6 csr6f7
# csr6f8 csr6f9 csr6fa csr6fb csr6fc csr6fd csr6fe csr6ff ];
#attach variables [ csr_70 ]
# [ csr700 csr701 csr702 csr703 csr704 csr705 csr706 csr707
# csr708 csr709 csr70a csr70b csr70c csr70d csr70e csr70f
# csr710 csr711 csr712 csr713 csr714 csr715 csr716 csr717
# csr718 csr719 csr71a csr71b csr71c csr71d csr71e csr71f
# csr720 csr721 csr722 csr723 csr724 csr725 csr726 csr727
# csr728 csr729 csr72a csr72b csr72c csr72d csr72e csr72f
# csr730 csr731 csr732 csr733 csr734 csr735 csr736 csr737
# csr738 csr739 csr73a csr73b csr73c csr73d csr73e csr73f
# csr740 csr741 csr742 csr743 csr744 csr745 csr746 csr747
# csr748 csr749 csr74a csr74b csr74c csr74d csr74e csr74f
# csr750 csr751 csr752 csr753 csr754 csr755 csr756 csr757
# csr758 csr759 csr75a csr75b csr75c csr75d csr75e csr75f
# csr760 csr761 csr762 csr763 csr764 csr765 csr766 csr767
# csr768 csr769 csr76a csr76b csr76c csr76d csr76e csr76f
# csr770 csr771 csr772 csr773 csr774 csr775 csr776 csr777
# csr778 csr779 csr77a csr77b csr77c csr77d csr77e csr77f ];
#attach variables [ csr_78 ]
# [ csr780 csr781 csr782 csr783 csr784 csr785 csr786 csr787
# csr788 csr789 csr78a csr78b csr78c csr78d csr78e csr78f
# csr790 csr791 csr792 csr793 csr794 csr795 csr796 csr797
# csr798 csr799 csr79a csr79b csr79c csr79d csr79e csr79f ];
#attach variables [ csr_7A ]
# [ tselect tdata1 tdata2 tdata3 csr7a4 csr7a5 csr7a6 csr7a7
# mcontext csr7a9 csr7aa csr7ab csr7ac csr7ad csr7ae csr7af ];
#attach variables [ csr_7B ]
# [ dcsr dpc dscratch0 dscratch1 csr7b4 csr7b5 csr7b6 csr7b7
# csr7b8 csr7b9 csr7ba csr7bb csr7bc csr7bd csr7be csr7bf ];
#attach variables [ csr_7C ]
# [ csr7c0 csr7c1 csr7c2 csr7c3 csr7c4 csr7c5 csr7c6 csr7c7
# csr7c8 csr7c9 csr7ca csr7cb csr7cc csr7cd csr7ce csr7cf
# csr7d0 csr7d1 csr7d2 csr7d3 csr7d4 csr7d5 csr7d6 csr7d7
# csr7d8 csr7d9 csr7da csr7db csr7dc csr7dd csr7de csr7df
# csr7e0 csr7e1 csr7e2 csr7e3 csr7e4 csr7e5 csr7e6 csr7e7
# csr7e8 csr7e9 csr7ea csr7eb csr7ec csr7ed csr7ee csr7ef
# csr7f0 csr7f1 csr7f2 csr7f3 csr7f4 csr7f5 csr7f6 csr7f7
# csr7f8 csr7f9 csr7fa csr7fb csr7fc csr7fd csr7fe csr7ff ];
#attach variables [ csr_8 ]
# [ csr800 csr801 csr802 csr803 csr804 csr805 csr806 csr807
# csr808 csr809 csr80a csr80b csr80c csr80d csr80e csr80f
# csr810 csr811 csr812 csr813 csr814 csr815 csr816 csr817
# csr818 csr819 csr81a csr81b csr81c csr81d csr81e csr81f
# csr820 csr821 csr822 csr823 csr824 csr825 csr826 csr827
# csr828 csr829 csr82a csr82b csr82c csr82d csr82e csr82f
# csr830 csr831 csr832 csr833 csr834 csr835 csr836 csr837
# csr838 csr839 csr83a csr83b csr83c csr83d csr83e csr83f
# csr840 csr841 csr842 csr843 csr844 csr845 csr846 csr847
# csr848 csr849 csr84a csr84b csr84c csr84d csr84e csr84f
# csr850 csr851 csr852 csr853 csr854 csr855 csr856 csr857
# csr858 csr859 csr85a csr85b csr85c csr85d csr85e csr85f
# csr860 csr861 csr862 csr863 csr864 csr865 csr866 csr867
# csr868 csr869 csr86a csr86b csr86c csr86d csr86e csr86f
# csr870 csr871 csr872 csr873 csr874 csr875 csr876 csr877
# csr878 csr879 csr87a csr87b csr87c csr87d csr87e csr87f
# csr880 csr881 csr882 csr883 csr884 csr885 csr886 csr887
# csr888 csr889 csr88a csr88b csr88c csr88d csr88e csr88f
# csr890 csr891 csr892 csr893 csr894 csr895 csr896 csr897
# csr898 csr899 csr89a csr89b csr89c csr89d csr89e csr89f
# csr8a0 csr8a1 csr8a2 csr8a3 csr8a4 csr8a5 csr8a6 csr8a7
# csr8a8 csr8a9 csr8aa csr8ab csr8ac csr8ad csr8ae csr8af
# csr8b0 csr8b1 csr8b2 csr8b3 csr8b4 csr8b5 csr8b6 csr8b7
# csr8b8 csr8b9 csr8ba csr8bb csr8bc csr8bd csr8be csr8bf
# csr8c0 csr8c1 csr8c2 csr8c3 csr8c4 csr8c5 csr8c6 csr8c7
# csr8c8 csr8c9 csr8ca csr8cb csr8cc csr8cd csr8ce csr8cf
# csr8d0 csr8d1 csr8d2 csr8d3 csr8d4 csr8d5 csr8d6 csr8d7
# csr8d8 csr8d9 csr8da csr8db csr8dc csr8dd csr8de csr8df
# csr8e0 csr8e1 csr8e2 csr8e3 csr8e4 csr8e5 csr8e6 csr8e7
# csr8e8 csr8e9 csr8ea csr8eb csr8ec csr8ed csr8ee csr8ef
# csr8f0 csr8f1 csr8f2 csr8f3 csr8f4 csr8f5 csr8f6 csr8f7
# csr8f8 csr8f9 csr8fa csr8fb csr8fc csr8fd csr8fe csr8ff ];
#attach variables [ csr_90 ]
# [ csr900 csr901 csr902 csr903 csr904 csr905 csr906 csr907
# csr908 csr909 csr90a csr90b csr90c csr90d csr90e csr90f
# csr910 csr911 csr912 csr913 csr914 csr915 csr916 csr917
# csr918 csr919 csr91a csr91b csr91c csr91d csr91e csr91f
# csr920 csr921 csr922 csr923 csr924 csr925 csr926 csr927
# csr928 csr929 csr92a csr92b csr92c csr92d csr92e csr92f
# csr930 csr931 csr932 csr933 csr934 csr935 csr936 csr937
# csr938 csr939 csr93a csr93b csr93c csr93d csr93e csr93f
# csr940 csr941 csr942 csr943 csr944 csr945 csr946 csr947
# csr948 csr949 csr94a csr94b csr94c csr94d csr94e csr94f
# csr950 csr951 csr952 csr953 csr954 csr955 csr956 csr957
# csr958 csr959 csr95a csr95b csr95c csr95d csr95e csr95f
# csr960 csr961 csr962 csr963 csr964 csr965 csr966 csr967
# csr968 csr969 csr96a csr96b csr96c csr96d csr96e csr96f
# csr970 csr971 csr972 csr973 csr974 csr975 csr976 csr977
# csr978 csr979 csr97a csr97b csr97c csr97d csr97e csr97f ];
#attach variables [ csr_98 ]
# [ csr980 csr981 csr982 csr983 csr984 csr985 csr986 csr987
# csr988 csr989 csr98a csr98b csr98c csr98d csr98e csr98f
# csr990 csr991 csr992 csr993 csr994 csr995 csr996 csr997
# csr998 csr999 csr99a csr99b csr99c csr99d csr99e csr99f
# csr9a0 csr9a1 csr9a2 csr9a3 csr9a4 csr9a5 csr9a6 csr9a7
# csr9a8 csr9a9 csr9aa csr9ab csr9ac csr9ad csr9ae csr9af
# csr9b0 csr9b1 csr9b2 csr9b3 csr9b4 csr9b5 csr9b6 csr9b7
# csr9b8 csr9b9 csr9ba csr9bb csr9bc csr9bd csr9be csr9bf ];
#attach variables [ csr_9C ]
# [ csr9c0 csr9c1 csr9c2 csr9c3 csr9c4 csr9c5 csr9c6 csr9c7
# csr9c8 csr9c9 csr9ca csr9cb csr9cc csr9cd csr9ce csr9cf
# csr9d0 csr9d1 csr9d2 csr9d3 csr9d4 csr9d5 csr9d6 csr9d7
# csr9d8 csr9d9 csr9da csr9db csr9dc csr9dd csr9de csr9df
# csr9e0 csr9e1 csr9e2 csr9e3 csr9e4 csr9e5 csr9e6 csr9e7
# csr9e8 csr9e9 csr9ea csr9eb csr9ec csr9ed csr9ee csr9ef
# csr9f0 csr9f1 csr9f2 csr9f3 csr9f4 csr9f5 csr9f6 csr9f7
# csr9f8 csr9f9 csr9fa csr9fb csr9fc csr9fd csr9fe csr9ff ];
#attach variables [ csr_A0 ]
# [ csra00 csra01 csra02 csra03 csra04 csra05 csra06 csra07
# csra08 csra09 csra0a csra0b csra0c csra0d csra0e csra0f
# csra10 csra11 csra12 csra13 csra14 csra15 csra16 csra17
# csra18 csra19 csra1a csra1b csra1c csra1d csra1e csra1f
# csra20 csra21 csra22 csra23 csra24 csra25 csra26 csra27
# csra28 csra29 csra2a csra2b csra2c csra2d csra2e csra2f
# csra30 csra31 csra32 csra33 csra34 csra35 csra36 csra37
# csra38 csra39 csra3a csra3b csra3c csra3d csra3e csra3f
# csra40 csra41 csra42 csra43 csra44 csra45 csra46 csra47
# csra48 csra49 csra4a csra4b csra4c csra4d csra4e csra4f
# csra50 csra51 csra52 csra53 csra54 csra55 csra56 csra57
# csra58 csra59 csra5a csra5b csra5c csra5d csra5e csra5f
# csra60 csra61 csra62 csra63 csra64 csra65 csra66 csra67
# csra68 csra69 csra6a csra6b csra6c csra6d csra6e csra6f
# csra70 csra71 csra72 csra73 csra74 csra75 csra76 csra77
# csra78 csra79 csra7a csra7b csra7c csra7d csra7e csra7f ];
#attach variables [ csr_A8 ]
# [ csra80 csra81 csra82 csra83 csra84 csra85 csra86 csra87
# csra88 csra89 csra8a csra8b csra8c csra8d csra8e csra8f
# csra90 csra91 csra92 csra93 csra94 csra95 csra96 csra97
# csra98 csra99 csra9a csra9b csra9c csra9d csra9e csra9f
# csraa0 csraa1 csraa2 csraa3 csraa4 csraa5 csraa6 csraa7
# csraa8 csraa9 csraaa csraab csraac csraad csraae csraaf
# csrab0 csrab1 csrab2 csrab3 csrab4 csrab5 csrab6 csrab7
# csrab8 csrab9 csraba csrabb csrabc csrabd csrabe csrabf ];
#attach variables [ csr_AC ]
# [ csrac0 csrac1 csrac2 csrac3 csrac4 csrac5 csrac6 csrac7
# csrac8 csrac9 csraca csracb csracc csracd csrace csracf
# csrad0 csrad1 csrad2 csrad3 csrad4 csrad5 csrad6 csrad7
# csrad8 csrad9 csrada csradb csradc csradd csrade csradf
# csrae0 csrae1 csrae2 csrae3 csrae4 csrae5 csrae6 csrae7
# csrae8 csrae9 csraea csraeb csraec csraed csraee csraef
# csraf0 csraf1 csraf2 csraf3 csraf4 csraf5 csraf6 csraf7
# csraf8 csraf9 csrafa csrafb csrafc csrafd csrafe csraff ];
#attach variables [ csr_B0 ]
# [ mcycle csrb01 minstret mhpmcounter3 mhpmcounter4 mhpmcounter5 mhpmcounter6 mhpmcounter7
# mhpmcounter8 mhpmcounter9 mhpmcounter10 mhpmcounter11 mhpmcounter12 mhpmcounter13 mhpmcounter14 mhpmcounter15
# mhpmcounter16 mhpmcounter17 mhpmcounter18 mhpmcounter19 mhpmcounter20 mhpmcounter21 mhpmcounter22 mhpmcounter23
# mhpmcounter24 mhpmcounter25 mhpmcounter26 mhpmcounter27 mhpmcounter28 mhpmcounter29 mhpmcounter30 mhpmcounter31
# csrb20 csrb21 csrb22 csrb23 csrb24 csrb25 csrb26 csrb27
# csrb28 csrb29 csrb2a csrb2b csrb2c csrb2d csrb2e csrb2f
# csrb30 csrb31 csrb32 csrb33 csrb34 csrb35 csrb36 csrb37
# csrb38 csrb39 csrb3a csrb3b csrb3c csrb3d csrb3e csrb3f
# csrb40 csrb41 csrb42 csrb43 csrb44 csrb45 csrb46 csrb47
# csrb48 csrb49 csrb4a csrb4b csrb4c csrb4d csrb4e csrb4f
# csrb50 csrb51 csrb52 csrb53 csrb54 csrb55 csrb56 csrb57
# csrb58 csrb59 csrb5a csrb5b csrb5c csrb5d csrb5e csrb5f
# csrb60 csrb61 csrb62 csrb63 csrb64 csrb65 csrb66 csrb67
# csrb68 csrb69 csrb6a csrb6b csrb6c csrb6d csrb6e csrb6f
# csrb70 csrb71 csrb72 csrb73 csrb74 csrb75 csrb76 csrb77
# csrb78 csrb79 csrb7a csrb7b csrb7c csrb7d csrb7e csrb7f ];
#attach variables [ csr_B8 ]
# [ mcycleh csrb81 minstreth mhpmcounter3h mhpmcounter4h mhpmcounter5h mhpmcounter6h mhpmcounter7h
# mhpmcounter8h mhpmcounter9h mhpmcounter10h mhpmcounter11h mhpmcounter12h mhpmcounter13h mhpmcounter14h mhpmcounter15h
# mhpmcounter16h mhpmcounter17h mhpmcounter18h mhpmcounter19h mhpmcounter20h mhpmcounter21h mhpmcounter22h mhpmcounter23h
# mhpmcounter24h mhpmcounter25h mhpmcounter26h mhpmcounter27h mhpmcounter28h mhpmcounter29h mhpmcounter30h mhpmcounter31h
# csrba0 csrba1 csrba2 csrba3 csrba4 csrba5 csrba6 csrba7
# csrba8 csrba9 csrbaa csrbab csrbac csrbad csrbae csrbaf
# csrbb0 csrbb1 csrbb2 csrbb3 csrbb4 csrbb5 csrbb6 csrbb7
# csrbb8 csrbb9 csrbba csrbbb csrbbc csrbbd csrbbe csrbbf ];
#attach variables [ csr_BC ]
# [ csrbc0 csrbc1 csrbc2 csrbc3 csrbc4 csrbc5 csrbc6 csrbc7
# csrbc8 csrbc9 csrbca csrbcb csrbcc csrbcd csrbce csrbcf
# csrbd0 csrbd1 csrbd2 csrbd3 csrbd4 csrbd5 csrbd6 csrbd7
# csrbd8 csrbd9 csrbda csrbdb csrbdc csrbdd csrbde csrbdf
# csrbe0 csrbe1 csrbe2 csrbe3 csrbe4 csrbe5 csrbe6 csrbe7
# csrbe8 csrbe9 csrbea csrbeb csrbec csrbed csrbee csrbef
# csrbf0 csrbf1 csrbf2 csrbf3 csrbf4 csrbf5 csrbf6 csrbf7
# csrbf8 csrbf9 csrbfa csrbfb csrbfc csrbfd csrbfe csrbff ];
#attach variables [ csr_C0 ]
# [ cycle time instret hpmcounter3 hpmcounter4 hpmcounter5 hpmcounter6 hpmcounter7
# hpmcounter8 hpmcounter9 hpmcounter10 hpmcounter11 hpmcounter12 hpmcounter13 hpmcounter14 hpmcounter15
# hpmcounter16 hpmcounter17 hpmcounter18 hpmcounter19 hpmcounter20 hpmcounter21 hpmcounter22 hpmcounter23
# hpmcounter24 hpmcounter25 hpmcounter26 hpmcounter27 hpmcounter28 hpmcounter29 hpmcounter30 hpmcounter31
# vl vtype vlenb csrc23 csrc24 csrc25 csrc26 csrc27
# csrc28 csrc29 csrc2a csrc2b csrc2c csrc2d csrc2e csrc2f
# csrc30 csrc31 csrc32 csrc33 csrc34 csrc35 csrc36 csrc37
# csrc38 csrc39 csrc3a csrc3b csrc3c csrc3d csrc3e csrc3f
# csrc40 csrc41 csrc42 csrc43 csrc44 csrc45 csrc46 csrc47
# csrc48 csrc49 csrc4a csrc4b csrc4c csrc4d csrc4e csrc4f
# csrc50 csrc51 csrc52 csrc53 csrc54 csrc55 csrc56 csrc57
# csrc58 csrc59 csrc5a csrc5b csrc5c csrc5d csrc5e csrc5f
# csrc60 csrc61 csrc62 csrc63 csrc64 csrc65 csrc66 csrc67
# csrc68 csrc69 csrc6a csrc6b csrc6c csrc6d csrc6e csrc6f
# csrc70 csrc71 csrc72 csrc73 csrc74 csrc75 csrc76 csrc77
# csrc78 csrc79 csrc7a csrc7b csrc7c csrc7d csrc7e csrc7f ];
#attach variables [ csr_C8 ]
# [ cycleh timeh instreth hpmcounter3h hpmcounter4h hpmcounter5h hpmcounter6h hpmcounter7h
# hpmcounter8h hpmcounter9h hpmcounter10h hpmcounter11h hpmcounter12h hpmcounter13h hpmcounter14h hpmcounter15h
# hpmcounter16h hpmcounter17h hpmcounter18h hpmcounter19h hpmcounter20h hpmcounter21h hpmcounter22h hpmcounter23h
# hpmcounter24h hpmcounter25h hpmcounter26h hpmcounter27h hpmcounter28h hpmcounter29h hpmcounter30h hpmcounter31h
# csrca0 csrca1 csrca2 csrca3 csrca4 csrca5 csrca6 csrca7
# csrca8 csrca9 csrcaa csrcab csrcac csrcad csrcae csrcaf
# csrcb0 csrcb1 csrcb2 csrcb3 csrcb4 csrcb5 csrcb6 csrcb7
# csrcb8 csrcb9 csrcba csrcbb csrcbc csrcbd csrcbe csrcbf ];
#attach variables [ csr_CC ]
# [ csrcc0 csrcc1 csrcc2 csrcc3 csrcc4 csrcc5 csrcc6 csrcc7
# csrcc8 csrcc9 csrcca csrccb csrccc csrccd csrcce csrccf
# csrcd0 csrcd1 csrcd2 csrcd3 csrcd4 csrcd5 csrcd6 csrcd7
# csrcd8 csrcd9 csrcda csrcdb csrcdc csrcdd csrcde csrcdf
# csrce0 csrce1 csrce2 csrce3 csrce4 csrce5 csrce6 csrce7
# csrce8 csrce9 csrcea csrceb csrcec csrced csrcee csrcef
# csrcf0 csrcf1 csrcf2 csrcf3 csrcf4 csrcf5 csrcf6 csrcf7
# csrcf8 csrcf9 csrcfa csrcfb csrcfc csrcfd csrcfe csrcff ];
#attach variables [ csr_D0 ]
# [ csrd00 csrd01 csrd02 csrd03 csrd04 csrd05 csrd06 csrd07
# csrd08 csrd09 csrd0a csrd0b csrd0c csrd0d csrd0e csrd0f
# csrd10 csrd11 csrd12 csrd13 csrd14 csrd15 csrd16 csrd17
# csrd18 csrd19 csrd1a csrd1b csrd1c csrd1d csrd1e csrd1f
# csrd20 csrd21 csrd22 csrd23 csrd24 csrd25 csrd26 csrd27
# csrd28 csrd29 csrd2a csrd2b csrd2c csrd2d csrd2e csrd2f
# csrd30 csrd31 csrd32 csrd33 csrd34 csrd35 csrd36 csrd37
# csrd38 csrd39 csrd3a csrd3b csrd3c csrd3d csrd3e csrd3f
# csrd40 csrd41 csrd42 csrd43 csrd44 csrd45 csrd46 csrd47
# csrd48 csrd49 csrd4a csrd4b csrd4c csrd4d csrd4e csrd4f
# csrd50 csrd51 csrd52 csrd53 csrd54 csrd55 csrd56 csrd57
# csrd58 csrd59 csrd5a csrd5b csrd5c csrd5d csrd5e csrd5f
# csrd60 csrd61 csrd62 csrd63 csrd64 csrd65 csrd66 csrd67
# csrd68 csrd69 csrd6a csrd6b csrd6c csrd6d csrd6e csrd6f
# csrd70 csrd71 csrd72 csrd73 csrd74 csrd75 csrd76 csrd77
# csrd78 csrd79 csrd7a csrd7b csrd7c csrd7d csrd7e csrd7f ];
#attach variables [ csr_D8 ]
# [ csrd80 csrd81 csrd82 csrd83 csrd84 csrd85 csrd86 csrd87
# csrd88 csrd89 csrd8a csrd8b csrd8c csrd8d csrd8e csrd8f
# csrd90 csrd91 csrd92 csrd93 csrd94 csrd95 csrd96 csrd97
# csrd98 csrd99 csrd9a csrd9b csrd9c csrd9d csrd9e csrd9f
# csrda0 csrda1 csrda2 csrda3 csrda4 csrda5 csrda6 csrda7
# csrda8 csrda9 csrdaa csrdab csrdac csrdad csrdae csrdaf
# csrdb0 csrdb1 csrdb2 csrdb3 csrdb4 csrdb5 csrdb6 csrdb7
# csrdb8 csrdb9 csrdba csrdbb csrdbc csrdbd csrdbe csrdbf ];
#attach variables [ csr_DC ]
# [ csrdc0 csrdc1 csrdc2 csrdc3 csrdc4 csrdc5 csrdc6 csrdc7
# csrdc8 csrdc9 csrdca csrdcb csrdcc csrdcd csrdce csrdcf
# csrdd0 csrdd1 csrdd2 csrdd3 csrdd4 csrdd5 csrdd6 csrdd7
# csrdd8 csrdd9 csrdda csrddb csrddc csrddd csrdde csrddf
# csrde0 csrde1 csrde2 csrde3 csrde4 csrde5 csrde6 csrde7
# csrde8 csrde9 csrdea csrdeb csrdec csrded csrdee csrdef
# csrdf0 csrdf1 csrdf2 csrdf3 csrdf4 csrdf5 csrdf6 csrdf7
# csrdf8 csrdf9 csrdfa csrdfb csrdfc csrdfd csrdfe csrdff ];
#attach variables [ csr_E0 ]
# [ csre00 csre01 csre02 csre03 csre04 csre05 csre06 csre07
# csre08 csre09 csre0a csre0b csre0c csre0d csre0e csre0f
# csre10 csre11 hgeip csre13 csre14 csre15 csre16 csre17
# csre18 csre19 csre1a csre1b csre1c csre1d csre1e csre1f
# csre20 csre21 csre22 csre23 csre24 csre25 csre26 csre27
# csre28 csre29 csre2a csre2b csre2c csre2d csre2e csre2f
# csre30 csre31 csre32 csre33 csre34 csre35 csre36 csre37
# csre38 csre39 csre3a csre3b csre3c csre3d csre3e csre3f
# csre40 csre41 csre42 csre43 csre44 csre45 csre46 csre47
# csre48 csre49 csre4a csre4b csre4c csre4d csre4e csre4f
# csre50 csre51 csre52 csre53 csre54 csre55 csre56 csre57
# csre58 csre59 csre5a csre5b csre5c csre5d csre5e csre5f
# csre60 csre61 csre62 csre63 csre64 csre65 csre66 csre67
# csre68 csre69 csre6a csre6b csre6c csre6d csre6e csre6f
# csre70 csre71 csre72 csre73 csre74 csre75 csre76 csre77
# csre78 csre79 csre7a csre7b csre7c csre7d csre7e csre7f ];
#attach variables [ csr_E8 ]
# [ csre80 csre81 csre82 csre83 csre84 csre85 csre86 csre87
# csre88 csre89 csre8a csre8b csre8c csre8d csre8e csre8f
# csre90 csre91 csre92 csre93 csre94 csre95 csre96 csre97
# csre98 csre99 csre9a csre9b csre9c csre9d csre9e csre9f
# csrea0 csrea1 csrea2 csrea3 csrea4 csrea5 csrea6 csrea7
# csrea8 csrea9 csreaa csreab csreac csread csreae csreaf
# csreb0 csreb1 csreb2 csreb3 csreb4 csreb5 csreb6 csreb7
# csreb8 csreb9 csreba csrebb csrebc csrebd csrebe csrebf ];
#attach variables [ csr_EC ]
# [ csrec0 csrec1 csrec2 csrec3 csrec4 csrec5 csrec6 csrec7
# csrec8 csrec9 csreca csrecb csrecc csrecd csrece csrecf
# csred0 csred1 csred2 csred3 csred4 csred5 csred6 csred7
# csred8 csred9 csreda csredb csredc csredd csrede csredf
# csree0 csree1 csree2 csree3 csree4 csree5 csree6 csree7
# csree8 csree9 csreea csreeb csreec csreed csreee csreef
# csref0 csref1 csref2 csref3 csref4 csref5 csref6 csref7
# csref8 csref9 csrefa csrefb csrefc csrefd csrefe csreff ];
#attach variables [ csr_F0 ]
# [ csrf00 csrf01 csrf02 csrf03 csrf04 csrf05 csrf06 csrf07
# csrf08 csrf09 csrf0a csrf0b csrf0c csrf0d csrf0e csrf0f
# csrf10 mvendorid marchid mimpid mhartid csrf15 csrf16 csrf17
# csrf18 csrf19 csrf1a csrf1b csrf1c csrf1d csrf1e csrf1f
# csrf20 csrf21 csrf22 csrf23 csrf24 csrf25 csrf26 csrf27
# csrf28 csrf29 csrf2a csrf2b csrf2c csrf2d csrf2e csrf2f
# csrf30 csrf31 csrf32 csrf33 csrf34 csrf35 csrf36 csrf37
# csrf38 csrf39 csrf3a csrf3b csrf3c csrf3d csrf3e csrf3f
# csrf40 csrf41 csrf42 csrf43 csrf44 csrf45 csrf46 csrf47
# csrf48 csrf49 csrf4a csrf4b csrf4c csrf4d csrf4e csrf4f
# csrf50 csrf51 csrf52 csrf53 csrf54 csrf55 csrf56 csrf57
# csrf58 csrf59 csrf5a csrf5b csrf5c csrf5d csrf5e csrf5f
# csrf60 csrf61 csrf62 csrf63 csrf64 csrf65 csrf66 csrf67
# csrf68 csrf69 csrf6a csrf6b csrf6c csrf6d csrf6e csrf6f
# csrf70 csrf71 csrf72 csrf73 csrf74 csrf75 csrf76 csrf77
# csrf78 csrf79 csrf7a csrf7b csrf7c csrf7d csrf7e csrf7f ];
#attach variables [ csr_F8 ]
# [ csrf80 csrf81 csrf82 csrf83 csrf84 csrf85 csrf86 csrf87
# csrf88 csrf89 csrf8a csrf8b csrf8c csrf8d csrf8e csrf8f
# csrf90 csrf91 csrf92 csrf93 csrf94 csrf95 csrf96 csrf97
# csrf98 csrf99 csrf9a csrf9b csrf9c csrf9d csrf9e csrf9f
# csrfa0 csrfa1 csrfa2 csrfa3 csrfa4 csrfa5 csrfa6 csrfa7
# csrfa8 csrfa9 csrfaa csrfab csrfac csrfad csrfae csrfaf
# csrfb0 csrfb1 csrfb2 csrfb3 csrfb4 csrfb5 csrfb6 csrfb7
# csrfb8 csrfb9 csrfba csrfbb csrfbc csrfbd csrfbe csrfbf ];
#attach variables [ csr_FC ]
# [ csrfc0 csrfc1 csrfc2 csrfc3 csrfc4 csrfc5 csrfc6 csrfc7
# csrfc8 csrfc9 csrfca csrfcb csrfcc csrfcd csrfce csrfcf
# csrfd0 csrfd1 csrfd2 csrfd3 csrfd4 csrfd5 csrfd6 csrfd7
# csrfd8 csrfd9 csrfda csrfdb csrfdc csrfdd csrfde csrfdf
# csrfe0 csrfe1 csrfe2 csrfe3 csrfe4 csrfe5 csrfe6 csrfe7
# csrfe8 csrfe9 csrfea csrfeb csrfec csrfed csrfee csrfef
# csrff0 csrff1 csrff2 csrff3 csrff4 csrff5 csrff6 csrff7
# csrff8 csrff9 csrffa csrffb csrffc csrffd csrffe csrfff ];
#TODO these names are madeup. do real ones exist?
#TODO go through and use these instead of numbers
@@ -177,6 +761,9 @@ aqrl: ".aqrl" is op2526=3 { export 3:$(XLEN); }
crs1: cr0711 is cr0711 { export cr0711; }
crs1: zero is cr0711 & zero & cop0711=0 { export 0:$(XLEN); }
crdNoSp: cd0711NoSp is cd0711NoSp { export cd0711NoSp; }
crdNoSp: zero is zero & cop0711=0 { export 0:$(XLEN); }
crd: cd0711 is cd0711 { export cd0711; }
crd: zero is zero & cop0711=0 { export 0:$(XLEN); }
@@ -254,117 +841,120 @@ csqspimm: uimm is cop0710 & cop1112 [ uimm = (cop0710 << 6) | (cop1112 << 4); ]
# csr[11:10] - read/write (00, 01, 10) or read-only (11)
# csr[9:8] - lowest privilege that can access the CSR
# 0x000-0x0ff
with csr: op3031=0 & op2829=0 {
: csr_0 is csr_0 { export csr_0; } # user, standard read/write
}
## 0x000-0x0ff
#with csr: op3031=0 & op2829=0 {
# : csr_0 is csr_0 { export csr_0; } # user, standard read/write
#}
#
## 0x100-0x1ff
#with csr: op3031=0 & op2829=1 {
# : csr_1 is csr_1 { export csr_1; } # supervisor, standard read/write
#}
#
## 0x200-0x2ff
#with csr: op3031=0 & op2829=2 {
# : csr_2 is csr_2 { export csr_2; } # hypervisor, standard read/write
#}
#
## 0x300-0x3ff
#with csr: op3031=0 & op2829=3 {
# : csr_3 is csr_3 { export csr_3; } # machine, standard read/write
#}
#
## 0x400-0x4ff
#with csr: op3031=1 & op2829=0 {
# : csr_4 is csr_4 { export csr_4; } # user, standard read/write
#}
#
## 0x500-0x5ff
#with csr: op3031=1 & op2829=1 {
# : csr_50 is csr_50 & op2727=0 { export csr_50; } # supervisor, standard read/write
# : csr_58 is csr_58 & op2627=2 { export csr_58; } # supervisor, standard read/write
# : csr_5C is csr_5C & op2627=3 { export csr_5C; } # supervisor, custom read/write
#}
#
## 0x600-0x6ff
#with csr: op3031=1 & op2829=2 {
# : csr_60 is csr_60 & op2727=0 { export csr_60; } # hypervisor, standard read/write
# : csr_68 is csr_68 & op2627=2 { export csr_68; } # hypervisor, standard read/write
# : csr_6C is csr_6C & op2627=3 { export csr_6C; } # hypervisor, custom read/write
#}
#
## 0x700-0x7ff
#with csr: op3031=1 & op2829=3 {
# : csr_70 is csr_70 & op2727=0 { export csr_70; } # machine, standard read/write
# : csr_78 is csr_78 & op2527=4 { export csr_78; } # machine, standard read/write
# : csr_7A is csr_7A & op2427=0xa { export csr_7A; } # machine, standard read/write debug
# : csr_7B is csr_7B & op2427=0xb { export csr_7B; } # machine, debug-mode-only
# : csr_7C is csr_7C & op2627=3 { export csr_7C; } # machine, custom read/write
#}
#
## 0x800-0x8ff
#with csr: op3031=2 & op2829=0 {
# : csr_8 is csr_8 { export csr_8; } # user, custom read/write
#}
#
## 0x900-0x9ff
#with csr: op3031=2 & op2829=1 {
# : csr_90 is csr_90 & op2727=0 { export csr_90; } # supervisor, standard read/write
# : csr_98 is csr_98 & op2627=2 { export csr_98; } # supervisor, standard read/write
# : csr_9C is csr_9C & op2627=3 { export csr_9C; } # supervisor, custom read/write
#}
#
## 0xa00-0xaff
#with csr: op3031=2 & op2829=2 {
# : csr_A0 is csr_A0 & op2727=0 { export csr_A0; } # hypervisor, standard read/write
# : csr_A8 is csr_A8 & op2627=2 { export csr_A8; } # hypervisor, standard read/write
# : csr_AC is csr_AC & op2627=3 { export csr_AC; } # hypervisor, custom read/write
#}
#
## 0xb00-0xbff
#with csr: op3031=2 & op2829=3 {
# : csr_B0 is csr_B0 & op2727=0 { export csr_B0; } # machine, standard read/write
# : csr_B8 is csr_B8 & op2627=2 { export csr_B8; } # machine, standard read/write
# : csr_BC is csr_BC & op2627=3 { export csr_BC; } # machine, custom read/write
#}
#
## 0xc00-0xcff
#with csr: op3031=3 & op2829=0 {
# : csr_C0 is csr_C0 & op2727=0 { export csr_C0; } # user, standard read-only
# : csr_C8 is csr_C8 & op2627=2 { export csr_C8; } # user, standard read-only
# : csr_CC is csr_CC & op2627=3 { export csr_CC; } # user, custom read-only
#}
#
## 0xd00-0xdff
#with csr: op3031=3 & op2829=1 {
# : csr_D0 is csr_D0 & op2727=0 { export csr_D0; } # supervisor, standard read-only
# : csr_D8 is csr_D8 & op2627=2 { export csr_D8; } # supervisor, standard read-only
# : csr_DC is csr_DC & op2627=3 { export csr_DC; } # supervisor, custom read-only
#}
#
## 0xe00-0xeff
#with csr: op3031=3 & op2829=2 {
# : csr_E0 is csr_E0 & op2727=0 { export csr_E0; } # hypervisor, standard read-only
# : csr_E8 is csr_E8 & op2627=2 { export csr_E8; } # hypervisor, standard read-only
# : csr_EC is csr_EC & op2627=3 { export csr_EC; } # hypervisor, custom read-only
#}
#
## 0xf00-0xfff
#with csr: op3031=3 & op2829=3 {
# : csr_F0 is csr_F0 & op2727=0 { export csr_F0; } # machine, standard read-only
# : csr_F8 is csr_F8 & op2627=2 { export csr_F8; } # machine, standard read-only
# : csr_FC is csr_FC & op2627=3 { export csr_FC; } # machine, custom read-only
#}
#
# 0x100-0x1ff
with csr: op3031=0 & op2829=1 {
: csr_1 is csr_1 { export csr_1; } # supervisor, standard read/write
}
csr: csr_reg is op2031 [ csr_reg = $(CSR_REG_START) + op2031; ] { export *[csreg]:$(XLEN) csr_reg; }
# 0x200-0x2ff
with csr: op3031=0 & op2829=2 {
: csr_2 is csr_2 { export csr_2; } # hypervisor, standard read/write
}
# 0x300-0x3ff
with csr: op3031=0 & op2829=3 {
: csr_3 is csr_3 { export csr_3; } # machine, standard read/write
}
# 0x400-0x4ff
with csr: op3031=1 & op2829=0 {
: csr_4 is csr_4 { export csr_4; } # user, standard read/write
}
# 0x500-0x5ff
with csr: op3031=1 & op2829=1 {
: csr_50 is csr_50 & op2727=0 { export csr_50; } # supervisor, standard read/write
: csr_58 is csr_58 & op2627=2 { export csr_58; } # supervisor, standard read/write
: csr_5C is csr_5C & op2627=3 { export csr_5C; } # supervisor, custom read/write
}
# 0x600-0x6ff
with csr: op3031=1 & op2829=2 {
: csr_60 is csr_60 & op2727=0 { export csr_60; } # hypervisor, standard read/write
: csr_68 is csr_68 & op2627=2 { export csr_68; } # hypervisor, standard read/write
: csr_6C is csr_6C & op2627=3 { export csr_6C; } # hypervisor, custom read/write
}
# 0x700-0x7ff
with csr: op3031=1 & op2829=3 {
: csr_70 is csr_70 & op2727=0 { export csr_70; } # machine, standard read/write
: csr_78 is csr_78 & op2527=4 { export csr_78; } # machine, standard read/write
: csr_7A is csr_7A & op2427=0xa { export csr_7A; } # machine, standard read/write debug
: csr_7B is csr_7B & op2427=0xb { export csr_7B; } # machine, debug-mode-only
: csr_7C is csr_7C & op2627=3 { export csr_7C; } # machine, custom read/write
}
# 0x800-0x8ff
with csr: op3031=2 & op2829=0 {
: csr_8 is csr_8 { export csr_8; } # user, custom read/write
}
# 0x900-0x9ff
with csr: op3031=2 & op2829=1 {
: csr_90 is csr_90 & op2727=0 { export csr_90; } # supervisor, standard read/write
: csr_98 is csr_98 & op2627=2 { export csr_98; } # supervisor, standard read/write
: csr_9C is csr_9C & op2627=3 { export csr_9C; } # supervisor, custom read/write
}
# 0xa00-0xaff
with csr: op3031=2 & op2829=2 {
: csr_A0 is csr_A0 & op2727=0 { export csr_A0; } # hypervisor, standard read/write
: csr_A8 is csr_A8 & op2627=2 { export csr_A8; } # hypervisor, standard read/write
: csr_AC is csr_AC & op2627=3 { export csr_AC; } # hypervisor, custom read/write
}
# 0xb00-0xbff
with csr: op3031=2 & op2829=3 {
: csr_B0 is csr_B0 & op2727=0 { export csr_B0; } # machine, standard read/write
: csr_B8 is csr_B8 & op2627=2 { export csr_B8; } # machine, standard read/write
: csr_BC is csr_BC & op2627=3 { export csr_BC; } # machine, custom read/write
}
# 0xc00-0xcff
with csr: op3031=3 & op2829=0 {
: csr_C0 is csr_C0 & op2727=0 { export csr_C0; } # user, standard read-only
: csr_C8 is csr_C8 & op2627=2 { export csr_C8; } # user, standard read-only
: csr_CC is csr_CC & op2627=3 { export csr_CC; } # user, custom read-only
}
# 0xd00-0xdff
with csr: op3031=3 & op2829=1 {
: csr_D0 is csr_D0 & op2727=0 { export csr_D0; } # supervisor, standard read-only
: csr_D8 is csr_D8 & op2627=2 { export csr_D8; } # supervisor, standard read-only
: csr_DC is csr_DC & op2627=3 { export csr_DC; } # supervisor, custom read-only
}
# 0xe00-0xeff
with csr: op3031=3 & op2829=2 {
: csr_E0 is csr_E0 & op2727=0 { export csr_E0; } # hypervisor, standard read-only
: csr_E8 is csr_E8 & op2627=2 { export csr_E8; } # hypervisor, standard read-only
: csr_EC is csr_EC & op2627=3 { export csr_EC; } # hypervisor, custom read-only
}
# 0xf00-0xfff
with csr: op3031=3 & op2829=3 {
: csr_F0 is csr_F0 & op2727=0 { export csr_F0; } # machine, standard read-only
: csr_F8 is csr_F8 & op2627=2 { export csr_F8; } # machine, standard read-only
: csr_FC is csr_FC & op2627=3 { export csr_FC; } # machine, custom read-only
}
vm: op2525 is op2525 { local tmp:1 = op2525; export tmp; }
vs1: v1519 is v1519 { export v1519; }
vs2: v2024 is v2024 { export v2024; }
vs3: v0711 is v0711 { export v0711; }
vd: v0711 is v0711 { export v0711; }
vm: ,v0^".t" is op2525=0 & v0 & vd { vd = vd & v0; }
vm: "" is op2525=1 { }
simm5: sop1519 is sop1519 { local tmp:$(XLEN) = sop1519; export tmp; }
# zimm: op1519 is op1519 { local tmp:$(XLEN) = op1519; export tmp; }

View File

@@ -22,6 +22,7 @@
</data_organization>
<global>
<range space="ram"/>
<range space="csreg"/>
<register name="gp"/>
<register name="tp"/>
</global>

View File

@@ -20,6 +20,7 @@
</data_organization>
<global>
<range space="ram"/>
<range space="csreg"/>
<register name="gp"/>
<register name="tp"/>
</global>

View File

@@ -22,6 +22,7 @@
</data_organization>
<global>
<range space="ram"/>
<range space="csreg"/>
<register name="gp"/>
<register name="tp"/>
</global>

View File

@@ -18,11 +18,14 @@
<entry size="8" alignment="8" />
</size_alignment_map>
</data_organization>
<global>
<range space="ram"/>
<range space="csreg"/>
<register name="gp"/>
<register name="tp"/>
</global>
<returnaddress>
<register name="ra"/>
</returnaddress>