mirror of
https://gitlab.com/camelot/kickc.git
synced 2025-01-13 18:30:21 +00:00
Changed pointer and directive parsing to distinguish directives applied to pointers and directives applied to variables. Fixed all example-code to reflect this. Closes #271
This commit is contained in:
parent
838b8f4d26
commit
a579ab491a
@ -61,6 +61,8 @@ public class VariableBuilder {
|
||||
variable.setVolatile(this.isVolatile());
|
||||
variable.setExport(this.isExport());
|
||||
variable.setPermanent(this.isPermanent());
|
||||
variable.setToNoModify(this.isToNoModify());
|
||||
variable.setToVolatile(this.isToVolatile());
|
||||
variable.setOptimize(this.isOptimize());
|
||||
variable.setRegister(this.getRegister());
|
||||
if(variable.getRegister() instanceof Registers.RegisterMainMem) {
|
||||
|
@ -68,6 +68,12 @@ public class Variable implements Symbol {
|
||||
/** Specifies that the variable must always live in memory to be available for any multi-threaded accees (eg. in interrupts). (volatile keyword) [Only Variables] */
|
||||
private boolean isVolatile;
|
||||
|
||||
/** Specifies that the variable points to a volatile. (volatile* keyword) */
|
||||
private boolean isToVolatile;
|
||||
|
||||
/** Specifies that the variable points to a a nomodify. (const* keyword) */
|
||||
private boolean isToNoModify;
|
||||
|
||||
/** Specifies that the variable must always be added to the output ASM even if it is never used anywhere. (export keyword) */
|
||||
private boolean export;
|
||||
|
||||
@ -188,6 +194,8 @@ public class Variable implements Symbol {
|
||||
version.setNoModify(phiMaster.isNoModify());
|
||||
version.setRegister(phiMaster.getRegister());
|
||||
version.setVolatile(phiMaster.isVolatile());
|
||||
version.setToNoModify(phiMaster.isToNoModify());
|
||||
version.setToVolatile(phiMaster.isToVolatile());
|
||||
version.setPermanent(phiMaster.isPermanent());
|
||||
version.setExport(phiMaster.isExport());
|
||||
version.setComments(phiMaster.getComments());
|
||||
@ -232,6 +240,8 @@ public class Variable implements Symbol {
|
||||
constVar.setNoModify(variable.isNoModify());
|
||||
constVar.setRegister(variable.getRegister());
|
||||
constVar.setVolatile(variable.isVolatile());
|
||||
constVar.setToNoModify(variable.isToNoModify());
|
||||
constVar.setToVolatile(variable.isToVolatile());
|
||||
constVar.setPermanent(variable.isPermanent());
|
||||
constVar.setExport(variable.isExport());
|
||||
constVar.setComments(variable.getComments());
|
||||
@ -252,6 +262,8 @@ public class Variable implements Symbol {
|
||||
copy.setNoModify(original.isNoModify());
|
||||
copy.setPermanent(original.isPermanent());
|
||||
copy.setVolatile(original.isVolatile());
|
||||
copy.setToNoModify(original.isToNoModify());
|
||||
copy.setToVolatile(original.isToVolatile());
|
||||
copy.setExport(original.isExport());
|
||||
copy.setRegister(original.getRegister());
|
||||
copy.setComments(original.getComments());
|
||||
@ -282,6 +294,8 @@ public class Variable implements Symbol {
|
||||
}
|
||||
memberVariable.setVolatile(structVar.isVolatile());
|
||||
memberVariable.setNoModify(structVar.isNoModify());
|
||||
memberVariable.setToNoModify(structVar.isToNoModify());
|
||||
memberVariable.setToVolatile(structVar.isToVolatile());
|
||||
memberVariable.setExport(structVar.isExport());
|
||||
memberVariable.setPermanent(structVar.isPermanent());
|
||||
return memberVariable;
|
||||
@ -479,14 +493,6 @@ public class Variable implements Symbol {
|
||||
this.noModify = noModify;
|
||||
}
|
||||
|
||||
public boolean isPermanent() {
|
||||
return permanent;
|
||||
}
|
||||
|
||||
public void setPermanent(boolean permanent) {
|
||||
this.permanent = permanent;
|
||||
}
|
||||
|
||||
public boolean isVolatile() {
|
||||
return isVolatile;
|
||||
}
|
||||
@ -495,6 +501,30 @@ public class Variable implements Symbol {
|
||||
this.isVolatile = aVolatile;
|
||||
}
|
||||
|
||||
public boolean isToNoModify() {
|
||||
return isToNoModify;
|
||||
}
|
||||
|
||||
public void setToNoModify(boolean toNoModify) {
|
||||
isToNoModify = toNoModify;
|
||||
}
|
||||
|
||||
public boolean isToVolatile() {
|
||||
return isToVolatile;
|
||||
}
|
||||
|
||||
public void setToVolatile(boolean toVolatile) {
|
||||
isToVolatile = toVolatile;
|
||||
}
|
||||
|
||||
public boolean isPermanent() {
|
||||
return permanent;
|
||||
}
|
||||
|
||||
public void setPermanent(boolean permanent) {
|
||||
this.permanent = permanent;
|
||||
}
|
||||
|
||||
public boolean isExport() {
|
||||
return export;
|
||||
}
|
||||
@ -582,6 +612,10 @@ public class Variable implements Symbol {
|
||||
return new StringBuilder()
|
||||
.append("(")
|
||||
.append(isKindConstant() ? "const " : "")
|
||||
//.append(isNoModify() ? "nomodify " : "")
|
||||
//.append(isVolatile() ? "volatile " : "")
|
||||
//.append(isToNoModify() ? "to_nomodify " : "")
|
||||
//.append(isToVolatile() ? "to_volatile " : "")
|
||||
.append(getType().getTypeName())
|
||||
.append(isKindIntermediate() ? "~" : "")
|
||||
.append(") ")
|
||||
|
@ -536,119 +536,207 @@ public class Pass0GenerateStatementSequence extends KickCParserBaseVisitor<Objec
|
||||
/** State specifying that we are currently populating struct members. */
|
||||
private boolean structMember = false;
|
||||
|
||||
/** Holds the declared type (type level). */
|
||||
private SymbolType type = null;
|
||||
/** Holds the information about whether the declared variable is an array and the size of the array if it is (type level). */
|
||||
private ArraySpec arraySpec;
|
||||
/** Holds the declared directives when descending into a Variable Declaration. (type level) */
|
||||
private List<Directive> directives = null;
|
||||
/** Holds directives that are not part of the type-spec (all other than const & volatile) when descending into a Variable Declaration. (type level) */
|
||||
private List<Directive> declDirectives = null;
|
||||
/** Holds the declared comments when descending into a Variable Declaration. (type level) */
|
||||
private List<Comment> comments = null;
|
||||
|
||||
/** Holds the type when diving into a single variable. (variable level) */
|
||||
private SymbolType varType = null;
|
||||
/** Holds the array information for a single variable. (variable level) */
|
||||
private ArraySpec varArraySpec;
|
||||
/** Holds the declared directives for a single variable. (variable level) */
|
||||
private List<Directive> varDirectives = null;
|
||||
private List<Comment> declComments = null;
|
||||
/** The declared type (type level) */
|
||||
private VariableDeclType declType;
|
||||
/** The declared type (variable level) */
|
||||
private VariableDeclType varDeclType;
|
||||
|
||||
/**
|
||||
* Exits the type layer (clears everyting except struct information)
|
||||
* Exits the type layer (clears everything except struct information)
|
||||
*/
|
||||
void exitType() {
|
||||
exitVar();
|
||||
this.type = null;
|
||||
this.directives = null;
|
||||
this.arraySpec = null;
|
||||
this.comments = null;
|
||||
this.declDirectives = null;
|
||||
this.declComments = null;
|
||||
this.declType = null;
|
||||
this.varDeclType = null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Exits the variable layer (clears variable information)
|
||||
*/
|
||||
void exitVar() {
|
||||
this.varType = null;
|
||||
this.varArraySpec = null;
|
||||
this.varDirectives = null;
|
||||
this.varDeclType = null;
|
||||
}
|
||||
|
||||
/** The declared type of a variable. Combines SymbolType, type directives (const, volatile) and ArraySpec. It holds advanced type information like <p><code>char volatile * const * [42]</code> */
|
||||
static class VariableDeclType {
|
||||
/** The type. */
|
||||
SymbolType type;
|
||||
/** The array specification (non-null if it is an array, also holds size) */
|
||||
ArraySpec arraySpec;
|
||||
/** Const / Volatile Directives if applied to the type */
|
||||
List<Directive> typeDirectives;
|
||||
/** If the type is SymbolTypePointer this holds the declaration type of the elements. */
|
||||
VariableDeclType elementDeclType;
|
||||
|
||||
public VariableDeclType(SymbolType type) {
|
||||
this.type = type;
|
||||
this.typeDirectives = new ArrayList<>();
|
||||
}
|
||||
|
||||
public SymbolType getType() {
|
||||
return type;
|
||||
}
|
||||
|
||||
public ArraySpec getArraySpec() {
|
||||
return arraySpec;
|
||||
}
|
||||
|
||||
public List<Directive> getTypeDirectives() {
|
||||
return typeDirectives;
|
||||
}
|
||||
|
||||
public void setTypeDirectives(List<Directive> directives) {
|
||||
this.typeDirectives = directives;
|
||||
}
|
||||
|
||||
public void setElementDeclType(VariableDeclType elementDeclType) {
|
||||
this.elementDeclType = elementDeclType;
|
||||
}
|
||||
|
||||
public void setArraySpec(ArraySpec arraySpec) {
|
||||
this.arraySpec = arraySpec;
|
||||
}
|
||||
|
||||
public VariableDeclType getElementDeclType() {
|
||||
return elementDeclType;
|
||||
}
|
||||
}
|
||||
|
||||
VariableDeclType getEffectiveDeclType() {
|
||||
return varDeclType != null ? varDeclType : declType;
|
||||
}
|
||||
|
||||
SymbolType getEffectiveType() {
|
||||
return varType != null ? varType : type;
|
||||
if(varDeclType != null)
|
||||
return varDeclType.getType();
|
||||
if(declType != null)
|
||||
return declType.getType();
|
||||
return null;
|
||||
}
|
||||
|
||||
ArraySpec getEffectiveArraySpec() {
|
||||
return varArraySpec != null ? varArraySpec : arraySpec;
|
||||
return varDeclType != null ? varDeclType.getArraySpec() : declType.getArraySpec();
|
||||
}
|
||||
|
||||
/**
|
||||
* Set type-level directives. Splits directives into type-directives (const, volatile) and general directives (all other).
|
||||
*
|
||||
* @param directives The directives
|
||||
*/
|
||||
void setDeclDirectives(List<Directive> directives) {
|
||||
this.declDirectives = new ArrayList<>();
|
||||
for(Directive directive : directives) {
|
||||
if(directive instanceof Directive.Const || directive instanceof Directive.Volatile) {
|
||||
// Type directive
|
||||
this.declType.getTypeDirectives().add(directive);
|
||||
} else {
|
||||
// general directive
|
||||
this.declDirectives.add(directive);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
List<Directive> getEffectiveDirectives() {
|
||||
final ArrayList<Directive> dirs = new ArrayList<>();
|
||||
if(directives != null)
|
||||
dirs.addAll(directives);
|
||||
if(varDirectives != null)
|
||||
dirs.addAll(varDirectives);
|
||||
// Add all general directives
|
||||
dirs.addAll(declDirectives);
|
||||
// Add type-directives
|
||||
final VariableDeclType effectiveDeclType = getEffectiveDeclType();
|
||||
dirs.addAll(effectiveDeclType.getTypeDirectives());
|
||||
// Convert element directives
|
||||
final VariableDeclType elementDeclType = effectiveDeclType.getElementDeclType();
|
||||
if(elementDeclType != null) {
|
||||
for(Directive elementTypeDirective : elementDeclType.getTypeDirectives()) {
|
||||
if(elementTypeDirective instanceof Directive.Const) {
|
||||
dirs.add(new Directive.ToConst());
|
||||
} else if(elementTypeDirective instanceof Directive.Volatile) {
|
||||
dirs.add(new Directive.ToVolatile());
|
||||
}
|
||||
}
|
||||
// Produce error on any deeper directives
|
||||
VariableDeclType deepDeclType = elementDeclType.getElementDeclType();
|
||||
while(deepDeclType != null) {
|
||||
if(!deepDeclType.getTypeDirectives().isEmpty()) {
|
||||
throw new CompileError("Deep const/volatile not supported.");
|
||||
}
|
||||
deepDeclType = deepDeclType.getElementDeclType();
|
||||
}
|
||||
}
|
||||
return dirs;
|
||||
}
|
||||
|
||||
public List<Comment> getComments() {
|
||||
return comments;
|
||||
public List<Comment> getDeclComments() {
|
||||
return declComments;
|
||||
}
|
||||
|
||||
boolean isStructMember() {
|
||||
return structMember;
|
||||
}
|
||||
|
||||
public void setType(SymbolType type) {
|
||||
this.type = type;
|
||||
public VariableDeclType getDeclType() {
|
||||
return declType;
|
||||
}
|
||||
|
||||
void setArraySpec(ArraySpec arraySpec) {
|
||||
this.arraySpec = arraySpec;
|
||||
public void setDeclType(SymbolType type) {
|
||||
this.declType = new VariableDeclType(type);
|
||||
}
|
||||
|
||||
void setDirectives(List<Directive> directives) {
|
||||
this.directives = directives;
|
||||
public void setVarDeclType(VariableDeclType varDeclType) {
|
||||
this.varDeclType = varDeclType;
|
||||
}
|
||||
|
||||
public void setComments(List<Comment> comments) {
|
||||
this.comments = comments;
|
||||
public VariableDeclType getVarDeclType() {
|
||||
return varDeclType;
|
||||
}
|
||||
|
||||
public void setDeclComments(List<Comment> declComments) {
|
||||
this.declComments = declComments;
|
||||
}
|
||||
|
||||
void setStructMember(boolean structMember) {
|
||||
this.structMember = structMember;
|
||||
}
|
||||
|
||||
void setVarArraySpec(ArraySpec varArraySpec) {
|
||||
this.varArraySpec = varArraySpec;
|
||||
}
|
||||
|
||||
void setVarType(SymbolType varType) {
|
||||
this.varType = varType;
|
||||
}
|
||||
}
|
||||
|
||||
private VariableDeclaration varDecl = new VariableDeclaration();
|
||||
|
||||
@Override
|
||||
public Object visitDeclPointer(KickCParser.DeclPointerContext ctx) {
|
||||
if(!ctx.directive().isEmpty()) {
|
||||
throw new InternalError("Not implemented!");
|
||||
}
|
||||
varDecl.setVarType(new SymbolTypePointer(varDecl.getEffectiveType()));
|
||||
// Detect char * const * x;
|
||||
//if(varDecl.getDeclDirectives()!=null && !varDecl.getDeclDirectives().isEmpty()) {
|
||||
// throw new CompileError("Pointer directives (const/volatile) not supported between pointers.", new StatementSource(ctx.getParent().getParent()));
|
||||
//};
|
||||
// Create a var-level declaration type
|
||||
final VariableDeclaration.VariableDeclType elementDeclType = varDecl.getEffectiveDeclType();
|
||||
VariableDeclaration.VariableDeclType pointerDeclType = new VariableDeclaration.VariableDeclType(new SymbolTypePointer(elementDeclType.getType()));
|
||||
pointerDeclType.setElementDeclType(elementDeclType);
|
||||
final List<Directive> typeDirectives = getDirectives(ctx.directive());
|
||||
pointerDeclType.setTypeDirectives(typeDirectives);
|
||||
varDecl.setVarDeclType(pointerDeclType);
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Object visitDeclArray(KickCParser.DeclArrayContext ctx) {
|
||||
// Handle array type declaration by updating the declared type and the array spec
|
||||
SymbolType elementType = varDecl.getEffectiveType();
|
||||
ArraySpec arraySpec;
|
||||
if(ctx.expr() != null) {
|
||||
RValue sizeVal = (RValue) visit(ctx.expr());
|
||||
varDecl.setVarArraySpec(new ArraySpec((ConstantValue) sizeVal));
|
||||
varDecl.setVarType(new SymbolTypePointer(elementType));
|
||||
arraySpec = new ArraySpec((ConstantValue) sizeVal);
|
||||
} else {
|
||||
varDecl.setVarArraySpec(new ArraySpec());
|
||||
varDecl.setVarType(new SymbolTypePointer(elementType));
|
||||
arraySpec = new ArraySpec();
|
||||
}
|
||||
final VariableDeclaration.VariableDeclType elementDeclType = varDecl.getEffectiveDeclType();
|
||||
VariableDeclaration.VariableDeclType arrayDeclType = new VariableDeclaration.VariableDeclType(new SymbolTypePointer(elementDeclType.getType()));
|
||||
arrayDeclType.setElementDeclType(elementDeclType);
|
||||
arrayDeclType.setArraySpec(arraySpec);
|
||||
varDecl.setVarDeclType(arrayDeclType);
|
||||
return null;
|
||||
}
|
||||
|
||||
@ -662,9 +750,9 @@ public class Pass0GenerateStatementSequence extends KickCParserBaseVisitor<Objec
|
||||
public Object visitDeclType(KickCParser.DeclTypeContext ctx) {
|
||||
List<KickCParser.DirectiveContext> directive = ctx.directive();
|
||||
varDecl.exitType();
|
||||
varDecl.setType((SymbolType) visit(ctx.type()));
|
||||
varDecl.setDirectives(getDirectives(directive));
|
||||
varDecl.setComments(getCommentsSymbol(ctx.getParent()));
|
||||
varDecl.setDeclType((SymbolType) visit(ctx.type()));
|
||||
varDecl.setDeclDirectives(getDirectives(directive));
|
||||
varDecl.setDeclComments(getCommentsSymbol(ctx.getParent()));
|
||||
return null;
|
||||
}
|
||||
|
||||
@ -713,9 +801,9 @@ public class Pass0GenerateStatementSequence extends KickCParserBaseVisitor<Objec
|
||||
ConstantValue constInitValue = getConstInitValue(initValue, initializer, statementSource);
|
||||
variable.setInitValue(constInitValue);
|
||||
// Add comments to constant
|
||||
variable.setComments(ensureUnusedComments(varDecl.getComments()));
|
||||
variable.setComments(ensureUnusedComments(varDecl.getDeclComments()));
|
||||
} else if(!variable.isKindConstant() && !varDecl.isStructMember()) {
|
||||
Statement initStmt = new StatementAssignment(variable.getVariableRef(), initValue, true, statementSource, ensureUnusedComments(varDecl.getComments()));
|
||||
Statement initStmt = new StatementAssignment(variable.getVariableRef(), initValue, true, statementSource, ensureUnusedComments(varDecl.getDeclComments()));
|
||||
sequence.addStatement(initStmt);
|
||||
}
|
||||
if(initializer != null)
|
||||
@ -781,7 +869,7 @@ public class Pass0GenerateStatementSequence extends KickCParserBaseVisitor<Objec
|
||||
// Set constant value
|
||||
variable.setInitValue(getConstInitValue(constantArrayKickAsm, null, statementSource));
|
||||
// Add comments to constant
|
||||
variable.setComments(ensureUnusedComments(varDecl.getComments()));
|
||||
variable.setComments(ensureUnusedComments(varDecl.getDeclComments()));
|
||||
varDecl.exitVar();
|
||||
return null;
|
||||
}
|
||||
@ -1287,6 +1375,7 @@ public class Pass0GenerateStatementSequence extends KickCParserBaseVisitor<Objec
|
||||
throw new CompileError("Error! Loop variable not declared " + varName, statementSource);
|
||||
}
|
||||
}
|
||||
boolean initialAssignment = (varDecl.getEffectiveType() != null);
|
||||
varDecl.exitType();
|
||||
KickCParser.StmtForContext stmtForCtx = (KickCParser.StmtForContext) ctx.getParent();
|
||||
KickCParser.ExprContext rangeFirstCtx = ctx.expr(0);
|
||||
@ -1298,7 +1387,6 @@ public class Pass0GenerateStatementSequence extends KickCParserBaseVisitor<Objec
|
||||
if(rangeFirstValue instanceof ConstantInteger) ((ConstantInteger) rangeFirstValue).setType(varType);
|
||||
if(rangeLastValue instanceof ConstantInteger) ((ConstantInteger) rangeLastValue).setType(varType);
|
||||
}
|
||||
boolean initialAssignment = (varDecl.getEffectiveType() != null);
|
||||
Statement stmtInit = new StatementAssignment((LValue) lValue.getRef(), rangeFirstValue, initialAssignment, statementSource, Comment.NO_COMMENTS);
|
||||
sequence.addStatement(stmtInit);
|
||||
// Add label
|
||||
@ -1636,13 +1724,14 @@ public class Pass0GenerateStatementSequence extends KickCParserBaseVisitor<Objec
|
||||
}
|
||||
|
||||
@Override
|
||||
public Object visitTypeNamedRef(KickCParser.TypeNamedRefContext ctx) {
|
||||
public SymbolType visitTypeNamedRef(KickCParser.TypeNamedRefContext ctx) {
|
||||
Scope typeDefScope = program.getScope().getTypeDefScope();
|
||||
Variable typeDefVariable = typeDefScope.getVariable(ctx.getText());
|
||||
if(typeDefVariable != null) {
|
||||
if(typeDefVariable.getArraySpec()!=null)
|
||||
if(typeDefVariable.getArraySpec() != null)
|
||||
// TODO: Handle typedef array of array correctly
|
||||
varDecl.setArraySpec(typeDefVariable.getArraySpec());
|
||||
//varDecl.getDeclType().setArraySpec(typeDefVariable.getArraySpec());
|
||||
throw new InternalError("Typedef with arrays not supported!");
|
||||
return typeDefVariable.getType();
|
||||
}
|
||||
throw new CompileError("Unknown type " + ctx.getText(), new StatementSource(ctx));
|
||||
@ -1678,11 +1767,13 @@ public class Pass0GenerateStatementSequence extends KickCParserBaseVisitor<Objec
|
||||
SymbolType elementType = (SymbolType) visit(ctx.type());
|
||||
if(ctx.expr() != null) {
|
||||
RValue sizeVal = (RValue) visit(ctx.expr());
|
||||
varDecl.setArraySpec(new ArraySpec((ConstantValue) sizeVal));
|
||||
return new SymbolTypePointer(elementType);
|
||||
//varDecl.getDeclType().setArraySpec(new ArraySpec((ConstantValue) sizeVal));
|
||||
//return new SymbolTypePointer(elementType);
|
||||
throw new InternalError("Array types not supported!");
|
||||
} else {
|
||||
varDecl.setArraySpec(new ArraySpec());
|
||||
return new SymbolTypePointer(elementType);
|
||||
//varDecl.getDeclType().setArraySpec(new ArraySpec());
|
||||
//return new SymbolTypePointer(elementType);
|
||||
throw new InternalError("Array types not supported!");
|
||||
}
|
||||
} else {
|
||||
throw new CompileError("ERROR! Non-standard array declaration. Allow using commandline option -Warraytype", new StatementSource(ctx));
|
||||
|
@ -3,8 +3,8 @@
|
||||
// See http://www.pagetable.com/c64rom/c64rom_sc.html
|
||||
|
||||
// Zeropage addresses used to hold lo/hi-bytes of addresses of float numbers in MEM
|
||||
const char* memLo = 0xfe;
|
||||
const char* memHi = 0xff;
|
||||
char* const memLo = 0xfe;
|
||||
char* const memHi = 0xff;
|
||||
|
||||
// Prepare MEM pointers for operations using MEM
|
||||
inline void prepareMEM(unsigned int mem) {
|
||||
|
@ -1,12 +1,12 @@
|
||||
// Commodore 64 Registers and Constants
|
||||
|
||||
// Processor port data direction register
|
||||
const byte* PROCPORT_DDR = $00;
|
||||
byte* const PROCPORT_DDR = $00;
|
||||
// Mask for PROCESSOR_PORT_DDR which allows only memory configuration to be written
|
||||
const byte PROCPORT_DDR_MEMORY_MASK = %00000111;
|
||||
|
||||
// Processor Port Register controlling RAM/ROM configuration and the datasette
|
||||
const byte* PROCPORT = $01;
|
||||
byte* const PROCPORT = $01;
|
||||
// RAM in all three areas $A000, $D000, $E000
|
||||
const byte PROCPORT_RAM_ALL = %00000000;
|
||||
// RAM in $A000, $E000 I/O in $D000
|
||||
@ -19,7 +19,7 @@ const byte PROCPORT_KERNEL_IO = %00000110;
|
||||
const byte PROCPORT_BASIC_KERNEL_IO = %00000111;
|
||||
|
||||
// The address of the CHARGEN character set
|
||||
const byte* CHARGEN = $d000;
|
||||
byte* const CHARGEN = $d000;
|
||||
|
||||
// Positions of the border (in sprite positions)
|
||||
const byte BORDER_XPOS_LEFT=24;
|
||||
@ -30,48 +30,48 @@ const byte BORDER_YPOS_BOTTOM=250;
|
||||
// The offset of the sprite pointers from the screen start address
|
||||
const word SPRITE_PTRS = $3f8;
|
||||
|
||||
const byte* SPRITES_XPOS = $d000;
|
||||
const byte* SPRITES_YPOS = $d001;
|
||||
const byte* SPRITES_XMSB = $d010;
|
||||
const byte* RASTER = $d012;
|
||||
const byte* SPRITES_ENABLE = $d015;
|
||||
const byte* SPRITES_EXPAND_Y = $d017;
|
||||
const byte* SPRITES_PRIORITY = $d01b;
|
||||
const byte* SPRITES_MC = $d01c;
|
||||
const byte* SPRITES_EXPAND_X = $d01d;
|
||||
const byte* BORDERCOL = $d020;
|
||||
const byte* BGCOL = $d021;
|
||||
const byte* BGCOL1 = $d021;
|
||||
const byte* BGCOL2 = $d022;
|
||||
const byte* BGCOL3 = $d023;
|
||||
const byte* BGCOL4 = $d024;
|
||||
const byte* SPRITES_MC1 = $d025;
|
||||
const byte* SPRITES_MC2 = $d026;
|
||||
const byte* SPRITES_COLS = $d027;
|
||||
byte* const SPRITES_XPOS = $d000;
|
||||
byte* const SPRITES_YPOS = $d001;
|
||||
byte* const SPRITES_XMSB = $d010;
|
||||
byte* const RASTER = $d012;
|
||||
byte* const SPRITES_ENABLE = $d015;
|
||||
byte* const SPRITES_EXPAND_Y = $d017;
|
||||
byte* const SPRITES_PRIORITY = $d01b;
|
||||
byte* const SPRITES_MC = $d01c;
|
||||
byte* const SPRITES_EXPAND_X = $d01d;
|
||||
byte* const BORDERCOL = $d020;
|
||||
byte* const BGCOL = $d021;
|
||||
byte* const BGCOL1 = $d021;
|
||||
byte* const BGCOL2 = $d022;
|
||||
byte* const BGCOL3 = $d023;
|
||||
byte* const BGCOL4 = $d024;
|
||||
byte* const SPRITES_MC1 = $d025;
|
||||
byte* const SPRITES_MC2 = $d026;
|
||||
byte* const SPRITES_COLS = $d027;
|
||||
|
||||
const byte* VIC_CONTROL = $d011;
|
||||
const byte* D011 = $d011;
|
||||
byte* const VIC_CONTROL = $d011;
|
||||
byte* const D011 = $d011;
|
||||
const byte VIC_RST8 = %10000000;
|
||||
const byte VIC_ECM = %01000000;
|
||||
const byte VIC_BMM = %00100000;
|
||||
const byte VIC_DEN = %00010000;
|
||||
const byte VIC_RSEL = %00001000;
|
||||
|
||||
const byte* VIC_CONTROL2 = $d016;
|
||||
const byte* D016 = $d016;
|
||||
byte* const VIC_CONTROL2 = $d016;
|
||||
byte* const D016 = $d016;
|
||||
const byte VIC_MCM = %00010000;
|
||||
const byte VIC_CSEL = %00001000;
|
||||
|
||||
const byte* D018 = $d018;
|
||||
const byte* VIC_MEMORY = $d018;
|
||||
byte* const D018 = $d018;
|
||||
byte* const VIC_MEMORY = $d018;
|
||||
|
||||
const byte* LIGHTPEN_X = $d013;
|
||||
const byte* LIGHTPEN_Y = $d014;
|
||||
byte* const LIGHTPEN_X = $d013;
|
||||
byte* const LIGHTPEN_Y = $d014;
|
||||
|
||||
// VIC II IRQ Status Register
|
||||
const byte* IRQ_STATUS = $d019;
|
||||
byte* const IRQ_STATUS = $d019;
|
||||
// VIC II IRQ Enable Register
|
||||
const byte* IRQ_ENABLE = $d01a;
|
||||
byte* const IRQ_ENABLE = $d01a;
|
||||
// Bits for the IRQ Status/Enable Registers
|
||||
const byte IRQ_RASTER = %00000001;
|
||||
const byte IRQ_COLLISION_BG = %00000010;
|
||||
@ -79,67 +79,67 @@ const byte IRQ_COLLISION_SPRITE = %00000100;
|
||||
const byte IRQ_LIGHTPEN = %00001000;
|
||||
|
||||
// Color Ram
|
||||
const byte* COLS = $d800;
|
||||
byte* const COLS = $d800;
|
||||
|
||||
// CIA#1 Port A: keyboard matrix columns and joystick #2
|
||||
const byte* CIA1_PORT_A = $dc00;
|
||||
byte* const CIA1_PORT_A = $dc00;
|
||||
// CIA#1 Port B: keyboard matrix rows and joystick #1.
|
||||
const byte* CIA1_PORT_B = $dc01;
|
||||
byte* const CIA1_PORT_B = $dc01;
|
||||
// CIA #1 Port A data direction register.
|
||||
const byte* CIA1_PORT_A_DDR = $dc02;
|
||||
byte* const CIA1_PORT_A_DDR = $dc02;
|
||||
// CIA #1 Port B data direction register.
|
||||
const byte* CIA1_PORT_B_DDR = $dc03;
|
||||
byte* const CIA1_PORT_B_DDR = $dc03;
|
||||
// CIA #1 Timer A Value
|
||||
const word* CIA1_TIMER_A = $dc04;
|
||||
word* const CIA1_TIMER_A = $dc04;
|
||||
// CIA #1 Timer B Value
|
||||
const word* CIA1_TIMER_B = $dc06;
|
||||
word* const CIA1_TIMER_B = $dc06;
|
||||
// CIA #1 Time-of-day real-time-clock tenth seconds (BCD)
|
||||
const byte* CIA1_TOD_10THS = $dc08;
|
||||
byte* const CIA1_TOD_10THS = $dc08;
|
||||
// CIA #1 Time-of-day real-time-clock seconds (BCD)
|
||||
const byte* CIA1_TOD_SEC = $dc09;
|
||||
byte* const CIA1_TOD_SEC = $dc09;
|
||||
// CIA #1 Time-of-day real-time-clock minutes (BCD)
|
||||
const byte* CIA1_TOD_MIN = $dc0a;
|
||||
byte* const CIA1_TOD_MIN = $dc0a;
|
||||
// CIA #1 Time-of-day real-time-clock hours (BCD)
|
||||
const byte* CIA1_TOD_HOURS = $dc0b;
|
||||
byte* const CIA1_TOD_HOURS = $dc0b;
|
||||
// CIA #1 Serial Shift Register
|
||||
const byte* CIA1_SERIAL_SHIFT_OUT = $dc0c;
|
||||
byte* const CIA1_SERIAL_SHIFT_OUT = $dc0c;
|
||||
// CIA#1 Interrupt Status & Control Register
|
||||
const byte* CIA1_INTERRUPT = $dc0d;
|
||||
byte* const CIA1_INTERRUPT = $dc0d;
|
||||
// CIA#1 Timer A Control Register
|
||||
const byte* CIA1_TIMER_A_CONTROL = $dc0e;
|
||||
byte* const CIA1_TIMER_A_CONTROL = $dc0e;
|
||||
// CIA#1 Timer B Control Register
|
||||
const byte* CIA1_TIMER_B_CONTROL = $dc0f;
|
||||
byte* const CIA1_TIMER_B_CONTROL = $dc0f;
|
||||
|
||||
// CIA#2 Port A: Serial bus, RS-232, VIC memory bank
|
||||
const byte* CIA2_PORT_A = $dd00;
|
||||
byte* const CIA2_PORT_A = $dd00;
|
||||
// CIA#2 Port B: RS-232
|
||||
const byte* CIA2_PORT_B = $dd01;
|
||||
byte* const CIA2_PORT_B = $dd01;
|
||||
// CIA #2 Port A data direction register.
|
||||
const byte* CIA2_PORT_A_DDR = $dd02;
|
||||
byte* const CIA2_PORT_A_DDR = $dd02;
|
||||
// CIA #2 Port B data direction register.
|
||||
const byte* CIA2_PORT_B_DDR = $dd03;
|
||||
byte* const CIA2_PORT_B_DDR = $dd03;
|
||||
// CIA #2 Timer A+B Value (32-bit)
|
||||
const dword* CIA2_TIMER_AB = $dd04;
|
||||
dword* const CIA2_TIMER_AB = $dd04;
|
||||
// CIA #2 Timer A Value (16-bit)
|
||||
const word* CIA2_TIMER_A = $dd04;
|
||||
word* const CIA2_TIMER_A = $dd04;
|
||||
// CIA #2 Timer B Value (16-bit)
|
||||
const word* CIA2_TIMER_B = $dd06;
|
||||
word* const CIA2_TIMER_B = $dd06;
|
||||
// CIA #2 Time-of-day real-time-clock tenth seconds (BCD)
|
||||
const byte* CIA2_TOD_10THS = $dd08;
|
||||
byte* const CIA2_TOD_10THS = $dd08;
|
||||
// CIA #2 Time-of-day real-time-clock seconds (BCD)
|
||||
const byte* CIA2_TOD_SEC = $dd09;
|
||||
byte* const CIA2_TOD_SEC = $dd09;
|
||||
// CIA #2 Time-of-day real-time-clock minutes (BCD)
|
||||
const byte* CIA2_TOD_MIN = $dd0a;
|
||||
byte* const CIA2_TOD_MIN = $dd0a;
|
||||
// CIA #2 Time-of-day real-time-clock hours (BCD)
|
||||
const byte* CIA2_TOD_HOURS = $dd0b;
|
||||
byte* const CIA2_TOD_HOURS = $dd0b;
|
||||
// CIA #2 Serial Shift Register
|
||||
const byte* CIA2_SERIAL_SHIFT_OUT = $dd0c;
|
||||
byte* const CIA2_SERIAL_SHIFT_OUT = $dd0c;
|
||||
// CIA #2 Interrupt Status & Control Register
|
||||
const byte* CIA2_INTERRUPT = $dd0d;
|
||||
byte* const CIA2_INTERRUPT = $dd0d;
|
||||
// CIA #2 Timer A Control Register
|
||||
const byte* CIA2_TIMER_A_CONTROL = $dd0e;
|
||||
byte* const CIA2_TIMER_A_CONTROL = $dd0e;
|
||||
// CIA #2 Timer B Control Register
|
||||
const byte* CIA2_TIMER_B_CONTROL = $dd0f;
|
||||
byte* const CIA2_TIMER_B_CONTROL = $dd0f;
|
||||
|
||||
// Value that disables all CIA interrupts when stored to the CIA Interrupt registers
|
||||
const byte CIA_INTERRUPT_CLEAR = $7f;
|
||||
@ -178,15 +178,15 @@ const byte CIA_TIMER_CONTROL_B_TOD_CLOCK_SET = 0b00000000;
|
||||
const byte CIA_TIMER_CONTROL_B_TOD_ALARM_SET = 0b10000000;
|
||||
|
||||
// The vector used when the KERNAL serves IRQ interrupts
|
||||
const void()** KERNEL_IRQ = $0314;
|
||||
void()** const KERNEL_IRQ = $0314;
|
||||
// The vector used when the KERNAL serves NMI interrupts
|
||||
const void()** KERNEL_NMI = $0318;
|
||||
void()** const KERNEL_NMI = $0318;
|
||||
|
||||
// The vector used when the HARDWARE serves IRQ interrupts
|
||||
const void()** HARDWARE_IRQ = $fffe;
|
||||
void()** const HARDWARE_IRQ = $fffe;
|
||||
|
||||
// The SID volume
|
||||
const byte* SID_VOLUME = $d418;
|
||||
byte* const SID_VOLUME = $d418;
|
||||
|
||||
|
||||
// The colors of the C64
|
||||
|
@ -7,12 +7,12 @@
|
||||
import "c64.kc"
|
||||
|
||||
// Feature enables or disables the extra C64 DTV features
|
||||
const byte* DTV_FEATURE = $d03f;
|
||||
byte* const DTV_FEATURE = $d03f;
|
||||
const byte DTV_FEATURE_ENABLE = 1;
|
||||
const byte DTV_FEATURE_DISABLE_TIL_RESET = 2;
|
||||
|
||||
// Controls the graphics modes of the C64 DTV
|
||||
const byte* DTV_CONTROL = $d03c;
|
||||
byte* const DTV_CONTROL = $d03c;
|
||||
const byte DTV_LINEAR = $01;
|
||||
const byte DTV_BORDER_OFF = $02;
|
||||
const byte DTV_HIGHCOLOR = $04;
|
||||
@ -22,43 +22,43 @@ const byte DTV_BADLINE_OFF = $20;
|
||||
const byte DTV_CHUNKY = $40;
|
||||
|
||||
// Defines colors for the 16 first colors ($00-$0f)
|
||||
const byte* DTV_PALETTE = $d200;
|
||||
byte* const DTV_PALETTE = $d200;
|
||||
|
||||
// Default vallues for the palette
|
||||
byte DTV_PALETTE_DEFAULT[16] = { $00, $0f, $36, $be, $58, $db, $86, $ff, $29, $26, $3b, $05, $07, $df, $9a, $0a };
|
||||
|
||||
// Linear Graphics Plane A Counter Control
|
||||
const byte* DTV_PLANEA_START_LO = $d03a;
|
||||
const byte* DTV_PLANEA_START_MI = $d03b;
|
||||
const byte* DTV_PLANEA_START_HI = $d045;
|
||||
const byte* DTV_PLANEA_STEP = $d046;
|
||||
const byte* DTV_PLANEA_MODULO_LO = $d038;
|
||||
const byte* DTV_PLANEA_MODULO_HI = $d039;
|
||||
byte* const DTV_PLANEA_START_LO = $d03a;
|
||||
byte* const DTV_PLANEA_START_MI = $d03b;
|
||||
byte* const DTV_PLANEA_START_HI = $d045;
|
||||
byte* const DTV_PLANEA_STEP = $d046;
|
||||
byte* const DTV_PLANEA_MODULO_LO = $d038;
|
||||
byte* const DTV_PLANEA_MODULO_HI = $d039;
|
||||
|
||||
// Linear Graphics Plane B Counter Control
|
||||
const byte* DTV_PLANEB_START_LO = $d049;
|
||||
const byte* DTV_PLANEB_START_MI = $d04a;
|
||||
const byte* DTV_PLANEB_START_HI = $d04b;
|
||||
const byte* DTV_PLANEB_STEP = $d04c;
|
||||
const byte* DTV_PLANEB_MODULO_LO = $d047;
|
||||
const byte* DTV_PLANEB_MODULO_HI = $d048;
|
||||
byte* const DTV_PLANEB_START_LO = $d049;
|
||||
byte* const DTV_PLANEB_START_MI = $d04a;
|
||||
byte* const DTV_PLANEB_START_HI = $d04b;
|
||||
byte* const DTV_PLANEB_STEP = $d04c;
|
||||
byte* const DTV_PLANEB_MODULO_LO = $d047;
|
||||
byte* const DTV_PLANEB_MODULO_HI = $d048;
|
||||
|
||||
// Select memory bank where sprite data is fetched from (bits 5:0) - source only (J)
|
||||
// Memory address of Sprite RAM is SpriteBank*$10000
|
||||
const byte* DTV_SPRITE_BANK = $d04d;
|
||||
byte* const DTV_SPRITE_BANK = $d04d;
|
||||
|
||||
// Select memory bank where color data is fetched from (bits 11:0)
|
||||
// Memory address of Color RAM is ColorBank*$400
|
||||
const byte* DTV_COLOR_BANK_LO = $d036;
|
||||
const byte* DTV_COLOR_BANK_HI = $d037;
|
||||
byte* const DTV_COLOR_BANK_LO = $d036;
|
||||
byte* const DTV_COLOR_BANK_HI = $d037;
|
||||
|
||||
const dword DTV_COLOR_BANK_DEFAULT = $1d800;
|
||||
|
||||
// Selects memory bank for normal VIC color mode and lower data for high color modes. (bits 5:0)
|
||||
// Memory address of VIC Graphics is GraphicsBank*$10000
|
||||
const byte* DTV_GRAPHICS_VIC_BANK = $d03d;
|
||||
byte* const DTV_GRAPHICS_VIC_BANK = $d03d;
|
||||
// Selects memory bank for upper data for high color modes. (bits 5:0) - source only (H)
|
||||
const byte* DTV_GRAPHICS_HICOL_BANK = $d03e;
|
||||
byte* const DTV_GRAPHICS_HICOL_BANK = $d03e;
|
||||
|
||||
// Set the memory pointed to by CPU BANK 1 SEGMENT ($4000-$7fff)
|
||||
// This sets which actual memory is addressed when the CPU reads/writes to $4000-$7fff
|
||||
@ -78,46 +78,46 @@ void dtvSetCpuBankSegment1(byte cpuBankIdx) {
|
||||
}
|
||||
|
||||
// Blitter Source A Start
|
||||
const byte* DTV_BLITTER_SRCA_LO = $d320;
|
||||
const byte* DTV_BLITTER_SRCA_MI = $d321;
|
||||
const byte* DTV_BLITTER_SRCA_HI = $d322;
|
||||
byte* const DTV_BLITTER_SRCA_LO = $d320;
|
||||
byte* const DTV_BLITTER_SRCA_MI = $d321;
|
||||
byte* const DTV_BLITTER_SRCA_HI = $d322;
|
||||
// Blitter Source A Modulo
|
||||
const byte* DTV_BLITTER_SRCA_MOD_LO = $d323;
|
||||
const byte* DTV_BLITTER_SRCA_MOD_HI = $d324;
|
||||
byte* const DTV_BLITTER_SRCA_MOD_LO = $d323;
|
||||
byte* const DTV_BLITTER_SRCA_MOD_HI = $d324;
|
||||
// Blitter Source A Line Length
|
||||
const byte* DTV_BLITTER_SRCA_LIN_LO = $d325;
|
||||
const byte* DTV_BLITTER_SRCA_LIN_HI = $d326;
|
||||
byte* const DTV_BLITTER_SRCA_LIN_LO = $d325;
|
||||
byte* const DTV_BLITTER_SRCA_LIN_HI = $d326;
|
||||
// Blitter Source A Step ([7:4] integral part, [3:0] fractional part)
|
||||
const byte* DTV_BLITTER_SRCA_STEP = $d327;
|
||||
byte* const DTV_BLITTER_SRCA_STEP = $d327;
|
||||
// Blitter Source B Start
|
||||
const byte* DTV_BLITTER_SRCB_LO = $d328;
|
||||
const byte* DTV_BLITTER_SRCB_MI = $d329;
|
||||
const byte* DTV_BLITTER_SRCB_HI = $d32a;
|
||||
byte* const DTV_BLITTER_SRCB_LO = $d328;
|
||||
byte* const DTV_BLITTER_SRCB_MI = $d329;
|
||||
byte* const DTV_BLITTER_SRCB_HI = $d32a;
|
||||
// Blitter Source B Modulo
|
||||
const byte* DTV_BLITTER_SRCB_MOD_LO = $d32b;
|
||||
const byte* DTV_BLITTER_SRCB_MOD_HI = $d32c;
|
||||
byte* const DTV_BLITTER_SRCB_MOD_LO = $d32b;
|
||||
byte* const DTV_BLITTER_SRCB_MOD_HI = $d32c;
|
||||
// Blitter Source B Line Length
|
||||
const byte* DTV_BLITTER_SRCB_LIN_LO = $d32d;
|
||||
const byte* DTV_BLITTER_SRCB_LIN_HI = $d32e;
|
||||
byte* const DTV_BLITTER_SRCB_LIN_LO = $d32d;
|
||||
byte* const DTV_BLITTER_SRCB_LIN_HI = $d32e;
|
||||
// Blitter Source B Step ([7:4] integral part, [3:0] fractional part)
|
||||
const byte* DTV_BLITTER_SRCB_STEP = $d32f;
|
||||
byte* const DTV_BLITTER_SRCB_STEP = $d32f;
|
||||
// Blitter Destination Start
|
||||
const byte* DTV_BLITTER_DEST_LO = $d330;
|
||||
const byte* DTV_BLITTER_DEST_MI = $d331;
|
||||
const byte* DTV_BLITTER_DEST_HI = $d332;
|
||||
byte* const DTV_BLITTER_DEST_LO = $d330;
|
||||
byte* const DTV_BLITTER_DEST_MI = $d331;
|
||||
byte* const DTV_BLITTER_DEST_HI = $d332;
|
||||
// Blitter Source B Modulo
|
||||
const byte* DTV_BLITTER_DEST_MOD_LO = $d333;
|
||||
const byte* DTV_BLITTER_DEST_MOD_HI = $d334;
|
||||
byte* const DTV_BLITTER_DEST_MOD_LO = $d333;
|
||||
byte* const DTV_BLITTER_DEST_MOD_HI = $d334;
|
||||
// Blitter Source B Line Length
|
||||
const byte* DTV_BLITTER_DEST_LIN_LO = $d335;
|
||||
const byte* DTV_BLITTER_DEST_LIN_HI = $d336;
|
||||
byte* const DTV_BLITTER_DEST_LIN_LO = $d335;
|
||||
byte* const DTV_BLITTER_DEST_LIN_HI = $d336;
|
||||
// Blitter Source B Step ([7:4] integral part, [3:0] fractional part)
|
||||
const byte* DTV_BLITTER_DEST_STEP = $d337;
|
||||
byte* const DTV_BLITTER_DEST_STEP = $d337;
|
||||
// Blitter Blit Length
|
||||
const byte* DTV_BLITTER_LEN_LO = $d338;
|
||||
const byte* DTV_BLITTER_LEN_HI = $d339;
|
||||
byte* const DTV_BLITTER_LEN_LO = $d338;
|
||||
byte* const DTV_BLITTER_LEN_HI = $d339;
|
||||
// Blitter Control
|
||||
const byte* DTV_BLITTER_CONTROL = $d33a;
|
||||
byte* const DTV_BLITTER_CONTROL = $d33a;
|
||||
// Bit[0] Force Start Strobe when set
|
||||
const byte DTV_BLIT_FORCE_START = %00000001;
|
||||
// Bit[1] Source A Direction Positive when set
|
||||
@ -135,7 +135,7 @@ const byte DTV_BLIT_VBLANK = %01000000;
|
||||
// Bit[7] Blitter IRQ Enable when set
|
||||
const byte DTV_BLIT_IRQ_EN = %10000000;
|
||||
// Blitter Transparency
|
||||
const byte* DTV_BLITTER_TRANSPARANCY = $d33b;
|
||||
byte* const DTV_BLITTER_TRANSPARANCY = $d33b;
|
||||
// Bit[0] Disable Channel B.
|
||||
// (data into b port of ALU is forced to %00000000. ALU functions as normal)
|
||||
const byte DTV_BLIT_DISABLE_B = %00000001;
|
||||
@ -169,7 +169,7 @@ const byte DTV_BLIT_XNOR = %00101000;
|
||||
const byte DTV_BLIT_ADD = %00110000;
|
||||
const byte DTV_BLIT_SUB = %00111000;
|
||||
// Blitter Control 2
|
||||
const byte* DTV_BLITTER_CONTROL2 = $d33f;
|
||||
byte* const DTV_BLITTER_CONTROL2 = $d33f;
|
||||
// Bit[0] Clear Blitter IRQ
|
||||
const byte DTV_BLIT_CLEAR_IRQ = %00000001;
|
||||
// Bit[1] Source A Continue
|
||||
|
@ -48,7 +48,7 @@ void mulf_init() {
|
||||
|
||||
// Prepare for fast multiply with an unsigned byte to a word result
|
||||
void mulf8u_prepare(byte a) {
|
||||
const byte* memA = $fd;
|
||||
byte* const memA = $fd;
|
||||
*memA = a;
|
||||
asm {
|
||||
lda memA
|
||||
@ -63,8 +63,8 @@ void mulf8u_prepare(byte a) {
|
||||
// Calculate fast multiply with a prepared unsigned byte to a word result
|
||||
// The prepared number is set by calling mulf8u_prepare(byte a)
|
||||
word mulf8u_prepared(byte b) {
|
||||
const byte* resL = $fe;
|
||||
const byte* memB = $ff;
|
||||
byte* const resL = $fe;
|
||||
byte* const memB = $ff;
|
||||
*memB = b;
|
||||
asm {
|
||||
ldx memB
|
||||
@ -97,7 +97,7 @@ inline void mulf8s_prepare(signed byte a) {
|
||||
// Calculate fast multiply with a prepared unsigned byte to a word result
|
||||
// The prepared number is set by calling mulf8s_prepare(byte a)
|
||||
signed word mulf8s_prepared(signed byte b) {
|
||||
const signed byte* memA = $fd;
|
||||
signed byte* const memA = $fd;
|
||||
word m = mulf8u_prepared((byte) b);
|
||||
if(*memA<0) {
|
||||
>m = (>m)-(byte)b;
|
||||
@ -117,9 +117,9 @@ signed word mulf8s(signed byte a, signed byte b) {
|
||||
// Fast multiply two unsigned words to a double word result
|
||||
// Done in assembler to utilize fast addition A+X
|
||||
dword mulf16u(word a, word b) {
|
||||
const word* memA = $f8;
|
||||
const word* memB = $fa;
|
||||
const dword* memR = $fc;
|
||||
word* const memA = $f8;
|
||||
word* const memB = $fa;
|
||||
dword* const memR = $fc;
|
||||
*memA = a;
|
||||
*memB = b;
|
||||
asm {
|
||||
|
@ -942,10 +942,10 @@ public class TestPrograms {
|
||||
compileAndCompare("enum-0");
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testTypedef3() throws IOException, URISyntaxException {
|
||||
compileAndCompare("typedef-3");
|
||||
}
|
||||
//@Test
|
||||
//public void testTypedef3() throws IOException, URISyntaxException {
|
||||
// compileAndCompare("typedef-3");
|
||||
//}
|
||||
|
||||
@Test
|
||||
public void testTypedef2() throws IOException, URISyntaxException {
|
||||
@ -1777,6 +1777,21 @@ public class TestPrograms {
|
||||
compileAndCompare("sandbox");
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testPointerConstDeep() throws IOException, URISyntaxException {
|
||||
assertError("pointer-const-deep", "Deep const/volatile not supported");
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testPointerConstTypedef() throws IOException, URISyntaxException {
|
||||
compileAndCompare("pointer-const-typedef");
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testPointerConst() throws IOException, URISyntaxException {
|
||||
compileAndCompare("pointer-const");
|
||||
}
|
||||
|
||||
@Test
|
||||
public void testPointerCast4() throws IOException, URISyntaxException {
|
||||
compileAndCompare("pointer-cast-4");
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Test that address vars are turned into load/store and located at hardcoded addresses
|
||||
// Hard-coded zero-page address - global variable
|
||||
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
|
||||
char __address(0x02) i = 3;
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Test that address vars are turned into load/store and located at hardcoded addresses
|
||||
// Hard-coded zero-page address - local variable
|
||||
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
|
||||
|
||||
void main() {
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Test that address vars are turned into load/store and located at hardcoded addresses
|
||||
// Hard-coded mainmem-page address - global variable
|
||||
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
|
||||
char __address(0x2000) i = 3;
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Test that address vars are turned into load/store and located at hardcoded addresses
|
||||
// Hard-coded mainmem address - local variable
|
||||
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
|
||||
void main() {
|
||||
char __address(0x2000) i = 3;
|
||||
|
@ -7,7 +7,7 @@ void main() {
|
||||
print('l');
|
||||
}
|
||||
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
|
||||
volatile char __address(0x03) idx;
|
||||
|
||||
|
@ -7,7 +7,7 @@ void main() {
|
||||
print('l');
|
||||
}
|
||||
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
|
||||
volatile char __address(0x3000) idx;
|
||||
|
||||
|
@ -3,8 +3,8 @@
|
||||
byte val = 0;
|
||||
|
||||
void main() {
|
||||
const byte* SCREEN1 = 0x0400;
|
||||
const byte* SCREEN2 = SCREEN1+40;
|
||||
byte* const SCREEN1 = 0x0400;
|
||||
byte* const SCREEN2 = SCREEN1+40;
|
||||
byte idx = 0;
|
||||
SCREEN1[idx] = val;
|
||||
SCREEN2[idx++] = '.';
|
||||
|
@ -11,7 +11,7 @@ void main() {
|
||||
|
||||
}
|
||||
|
||||
const int* SCREEN = 0x0400;
|
||||
int* const SCREEN = 0x0400;
|
||||
char idx = 0;
|
||||
|
||||
void print(int* p) {
|
||||
|
@ -3,7 +3,7 @@
|
||||
char msg1[16] ="camelot";
|
||||
char msg2[16] = { 'c', 'm', 'l' };
|
||||
|
||||
const char* SCREEN = 0x400;
|
||||
char* const SCREEN = 0x400;
|
||||
|
||||
void main() {
|
||||
for(char i=0;msg1[i];i++)
|
||||
|
@ -2,7 +2,7 @@
|
||||
|
||||
char[16] msg ="camelot";
|
||||
|
||||
const char* SCREEN = 0x400;
|
||||
char* const SCREEN = 0x400;
|
||||
|
||||
void main() {
|
||||
for(char i=0;msg[i];i++)
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Test using an ASM mnemonic as a C symbol names
|
||||
// Works if the C-lexer and the ASM-lexer are separated properly
|
||||
|
||||
const char* lda = 0x0400;
|
||||
char* const lda = 0x0400;
|
||||
|
||||
void main() {
|
||||
char jmp = 1;
|
||||
|
@ -6,7 +6,7 @@ void main() {
|
||||
}
|
||||
}
|
||||
|
||||
const char* BGCOL = 0xd020;
|
||||
char* const BGCOL = 0xd020;
|
||||
|
||||
// Function only used inside the inline asm
|
||||
void init() {
|
||||
|
@ -1,2 +1,2 @@
|
||||
const char* BGCOL = 0xd021;
|
||||
char* const BGCOL = 0xd021;
|
||||
const char BLACK = 0x00;
|
@ -1,8 +1,8 @@
|
||||
import "c64"
|
||||
|
||||
const byte* SCREEN = $400;
|
||||
const byte* BITMAP = $2000;
|
||||
const byte* COLORS = $d800;
|
||||
byte* const SCREEN = $400;
|
||||
byte* const BITMAP = $2000;
|
||||
byte* const COLORS = $d800;
|
||||
|
||||
byte bitmask[] = { 128, 64, 32, 16, 8, 4, 2, 1 };
|
||||
|
||||
|
@ -4,9 +4,9 @@
|
||||
|
||||
import "c64"
|
||||
|
||||
const byte* SCREEN = $400;
|
||||
const byte* BITMAP = $2000;
|
||||
const byte* COLORS = $d800;
|
||||
byte* const SCREEN = $400;
|
||||
byte* const BITMAP = $2000;
|
||||
byte* const COLORS = $d800;
|
||||
|
||||
byte bitmask[] = { 128, 64, 32, 16, 8, 4, 2, 1 };
|
||||
|
||||
|
@ -4,8 +4,8 @@
|
||||
import "c64.kc"
|
||||
import "bitmap-draw.kc"
|
||||
|
||||
const byte* SCREEN = $400;
|
||||
const byte* BITMAP = $2000;
|
||||
byte* const SCREEN = $400;
|
||||
byte* const BITMAP = $2000;
|
||||
|
||||
byte next=0;
|
||||
|
||||
|
@ -4,8 +4,8 @@
|
||||
import "c64.kc"
|
||||
import "bitmap2.kc"
|
||||
|
||||
const byte* SCREEN = $400;
|
||||
const byte* BITMAP = $2000;
|
||||
byte* const SCREEN = $400;
|
||||
byte* const BITMAP = $2000;
|
||||
|
||||
word next=0;
|
||||
|
||||
|
@ -16,7 +16,7 @@ byte* COLS = $d800;
|
||||
|
||||
|
||||
byte* SCREEN = $400;
|
||||
const byte* BITMAP = $2000;
|
||||
byte* const BITMAP = $2000;
|
||||
|
||||
void main() {
|
||||
*BGCOL = 0;
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Test that bitwise NOT (~) is handled correctly
|
||||
|
||||
void main() {
|
||||
const char* screen = 0x0400;
|
||||
char* const screen = 0x0400;
|
||||
char b = ~0x10;
|
||||
*screen = b;
|
||||
}
|
@ -1,6 +1,6 @@
|
||||
// A Minimal test of boolean constants.
|
||||
|
||||
const byte* SCREEN = $400;
|
||||
byte* const SCREEN = $400;
|
||||
|
||||
void main() {
|
||||
bool_const_if();
|
||||
|
@ -1,7 +1,7 @@
|
||||
// A test of boolean conditions using && || and !
|
||||
|
||||
void main() {
|
||||
const char* screen = 0x400;
|
||||
char* const screen = 0x400;
|
||||
for( char i : 0..20) {
|
||||
if( (i<10) && ((i&1)==0) ) {
|
||||
screen[i] = '*';
|
||||
|
@ -8,7 +8,7 @@ void main() {
|
||||
}
|
||||
|
||||
void bool_and() {
|
||||
const byte* screen = $400;
|
||||
byte* const screen = $400;
|
||||
for( byte i : 0..20) {
|
||||
if( (i<10) && ((i&1)==0) ) {
|
||||
screen[i] = '*';
|
||||
@ -19,7 +19,7 @@ void bool_and() {
|
||||
}
|
||||
|
||||
void bool_or() {
|
||||
const byte* screen = $428;
|
||||
byte* const screen = $428;
|
||||
for( byte i : 0..20) {
|
||||
if( (i<10) || ((i&1)==0) ) {
|
||||
screen[i] = '*';
|
||||
@ -30,7 +30,7 @@ void bool_or() {
|
||||
}
|
||||
|
||||
void bool_not() {
|
||||
const byte* screen = $450;
|
||||
byte* const screen = $450;
|
||||
for( byte i : 0..20) {
|
||||
if( !((i<10) || (i&1)==0)) {
|
||||
screen[i] = '*';
|
||||
@ -41,7 +41,7 @@ void bool_not() {
|
||||
}
|
||||
|
||||
void bool_complex() {
|
||||
const byte* screen = $478;
|
||||
byte* const screen = $478;
|
||||
for( byte i : 0..20) {
|
||||
if( ((i<10) && (i&1)==0) || !((i<10) || (i&1)==0) ) {
|
||||
screen[i] = '*';
|
||||
|
@ -4,7 +4,7 @@
|
||||
// https://gitlab.com/camelot/kickc/issues/199
|
||||
|
||||
void main() {
|
||||
const char* screen = 0x0400;
|
||||
char* const screen = 0x0400;
|
||||
for(char i: 0..7) {
|
||||
bool b = (i&1)==1;
|
||||
char c = !b ? 1 : 0 ;
|
||||
|
@ -4,7 +4,7 @@
|
||||
// https://gitlab.com/camelot/kickc/issues/199
|
||||
|
||||
void main() {
|
||||
const char* screen = 0x0400;
|
||||
char* const screen = 0x0400;
|
||||
for(char i: 0..7) {
|
||||
char b = i&1;
|
||||
char c = !b ? 1 : 0 ;
|
||||
|
@ -4,7 +4,7 @@
|
||||
// https://gitlab.com/camelot/kickc/issues/295
|
||||
|
||||
void main() {
|
||||
const char* screen = 0x0400;
|
||||
char* const screen = 0x0400;
|
||||
for(char i: 0..7) {
|
||||
char b = (i&1);
|
||||
screen[i] = !b;
|
||||
|
@ -8,7 +8,7 @@ void main() {
|
||||
}
|
||||
|
||||
void bool_and() {
|
||||
const byte* screen = $400;
|
||||
byte* const screen = $400;
|
||||
for( byte i : 0..20) {
|
||||
bool o1 = (i<10);
|
||||
bool o2 = ((i&1)==0);
|
||||
@ -22,7 +22,7 @@ void bool_and() {
|
||||
}
|
||||
|
||||
void bool_or() {
|
||||
const byte* screen = $428;
|
||||
byte* const screen = $428;
|
||||
for( byte i : 0..20) {
|
||||
bool o1 = (i<10);
|
||||
bool o2 = ((i&1)==0);
|
||||
@ -36,7 +36,7 @@ void bool_or() {
|
||||
}
|
||||
|
||||
void bool_not() {
|
||||
const byte* screen = $450;
|
||||
byte* const screen = $450;
|
||||
for( byte i : 0..20) {
|
||||
bool o1 = (i<10);
|
||||
bool o2 = (i&1)==0;
|
||||
@ -50,7 +50,7 @@ void bool_not() {
|
||||
}
|
||||
|
||||
void bool_complex() {
|
||||
const byte* screen = $478;
|
||||
byte* const screen = $478;
|
||||
for( byte i : 0..20) {
|
||||
bool o1 = (i<10);
|
||||
bool o2 = (i&1)==0;
|
||||
|
@ -2,9 +2,9 @@
|
||||
import "c64dtv.kc"
|
||||
|
||||
// Plane with the screen
|
||||
const byte* SCREEN = $7c00;
|
||||
byte* const SCREEN = $7c00;
|
||||
// Plane with all pixels
|
||||
const byte* CHARSET8 = $8000;
|
||||
byte* const CHARSET8 = $8000;
|
||||
|
||||
void main() {
|
||||
asm { sei } // Disable normal interrupt (prevent keyboard reading glitches and allows to hide basic/kernal)
|
||||
|
@ -2,7 +2,7 @@
|
||||
import "c64dtv.kc"
|
||||
|
||||
// Plane with all pixels
|
||||
const byte* CHUNKY = $8000;
|
||||
byte* const CHUNKY = $8000;
|
||||
|
||||
void main() {
|
||||
asm { sei } // Disable normal interrupt (prevent keyboard reading glitches and allows to hide basic/kernal)
|
||||
|
@ -2,7 +2,7 @@
|
||||
|
||||
import "c64dtv.kc"
|
||||
|
||||
const byte* SCREEN = $400;
|
||||
byte* const SCREEN = $400;
|
||||
const byte SRCA[] = "camelot rules!";
|
||||
const byte SRCB[] = { $80 };
|
||||
|
||||
|
@ -1,6 +1,6 @@
|
||||
import "c64dtv.kc"
|
||||
|
||||
const byte* SCREEN = $400;
|
||||
byte* const SCREEN = $400;
|
||||
const byte SRCA[] = { 'c', 'a', 'm', 'e', 'l', 'o', 't', '!', ' '};
|
||||
const byte SRCA_LEN = 9;
|
||||
const byte SRCB[] = { $80 };
|
||||
|
@ -22,15 +22,15 @@ void main() {
|
||||
}
|
||||
|
||||
// VIC Screens
|
||||
const byte* VIC_SCREEN0 = $4000;
|
||||
const byte* VIC_SCREEN1 = $4400;
|
||||
const byte* VIC_SCREEN2 = $4800;
|
||||
const byte* VIC_SCREEN3 = $4c00;
|
||||
const byte* VIC_SCREEN4 = $5000;
|
||||
byte* const VIC_SCREEN0 = $4000;
|
||||
byte* const VIC_SCREEN1 = $4400;
|
||||
byte* const VIC_SCREEN2 = $4800;
|
||||
byte* const VIC_SCREEN3 = $4c00;
|
||||
byte* const VIC_SCREEN4 = $5000;
|
||||
// VIC Charset from ROM
|
||||
const byte* VIC_CHARSET_ROM = $5800;
|
||||
byte* const VIC_CHARSET_ROM = $5800;
|
||||
// VIC Bitmap
|
||||
const byte* VIC_BITMAP = $6000;
|
||||
byte* const VIC_BITMAP = $6000;
|
||||
|
||||
// 8BPP Chunky Bitmap (contains 8bpp pixels)
|
||||
const dword PLANE_8BPP_CHUNKY = $20000;
|
||||
@ -110,9 +110,9 @@ byte* get_vic_charset(byte idx) {
|
||||
}
|
||||
|
||||
// Screen containing the FORM
|
||||
const byte* FORM_SCREEN = $0400;
|
||||
byte* const FORM_SCREEN = $0400;
|
||||
// Charset used for the FORM
|
||||
const byte* FORM_CHARSET = $1800; // Charset ROM
|
||||
byte* const FORM_CHARSET = $1800; // Charset ROM
|
||||
|
||||
byte FORM_TEXT[] =
|
||||
" C64 DTV Graphics Mode Explorer @"
|
||||
@ -254,42 +254,42 @@ void render_preset_name(byte idx) {
|
||||
|
||||
|
||||
// Form fields direct addressing
|
||||
const byte* form_preset = form_fields_val+0;
|
||||
const byte* form_ctrl_bmm = form_fields_val+1;
|
||||
const byte* form_ctrl_mcm = form_fields_val+2;
|
||||
const byte* form_ctrl_ecm = form_fields_val+3;
|
||||
const byte* form_ctrl_hicol = form_fields_val+4;
|
||||
const byte* form_ctrl_line = form_fields_val+5;
|
||||
const byte* form_ctrl_colof = form_fields_val+6;
|
||||
const byte* form_ctrl_chunk = form_fields_val+7;
|
||||
const byte* form_ctrl_borof = form_fields_val+8;
|
||||
const byte* form_ctrl_overs = form_fields_val+9;
|
||||
const byte* form_a_pattern = form_fields_val+10;
|
||||
const byte* form_a_start_hi = form_fields_val+11;
|
||||
const byte* form_a_start_lo = form_fields_val+12;
|
||||
const byte* form_a_step_hi = form_fields_val+13;
|
||||
const byte* form_a_step_lo = form_fields_val+14;
|
||||
const byte* form_a_mod_hi = form_fields_val+15;
|
||||
const byte* form_a_mod_lo = form_fields_val+16;
|
||||
const byte* form_b_pattern = form_fields_val+17;
|
||||
const byte* form_b_start_hi = form_fields_val+18;
|
||||
const byte* form_b_start_lo = form_fields_val+19;
|
||||
const byte* form_b_step_hi = form_fields_val+20;
|
||||
const byte* form_b_step_lo = form_fields_val+21;
|
||||
const byte* form_b_mod_hi = form_fields_val+22;
|
||||
const byte* form_b_mod_lo = form_fields_val+23;
|
||||
const byte* form_vic_screen = form_fields_val+24;
|
||||
const byte* form_vic_gfx = form_fields_val+25;
|
||||
const byte* form_vic_cols = form_fields_val+26;
|
||||
const byte* form_dtv_palet = form_fields_val+27;
|
||||
const byte* form_vic_bg0_hi = form_fields_val+28;
|
||||
const byte* form_vic_bg0_lo = form_fields_val+29;
|
||||
const byte* form_vic_bg1_hi = form_fields_val+30;
|
||||
const byte* form_vic_bg1_lo = form_fields_val+31;
|
||||
const byte* form_vic_bg2_hi = form_fields_val+32;
|
||||
const byte* form_vic_bg2_lo = form_fields_val+33;
|
||||
const byte* form_vic_bg3_hi = form_fields_val+34;
|
||||
const byte* form_vic_bg3_lo = form_fields_val+35;
|
||||
byte* const form_preset = form_fields_val+0;
|
||||
byte* const form_ctrl_bmm = form_fields_val+1;
|
||||
byte* const form_ctrl_mcm = form_fields_val+2;
|
||||
byte* const form_ctrl_ecm = form_fields_val+3;
|
||||
byte* const form_ctrl_hicol = form_fields_val+4;
|
||||
byte* const form_ctrl_line = form_fields_val+5;
|
||||
byte* const form_ctrl_colof = form_fields_val+6;
|
||||
byte* const form_ctrl_chunk = form_fields_val+7;
|
||||
byte* const form_ctrl_borof = form_fields_val+8;
|
||||
byte* const form_ctrl_overs = form_fields_val+9;
|
||||
byte* const form_a_pattern = form_fields_val+10;
|
||||
byte* const form_a_start_hi = form_fields_val+11;
|
||||
byte* const form_a_start_lo = form_fields_val+12;
|
||||
byte* const form_a_step_hi = form_fields_val+13;
|
||||
byte* const form_a_step_lo = form_fields_val+14;
|
||||
byte* const form_a_mod_hi = form_fields_val+15;
|
||||
byte* const form_a_mod_lo = form_fields_val+16;
|
||||
byte* const form_b_pattern = form_fields_val+17;
|
||||
byte* const form_b_start_hi = form_fields_val+18;
|
||||
byte* const form_b_start_lo = form_fields_val+19;
|
||||
byte* const form_b_step_hi = form_fields_val+20;
|
||||
byte* const form_b_step_lo = form_fields_val+21;
|
||||
byte* const form_b_mod_hi = form_fields_val+22;
|
||||
byte* const form_b_mod_lo = form_fields_val+23;
|
||||
byte* const form_vic_screen = form_fields_val+24;
|
||||
byte* const form_vic_gfx = form_fields_val+25;
|
||||
byte* const form_vic_cols = form_fields_val+26;
|
||||
byte* const form_dtv_palet = form_fields_val+27;
|
||||
byte* const form_vic_bg0_hi = form_fields_val+28;
|
||||
byte* const form_vic_bg0_lo = form_fields_val+29;
|
||||
byte* const form_vic_bg1_hi = form_fields_val+30;
|
||||
byte* const form_vic_bg1_lo = form_fields_val+31;
|
||||
byte* const form_vic_bg2_hi = form_fields_val+32;
|
||||
byte* const form_vic_bg2_lo = form_fields_val+33;
|
||||
byte* const form_vic_bg3_hi = form_fields_val+34;
|
||||
byte* const form_vic_bg3_lo = form_fields_val+35;
|
||||
|
||||
// Change graphics mode to show the selected graphics mode
|
||||
void gfx_mode() {
|
||||
|
@ -42,8 +42,8 @@ byte MENU_TEXT[] =
|
||||
|
||||
|
||||
void menu() {
|
||||
const byte* SCREEN = $8000;
|
||||
const byte* CHARSET = $9800; // Charset ROM
|
||||
byte* const SCREEN = $8000;
|
||||
byte* const CHARSET = $9800; // Charset ROM
|
||||
// DTV Graphics Bank
|
||||
*DTV_GRAPHICS_VIC_BANK = (byte)((dword)CHARSET/$10000);
|
||||
// DTV Color Bank
|
||||
@ -187,9 +187,9 @@ void mode_ctrl() {
|
||||
// - 0: 4bpp BgColor0[3:0]
|
||||
// - 1: 4bpp ColorData[3:0]
|
||||
void mode_stdchar() {
|
||||
const byte* SCREEN = $8000;
|
||||
const byte* CHARSET = $9000; // Charset ROM
|
||||
const byte* COLORS = $d800;
|
||||
byte* const SCREEN = $8000;
|
||||
byte* const CHARSET = $9000; // Charset ROM
|
||||
byte* const COLORS = $d800;
|
||||
// DTV Graphics Bank
|
||||
*DTV_GRAPHICS_VIC_BANK = (byte)((dword)CHARSET/$10000);
|
||||
// DTV Color Bank
|
||||
@ -238,9 +238,9 @@ void mode_stdchar() {
|
||||
// - CharData[7:6] 11: 4bpp BgColor3[3:0]
|
||||
// - 1: 4bpp ColorData[3:0]
|
||||
void mode_ecmchar() {
|
||||
const byte* SCREEN = $8000;
|
||||
const byte* CHARSET = $9000; // Charset ROM
|
||||
const byte* COLORS = $d800;
|
||||
byte* const SCREEN = $8000;
|
||||
byte* const CHARSET = $9000; // Charset ROM
|
||||
byte* const COLORS = $d800;
|
||||
// DTV Graphics Bank
|
||||
*DTV_GRAPHICS_VIC_BANK = (byte)((dword)CHARSET/$10000);
|
||||
// DTV Color Bank
|
||||
@ -294,9 +294,9 @@ void mode_ecmchar() {
|
||||
// - 10: 4bpp BgColor2[3:0]
|
||||
// - 11: 4bpp ColorData[2:0]// Standard Character Mode (LINEAR/HICOL/CHUNK/COLDIS/ECM/MCM/BMM = 0)
|
||||
void mode_mcchar() {
|
||||
const byte* SCREEN = $8000;
|
||||
const byte* CHARSET = $9000; // Charset ROM
|
||||
const byte* COLORS = $d800;
|
||||
byte* const SCREEN = $8000;
|
||||
byte* const CHARSET = $9000; // Charset ROM
|
||||
byte* const COLORS = $d800;
|
||||
// DTV Graphics Bank
|
||||
*DTV_GRAPHICS_VIC_BANK = (byte)((dword)CHARSET/$10000);
|
||||
// DTV Color Bank
|
||||
@ -344,8 +344,8 @@ void mode_mcchar() {
|
||||
// - 0: 4bpp CharData[3:0]
|
||||
// - 1: 4bpp CharData[7:4]
|
||||
void mode_stdbitmap() {
|
||||
const byte* SCREEN = $4000;
|
||||
const byte* BITMAP = $6000;
|
||||
byte* const SCREEN = $4000;
|
||||
byte* const BITMAP = $6000;
|
||||
// DTV Graphics Bank
|
||||
*DTV_GRAPHICS_VIC_BANK = (byte)((dword)BITMAP/$10000);
|
||||
// DTV Graphics Mode
|
||||
@ -396,9 +396,9 @@ void mode_stdbitmap() {
|
||||
// - 0: 8bpp BgColor0[7:0]
|
||||
// - 1: 8bpp ColorData[7:0]
|
||||
void mode_hicolstdchar() {
|
||||
const byte* SCREEN = $8000;
|
||||
const byte* CHARSET = $9000; // Charset ROM
|
||||
const byte* COLORS = $8400;
|
||||
byte* const SCREEN = $8000;
|
||||
byte* const CHARSET = $9000; // Charset ROM
|
||||
byte* const COLORS = $8400;
|
||||
// DTV Graphics Bank
|
||||
*DTV_GRAPHICS_VIC_BANK = (byte)((dword)CHARSET/$10000);
|
||||
// DTV Color Bank
|
||||
@ -449,9 +449,9 @@ void mode_hicolstdchar() {
|
||||
// - CharData[7:6] 11: 8bpp BgColor3[7:0]
|
||||
// - 1: 8bpp ColorData[7:0]
|
||||
void mode_hicolecmchar() {
|
||||
const byte* SCREEN = $8000;
|
||||
const byte* CHARSET = $9000; // Charset ROM
|
||||
const byte* COLORS = $8400;
|
||||
byte* const SCREEN = $8000;
|
||||
byte* const CHARSET = $9000; // Charset ROM
|
||||
byte* const COLORS = $8400;
|
||||
// DTV Graphics Bank
|
||||
*DTV_GRAPHICS_VIC_BANK = (byte)((dword)CHARSET/$10000);
|
||||
// DTV Color Bank
|
||||
@ -505,9 +505,9 @@ void mode_hicolecmchar() {
|
||||
// - 10: 8bpp BgColor2[7:0]
|
||||
// - 11: 8bpp ColorData[7:4] "0" & Color[2:0]
|
||||
void mode_hicolmcchar() {
|
||||
const byte* SCREEN = $8000;
|
||||
const byte* CHARSET = $9000; // Charset ROM
|
||||
const byte* COLORS = $8400;
|
||||
byte* const SCREEN = $8000;
|
||||
byte* const CHARSET = $9000; // Charset ROM
|
||||
byte* const COLORS = $8400;
|
||||
// DTV Graphics Bank
|
||||
*DTV_GRAPHICS_VIC_BANK = (byte)((dword)CHARSET/$10000);
|
||||
// DTV Color Bank
|
||||
@ -557,9 +557,9 @@ void mode_hicolmcchar() {
|
||||
// - Plane A = 1 Plane B = 0: 8bpp "0000" & ColorData[3:0]
|
||||
// - Plane A = 1 Plane B = 1: 8bpp BgColor1[7:0]
|
||||
void mode_twoplanebitmap() {
|
||||
const byte* PLANEA = $4000;
|
||||
const byte* PLANEB = $6000;
|
||||
const byte* COLORS = $8000;
|
||||
byte* const PLANEA = $4000;
|
||||
byte* const PLANEB = $6000;
|
||||
byte* const COLORS = $8000;
|
||||
// DTV Graphics Mode
|
||||
dtv_control = DTV_HIGHCOLOR | DTV_LINEAR;
|
||||
*DTV_CONTROL = DTV_HIGHCOLOR | DTV_LINEAR;
|
||||
@ -627,9 +627,9 @@ void mode_twoplanebitmap() {
|
||||
// GfxData/PlaneA Pixel Shifter (2), CharData/PlaneB Pixel Shifter (2):
|
||||
// - 8bpp color (ColorData[3:0],CharData/PlaneB[1:0], GfxData/PlaneA[1:0])
|
||||
void mode_sixsfred() {
|
||||
const byte* PLANEA = $4000;
|
||||
const byte* PLANEB = $6000;
|
||||
const byte* COLORS = $8000;
|
||||
byte* const PLANEA = $4000;
|
||||
byte* const PLANEB = $6000;
|
||||
byte* const COLORS = $8000;
|
||||
// DTV Graphics Mode
|
||||
dtv_control = DTV_HIGHCOLOR | DTV_LINEAR;
|
||||
*DTV_CONTROL = DTV_HIGHCOLOR | DTV_LINEAR;
|
||||
@ -693,9 +693,9 @@ void mode_sixsfred() {
|
||||
// PlaneA Pixel Shifter (2), PlaneB Pixel Shifter (2):
|
||||
// - 8bpp color (PlaneB[1:0],ColorData[5:4],PlaneA[1:0],ColorData[1:0])
|
||||
void mode_sixsfred2() {
|
||||
const byte* PLANEA = $4000;
|
||||
const byte* PLANEB = $6000;
|
||||
const byte* COLORS = $8000;
|
||||
byte* const PLANEA = $4000;
|
||||
byte* const PLANEB = $6000;
|
||||
byte* const COLORS = $8000;
|
||||
// DTV Graphics Mode
|
||||
dtv_control = DTV_LINEAR;
|
||||
*DTV_CONTROL = DTV_LINEAR;
|
||||
@ -764,9 +764,9 @@ void mode_sixsfred2() {
|
||||
//Counter B step and modulo should be set to 0, counter A modulo to 0 and counter A step to 1 for normal operation.
|
||||
void mode_8bpppixelcell() {
|
||||
// 8BPP Pixel Cell Screen (contains 40x25=1000 chars)
|
||||
const byte* PLANEA = $3c00;
|
||||
byte* const PLANEA = $3c00;
|
||||
// 8BPP Pixel Cell Charset (contains 256 64 byte chars)
|
||||
const byte* PLANEB = $4000;
|
||||
byte* const PLANEB = $4000;
|
||||
// DTV Graphics Mode
|
||||
dtv_control = DTV_HIGHCOLOR | DTV_LINEAR | DTV_CHUNKY;
|
||||
*DTV_CONTROL = DTV_HIGHCOLOR | DTV_LINEAR | DTV_CHUNKY;
|
||||
|
@ -7,7 +7,7 @@ void main() {
|
||||
print( {0x12,0x34} );
|
||||
}
|
||||
|
||||
const word* SCREEN = 0x0400;
|
||||
word* const SCREEN = 0x0400;
|
||||
byte idx = 0;
|
||||
|
||||
void print(word w) {
|
||||
|
@ -4,7 +4,7 @@ import "c64"
|
||||
import "time"
|
||||
import "print"
|
||||
|
||||
const byte* SCREEN = 0x0400;
|
||||
byte* const SCREEN = 0x0400;
|
||||
|
||||
void main() {
|
||||
|
||||
|
@ -4,7 +4,7 @@ import "c64"
|
||||
import "time"
|
||||
import "print"
|
||||
|
||||
const byte* SCREEN = 0x0400;
|
||||
byte* const SCREEN = 0x0400;
|
||||
|
||||
void main() {
|
||||
|
||||
|
@ -3,7 +3,7 @@ byte* BORDERCOL = $d020;
|
||||
byte* RASTER = $d012;
|
||||
byte DARK_GREY = $b;
|
||||
byte BLACK = 0;
|
||||
const void()** KERNEL_IRQ = $0314;
|
||||
void()** const KERNEL_IRQ = $0314;
|
||||
|
||||
|
||||
void main() {
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Tests variable coalescing over assignments
|
||||
|
||||
void main() {
|
||||
const byte* SCREEN = 0x0400;
|
||||
byte* const SCREEN = 0x0400;
|
||||
byte idx = 0;
|
||||
for( byte a: 0..5) {
|
||||
for( byte b: 0..5) {
|
||||
|
@ -1,6 +1,6 @@
|
||||
// Test code after return in main()
|
||||
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
|
||||
char b = 0;
|
||||
|
||||
|
@ -1,6 +1,6 @@
|
||||
// Test code after return in main()
|
||||
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
|
||||
void main() {
|
||||
SCREEN[0] = 'a';
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Tests comma-separated declarations with different array-ness
|
||||
|
||||
void main() {
|
||||
const char* SCREEN = $400;
|
||||
char* const SCREEN = $400;
|
||||
char b, c[3], d;
|
||||
SCREEN[0] = b;
|
||||
SCREEN[1] = c[0];
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Tests comma-separated declarations inside for()
|
||||
|
||||
void main() {
|
||||
const byte* SCREEN = $400;
|
||||
byte* const SCREEN = $400;
|
||||
for(byte i, j='g'; i<10; i++, j++) {
|
||||
SCREEN[i] = j;
|
||||
}
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Tests comma-separated declarations
|
||||
|
||||
void main() {
|
||||
const byte* SCREEN = $400;
|
||||
byte* const SCREEN = $400;
|
||||
byte b = 'c', c = b+1, d = c+1;
|
||||
SCREEN[0] = b;
|
||||
SCREEN[1] = c;
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Tests simple comma-expression (in parenthesis)
|
||||
|
||||
void main() {
|
||||
const byte* SCREEN = $400;
|
||||
byte* const SCREEN = $400;
|
||||
byte b = (1,2,3);
|
||||
byte c = (1+1,b+1);
|
||||
SCREEN[1,0] = c;
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Tests simple comma-expressions (without parenthesis)
|
||||
|
||||
void main() {
|
||||
const byte* SCREEN = $400;
|
||||
byte* const SCREEN = $400;
|
||||
byte b;
|
||||
byte c;
|
||||
b = 1,2,3;
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Tests comma-expressions in for()-statement
|
||||
|
||||
void main() {
|
||||
const byte* SCREEN = $400;
|
||||
byte* const SCREEN = $400;
|
||||
byte j='g';
|
||||
for( byte i=0; j<10, i<10; i++, j++) {
|
||||
SCREEN[i] = j;
|
||||
|
@ -1,10 +1,10 @@
|
||||
// Test rewriting of constant comparisons for pointers
|
||||
|
||||
void main() {
|
||||
const byte* screen = $0400;
|
||||
byte* const screen = $0400;
|
||||
for(byte* sc =screen;sc<=screen+999;sc++) *sc='a';
|
||||
|
||||
const byte* cols = $d800;
|
||||
byte* const cols = $d800;
|
||||
for(byte* cc =cols+999;cc>cols-1;cc--) *cc=2;
|
||||
|
||||
}
|
@ -1,7 +1,7 @@
|
||||
// Test rewriting of constant comparisons
|
||||
|
||||
void main() {
|
||||
const byte* SCREEN = $0400;
|
||||
byte* const SCREEN = $0400;
|
||||
|
||||
for(byte* sc : SCREEN..SCREEN+1000) *sc=' ';
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Test to provoke Exception when using complex || condition
|
||||
|
||||
const byte* RASTER = $d012;
|
||||
const byte* SCREEN = $0400;
|
||||
byte* const RASTER = $d012;
|
||||
byte* const SCREEN = $0400;
|
||||
|
||||
void main() {
|
||||
while(true) {
|
||||
|
@ -4,7 +4,7 @@
|
||||
|
||||
#pragma link("ataritempest.ld")
|
||||
|
||||
const char* BGCOL = 0xc01a;
|
||||
char* const BGCOL = 0xc01a;
|
||||
|
||||
#pragma data_seg(RomData)
|
||||
char MESSAGE[] = "hello world";
|
||||
@ -25,4 +25,4 @@ void main() {
|
||||
}
|
||||
|
||||
#pragma data_seg(Vectors)
|
||||
export const void()* VECTORS[] = { &nmiHandler, &entryPoint };
|
||||
export void()* const VECTORS[] = { &nmiHandler, &entryPoint };
|
||||
|
@ -9,9 +9,9 @@ import "c64"
|
||||
const bool DEBUG = false;
|
||||
|
||||
// Address of the screen
|
||||
const byte* SCREEN = 0x0400;
|
||||
byte* const SCREEN = 0x0400;
|
||||
// Sprite data for the animating sprites
|
||||
const byte* SPRITE_DATA = 0x2000;
|
||||
byte* const SPRITE_DATA = 0x2000;
|
||||
// Values added to VX
|
||||
const unsigned int VXSIN[40] = kickasm {{
|
||||
.for(var i=0; i<40; i++) {
|
||||
|
@ -29,13 +29,13 @@ signed char align(0x40) SIN[0x140] = kickasm {{
|
||||
signed char* COS = SIN+$40; // sin(x) = cos(x+PI/2)
|
||||
|
||||
// The BASIC screen
|
||||
const char* BASIC_SCREEN = 0x0400;
|
||||
char* const BASIC_SCREEN = 0x0400;
|
||||
// The BASIC charset
|
||||
const char* BASIC_CHARSET = 0x1000;
|
||||
char* const BASIC_CHARSET = 0x1000;
|
||||
// The BOB screen
|
||||
const char* BOB_SCREEN = 0x2800;
|
||||
char* const BOB_SCREEN = 0x2800;
|
||||
// The BOB charset
|
||||
const char* BOB_CHARSET = 0x2000;
|
||||
char* const BOB_CHARSET = 0x2000;
|
||||
|
||||
// Tables containing the char to use for a specific cell of a shifted BOB.
|
||||
// char_id = BOB_TABLES[cell*BOB_SUBTABLE_SIZE + shift_y*BOB_SHIFTS_X + shift_x];
|
||||
|
@ -36,13 +36,13 @@ align(0x100) const char VOGEL_THETA[] = kickasm {{
|
||||
align(0x100) const char VOGEL_R[] = kickasm {{ .fill 100, round(sqrt(i)*15) }};
|
||||
|
||||
// The BASIC screen
|
||||
const char* SCREEN_BASIC = 0x0400;
|
||||
char* const SCREEN_BASIC = 0x0400;
|
||||
// The BASIC charset
|
||||
const char* CHARSET_BASIC = 0x1000;
|
||||
char* const CHARSET_BASIC = 0x1000;
|
||||
// The BOB screen
|
||||
const char* BOB_SCREEN = 0x2800;
|
||||
char* const BOB_SCREEN = 0x2800;
|
||||
// The BOB charset
|
||||
const char* BOB_CHARSET = 0x2000;
|
||||
char* const BOB_CHARSET = 0x2000;
|
||||
|
||||
// Tables containing the char to use for a specific cell of a shifted BOB.
|
||||
// char_id = BOB_TABLES[cell*BOB_SUBTABLE_SIZE + shift_y*BOB_SHIFTS_X + shift_x];
|
||||
|
@ -24,7 +24,7 @@ align(0x40) signed char SIN[0x140] = kickasm {{
|
||||
signed char* COS = SIN+0x40; // sin(x) = cos(x+PI/2)
|
||||
|
||||
// The BASIC screen
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
|
||||
// The number of BOBs to render
|
||||
const char NUM_BOBS = 16;
|
||||
|
@ -7,9 +7,9 @@ import "print"
|
||||
import "fastmultiply"
|
||||
import "c64"
|
||||
|
||||
const char* PRINT_SCREEN = 0x0400;
|
||||
const char* BITMAP_SCREEN = 0x5c00;
|
||||
const char* BITMAP_GRAPHICS = 0x6000;
|
||||
char* const PRINT_SCREEN = 0x0400;
|
||||
char* const BITMAP_SCREEN = 0x5c00;
|
||||
char* const BITMAP_GRAPHICS = 0x6000;
|
||||
|
||||
// A segment of a spline
|
||||
struct Segment {
|
||||
|
@ -1,8 +1,8 @@
|
||||
// SID registers for random number generation
|
||||
const unsigned int* SID_VOICE3_FREQ = 0xd40e;
|
||||
const char* SID_VOICE3_FREQ_LOW = 0xd40e;
|
||||
const char* SID_VOICE3_FREQ_HIGH = 0xd40f;
|
||||
const char* SID_VOICE3_CONTROL = 0xd412;
|
||||
unsigned int* const SID_VOICE3_FREQ = 0xd40e;
|
||||
char* const SID_VOICE3_FREQ_LOW = 0xd40e;
|
||||
char* const SID_VOICE3_FREQ_HIGH = 0xd40f;
|
||||
char* const SID_VOICE3_CONTROL = 0xd412;
|
||||
const char SID_CONTROL_NOISE = 0x80;
|
||||
const char SID_CONTROL_PULSE = 0x40;
|
||||
const char SID_CONTROL_SAWTOOTH = 0x20;
|
||||
@ -11,7 +11,7 @@ const char SID_CONTROL_TEST = 0x08;
|
||||
const char SID_CONTROL_RING = 0x04;
|
||||
const char SID_CONTROL_SYNC = 0x02;
|
||||
const char SID_CONTROL_GATE = 0x01;
|
||||
const char* SID_VOICE3_OSC = 0xd41b;
|
||||
char* const SID_VOICE3_OSC = 0xd41b;
|
||||
|
||||
// Initialize SID voice 3 for random number generation
|
||||
void sid_rnd_init() {
|
||||
|
@ -2,17 +2,17 @@
|
||||
// Memory Layout and Shared Data
|
||||
|
||||
// Address of the first screen
|
||||
const char* PLAYFIELD_SCREEN_1 = 0x0400;
|
||||
char* const PLAYFIELD_SCREEN_1 = 0x0400;
|
||||
// Address of the second screen
|
||||
const char* PLAYFIELD_SCREEN_2 = 0x2c00;
|
||||
char* const PLAYFIELD_SCREEN_2 = 0x2c00;
|
||||
// Screen Sprite pointers on screen 1
|
||||
const char* PLAYFIELD_SPRITE_PTRS_1 = (PLAYFIELD_SCREEN_1+SPRITE_PTRS);
|
||||
char* const PLAYFIELD_SPRITE_PTRS_1 = (PLAYFIELD_SCREEN_1+SPRITE_PTRS);
|
||||
// Screen Sprite pointers on screen 2
|
||||
const char* PLAYFIELD_SPRITE_PTRS_2 = (PLAYFIELD_SCREEN_2+SPRITE_PTRS);
|
||||
char* const PLAYFIELD_SPRITE_PTRS_2 = (PLAYFIELD_SCREEN_2+SPRITE_PTRS);
|
||||
// Address of the sprites covering the playfield
|
||||
const char* PLAYFIELD_SPRITES = 0x3000;
|
||||
char* const PLAYFIELD_SPRITES = 0x3000;
|
||||
// Address of the charset
|
||||
const char* PLAYFIELD_CHARSET = 0x2800;
|
||||
char* const PLAYFIELD_CHARSET = 0x2800;
|
||||
|
||||
// The size of the playfield
|
||||
const char PLAYFIELD_LINES = 22;
|
||||
|
@ -7,11 +7,11 @@ import "string"
|
||||
#pragma link("xmega65.ld")
|
||||
|
||||
|
||||
const char* RASTER = 0xd012;
|
||||
const char* VIC_MEMORY = 0xd018;
|
||||
const char* SCREEN = 0x0400;
|
||||
const char* BGCOL = 0xd021;
|
||||
const char* COLS = 0xd800;
|
||||
char* const RASTER = 0xd012;
|
||||
char* const VIC_MEMORY = 0xd018;
|
||||
char* const SCREEN = 0x0400;
|
||||
char* const BGCOL = 0xd021;
|
||||
char* const COLS = 0xd800;
|
||||
const char BLACK = 0;
|
||||
const char WHITE = 1;
|
||||
|
||||
|
@ -2,7 +2,7 @@
|
||||
// Fill the palette values into
|
||||
|
||||
void main() {
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
for(byte i:0..0xff) {
|
||||
(SCREEN+40*0)[i] = LOGO256_RED[i];
|
||||
(SCREEN+40*8)[i] = LOGO256_GREEN[i];
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Tests using integer conditions in if()
|
||||
// This should produce '+ ++ ++' at the top of the screen
|
||||
|
||||
const byte* SCREEN = 0x0400;
|
||||
byte* const SCREEN = 0x0400;
|
||||
|
||||
void main() {
|
||||
byte idx = 0;
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Tests using integer conditions in if()
|
||||
// This should produce '0 0 0' at the top of the screen
|
||||
|
||||
const byte* SCREEN = 0x0400;
|
||||
byte* const SCREEN = 0x0400;
|
||||
|
||||
void main() {
|
||||
byte idx = 0;
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Tests using integer conditions in while() / for() / do..while
|
||||
// This should produce 'ba ba ba' at the top of the screen
|
||||
|
||||
const byte* SCREEN = 0x0400;
|
||||
byte* const SCREEN = 0x0400;
|
||||
byte idx = 0;
|
||||
|
||||
void main() {
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Tests using integer conditions in ternary operator
|
||||
// This should produce '++0++' at the top of the screen
|
||||
|
||||
const byte* SCREEN = 0x0400;
|
||||
byte* const SCREEN = 0x0400;
|
||||
|
||||
void main() {
|
||||
byte idx = 0;
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Tests using integer conditions in && and || operator
|
||||
// This should produce '01010101', '00110011', '00010001', '01110111' at the top of the screen
|
||||
|
||||
const byte* SCREEN = 0x0400;
|
||||
byte* const SCREEN = 0x0400;
|
||||
|
||||
void main() {
|
||||
byte idx = 0;
|
||||
|
@ -1,4 +1,4 @@
|
||||
const byte* screen = $400;
|
||||
byte* const screen = $400;
|
||||
|
||||
void main() {
|
||||
inline for( byte j: 0..1) {
|
||||
|
@ -3,7 +3,7 @@
|
||||
void main() {
|
||||
char bError = 7;
|
||||
bError &= ~(0x10 | 0x20 | 0x40);
|
||||
const char* screen = 0x0400;
|
||||
char* const screen = 0x0400;
|
||||
*screen = bError;
|
||||
}
|
||||
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Ensure that if()'s with constant comparisons are identified and eliminated
|
||||
|
||||
void main() {
|
||||
const byte* SCREEN = $0400;
|
||||
byte* const SCREEN = $0400;
|
||||
if(7<4) {
|
||||
SCREEN[0] = '*';
|
||||
} else {
|
||||
|
@ -1,12 +1,12 @@
|
||||
// Tests a number of constant declarations
|
||||
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
const char LINE_LEN = 40;
|
||||
const char MARGIN_TOP = 4;
|
||||
const char MARGIN_LEFT = 4;
|
||||
const unsigned int OFFSET = 40*5+5;
|
||||
const char* BODY1 = SCREEN+MARGIN_TOP*LINE_LEN+MARGIN_LEFT;
|
||||
const char* BODY2 = SCREEN+OFFSET;
|
||||
char* const BODY1 = SCREEN+MARGIN_TOP*LINE_LEN+MARGIN_LEFT;
|
||||
char* const BODY2 = SCREEN+OFFSET;
|
||||
|
||||
void main() {
|
||||
*BODY1 = '*';
|
||||
|
@ -1,5 +1,5 @@
|
||||
const byte* plots = $1000;
|
||||
const byte* SCREEN = $0400;
|
||||
byte* const plots = $1000;
|
||||
byte* const SCREEN = $0400;
|
||||
|
||||
void main() {
|
||||
for(byte i : 0..39) {
|
||||
|
@ -1,5 +1,5 @@
|
||||
// Test a problem with converting casted constant numbers to fixed type constant integers
|
||||
const byte* SCREEN = $0400;
|
||||
byte* const SCREEN = $0400;
|
||||
|
||||
void main() {
|
||||
for( byte i: 121..122) {
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Test that modifying constant pointers fail
|
||||
|
||||
void main() {
|
||||
const byte* screen = $400;
|
||||
byte* const screen = $400;
|
||||
screen[0] = 'c';
|
||||
screen++;
|
||||
screen[0] = 'm';
|
||||
|
@ -1,4 +1,4 @@
|
||||
const byte* SCREEN = $0400;
|
||||
byte* const SCREEN = $0400;
|
||||
|
||||
void main() {
|
||||
*SCREEN = 1;
|
||||
|
@ -1,4 +1,4 @@
|
||||
const byte* SCREEN = $0400;
|
||||
byte* const SCREEN = $0400;
|
||||
const byte STAR = 81;
|
||||
|
||||
byte* VIC = $d000;
|
||||
|
@ -1,5 +1,5 @@
|
||||
import "print.kc"
|
||||
const byte* BGCOL = $d021;
|
||||
byte* const BGCOL = $d021;
|
||||
const byte GREEN = 5;
|
||||
const byte RED = 2 ;
|
||||
|
||||
|
@ -6,8 +6,8 @@ import "atan2"
|
||||
import "c64"
|
||||
import "print"
|
||||
|
||||
const byte* CHARSET = 0x2000;
|
||||
const byte* SCREEN = 0x2800;
|
||||
byte* const CHARSET = 0x2000;
|
||||
byte* const SCREEN = 0x2800;
|
||||
|
||||
const byte SCREEN_REF[1000] = kickasm {{
|
||||
.for(var y=-12;y<=12;y++)
|
||||
|
@ -5,8 +5,8 @@ import "font-hex"
|
||||
import "atan2"
|
||||
import "c64"
|
||||
|
||||
const byte* CHARSET = 0x2000;
|
||||
const byte* SCREEN = 0x2800;
|
||||
byte* const CHARSET = 0x2000;
|
||||
byte* const SCREEN = 0x2800;
|
||||
|
||||
void main() {
|
||||
init_font_hex(CHARSET);
|
||||
|
@ -4,8 +4,8 @@ import "font-hex"
|
||||
import "atan2"
|
||||
import "c64"
|
||||
|
||||
const byte* CHARSET = 0x2000;
|
||||
const byte* SCREEN = 0x2800;
|
||||
byte* const CHARSET = 0x2000;
|
||||
byte* const SCREEN = 0x2800;
|
||||
|
||||
void main() {
|
||||
init_font_hex(CHARSET);
|
||||
|
@ -6,8 +6,8 @@ import "c64"
|
||||
import "atan2"
|
||||
|
||||
|
||||
const byte* CHARSET = 0x2000;
|
||||
const byte* SCREEN = 0x2800;
|
||||
byte* const CHARSET = 0x2000;
|
||||
byte* const SCREEN = 0x2800;
|
||||
|
||||
void main() {
|
||||
init_font_hex(CHARSET);
|
||||
|
@ -4,7 +4,7 @@
|
||||
#pragma cpu(MOS6502)
|
||||
|
||||
void main() {
|
||||
const char* screen = 0x0400;
|
||||
char* const screen = 0x0400;
|
||||
char c=0;
|
||||
while(c<100) {
|
||||
screen[c] = '*';
|
||||
|
@ -2,7 +2,7 @@
|
||||
// https://www.protovision.games/hardw/build4player.php?language=en&fbclid=IwAR1MJLgQjOU0zVa0ax2aNeGa-xVbE9IGY9zC6b6eInTV4HQzoUAoCPoXu14
|
||||
|
||||
import "c64"
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
void main() {
|
||||
(*CIA2_PORT_B) &= 0x7f;
|
||||
asm { lda #0 }
|
||||
|
@ -2,7 +2,7 @@
|
||||
|
||||
__mem __ma char idx;
|
||||
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
|
||||
void main() {
|
||||
for( char i: 0..5 ) {
|
||||
|
@ -4,7 +4,7 @@
|
||||
__mem __ma char idx;
|
||||
char* idx_p = &idx;
|
||||
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
|
||||
void main() {
|
||||
for( char i: 0..5 ) {
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Test declaring a variable as "memory", meaning it will be stored in memory and accessed through an implicit pointer (using load/store)
|
||||
// Test a memory variable containing a pointer
|
||||
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
|
||||
__mem __ma char* cursor = SCREEN;
|
||||
|
||||
|
@ -10,7 +10,7 @@ __mem __ma struct foo bar = { 'a', 'b' };
|
||||
|
||||
void main(void) {
|
||||
struct foo* barp = &bar;
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
char i=0;
|
||||
SCREEN[i++] = barp->thing1;
|
||||
SCREEN[i++] = barp->thing2;
|
||||
|
@ -11,7 +11,7 @@ __mem __ma struct foo bar = { 'a', 'b', "qwe" };
|
||||
|
||||
void main(void) {
|
||||
struct foo* barp = &bar;
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
char i=0;
|
||||
SCREEN[i++] = barp->thing1;
|
||||
SCREEN[i++] = barp->thing2;
|
||||
|
@ -9,7 +9,7 @@ struct foo {
|
||||
__mem __ma struct foo bar = { 'a', 'b' };
|
||||
|
||||
void main(void) {
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
char i=0;
|
||||
SCREEN[i++] = bar.thing1;
|
||||
SCREEN[i++] = bar.thing2;
|
||||
|
@ -1,6 +1,6 @@
|
||||
// Test declaring a variable as "memory", meaning it will be stored in memory and accessed through an implicit pointer (using load/store)
|
||||
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
char i=0;
|
||||
|
||||
void main(void) {
|
||||
|
@ -3,7 +3,7 @@
|
||||
|
||||
__ma char idx;
|
||||
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
|
||||
void main() {
|
||||
for( char i: 0..5 ) {
|
||||
|
@ -3,7 +3,7 @@
|
||||
|
||||
__ma __address(0x1000) char idx;
|
||||
|
||||
const char* SCREEN = 0x0400;
|
||||
char* const SCREEN = 0x0400;
|
||||
|
||||
void main() {
|
||||
for( char i: 0..5 ) {
|
||||
|
@ -3,10 +3,10 @@
|
||||
char __ssa idx_ssa_g;
|
||||
char __ma idx_nssa_g;
|
||||
|
||||
const char* SCREEN1 = 0x0400;
|
||||
const char* SCREEN2 = 0x0400+40;
|
||||
const char* SCREEN3 = 0x0400+80;
|
||||
const char* SCREEN4 = 0x0400+120;
|
||||
char* const SCREEN1 = 0x0400;
|
||||
char* const SCREEN2 = 0x0400+40;
|
||||
char* const SCREEN3 = 0x0400+80;
|
||||
char* const SCREEN4 = 0x0400+120;
|
||||
|
||||
void main() {
|
||||
char __ssa idx_ssa_l;
|
||||
|
@ -8,7 +8,7 @@ void main() {
|
||||
print(msg2);
|
||||
}
|
||||
|
||||
const word* SCREEN = $0400;
|
||||
word* const SCREEN = $0400;
|
||||
byte screen_idx=0;
|
||||
|
||||
void print(byte* m) {
|
||||
|
@ -8,7 +8,7 @@ void main() {
|
||||
print(msg2);
|
||||
}
|
||||
|
||||
const byte* SCREEN = $0400;
|
||||
byte* const SCREEN = $0400;
|
||||
byte idx=0;
|
||||
|
||||
void print(byte* m) {
|
||||
|
@ -1,7 +1,7 @@
|
||||
// Tests that array-indexing by a word variable is turned into pointer addition
|
||||
|
||||
void main() {
|
||||
const byte* screen = 0x0400;
|
||||
byte* const screen = 0x0400;
|
||||
for( word i=0;i<1000;i+=40) {
|
||||
screen[i] = 'a';
|
||||
}
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user