1
0
mirror of https://gitlab.com/camelot/kickc.git synced 2025-04-08 14:37:40 +00:00

Fixed tests

This commit is contained in:
jespergravgaard 2018-08-10 20:32:45 +02:00
parent f8ec74dc14
commit df224c70b6
32 changed files with 1374 additions and 1403 deletions

View File

@ -91,7 +91,7 @@ public class Procedure extends Scope {
/** The different types of supported interrupts. */
public enum InterruptType {
/** Interrupt served by the kernel called through $0314-5. Will exit through the kernel using $ea31. */
KERNEL_STD,
KERNEL_KEYBOARD,
/** Interrupt served by the kernel called through $0314-5. Will exit through the kernel using $ea81. */
KERNEL_MIN,
/** Interrupt served directly from hardware through $fffe-f. Will exit through RTI and will save NO registers. */

View File

@ -65,7 +65,7 @@ directive
| 'register' '(' NAME ')' #directiveRegister
| 'inline' #directiveInline
| 'volatile' #directiveVolatile
| 'interrupt' ( '(' ('hardware' ( 'none' | 'clobber' | 'all' )? | 'kernel' ( 'min' | 'std' )? ) ')' )? #directiveInterrupt
| 'interrupt' ( '(' NAME ')' )? #directiveInterrupt
;
stmtSeq

View File

@ -66,32 +66,26 @@ T__64=65
T__65=66
T__66=67
T__67=68
T__68=69
T__69=70
T__70=71
T__71=72
T__72=73
T__73=74
MNEMONIC=75
KICKASM=76
SIMPLETYPE=77
STRING=78
CHAR=79
BOOLEAN=80
NUMBER=81
NUMFLOAT=82
BINFLOAT=83
DECFLOAT=84
HEXFLOAT=85
NUMINT=86
BININTEGER=87
DECINTEGER=88
HEXINTEGER=89
NAME=90
ASMREL=91
WS=92
COMMENT_LINE=93
COMMENT_BLOCK=94
MNEMONIC=69
KICKASM=70
SIMPLETYPE=71
STRING=72
CHAR=73
BOOLEAN=74
NUMBER=75
NUMFLOAT=76
BINFLOAT=77
DECFLOAT=78
HEXFLOAT=79
NUMINT=80
BININTEGER=81
DECINTEGER=82
HEXINTEGER=83
NAME=84
ASMREL=85
WS=86
COMMENT_LINE=87
COMMENT_BLOCK=88
'import'=1
'='=2
';'=3
@ -115,54 +109,48 @@ COMMENT_BLOCK=94
'register'=21
'volatile'=22
'interrupt'=23
'hardware'=24
'none'=25
'all'=26
'kernel'=27
'min'=28
'std'=29
'if'=30
'else'=31
'while'=32
'do'=33
'for'=34
'return'=35
'asm'=36
'..'=37
'signed'=38
'*'=39
'['=40
']'=41
'--'=42
'++'=43
'+'=44
'-'=45
'!'=46
'&'=47
'~'=48
'>>'=49
'<<'=50
'/'=51
'%'=52
'<'=53
'>'=54
'=='=55
'!='=56
'<='=57
'>='=58
'^'=59
'|'=60
'&&'=61
'||'=62
'+='=63
'-='=64
'*='=65
'/='=66
'%='=67
'<<='=68
'>>='=69
'&='=70
'|='=71
'^='=72
'.byte'=73
'#'=74
'if'=24
'else'=25
'while'=26
'do'=27
'for'=28
'return'=29
'asm'=30
'..'=31
'signed'=32
'*'=33
'['=34
']'=35
'--'=36
'++'=37
'+'=38
'-'=39
'!'=40
'&'=41
'~'=42
'>>'=43
'<<'=44
'/'=45
'%'=46
'<'=47
'>'=48
'=='=49
'!='=50
'<='=51
'>='=52
'^'=53
'|'=54
'&&'=55
'||'=56
'+='=57
'-='=58
'*='=59
'/='=60
'%='=61
'<<='=62
'>>='=63
'&='=64
'|='=65
'^='=66
'.byte'=67
'#'=68

View File

@ -26,11 +26,10 @@ public class KickCLexer extends Lexer {
T__45=46, T__46=47, T__47=48, T__48=49, T__49=50, T__50=51, T__51=52,
T__52=53, T__53=54, T__54=55, T__55=56, T__56=57, T__57=58, T__58=59,
T__59=60, T__60=61, T__61=62, T__62=63, T__63=64, T__64=65, T__65=66,
T__66=67, T__67=68, T__68=69, T__69=70, T__70=71, T__71=72, T__72=73,
T__73=74, MNEMONIC=75, KICKASM=76, SIMPLETYPE=77, STRING=78, CHAR=79,
BOOLEAN=80, NUMBER=81, NUMFLOAT=82, BINFLOAT=83, DECFLOAT=84, HEXFLOAT=85,
NUMINT=86, BININTEGER=87, DECINTEGER=88, HEXINTEGER=89, NAME=90, ASMREL=91,
WS=92, COMMENT_LINE=93, COMMENT_BLOCK=94;
T__66=67, T__67=68, MNEMONIC=69, KICKASM=70, SIMPLETYPE=71, STRING=72,
CHAR=73, BOOLEAN=74, NUMBER=75, NUMFLOAT=76, BINFLOAT=77, DECFLOAT=78,
HEXFLOAT=79, NUMINT=80, BININTEGER=81, DECINTEGER=82, HEXINTEGER=83, NAME=84,
ASMREL=85, WS=86, COMMENT_LINE=87, COMMENT_BLOCK=88;
public static String[] channelNames = {
"DEFAULT_TOKEN_CHANNEL", "HIDDEN"
};
@ -48,23 +47,23 @@ public class KickCLexer extends Lexer {
"T__41", "T__42", "T__43", "T__44", "T__45", "T__46", "T__47", "T__48",
"T__49", "T__50", "T__51", "T__52", "T__53", "T__54", "T__55", "T__56",
"T__57", "T__58", "T__59", "T__60", "T__61", "T__62", "T__63", "T__64",
"T__65", "T__66", "T__67", "T__68", "T__69", "T__70", "T__71", "T__72",
"T__73", "MNEMONIC", "KICKASM", "SIMPLETYPE", "STRING", "CHAR", "BOOLEAN",
"NUMBER", "NUMFLOAT", "BINFLOAT", "DECFLOAT", "HEXFLOAT", "NUMINT", "BININTEGER",
"DECINTEGER", "HEXINTEGER", "BINDIGIT", "DECDIGIT", "HEXDIGIT", "NAME",
"NAME_START", "NAME_CHAR", "ASMREL", "WS", "COMMENT_LINE", "COMMENT_BLOCK"
"T__65", "T__66", "T__67", "MNEMONIC", "KICKASM", "SIMPLETYPE", "STRING",
"CHAR", "BOOLEAN", "NUMBER", "NUMFLOAT", "BINFLOAT", "DECFLOAT", "HEXFLOAT",
"NUMINT", "BININTEGER", "DECINTEGER", "HEXINTEGER", "BINDIGIT", "DECDIGIT",
"HEXDIGIT", "NAME", "NAME_START", "NAME_CHAR", "ASMREL", "WS", "COMMENT_LINE",
"COMMENT_BLOCK"
};
private static final String[] _LITERAL_NAMES = {
null, "'import'", "'='", "';'", "'('", "')'", "'{'", "'}'", "'kickasm'",
"','", "'resource'", "'clobber'", "'param'", "':'", "'bytes'", "'cycles'",
"'pc'", "'inline'", "'const'", "'extern'", "'align'", "'register'", "'volatile'",
"'interrupt'", "'hardware'", "'none'", "'all'", "'kernel'", "'min'", "'std'",
"'if'", "'else'", "'while'", "'do'", "'for'", "'return'", "'asm'", "'..'",
"'signed'", "'*'", "'['", "']'", "'--'", "'++'", "'+'", "'-'", "'!'",
"'&'", "'~'", "'>>'", "'<<'", "'/'", "'%'", "'<'", "'>'", "'=='", "'!='",
"'<='", "'>='", "'^'", "'|'", "'&&'", "'||'", "'+='", "'-='", "'*='",
"'/='", "'%='", "'<<='", "'>>='", "'&='", "'|='", "'^='", "'.byte'", "'#'"
"'interrupt'", "'if'", "'else'", "'while'", "'do'", "'for'", "'return'",
"'asm'", "'..'", "'signed'", "'*'", "'['", "']'", "'--'", "'++'", "'+'",
"'-'", "'!'", "'&'", "'~'", "'>>'", "'<<'", "'/'", "'%'", "'<'", "'>'",
"'=='", "'!='", "'<='", "'>='", "'^'", "'|'", "'&&'", "'||'", "'+='",
"'-='", "'*='", "'/='", "'%='", "'<<='", "'>>='", "'&='", "'|='", "'^='",
"'.byte'", "'#'"
};
private static final String[] _SYMBOLIC_NAMES = {
null, null, null, null, null, null, null, null, null, null, null, null,
@ -72,11 +71,10 @@ public class KickCLexer extends Lexer {
null, null, null, null, null, null, null, null, null, null, null, null,
null, null, null, null, null, null, null, null, null, null, null, null,
null, null, null, null, null, null, null, null, null, null, null, null,
null, null, null, null, null, null, null, null, null, null, null, null,
null, null, null, "MNEMONIC", "KICKASM", "SIMPLETYPE", "STRING", "CHAR",
"BOOLEAN", "NUMBER", "NUMFLOAT", "BINFLOAT", "DECFLOAT", "HEXFLOAT", "NUMINT",
"BININTEGER", "DECINTEGER", "HEXINTEGER", "NAME", "ASMREL", "WS", "COMMENT_LINE",
"COMMENT_BLOCK"
null, null, null, null, null, null, null, null, null, "MNEMONIC", "KICKASM",
"SIMPLETYPE", "STRING", "CHAR", "BOOLEAN", "NUMBER", "NUMFLOAT", "BINFLOAT",
"DECFLOAT", "HEXFLOAT", "NUMINT", "BININTEGER", "DECINTEGER", "HEXINTEGER",
"NAME", "ASMREL", "WS", "COMMENT_LINE", "COMMENT_BLOCK"
};
public static final Vocabulary VOCABULARY = new VocabularyImpl(_LITERAL_NAMES, _SYMBOLIC_NAMES);
@ -136,7 +134,7 @@ public class KickCLexer extends Lexer {
public ATN getATN() { return _ATN; }
public static final String _serializedATN =
"\3\u608b\ua72a\u8133\ub9ed\u417c\u3be7\u7786\u5964\2`\u03b0\b\1\4\2\t"+
"\3\u608b\ua72a\u8133\ub9ed\u417c\u3be7\u7786\u5964\2Z\u0383\b\1\4\2\t"+
"\2\4\3\t\3\4\4\t\4\4\5\t\5\4\6\t\6\4\7\t\7\4\b\t\b\4\t\t\t\4\n\t\n\4\13"+
"\t\13\4\f\t\f\4\r\t\r\4\16\t\16\4\17\t\17\4\20\t\20\4\21\t\21\4\22\t\22"+
"\4\23\t\23\4\24\t\24\4\25\t\25\4\26\t\26\4\27\t\27\4\30\t\30\4\31\t\31"+
@ -146,335 +144,320 @@ public class KickCLexer extends Lexer {
"\64\4\65\t\65\4\66\t\66\4\67\t\67\48\t8\49\t9\4:\t:\4;\t;\4<\t<\4=\t="+
"\4>\t>\4?\t?\4@\t@\4A\tA\4B\tB\4C\tC\4D\tD\4E\tE\4F\tF\4G\tG\4H\tH\4I"+
"\tI\4J\tJ\4K\tK\4L\tL\4M\tM\4N\tN\4O\tO\4P\tP\4Q\tQ\4R\tR\4S\tS\4T\tT"+
"\4U\tU\4V\tV\4W\tW\4X\tX\4Y\tY\4Z\tZ\4[\t[\4\\\t\\\4]\t]\4^\t^\4_\t_\4"+
"`\t`\4a\ta\4b\tb\4c\tc\4d\td\3\2\3\2\3\2\3\2\3\2\3\2\3\2\3\3\3\3\3\4\3"+
"\4\3\5\3\5\3\6\3\6\3\7\3\7\3\b\3\b\3\t\3\t\3\t\3\t\3\t\3\t\3\t\3\t\3\n"+
"\3\n\3\13\3\13\3\13\3\13\3\13\3\13\3\13\3\13\3\13\3\f\3\f\3\f\3\f\3\f"+
"\3\f\3\f\3\f\3\r\3\r\3\r\3\r\3\r\3\r\3\16\3\16\3\17\3\17\3\17\3\17\3\17"+
"\3\17\3\20\3\20\3\20\3\20\3\20\3\20\3\20\3\21\3\21\3\21\3\22\3\22\3\22"+
"\3\22\3\22\3\22\3\22\3\23\3\23\3\23\3\23\3\23\3\23\3\24\3\24\3\24\3\24"+
"\3\24\3\24\3\24\3\25\3\25\3\25\3\25\3\25\3\25\3\26\3\26\3\26\3\26\3\26"+
"\3\26\3\26\3\26\3\26\3\27\3\27\3\27\3\27\3\27\3\27\3\27\3\27\3\27\3\30"+
"\3\30\3\30\3\30\3\30\3\30\3\30\3\30\3\30\3\30\3\31\3\31\3\31\3\31\3\31"+
"\3\31\3\31\3\31\3\31\3\32\3\32\3\32\3\32\3\32\3\33\3\33\3\33\3\33\3\34"+
"\3\34\3\34\3\34\3\34\3\34\3\34\3\35\3\35\3\35\3\35\3\36\3\36\3\36\3\36"+
"\3\37\3\37\3\37\3 \3 \3 \3 \3 \3!\3!\3!\3!\3!\3!\3\"\3\"\3\"\3#\3#\3#"+
"\3#\3$\3$\3$\3$\3$\3$\3$\3%\3%\3%\3%\3&\3&\3&\3\'\3\'\3\'\3\'\3\'\3\'"+
"\3\'\3(\3(\3)\3)\3*\3*\3+\3+\3+\3,\3,\3,\3-\3-\3.\3.\3/\3/\3\60\3\60\3"+
"\61\3\61\3\62\3\62\3\62\3\63\3\63\3\63\3\64\3\64\3\65\3\65\3\66\3\66\3"+
"\67\3\67\38\38\38\39\39\39\3:\3:\3:\3;\3;\3;\3<\3<\3=\3=\3>\3>\3>\3?\3"+
"?\3?\3@\3@\3@\3A\3A\3A\3B\3B\3B\3C\3C\3C\3D\3D\3D\3E\3E\3E\3E\3F\3F\3"+
"F\3F\3G\3G\3G\3H\3H\3H\3I\3I\3I\3J\3J\3J\3J\3J\3J\3K\3K\3L\3L\3L\3L\3"+
"L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3"+
"L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3"+
"L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3"+
"L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3"+
"L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3"+
"L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3"+
"L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3"+
"L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3"+
"L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3"+
"L\3L\3L\3L\3L\3L\3L\3L\3L\3L\3L\5L\u02d1\nL\3M\3M\3M\3M\7M\u02d7\nM\f"+
"M\16M\u02da\13M\3M\3M\3M\3N\3N\3N\3N\3N\3N\3N\3N\3N\3N\3N\3N\3N\3N\3N"+
"\3N\3N\3N\3N\3N\3N\5N\u02f4\nN\3O\3O\3O\3O\7O\u02fa\nO\fO\16O\u02fd\13"+
"O\3O\3O\3P\3P\3P\3P\5P\u0305\nP\3P\3P\3Q\3Q\3Q\3Q\3Q\3Q\3Q\3Q\3Q\5Q\u0312"+
"\nQ\3R\3R\5R\u0316\nR\3S\3S\3S\5S\u031b\nS\3T\3T\3T\3T\3T\5T\u0322\nT"+
"\3T\7T\u0325\nT\fT\16T\u0328\13T\3T\3T\6T\u032c\nT\rT\16T\u032d\3U\7U"+
"\u0331\nU\fU\16U\u0334\13U\3U\3U\6U\u0338\nU\rU\16U\u0339\3V\3V\3V\3V"+
"\3V\5V\u0341\nV\3V\7V\u0344\nV\fV\16V\u0347\13V\3V\3V\6V\u034b\nV\rV\16"+
"V\u034c\3W\3W\3W\5W\u0352\nW\3X\3X\3X\6X\u0357\nX\rX\16X\u0358\3X\3X\6"+
"X\u035d\nX\rX\16X\u035e\5X\u0361\nX\3Y\6Y\u0364\nY\rY\16Y\u0365\3Z\3Z"+
"\3Z\3Z\3Z\5Z\u036d\nZ\3Z\6Z\u0370\nZ\rZ\16Z\u0371\3[\3[\3\\\3\\\3]\3]"+
"\3^\3^\7^\u037c\n^\f^\16^\u037f\13^\3_\3_\3`\3`\3a\3a\7a\u0387\na\fa\16"+
"a\u038a\13a\3a\6a\u038d\na\ra\16a\u038e\3b\6b\u0392\nb\rb\16b\u0393\3"+
"b\3b\3c\3c\3c\3c\7c\u039c\nc\fc\16c\u039f\13c\3c\3c\3d\3d\3d\3d\7d\u03a7"+
"\nd\fd\16d\u03aa\13d\3d\3d\3d\3d\3d\4\u02d8\u03a8\2e\3\3\5\4\7\5\t\6\13"+
"\7\r\b\17\t\21\n\23\13\25\f\27\r\31\16\33\17\35\20\37\21!\22#\23%\24\'"+
"\25)\26+\27-\30/\31\61\32\63\33\65\34\67\359\36;\37= ?!A\"C#E$G%I&K\'"+
"M(O)Q*S+U,W-Y.[/]\60_\61a\62c\63e\64g\65i\66k\67m8o9q:s;u<w=y>{?}@\177"+
"A\u0081B\u0083C\u0085D\u0087E\u0089F\u008bG\u008dH\u008fI\u0091J\u0093"+
"K\u0095L\u0097M\u0099N\u009bO\u009dP\u009fQ\u00a1R\u00a3S\u00a5T\u00a7"+
"U\u00a9V\u00abW\u00adX\u00afY\u00b1Z\u00b3[\u00b5\2\u00b7\2\u00b9\2\u00bb"+
"\\\u00bd\2\u00bf\2\u00c1]\u00c3^\u00c5_\u00c7`\3\2\r\3\2$$\3\2))\4\2D"+
"Ddd\3\2\62\63\3\2\62;\5\2\62;CHch\5\2C\\aac|\6\2\62;C\\aac|\4\2--//\5"+
"\2\13\f\17\17\"\"\4\2\f\f\17\17\2\u0418\2\3\3\2\2\2\2\5\3\2\2\2\2\7\3"+
"\2\2\2\2\t\3\2\2\2\2\13\3\2\2\2\2\r\3\2\2\2\2\17\3\2\2\2\2\21\3\2\2\2"+
"\2\23\3\2\2\2\2\25\3\2\2\2\2\27\3\2\2\2\2\31\3\2\2\2\2\33\3\2\2\2\2\35"+
"\3\2\2\2\2\37\3\2\2\2\2!\3\2\2\2\2#\3\2\2\2\2%\3\2\2\2\2\'\3\2\2\2\2)"+
"\3\2\2\2\2+\3\2\2\2\2-\3\2\2\2\2/\3\2\2\2\2\61\3\2\2\2\2\63\3\2\2\2\2"+
"\65\3\2\2\2\2\67\3\2\2\2\29\3\2\2\2\2;\3\2\2\2\2=\3\2\2\2\2?\3\2\2\2\2"+
"A\3\2\2\2\2C\3\2\2\2\2E\3\2\2\2\2G\3\2\2\2\2I\3\2\2\2\2K\3\2\2\2\2M\3"+
"\2\2\2\2O\3\2\2\2\2Q\3\2\2\2\2S\3\2\2\2\2U\3\2\2\2\2W\3\2\2\2\2Y\3\2\2"+
"\2\2[\3\2\2\2\2]\3\2\2\2\2_\3\2\2\2\2a\3\2\2\2\2c\3\2\2\2\2e\3\2\2\2\2"+
"g\3\2\2\2\2i\3\2\2\2\2k\3\2\2\2\2m\3\2\2\2\2o\3\2\2\2\2q\3\2\2\2\2s\3"+
"\2\2\2\2u\3\2\2\2\2w\3\2\2\2\2y\3\2\2\2\2{\3\2\2\2\2}\3\2\2\2\2\177\3"+
"\2\2\2\2\u0081\3\2\2\2\2\u0083\3\2\2\2\2\u0085\3\2\2\2\2\u0087\3\2\2\2"+
"\2\u0089\3\2\2\2\2\u008b\3\2\2\2\2\u008d\3\2\2\2\2\u008f\3\2\2\2\2\u0091"+
"\3\2\2\2\2\u0093\3\2\2\2\2\u0095\3\2\2\2\2\u0097\3\2\2\2\2\u0099\3\2\2"+
"\2\2\u009b\3\2\2\2\2\u009d\3\2\2\2\2\u009f\3\2\2\2\2\u00a1\3\2\2\2\2\u00a3"+
"\3\2\2\2\2\u00a5\3\2\2\2\2\u00a7\3\2\2\2\2\u00a9\3\2\2\2\2\u00ab\3\2\2"+
"\2\2\u00ad\3\2\2\2\2\u00af\3\2\2\2\2\u00b1\3\2\2\2\2\u00b3\3\2\2\2\2\u00bb"+
"\3\2\2\2\2\u00c1\3\2\2\2\2\u00c3\3\2\2\2\2\u00c5\3\2\2\2\2\u00c7\3\2\2"+
"\2\3\u00c9\3\2\2\2\5\u00d0\3\2\2\2\7\u00d2\3\2\2\2\t\u00d4\3\2\2\2\13"+
"\u00d6\3\2\2\2\r\u00d8\3\2\2\2\17\u00da\3\2\2\2\21\u00dc\3\2\2\2\23\u00e4"+
"\3\2\2\2\25\u00e6\3\2\2\2\27\u00ef\3\2\2\2\31\u00f7\3\2\2\2\33\u00fd\3"+
"\2\2\2\35\u00ff\3\2\2\2\37\u0105\3\2\2\2!\u010c\3\2\2\2#\u010f\3\2\2\2"+
"%\u0116\3\2\2\2\'\u011c\3\2\2\2)\u0123\3\2\2\2+\u0129\3\2\2\2-\u0132\3"+
"\2\2\2/\u013b\3\2\2\2\61\u0145\3\2\2\2\63\u014e\3\2\2\2\65\u0153\3\2\2"+
"\2\67\u0157\3\2\2\29\u015e\3\2\2\2;\u0162\3\2\2\2=\u0166\3\2\2\2?\u0169"+
"\3\2\2\2A\u016e\3\2\2\2C\u0174\3\2\2\2E\u0177\3\2\2\2G\u017b\3\2\2\2I"+
"\u0182\3\2\2\2K\u0186\3\2\2\2M\u0189\3\2\2\2O\u0190\3\2\2\2Q\u0192\3\2"+
"\2\2S\u0194\3\2\2\2U\u0196\3\2\2\2W\u0199\3\2\2\2Y\u019c\3\2\2\2[\u019e"+
"\3\2\2\2]\u01a0\3\2\2\2_\u01a2\3\2\2\2a\u01a4\3\2\2\2c\u01a6\3\2\2\2e"+
"\u01a9\3\2\2\2g\u01ac\3\2\2\2i\u01ae\3\2\2\2k\u01b0\3\2\2\2m\u01b2\3\2"+
"\2\2o\u01b4\3\2\2\2q\u01b7\3\2\2\2s\u01ba\3\2\2\2u\u01bd\3\2\2\2w\u01c0"+
"\3\2\2\2y\u01c2\3\2\2\2{\u01c4\3\2\2\2}\u01c7\3\2\2\2\177\u01ca\3\2\2"+
"\2\u0081\u01cd\3\2\2\2\u0083\u01d0\3\2\2\2\u0085\u01d3\3\2\2\2\u0087\u01d6"+
"\3\2\2\2\u0089\u01d9\3\2\2\2\u008b\u01dd\3\2\2\2\u008d\u01e1\3\2\2\2\u008f"+
"\u01e4\3\2\2\2\u0091\u01e7\3\2\2\2\u0093\u01ea\3\2\2\2\u0095\u01f0\3\2"+
"\2\2\u0097\u02d0\3\2\2\2\u0099\u02d2\3\2\2\2\u009b\u02f3\3\2\2\2\u009d"+
"\u02f5\3\2\2\2\u009f\u0300\3\2\2\2\u00a1\u0311\3\2\2\2\u00a3\u0315\3\2"+
"\2\2\u00a5\u031a\3\2\2\2\u00a7\u0321\3\2\2\2\u00a9\u0332\3\2\2\2\u00ab"+
"\u0340\3\2\2\2\u00ad\u0351\3\2\2\2\u00af\u0360\3\2\2\2\u00b1\u0363\3\2"+
"\2\2\u00b3\u036c\3\2\2\2\u00b5\u0373\3\2\2\2\u00b7\u0375\3\2\2\2\u00b9"+
"\u0377\3\2\2\2\u00bb\u0379\3\2\2\2\u00bd\u0380\3\2\2\2\u00bf\u0382\3\2"+
"\2\2\u00c1\u0384\3\2\2\2\u00c3\u0391\3\2\2\2\u00c5\u0397\3\2\2\2\u00c7"+
"\u03a2\3\2\2\2\u00c9\u00ca\7k\2\2\u00ca\u00cb\7o\2\2\u00cb\u00cc\7r\2"+
"\2\u00cc\u00cd\7q\2\2\u00cd\u00ce\7t\2\2\u00ce\u00cf\7v\2\2\u00cf\4\3"+
"\2\2\2\u00d0\u00d1\7?\2\2\u00d1\6\3\2\2\2\u00d2\u00d3\7=\2\2\u00d3\b\3"+
"\2\2\2\u00d4\u00d5\7*\2\2\u00d5\n\3\2\2\2\u00d6\u00d7\7+\2\2\u00d7\f\3"+
"\2\2\2\u00d8\u00d9\7}\2\2\u00d9\16\3\2\2\2\u00da\u00db\7\177\2\2\u00db"+
"\20\3\2\2\2\u00dc\u00dd\7m\2\2\u00dd\u00de\7k\2\2\u00de\u00df\7e\2\2\u00df"+
"\u00e0\7m\2\2\u00e0\u00e1\7c\2\2\u00e1\u00e2\7u\2\2\u00e2\u00e3\7o\2\2"+
"\u00e3\22\3\2\2\2\u00e4\u00e5\7.\2\2\u00e5\24\3\2\2\2\u00e6\u00e7\7t\2"+
"\2\u00e7\u00e8\7g\2\2\u00e8\u00e9\7u\2\2\u00e9\u00ea\7q\2\2\u00ea\u00eb"+
"\7w\2\2\u00eb\u00ec\7t\2\2\u00ec\u00ed\7e\2\2\u00ed\u00ee\7g\2\2\u00ee"+
"\26\3\2\2\2\u00ef\u00f0\7e\2\2\u00f0\u00f1\7n\2\2\u00f1\u00f2\7q\2\2\u00f2"+
"\u00f3\7d\2\2\u00f3\u00f4\7d\2\2\u00f4\u00f5\7g\2\2\u00f5\u00f6\7t\2\2"+
"\u00f6\30\3\2\2\2\u00f7\u00f8\7r\2\2\u00f8\u00f9\7c\2\2\u00f9\u00fa\7"+
"t\2\2\u00fa\u00fb\7c\2\2\u00fb\u00fc\7o\2\2\u00fc\32\3\2\2\2\u00fd\u00fe"+
"\7<\2\2\u00fe\34\3\2\2\2\u00ff\u0100\7d\2\2\u0100\u0101\7{\2\2\u0101\u0102"+
"\7v\2\2\u0102\u0103\7g\2\2\u0103\u0104\7u\2\2\u0104\36\3\2\2\2\u0105\u0106"+
"\7e\2\2\u0106\u0107\7{\2\2\u0107\u0108\7e\2\2\u0108\u0109\7n\2\2\u0109"+
"\u010a\7g\2\2\u010a\u010b\7u\2\2\u010b \3\2\2\2\u010c\u010d\7r\2\2\u010d"+
"\u010e\7e\2\2\u010e\"\3\2\2\2\u010f\u0110\7k\2\2\u0110\u0111\7p\2\2\u0111"+
"\u0112\7n\2\2\u0112\u0113\7k\2\2\u0113\u0114\7p\2\2\u0114\u0115\7g\2\2"+
"\u0115$\3\2\2\2\u0116\u0117\7e\2\2\u0117\u0118\7q\2\2\u0118\u0119\7p\2"+
"\2\u0119\u011a\7u\2\2\u011a\u011b\7v\2\2\u011b&\3\2\2\2\u011c\u011d\7"+
"g\2\2\u011d\u011e\7z\2\2\u011e\u011f\7v\2\2\u011f\u0120\7g\2\2\u0120\u0121"+
"\7t\2\2\u0121\u0122\7p\2\2\u0122(\3\2\2\2\u0123\u0124\7c\2\2\u0124\u0125"+
"\7n\2\2\u0125\u0126\7k\2\2\u0126\u0127\7i\2\2\u0127\u0128\7p\2\2\u0128"+
"*\3\2\2\2\u0129\u012a\7t\2\2\u012a\u012b\7g\2\2\u012b\u012c\7i\2\2\u012c"+
"\u012d\7k\2\2\u012d\u012e\7u\2\2\u012e\u012f\7v\2\2\u012f\u0130\7g\2\2"+
"\u0130\u0131\7t\2\2\u0131,\3\2\2\2\u0132\u0133\7x\2\2\u0133\u0134\7q\2"+
"\2\u0134\u0135\7n\2\2\u0135\u0136\7c\2\2\u0136\u0137\7v\2\2\u0137\u0138"+
"\7k\2\2\u0138\u0139\7n\2\2\u0139\u013a\7g\2\2\u013a.\3\2\2\2\u013b\u013c"+
"\7k\2\2\u013c\u013d\7p\2\2\u013d\u013e\7v\2\2\u013e\u013f\7g\2\2\u013f"+
"\u0140\7t\2\2\u0140\u0141\7t\2\2\u0141\u0142\7w\2\2\u0142\u0143\7r\2\2"+
"\u0143\u0144\7v\2\2\u0144\60\3\2\2\2\u0145\u0146\7j\2\2\u0146\u0147\7"+
"c\2\2\u0147\u0148\7t\2\2\u0148\u0149\7f\2\2\u0149\u014a\7y\2\2\u014a\u014b"+
"\7c\2\2\u014b\u014c\7t\2\2\u014c\u014d\7g\2\2\u014d\62\3\2\2\2\u014e\u014f"+
"\7p\2\2\u014f\u0150\7q\2\2\u0150\u0151\7p\2\2\u0151\u0152\7g\2\2\u0152"+
"\64\3\2\2\2\u0153\u0154\7c\2\2\u0154\u0155\7n\2\2\u0155\u0156\7n\2\2\u0156"+
"\66\3\2\2\2\u0157\u0158\7m\2\2\u0158\u0159\7g\2\2\u0159\u015a\7t\2\2\u015a"+
"\u015b\7p\2\2\u015b\u015c\7g\2\2\u015c\u015d\7n\2\2\u015d8\3\2\2\2\u015e"+
"\u015f\7o\2\2\u015f\u0160\7k\2\2\u0160\u0161\7p\2\2\u0161:\3\2\2\2\u0162"+
"\u0163\7u\2\2\u0163\u0164\7v\2\2\u0164\u0165\7f\2\2\u0165<\3\2\2\2\u0166"+
"\u0167\7k\2\2\u0167\u0168\7h\2\2\u0168>\3\2\2\2\u0169\u016a\7g\2\2\u016a"+
"\u016b\7n\2\2\u016b\u016c\7u\2\2\u016c\u016d\7g\2\2\u016d@\3\2\2\2\u016e"+
"\u016f\7y\2\2\u016f\u0170\7j\2\2\u0170\u0171\7k\2\2\u0171\u0172\7n\2\2"+
"\u0172\u0173\7g\2\2\u0173B\3\2\2\2\u0174\u0175\7f\2\2\u0175\u0176\7q\2"+
"\2\u0176D\3\2\2\2\u0177\u0178\7h\2\2\u0178\u0179\7q\2\2\u0179\u017a\7"+
"t\2\2\u017aF\3\2\2\2\u017b\u017c\7t\2\2\u017c\u017d\7g\2\2\u017d\u017e"+
"\7v\2\2\u017e\u017f\7w\2\2\u017f\u0180\7t\2\2\u0180\u0181\7p\2\2\u0181"+
"H\3\2\2\2\u0182\u0183\7c\2\2\u0183\u0184\7u\2\2\u0184\u0185\7o\2\2\u0185"+
"J\3\2\2\2\u0186\u0187\7\60\2\2\u0187\u0188\7\60\2\2\u0188L\3\2\2\2\u0189"+
"\u018a\7u\2\2\u018a\u018b\7k\2\2\u018b\u018c\7i\2\2\u018c\u018d\7p\2\2"+
"\u018d\u018e\7g\2\2\u018e\u018f\7f\2\2\u018fN\3\2\2\2\u0190\u0191\7,\2"+
"\2\u0191P\3\2\2\2\u0192\u0193\7]\2\2\u0193R\3\2\2\2\u0194\u0195\7_\2\2"+
"\u0195T\3\2\2\2\u0196\u0197\7/\2\2\u0197\u0198\7/\2\2\u0198V\3\2\2\2\u0199"+
"\u019a\7-\2\2\u019a\u019b\7-\2\2\u019bX\3\2\2\2\u019c\u019d\7-\2\2\u019d"+
"Z\3\2\2\2\u019e\u019f\7/\2\2\u019f\\\3\2\2\2\u01a0\u01a1\7#\2\2\u01a1"+
"^\3\2\2\2\u01a2\u01a3\7(\2\2\u01a3`\3\2\2\2\u01a4\u01a5\7\u0080\2\2\u01a5"+
"b\3\2\2\2\u01a6\u01a7\7@\2\2\u01a7\u01a8\7@\2\2\u01a8d\3\2\2\2\u01a9\u01aa"+
"\7>\2\2\u01aa\u01ab\7>\2\2\u01abf\3\2\2\2\u01ac\u01ad\7\61\2\2\u01adh"+
"\3\2\2\2\u01ae\u01af\7\'\2\2\u01afj\3\2\2\2\u01b0\u01b1\7>\2\2\u01b1l"+
"\3\2\2\2\u01b2\u01b3\7@\2\2\u01b3n\3\2\2\2\u01b4\u01b5\7?\2\2\u01b5\u01b6"+
"\7?\2\2\u01b6p\3\2\2\2\u01b7\u01b8\7#\2\2\u01b8\u01b9\7?\2\2\u01b9r\3"+
"\2\2\2\u01ba\u01bb\7>\2\2\u01bb\u01bc\7?\2\2\u01bct\3\2\2\2\u01bd\u01be"+
"\7@\2\2\u01be\u01bf\7?\2\2\u01bfv\3\2\2\2\u01c0\u01c1\7`\2\2\u01c1x\3"+
"\2\2\2\u01c2\u01c3\7~\2\2\u01c3z\3\2\2\2\u01c4\u01c5\7(\2\2\u01c5\u01c6"+
"\7(\2\2\u01c6|\3\2\2\2\u01c7\u01c8\7~\2\2\u01c8\u01c9\7~\2\2\u01c9~\3"+
"\2\2\2\u01ca\u01cb\7-\2\2\u01cb\u01cc\7?\2\2\u01cc\u0080\3\2\2\2\u01cd"+
"\u01ce\7/\2\2\u01ce\u01cf\7?\2\2\u01cf\u0082\3\2\2\2\u01d0\u01d1\7,\2"+
"\2\u01d1\u01d2\7?\2\2\u01d2\u0084\3\2\2\2\u01d3\u01d4\7\61\2\2\u01d4\u01d5"+
"\7?\2\2\u01d5\u0086\3\2\2\2\u01d6\u01d7\7\'\2\2\u01d7\u01d8\7?\2\2\u01d8"+
"\u0088\3\2\2\2\u01d9\u01da\7>\2\2\u01da\u01db\7>\2\2\u01db\u01dc\7?\2"+
"\2\u01dc\u008a\3\2\2\2\u01dd\u01de\7@\2\2\u01de\u01df\7@\2\2\u01df\u01e0"+
"\7?\2\2\u01e0\u008c\3\2\2\2\u01e1\u01e2\7(\2\2\u01e2\u01e3\7?\2\2\u01e3"+
"\u008e\3\2\2\2\u01e4\u01e5\7~\2\2\u01e5\u01e6\7?\2\2\u01e6\u0090\3\2\2"+
"\2\u01e7\u01e8\7`\2\2\u01e8\u01e9\7?\2\2\u01e9\u0092\3\2\2\2\u01ea\u01eb"+
"\7\60\2\2\u01eb\u01ec\7d\2\2\u01ec\u01ed\7{\2\2\u01ed\u01ee\7v\2\2\u01ee"+
"\u01ef\7g\2\2\u01ef\u0094\3\2\2\2\u01f0\u01f1\7%\2\2\u01f1\u0096\3\2\2"+
"\2\u01f2\u01f3\7d\2\2\u01f3\u01f4\7t\2\2\u01f4\u02d1\7m\2\2\u01f5\u01f6"+
"\7q\2\2\u01f6\u01f7\7t\2\2\u01f7\u02d1\7c\2\2\u01f8\u01f9\7m\2\2\u01f9"+
"\u01fa\7k\2\2\u01fa\u02d1\7n\2\2\u01fb\u01fc\7u\2\2\u01fc\u01fd\7n\2\2"+
"\u01fd\u02d1\7q\2\2\u01fe\u01ff\7p\2\2\u01ff\u0200\7q\2\2\u0200\u02d1"+
"\7r\2\2\u0201\u0202\7c\2\2\u0202\u0203\7u\2\2\u0203\u02d1\7n\2\2\u0204"+
"\u0205\7r\2\2\u0205\u0206\7j\2\2\u0206\u02d1\7r\2\2\u0207\u0208\7c\2\2"+
"\u0208\u0209\7p\2\2\u0209\u02d1\7e\2\2\u020a\u020b\7d\2\2\u020b\u020c"+
"\7r\2\2\u020c\u02d1\7n\2\2\u020d\u020e\7e\2\2\u020e\u020f\7n\2\2\u020f"+
"\u02d1\7e\2\2\u0210\u0211\7l\2\2\u0211\u0212\7u\2\2\u0212\u02d1\7t\2\2"+
"\u0213\u0214\7c\2\2\u0214\u0215\7p\2\2\u0215\u02d1\7f\2\2\u0216\u0217"+
"\7t\2\2\u0217\u0218\7n\2\2\u0218\u02d1\7c\2\2\u0219\u021a\7d\2\2\u021a"+
"\u021b\7k\2\2\u021b\u02d1\7v\2\2\u021c\u021d\7t\2\2\u021d\u021e\7q\2\2"+
"\u021e\u02d1\7n\2\2\u021f\u0220\7r\2\2\u0220\u0221\7n\2\2\u0221\u02d1"+
"\7c\2\2\u0222\u0223\7r\2\2\u0223\u0224\7n\2\2\u0224\u02d1\7r\2\2\u0225"+
"\u0226\7d\2\2\u0226\u0227\7o\2\2\u0227\u02d1\7k\2\2\u0228\u0229\7u\2\2"+
"\u0229\u022a\7g\2\2\u022a\u02d1\7e\2\2\u022b\u022c\7t\2\2\u022c\u022d"+
"\7v\2\2\u022d\u02d1\7k\2\2\u022e\u022f\7g\2\2\u022f\u0230\7q\2\2\u0230"+
"\u02d1\7t\2\2\u0231\u0232\7u\2\2\u0232\u0233\7t\2\2\u0233\u02d1\7g\2\2"+
"\u0234\u0235\7n\2\2\u0235\u0236\7u\2\2\u0236\u02d1\7t\2\2\u0237\u0238"+
"\7r\2\2\u0238\u0239\7j\2\2\u0239\u02d1\7c\2\2\u023a\u023b\7c\2\2\u023b"+
"\u023c\7n\2\2\u023c\u02d1\7t\2\2\u023d\u023e\7l\2\2\u023e\u023f\7o\2\2"+
"\u023f\u02d1\7r\2\2\u0240\u0241\7d\2\2\u0241\u0242\7x\2\2\u0242\u02d1"+
"\7e\2\2\u0243\u0244\7e\2\2\u0244\u0245\7n\2\2\u0245\u02d1\7k\2\2\u0246"+
"\u0247\7t\2\2\u0247\u0248\7v\2\2\u0248\u02d1\7u\2\2\u0249\u024a\7c\2\2"+
"\u024a\u024b\7f\2\2\u024b\u02d1\7e\2\2\u024c\u024d\7t\2\2\u024d\u024e"+
"\7t\2\2\u024e\u02d1\7c\2\2\u024f\u0250\7d\2\2\u0250\u0251\7x\2\2\u0251"+
"\u02d1\7u\2\2\u0252\u0253\7u\2\2\u0253\u0254\7g\2\2\u0254\u02d1\7k\2\2"+
"\u0255\u0256\7u\2\2\u0256\u0257\7c\2\2\u0257\u02d1\7z\2\2\u0258\u0259"+
"\7u\2\2\u0259\u025a\7v\2\2\u025a\u02d1\7{\2\2\u025b\u025c\7u\2\2\u025c"+
"\u025d\7v\2\2\u025d\u02d1\7c\2\2\u025e\u025f\7u\2\2\u025f\u0260\7v\2\2"+
"\u0260\u02d1\7z\2\2\u0261\u0262\7f\2\2\u0262\u0263\7g\2\2\u0263\u02d1"+
"\7{\2\2\u0264\u0265\7v\2\2\u0265\u0266\7z\2\2\u0266\u02d1\7c\2\2\u0267"+
"\u0268\7z\2\2\u0268\u0269\7c\2\2\u0269\u02d1\7c\2\2\u026a\u026b\7d\2\2"+
"\u026b\u026c\7e\2\2\u026c\u02d1\7e\2\2\u026d\u026e\7c\2\2\u026e\u026f"+
"\7j\2\2\u026f\u02d1\7z\2\2\u0270\u0271\7v\2\2\u0271\u0272\7{\2\2\u0272"+
"\u02d1\7c\2\2\u0273\u0274\7v\2\2\u0274\u0275\7z\2\2\u0275\u02d1\7u\2\2"+
"\u0276\u0277\7v\2\2\u0277\u0278\7c\2\2\u0278\u02d1\7u\2\2\u0279\u027a"+
"\7u\2\2\u027a\u027b\7j\2\2\u027b\u02d1\7{\2\2\u027c\u027d\7u\2\2\u027d"+
"\u027e\7j\2\2\u027e\u02d1\7z\2\2\u027f\u0280\7n\2\2\u0280\u0281\7f\2\2"+
"\u0281\u02d1\7{\2\2\u0282\u0283\7n\2\2\u0283\u0284\7f\2\2\u0284\u02d1"+
"\7c\2\2\u0285\u0286\7n\2\2\u0286\u0287\7f\2\2\u0287\u02d1\7z\2\2\u0288"+
"\u0289\7n\2\2\u0289\u028a\7c\2\2\u028a\u02d1\7z\2\2\u028b\u028c\7v\2\2"+
"\u028c\u028d\7c\2\2\u028d\u02d1\7{\2\2\u028e\u028f\7v\2\2\u028f\u0290"+
"\7c\2\2\u0290\u02d1\7z\2\2\u0291\u0292\7d\2\2\u0292\u0293\7e\2\2\u0293"+
"\u02d1\7u\2\2\u0294\u0295\7e\2\2\u0295\u0296\7n\2\2\u0296\u02d1\7x\2\2"+
"\u0297\u0298\7v\2\2\u0298\u0299\7u\2\2\u0299\u02d1\7z\2\2\u029a\u029b"+
"\7n\2\2\u029b\u029c\7c\2\2\u029c\u02d1\7u\2\2\u029d\u029e\7e\2\2\u029e"+
"\u029f\7r\2\2\u029f\u02d1\7{\2\2\u02a0\u02a1\7e\2\2\u02a1\u02a2\7o\2\2"+
"\u02a2\u02d1\7r\2\2\u02a3\u02a4\7e\2\2\u02a4\u02a5\7r\2\2\u02a5\u02d1"+
"\7z\2\2\u02a6\u02a7\7f\2\2\u02a7\u02a8\7e\2\2\u02a8\u02d1\7r\2\2\u02a9"+
"\u02aa\7f\2\2\u02aa\u02ab\7g\2\2\u02ab\u02d1\7e\2\2\u02ac\u02ad\7k\2\2"+
"\u02ad\u02ae\7p\2\2\u02ae\u02d1\7e\2\2\u02af\u02b0\7c\2\2\u02b0\u02b1"+
"\7z\2\2\u02b1\u02d1\7u\2\2\u02b2\u02b3\7d\2\2\u02b3\u02b4\7p\2\2\u02b4"+
"\u02d1\7g\2\2\u02b5\u02b6\7e\2\2\u02b6\u02b7\7n\2\2\u02b7\u02d1\7f\2\2"+
"\u02b8\u02b9\7u\2\2\u02b9\u02ba\7d\2\2\u02ba\u02d1\7e\2\2\u02bb\u02bc"+
"\7k\2\2\u02bc\u02bd\7u\2\2\u02bd\u02d1\7e\2\2\u02be\u02bf\7k\2\2\u02bf"+
"\u02c0\7p\2\2\u02c0\u02d1\7z\2\2\u02c1\u02c2\7d\2\2\u02c2\u02c3\7g\2\2"+
"\u02c3\u02d1\7s\2\2\u02c4\u02c5\7u\2\2\u02c5\u02c6\7g\2\2\u02c6\u02d1"+
"\7f\2\2\u02c7\u02c8\7f\2\2\u02c8\u02c9\7g\2\2\u02c9\u02d1\7z\2\2\u02ca"+
"\u02cb\7k\2\2\u02cb\u02cc\7p\2\2\u02cc\u02d1\7{\2\2\u02cd\u02ce\7t\2\2"+
"\u02ce\u02cf\7q\2\2\u02cf\u02d1\7t\2\2\u02d0\u01f2\3\2\2\2\u02d0\u01f5"+
"\3\2\2\2\u02d0\u01f8\3\2\2\2\u02d0\u01fb\3\2\2\2\u02d0\u01fe\3\2\2\2\u02d0"+
"\u0201\3\2\2\2\u02d0\u0204\3\2\2\2\u02d0\u0207\3\2\2\2\u02d0\u020a\3\2"+
"\2\2\u02d0\u020d\3\2\2\2\u02d0\u0210\3\2\2\2\u02d0\u0213\3\2\2\2\u02d0"+
"\u0216\3\2\2\2\u02d0\u0219\3\2\2\2\u02d0\u021c\3\2\2\2\u02d0\u021f\3\2"+
"\2\2\u02d0\u0222\3\2\2\2\u02d0\u0225\3\2\2\2\u02d0\u0228\3\2\2\2\u02d0"+
"\u022b\3\2\2\2\u02d0\u022e\3\2\2\2\u02d0\u0231\3\2\2\2\u02d0\u0234\3\2"+
"\2\2\u02d0\u0237\3\2\2\2\u02d0\u023a\3\2\2\2\u02d0\u023d\3\2\2\2\u02d0"+
"\u0240\3\2\2\2\u02d0\u0243\3\2\2\2\u02d0\u0246\3\2\2\2\u02d0\u0249\3\2"+
"\2\2\u02d0\u024c\3\2\2\2\u02d0\u024f\3\2\2\2\u02d0\u0252\3\2\2\2\u02d0"+
"\u0255\3\2\2\2\u02d0\u0258\3\2\2\2\u02d0\u025b\3\2\2\2\u02d0\u025e\3\2"+
"\2\2\u02d0\u0261\3\2\2\2\u02d0\u0264\3\2\2\2\u02d0\u0267\3\2\2\2\u02d0"+
"\u026a\3\2\2\2\u02d0\u026d\3\2\2\2\u02d0\u0270\3\2\2\2\u02d0\u0273\3\2"+
"\2\2\u02d0\u0276\3\2\2\2\u02d0\u0279\3\2\2\2\u02d0\u027c\3\2\2\2\u02d0"+
"\u027f\3\2\2\2\u02d0\u0282\3\2\2\2\u02d0\u0285\3\2\2\2\u02d0\u0288\3\2"+
"\2\2\u02d0\u028b\3\2\2\2\u02d0\u028e\3\2\2\2\u02d0\u0291\3\2\2\2\u02d0"+
"\u0294\3\2\2\2\u02d0\u0297\3\2\2\2\u02d0\u029a\3\2\2\2\u02d0\u029d\3\2"+
"\2\2\u02d0\u02a0\3\2\2\2\u02d0\u02a3\3\2\2\2\u02d0\u02a6\3\2\2\2\u02d0"+
"\u02a9\3\2\2\2\u02d0\u02ac\3\2\2\2\u02d0\u02af\3\2\2\2\u02d0\u02b2\3\2"+
"\2\2\u02d0\u02b5\3\2\2\2\u02d0\u02b8\3\2\2\2\u02d0\u02bb\3\2\2\2\u02d0"+
"\u02be\3\2\2\2\u02d0\u02c1\3\2\2\2\u02d0\u02c4\3\2\2\2\u02d0\u02c7\3\2"+
"\2\2\u02d0\u02ca\3\2\2\2\u02d0\u02cd\3\2\2\2\u02d1\u0098\3\2\2\2\u02d2"+
"\u02d3\7}\2\2\u02d3\u02d4\7}\2\2\u02d4\u02d8\3\2\2\2\u02d5\u02d7\13\2"+
"\2\2\u02d6\u02d5\3\2\2\2\u02d7\u02da\3\2\2\2\u02d8\u02d9\3\2\2\2\u02d8"+
"\u02d6\3\2\2\2\u02d9\u02db\3\2\2\2\u02da\u02d8\3\2\2\2\u02db\u02dc\7\177"+
"\2\2\u02dc\u02dd\7\177\2\2\u02dd\u009a\3\2\2\2\u02de\u02df\7d\2\2\u02df"+
"\u02e0\7{\2\2\u02e0\u02e1\7v\2\2\u02e1\u02f4\7g\2\2\u02e2\u02e3\7y\2\2"+
"\u02e3\u02e4\7q\2\2\u02e4\u02e5\7t\2\2\u02e5\u02f4\7f\2\2\u02e6\u02e7"+
"\7f\2\2\u02e7\u02e8\7y\2\2\u02e8\u02e9\7q\2\2\u02e9\u02ea\7t\2\2\u02ea"+
"\u02f4\7f\2\2\u02eb\u02ec\7d\2\2\u02ec\u02ed\7q\2\2\u02ed\u02ee\7q\2\2"+
"\u02ee\u02f4\7n\2\2\u02ef\u02f0\7x\2\2\u02f0\u02f1\7q\2\2\u02f1\u02f2"+
"\7k\2\2\u02f2\u02f4\7f\2\2\u02f3\u02de\3\2\2\2\u02f3\u02e2\3\2\2\2\u02f3"+
"\u02e6\3\2\2\2\u02f3\u02eb\3\2\2\2\u02f3\u02ef\3\2\2\2\u02f4\u009c\3\2"+
"\2\2\u02f5\u02fb\7$\2\2\u02f6\u02f7\7^\2\2\u02f7\u02fa\7$\2\2\u02f8\u02fa"+
"\n\2\2\2\u02f9\u02f6\3\2\2\2\u02f9\u02f8\3\2\2\2\u02fa\u02fd\3\2\2\2\u02fb"+
"\u02f9\3\2\2\2\u02fb\u02fc\3\2\2\2\u02fc\u02fe\3\2\2\2\u02fd\u02fb\3\2"+
"\2\2\u02fe\u02ff\7$\2\2\u02ff\u009e\3\2\2\2\u0300\u0304\7)\2\2\u0301\u0302"+
"\7^\2\2\u0302\u0305\7)\2\2\u0303\u0305\n\3\2\2\u0304\u0301\3\2\2\2\u0304"+
"\u0303\3\2\2\2\u0305\u0306\3\2\2\2\u0306\u0307\7)\2\2\u0307\u00a0\3\2"+
"\2\2\u0308\u0309\7v\2\2\u0309\u030a\7t\2\2\u030a\u030b\7w\2\2\u030b\u0312"+
"\7g\2\2\u030c\u030d\7h\2\2\u030d\u030e\7c\2\2\u030e\u030f\7n\2\2\u030f"+
"\u0310\7u\2\2\u0310\u0312\7g\2\2\u0311\u0308\3\2\2\2\u0311\u030c\3\2\2"+
"\2\u0312\u00a2\3\2\2\2\u0313\u0316\5\u00a5S\2\u0314\u0316\5\u00adW\2\u0315"+
"\u0313\3\2\2\2\u0315\u0314\3\2\2\2\u0316\u00a4\3\2\2\2\u0317\u031b\5\u00a7"+
"T\2\u0318\u031b\5\u00a9U\2\u0319\u031b\5\u00abV\2\u031a\u0317\3\2\2\2"+
"\u031a\u0318\3\2\2\2\u031a\u0319\3\2\2\2\u031b\u00a6\3\2\2\2\u031c\u0322"+
"\7\'\2\2\u031d\u031e\7\62\2\2\u031e\u0322\7d\2\2\u031f\u0320\7\62\2\2"+
"\u0320\u0322\7D\2\2\u0321\u031c\3\2\2\2\u0321\u031d\3\2\2\2\u0321\u031f"+
"\3\2\2\2\u0322\u0326\3\2\2\2\u0323\u0325\5\u00b5[\2\u0324\u0323\3\2\2"+
"\2\u0325\u0328\3\2\2\2\u0326\u0324\3\2\2\2\u0326\u0327\3\2\2\2\u0327\u0329"+
"\3\2\2\2\u0328\u0326\3\2\2\2\u0329\u032b\7\60\2\2\u032a\u032c\5\u00b5"+
"[\2\u032b\u032a\3\2\2\2\u032c\u032d\3\2\2\2\u032d\u032b\3\2\2\2\u032d"+
"\u032e\3\2\2\2\u032e\u00a8\3\2\2\2\u032f\u0331\5\u00b7\\\2\u0330\u032f"+
"\3\2\2\2\u0331\u0334\3\2\2\2\u0332\u0330\3\2\2\2\u0332\u0333\3\2\2\2\u0333"+
"\u0335\3\2\2\2\u0334\u0332\3\2\2\2\u0335\u0337\7\60\2\2\u0336\u0338\5"+
"\u00b7\\\2\u0337\u0336\3\2\2\2\u0338\u0339\3\2\2\2\u0339\u0337\3\2\2\2"+
"\u0339\u033a\3\2\2\2\u033a\u00aa\3\2\2\2\u033b\u0341\7&\2\2\u033c\u033d"+
"\7\62\2\2\u033d\u0341\7z\2\2\u033e\u033f\7\62\2\2\u033f\u0341\7Z\2\2\u0340"+
"\u033b\3\2\2\2\u0340\u033c\3\2\2\2\u0340\u033e\3\2\2\2\u0341\u0345\3\2"+
"\2\2\u0342\u0344\5\u00b9]\2\u0343\u0342\3\2\2\2\u0344\u0347\3\2\2\2\u0345"+
"\u0343\3\2\2\2\u0345\u0346\3\2\2\2\u0346\u0348\3\2\2\2\u0347\u0345\3\2"+
"\2\2\u0348\u034a\7\60\2\2\u0349\u034b\5\u00b9]\2\u034a\u0349\3\2\2\2\u034b"+
"\u034c\3\2\2\2\u034c\u034a\3\2\2\2\u034c\u034d\3\2\2\2\u034d\u00ac\3\2"+
"\2\2\u034e\u0352\5\u00b1Y\2\u034f\u0352\5\u00b3Z\2\u0350\u0352\5\u00af"+
"X\2\u0351\u034e\3\2\2\2\u0351\u034f\3\2\2\2\u0351\u0350\3\2\2\2\u0352"+
"\u00ae\3\2\2\2\u0353\u0354\7\62\2\2\u0354\u0356\t\4\2\2\u0355\u0357\5"+
"\u00b5[\2\u0356\u0355\3\2\2\2\u0357\u0358\3\2\2\2\u0358\u0356\3\2\2\2"+
"\u0358\u0359\3\2\2\2\u0359\u0361\3\2\2\2\u035a\u035c\7\'\2\2\u035b\u035d"+
"\5\u00b5[\2\u035c\u035b\3\2\2\2\u035d\u035e\3\2\2\2\u035e\u035c\3\2\2"+
"\2\u035e\u035f\3\2\2\2\u035f\u0361\3\2\2\2\u0360\u0353\3\2\2\2\u0360\u035a"+
"\3\2\2\2\u0361\u00b0\3\2\2\2\u0362\u0364\5\u00b7\\\2\u0363\u0362\3\2\2"+
"\2\u0364\u0365\3\2\2\2\u0365\u0363\3\2\2\2\u0365\u0366\3\2\2\2\u0366\u00b2"+
"\3\2\2\2\u0367\u036d\7&\2\2\u0368\u0369\7\62\2\2\u0369\u036d\7z\2\2\u036a"+
"\u036b\7\62\2\2\u036b\u036d\7Z\2\2\u036c\u0367\3\2\2\2\u036c\u0368\3\2"+
"\2\2\u036c\u036a\3\2\2\2\u036d\u036f\3\2\2\2\u036e\u0370\5\u00b9]\2\u036f"+
"\u036e\3\2\2\2\u0370\u0371\3\2\2\2\u0371\u036f\3\2\2\2\u0371\u0372\3\2"+
"\2\2\u0372\u00b4\3\2\2\2\u0373\u0374\t\5\2\2\u0374\u00b6\3\2\2\2\u0375"+
"\u0376\t\6\2\2\u0376\u00b8\3\2\2\2\u0377\u0378\t\7\2\2\u0378\u00ba\3\2"+
"\2\2\u0379\u037d\5\u00bd_\2\u037a\u037c\5\u00bf`\2\u037b\u037a\3\2\2\2"+
"\u037c\u037f\3\2\2\2\u037d\u037b\3\2\2\2\u037d\u037e\3\2\2\2\u037e\u00bc"+
"\3\2\2\2\u037f\u037d\3\2\2\2\u0380\u0381\t\b\2\2\u0381\u00be\3\2\2\2\u0382"+
"\u0383\t\t\2\2\u0383\u00c0\3\2\2\2\u0384\u0388\7#\2\2\u0385\u0387\5\u00bf"+
"`\2\u0386\u0385\3\2\2\2\u0387\u038a\3\2\2\2\u0388\u0386\3\2\2\2\u0388"+
"\u0389\3\2\2\2\u0389\u038c\3\2\2\2\u038a\u0388\3\2\2\2\u038b\u038d\t\n"+
"\2\2\u038c\u038b\3\2\2\2\u038d\u038e\3\2\2\2\u038e\u038c\3\2\2\2\u038e"+
"\u038f\3\2\2\2\u038f\u00c2\3\2\2\2\u0390\u0392\t\13\2\2\u0391\u0390\3"+
"\2\2\2\u0392\u0393\3\2\2\2\u0393\u0391\3\2\2\2\u0393\u0394\3\2\2\2\u0394"+
"\u0395\3\2\2\2\u0395\u0396\bb\2\2\u0396\u00c4\3\2\2\2\u0397\u0398\7\61"+
"\2\2\u0398\u0399\7\61\2\2\u0399\u039d\3\2\2\2\u039a\u039c\n\f\2\2\u039b"+
"\u039a\3\2\2\2\u039c\u039f\3\2\2\2\u039d\u039b\3\2\2\2\u039d\u039e\3\2"+
"\2\2\u039e\u03a0\3\2\2\2\u039f\u039d\3\2\2\2\u03a0\u03a1\bc\2\2\u03a1"+
"\u00c6\3\2\2\2\u03a2\u03a3\7\61\2\2\u03a3\u03a4\7,\2\2\u03a4\u03a8\3\2"+
"\2\2\u03a5\u03a7\13\2\2\2\u03a6\u03a5\3\2\2\2\u03a7\u03aa\3\2\2\2\u03a8"+
"\u03a9\3\2\2\2\u03a8\u03a6\3\2\2\2\u03a9\u03ab\3\2\2\2\u03aa\u03a8\3\2"+
"\2\2\u03ab\u03ac\7,\2\2\u03ac\u03ad\7\61\2\2\u03ad\u03ae\3\2\2\2\u03ae"+
"\u03af\bd\2\2\u03af\u00c8\3\2\2\2!\2\u02d0\u02d8\u02f3\u02f9\u02fb\u0304"+
"\u0311\u0315\u031a\u0321\u0326\u032d\u0332\u0339\u0340\u0345\u034c\u0351"+
"\u0358\u035e\u0360\u0365\u036c\u0371\u037d\u0388\u038e\u0393\u039d\u03a8"+
"\3\b\2\2";
"\4U\tU\4V\tV\4W\tW\4X\tX\4Y\tY\4Z\tZ\4[\t[\4\\\t\\\4]\t]\4^\t^\3\2\3\2"+
"\3\2\3\2\3\2\3\2\3\2\3\3\3\3\3\4\3\4\3\5\3\5\3\6\3\6\3\7\3\7\3\b\3\b\3"+
"\t\3\t\3\t\3\t\3\t\3\t\3\t\3\t\3\n\3\n\3\13\3\13\3\13\3\13\3\13\3\13\3"+
"\13\3\13\3\13\3\f\3\f\3\f\3\f\3\f\3\f\3\f\3\f\3\r\3\r\3\r\3\r\3\r\3\r"+
"\3\16\3\16\3\17\3\17\3\17\3\17\3\17\3\17\3\20\3\20\3\20\3\20\3\20\3\20"+
"\3\20\3\21\3\21\3\21\3\22\3\22\3\22\3\22\3\22\3\22\3\22\3\23\3\23\3\23"+
"\3\23\3\23\3\23\3\24\3\24\3\24\3\24\3\24\3\24\3\24\3\25\3\25\3\25\3\25"+
"\3\25\3\25\3\26\3\26\3\26\3\26\3\26\3\26\3\26\3\26\3\26\3\27\3\27\3\27"+
"\3\27\3\27\3\27\3\27\3\27\3\27\3\30\3\30\3\30\3\30\3\30\3\30\3\30\3\30"+
"\3\30\3\30\3\31\3\31\3\31\3\32\3\32\3\32\3\32\3\32\3\33\3\33\3\33\3\33"+
"\3\33\3\33\3\34\3\34\3\34\3\35\3\35\3\35\3\35\3\36\3\36\3\36\3\36\3\36"+
"\3\36\3\36\3\37\3\37\3\37\3\37\3 \3 \3 \3!\3!\3!\3!\3!\3!\3!\3\"\3\"\3"+
"#\3#\3$\3$\3%\3%\3%\3&\3&\3&\3\'\3\'\3(\3(\3)\3)\3*\3*\3+\3+\3,\3,\3,"+
"\3-\3-\3-\3.\3.\3/\3/\3\60\3\60\3\61\3\61\3\62\3\62\3\62\3\63\3\63\3\63"+
"\3\64\3\64\3\64\3\65\3\65\3\65\3\66\3\66\3\67\3\67\38\38\38\39\39\39\3"+
":\3:\3:\3;\3;\3;\3<\3<\3<\3=\3=\3=\3>\3>\3>\3?\3?\3?\3?\3@\3@\3@\3@\3"+
"A\3A\3A\3B\3B\3B\3C\3C\3C\3D\3D\3D\3D\3D\3D\3E\3E\3F\3F\3F\3F\3F\3F\3"+
"F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3"+
"F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3"+
"F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3"+
"F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3"+
"F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3"+
"F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3"+
"F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3"+
"F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3"+
"F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3F\3"+
"F\3F\3F\3F\3F\3F\3F\3F\3F\5F\u02a4\nF\3G\3G\3G\3G\7G\u02aa\nG\fG\16G\u02ad"+
"\13G\3G\3G\3G\3H\3H\3H\3H\3H\3H\3H\3H\3H\3H\3H\3H\3H\3H\3H\3H\3H\3H\3"+
"H\3H\3H\5H\u02c7\nH\3I\3I\3I\3I\7I\u02cd\nI\fI\16I\u02d0\13I\3I\3I\3J"+
"\3J\3J\3J\5J\u02d8\nJ\3J\3J\3K\3K\3K\3K\3K\3K\3K\3K\3K\5K\u02e5\nK\3L"+
"\3L\5L\u02e9\nL\3M\3M\3M\5M\u02ee\nM\3N\3N\3N\3N\3N\5N\u02f5\nN\3N\7N"+
"\u02f8\nN\fN\16N\u02fb\13N\3N\3N\6N\u02ff\nN\rN\16N\u0300\3O\7O\u0304"+
"\nO\fO\16O\u0307\13O\3O\3O\6O\u030b\nO\rO\16O\u030c\3P\3P\3P\3P\3P\5P"+
"\u0314\nP\3P\7P\u0317\nP\fP\16P\u031a\13P\3P\3P\6P\u031e\nP\rP\16P\u031f"+
"\3Q\3Q\3Q\5Q\u0325\nQ\3R\3R\3R\6R\u032a\nR\rR\16R\u032b\3R\3R\6R\u0330"+
"\nR\rR\16R\u0331\5R\u0334\nR\3S\6S\u0337\nS\rS\16S\u0338\3T\3T\3T\3T\3"+
"T\5T\u0340\nT\3T\6T\u0343\nT\rT\16T\u0344\3U\3U\3V\3V\3W\3W\3X\3X\7X\u034f"+
"\nX\fX\16X\u0352\13X\3Y\3Y\3Z\3Z\3[\3[\7[\u035a\n[\f[\16[\u035d\13[\3"+
"[\6[\u0360\n[\r[\16[\u0361\3\\\6\\\u0365\n\\\r\\\16\\\u0366\3\\\3\\\3"+
"]\3]\3]\3]\7]\u036f\n]\f]\16]\u0372\13]\3]\3]\3^\3^\3^\3^\7^\u037a\n^"+
"\f^\16^\u037d\13^\3^\3^\3^\3^\3^\4\u02ab\u037b\2_\3\3\5\4\7\5\t\6\13\7"+
"\r\b\17\t\21\n\23\13\25\f\27\r\31\16\33\17\35\20\37\21!\22#\23%\24\'\25"+
")\26+\27-\30/\31\61\32\63\33\65\34\67\359\36;\37= ?!A\"C#E$G%I&K\'M(O"+
")Q*S+U,W-Y.[/]\60_\61a\62c\63e\64g\65i\66k\67m8o9q:s;u<w=y>{?}@\177A\u0081"+
"B\u0083C\u0085D\u0087E\u0089F\u008bG\u008dH\u008fI\u0091J\u0093K\u0095"+
"L\u0097M\u0099N\u009bO\u009dP\u009fQ\u00a1R\u00a3S\u00a5T\u00a7U\u00a9"+
"\2\u00ab\2\u00ad\2\u00afV\u00b1\2\u00b3\2\u00b5W\u00b7X\u00b9Y\u00bbZ"+
"\3\2\r\3\2$$\3\2))\4\2DDdd\3\2\62\63\3\2\62;\5\2\62;CHch\5\2C\\aac|\6"+
"\2\62;C\\aac|\4\2--//\5\2\13\f\17\17\"\"\4\2\f\f\17\17\2\u03eb\2\3\3\2"+
"\2\2\2\5\3\2\2\2\2\7\3\2\2\2\2\t\3\2\2\2\2\13\3\2\2\2\2\r\3\2\2\2\2\17"+
"\3\2\2\2\2\21\3\2\2\2\2\23\3\2\2\2\2\25\3\2\2\2\2\27\3\2\2\2\2\31\3\2"+
"\2\2\2\33\3\2\2\2\2\35\3\2\2\2\2\37\3\2\2\2\2!\3\2\2\2\2#\3\2\2\2\2%\3"+
"\2\2\2\2\'\3\2\2\2\2)\3\2\2\2\2+\3\2\2\2\2-\3\2\2\2\2/\3\2\2\2\2\61\3"+
"\2\2\2\2\63\3\2\2\2\2\65\3\2\2\2\2\67\3\2\2\2\29\3\2\2\2\2;\3\2\2\2\2"+
"=\3\2\2\2\2?\3\2\2\2\2A\3\2\2\2\2C\3\2\2\2\2E\3\2\2\2\2G\3\2\2\2\2I\3"+
"\2\2\2\2K\3\2\2\2\2M\3\2\2\2\2O\3\2\2\2\2Q\3\2\2\2\2S\3\2\2\2\2U\3\2\2"+
"\2\2W\3\2\2\2\2Y\3\2\2\2\2[\3\2\2\2\2]\3\2\2\2\2_\3\2\2\2\2a\3\2\2\2\2"+
"c\3\2\2\2\2e\3\2\2\2\2g\3\2\2\2\2i\3\2\2\2\2k\3\2\2\2\2m\3\2\2\2\2o\3"+
"\2\2\2\2q\3\2\2\2\2s\3\2\2\2\2u\3\2\2\2\2w\3\2\2\2\2y\3\2\2\2\2{\3\2\2"+
"\2\2}\3\2\2\2\2\177\3\2\2\2\2\u0081\3\2\2\2\2\u0083\3\2\2\2\2\u0085\3"+
"\2\2\2\2\u0087\3\2\2\2\2\u0089\3\2\2\2\2\u008b\3\2\2\2\2\u008d\3\2\2\2"+
"\2\u008f\3\2\2\2\2\u0091\3\2\2\2\2\u0093\3\2\2\2\2\u0095\3\2\2\2\2\u0097"+
"\3\2\2\2\2\u0099\3\2\2\2\2\u009b\3\2\2\2\2\u009d\3\2\2\2\2\u009f\3\2\2"+
"\2\2\u00a1\3\2\2\2\2\u00a3\3\2\2\2\2\u00a5\3\2\2\2\2\u00a7\3\2\2\2\2\u00af"+
"\3\2\2\2\2\u00b5\3\2\2\2\2\u00b7\3\2\2\2\2\u00b9\3\2\2\2\2\u00bb\3\2\2"+
"\2\3\u00bd\3\2\2\2\5\u00c4\3\2\2\2\7\u00c6\3\2\2\2\t\u00c8\3\2\2\2\13"+
"\u00ca\3\2\2\2\r\u00cc\3\2\2\2\17\u00ce\3\2\2\2\21\u00d0\3\2\2\2\23\u00d8"+
"\3\2\2\2\25\u00da\3\2\2\2\27\u00e3\3\2\2\2\31\u00eb\3\2\2\2\33\u00f1\3"+
"\2\2\2\35\u00f3\3\2\2\2\37\u00f9\3\2\2\2!\u0100\3\2\2\2#\u0103\3\2\2\2"+
"%\u010a\3\2\2\2\'\u0110\3\2\2\2)\u0117\3\2\2\2+\u011d\3\2\2\2-\u0126\3"+
"\2\2\2/\u012f\3\2\2\2\61\u0139\3\2\2\2\63\u013c\3\2\2\2\65\u0141\3\2\2"+
"\2\67\u0147\3\2\2\29\u014a\3\2\2\2;\u014e\3\2\2\2=\u0155\3\2\2\2?\u0159"+
"\3\2\2\2A\u015c\3\2\2\2C\u0163\3\2\2\2E\u0165\3\2\2\2G\u0167\3\2\2\2I"+
"\u0169\3\2\2\2K\u016c\3\2\2\2M\u016f\3\2\2\2O\u0171\3\2\2\2Q\u0173\3\2"+
"\2\2S\u0175\3\2\2\2U\u0177\3\2\2\2W\u0179\3\2\2\2Y\u017c\3\2\2\2[\u017f"+
"\3\2\2\2]\u0181\3\2\2\2_\u0183\3\2\2\2a\u0185\3\2\2\2c\u0187\3\2\2\2e"+
"\u018a\3\2\2\2g\u018d\3\2\2\2i\u0190\3\2\2\2k\u0193\3\2\2\2m\u0195\3\2"+
"\2\2o\u0197\3\2\2\2q\u019a\3\2\2\2s\u019d\3\2\2\2u\u01a0\3\2\2\2w\u01a3"+
"\3\2\2\2y\u01a6\3\2\2\2{\u01a9\3\2\2\2}\u01ac\3\2\2\2\177\u01b0\3\2\2"+
"\2\u0081\u01b4\3\2\2\2\u0083\u01b7\3\2\2\2\u0085\u01ba\3\2\2\2\u0087\u01bd"+
"\3\2\2\2\u0089\u01c3\3\2\2\2\u008b\u02a3\3\2\2\2\u008d\u02a5\3\2\2\2\u008f"+
"\u02c6\3\2\2\2\u0091\u02c8\3\2\2\2\u0093\u02d3\3\2\2\2\u0095\u02e4\3\2"+
"\2\2\u0097\u02e8\3\2\2\2\u0099\u02ed\3\2\2\2\u009b\u02f4\3\2\2\2\u009d"+
"\u0305\3\2\2\2\u009f\u0313\3\2\2\2\u00a1\u0324\3\2\2\2\u00a3\u0333\3\2"+
"\2\2\u00a5\u0336\3\2\2\2\u00a7\u033f\3\2\2\2\u00a9\u0346\3\2\2\2\u00ab"+
"\u0348\3\2\2\2\u00ad\u034a\3\2\2\2\u00af\u034c\3\2\2\2\u00b1\u0353\3\2"+
"\2\2\u00b3\u0355\3\2\2\2\u00b5\u0357\3\2\2\2\u00b7\u0364\3\2\2\2\u00b9"+
"\u036a\3\2\2\2\u00bb\u0375\3\2\2\2\u00bd\u00be\7k\2\2\u00be\u00bf\7o\2"+
"\2\u00bf\u00c0\7r\2\2\u00c0\u00c1\7q\2\2\u00c1\u00c2\7t\2\2\u00c2\u00c3"+
"\7v\2\2\u00c3\4\3\2\2\2\u00c4\u00c5\7?\2\2\u00c5\6\3\2\2\2\u00c6\u00c7"+
"\7=\2\2\u00c7\b\3\2\2\2\u00c8\u00c9\7*\2\2\u00c9\n\3\2\2\2\u00ca\u00cb"+
"\7+\2\2\u00cb\f\3\2\2\2\u00cc\u00cd\7}\2\2\u00cd\16\3\2\2\2\u00ce\u00cf"+
"\7\177\2\2\u00cf\20\3\2\2\2\u00d0\u00d1\7m\2\2\u00d1\u00d2\7k\2\2\u00d2"+
"\u00d3\7e\2\2\u00d3\u00d4\7m\2\2\u00d4\u00d5\7c\2\2\u00d5\u00d6\7u\2\2"+
"\u00d6\u00d7\7o\2\2\u00d7\22\3\2\2\2\u00d8\u00d9\7.\2\2\u00d9\24\3\2\2"+
"\2\u00da\u00db\7t\2\2\u00db\u00dc\7g\2\2\u00dc\u00dd\7u\2\2\u00dd\u00de"+
"\7q\2\2\u00de\u00df\7w\2\2\u00df\u00e0\7t\2\2\u00e0\u00e1\7e\2\2\u00e1"+
"\u00e2\7g\2\2\u00e2\26\3\2\2\2\u00e3\u00e4\7e\2\2\u00e4\u00e5\7n\2\2\u00e5"+
"\u00e6\7q\2\2\u00e6\u00e7\7d\2\2\u00e7\u00e8\7d\2\2\u00e8\u00e9\7g\2\2"+
"\u00e9\u00ea\7t\2\2\u00ea\30\3\2\2\2\u00eb\u00ec\7r\2\2\u00ec\u00ed\7"+
"c\2\2\u00ed\u00ee\7t\2\2\u00ee\u00ef\7c\2\2\u00ef\u00f0\7o\2\2\u00f0\32"+
"\3\2\2\2\u00f1\u00f2\7<\2\2\u00f2\34\3\2\2\2\u00f3\u00f4\7d\2\2\u00f4"+
"\u00f5\7{\2\2\u00f5\u00f6\7v\2\2\u00f6\u00f7\7g\2\2\u00f7\u00f8\7u\2\2"+
"\u00f8\36\3\2\2\2\u00f9\u00fa\7e\2\2\u00fa\u00fb\7{\2\2\u00fb\u00fc\7"+
"e\2\2\u00fc\u00fd\7n\2\2\u00fd\u00fe\7g\2\2\u00fe\u00ff\7u\2\2\u00ff "+
"\3\2\2\2\u0100\u0101\7r\2\2\u0101\u0102\7e\2\2\u0102\"\3\2\2\2\u0103\u0104"+
"\7k\2\2\u0104\u0105\7p\2\2\u0105\u0106\7n\2\2\u0106\u0107\7k\2\2\u0107"+
"\u0108\7p\2\2\u0108\u0109\7g\2\2\u0109$\3\2\2\2\u010a\u010b\7e\2\2\u010b"+
"\u010c\7q\2\2\u010c\u010d\7p\2\2\u010d\u010e\7u\2\2\u010e\u010f\7v\2\2"+
"\u010f&\3\2\2\2\u0110\u0111\7g\2\2\u0111\u0112\7z\2\2\u0112\u0113\7v\2"+
"\2\u0113\u0114\7g\2\2\u0114\u0115\7t\2\2\u0115\u0116\7p\2\2\u0116(\3\2"+
"\2\2\u0117\u0118\7c\2\2\u0118\u0119\7n\2\2\u0119\u011a\7k\2\2\u011a\u011b"+
"\7i\2\2\u011b\u011c\7p\2\2\u011c*\3\2\2\2\u011d\u011e\7t\2\2\u011e\u011f"+
"\7g\2\2\u011f\u0120\7i\2\2\u0120\u0121\7k\2\2\u0121\u0122\7u\2\2\u0122"+
"\u0123\7v\2\2\u0123\u0124\7g\2\2\u0124\u0125\7t\2\2\u0125,\3\2\2\2\u0126"+
"\u0127\7x\2\2\u0127\u0128\7q\2\2\u0128\u0129\7n\2\2\u0129\u012a\7c\2\2"+
"\u012a\u012b\7v\2\2\u012b\u012c\7k\2\2\u012c\u012d\7n\2\2\u012d\u012e"+
"\7g\2\2\u012e.\3\2\2\2\u012f\u0130\7k\2\2\u0130\u0131\7p\2\2\u0131\u0132"+
"\7v\2\2\u0132\u0133\7g\2\2\u0133\u0134\7t\2\2\u0134\u0135\7t\2\2\u0135"+
"\u0136\7w\2\2\u0136\u0137\7r\2\2\u0137\u0138\7v\2\2\u0138\60\3\2\2\2\u0139"+
"\u013a\7k\2\2\u013a\u013b\7h\2\2\u013b\62\3\2\2\2\u013c\u013d\7g\2\2\u013d"+
"\u013e\7n\2\2\u013e\u013f\7u\2\2\u013f\u0140\7g\2\2\u0140\64\3\2\2\2\u0141"+
"\u0142\7y\2\2\u0142\u0143\7j\2\2\u0143\u0144\7k\2\2\u0144\u0145\7n\2\2"+
"\u0145\u0146\7g\2\2\u0146\66\3\2\2\2\u0147\u0148\7f\2\2\u0148\u0149\7"+
"q\2\2\u01498\3\2\2\2\u014a\u014b\7h\2\2\u014b\u014c\7q\2\2\u014c\u014d"+
"\7t\2\2\u014d:\3\2\2\2\u014e\u014f\7t\2\2\u014f\u0150\7g\2\2\u0150\u0151"+
"\7v\2\2\u0151\u0152\7w\2\2\u0152\u0153\7t\2\2\u0153\u0154\7p\2\2\u0154"+
"<\3\2\2\2\u0155\u0156\7c\2\2\u0156\u0157\7u\2\2\u0157\u0158\7o\2\2\u0158"+
">\3\2\2\2\u0159\u015a\7\60\2\2\u015a\u015b\7\60\2\2\u015b@\3\2\2\2\u015c"+
"\u015d\7u\2\2\u015d\u015e\7k\2\2\u015e\u015f\7i\2\2\u015f\u0160\7p\2\2"+
"\u0160\u0161\7g\2\2\u0161\u0162\7f\2\2\u0162B\3\2\2\2\u0163\u0164\7,\2"+
"\2\u0164D\3\2\2\2\u0165\u0166\7]\2\2\u0166F\3\2\2\2\u0167\u0168\7_\2\2"+
"\u0168H\3\2\2\2\u0169\u016a\7/\2\2\u016a\u016b\7/\2\2\u016bJ\3\2\2\2\u016c"+
"\u016d\7-\2\2\u016d\u016e\7-\2\2\u016eL\3\2\2\2\u016f\u0170\7-\2\2\u0170"+
"N\3\2\2\2\u0171\u0172\7/\2\2\u0172P\3\2\2\2\u0173\u0174\7#\2\2\u0174R"+
"\3\2\2\2\u0175\u0176\7(\2\2\u0176T\3\2\2\2\u0177\u0178\7\u0080\2\2\u0178"+
"V\3\2\2\2\u0179\u017a\7@\2\2\u017a\u017b\7@\2\2\u017bX\3\2\2\2\u017c\u017d"+
"\7>\2\2\u017d\u017e\7>\2\2\u017eZ\3\2\2\2\u017f\u0180\7\61\2\2\u0180\\"+
"\3\2\2\2\u0181\u0182\7\'\2\2\u0182^\3\2\2\2\u0183\u0184\7>\2\2\u0184`"+
"\3\2\2\2\u0185\u0186\7@\2\2\u0186b\3\2\2\2\u0187\u0188\7?\2\2\u0188\u0189"+
"\7?\2\2\u0189d\3\2\2\2\u018a\u018b\7#\2\2\u018b\u018c\7?\2\2\u018cf\3"+
"\2\2\2\u018d\u018e\7>\2\2\u018e\u018f\7?\2\2\u018fh\3\2\2\2\u0190\u0191"+
"\7@\2\2\u0191\u0192\7?\2\2\u0192j\3\2\2\2\u0193\u0194\7`\2\2\u0194l\3"+
"\2\2\2\u0195\u0196\7~\2\2\u0196n\3\2\2\2\u0197\u0198\7(\2\2\u0198\u0199"+
"\7(\2\2\u0199p\3\2\2\2\u019a\u019b\7~\2\2\u019b\u019c\7~\2\2\u019cr\3"+
"\2\2\2\u019d\u019e\7-\2\2\u019e\u019f\7?\2\2\u019ft\3\2\2\2\u01a0\u01a1"+
"\7/\2\2\u01a1\u01a2\7?\2\2\u01a2v\3\2\2\2\u01a3\u01a4\7,\2\2\u01a4\u01a5"+
"\7?\2\2\u01a5x\3\2\2\2\u01a6\u01a7\7\61\2\2\u01a7\u01a8\7?\2\2\u01a8z"+
"\3\2\2\2\u01a9\u01aa\7\'\2\2\u01aa\u01ab\7?\2\2\u01ab|\3\2\2\2\u01ac\u01ad"+
"\7>\2\2\u01ad\u01ae\7>\2\2\u01ae\u01af\7?\2\2\u01af~\3\2\2\2\u01b0\u01b1"+
"\7@\2\2\u01b1\u01b2\7@\2\2\u01b2\u01b3\7?\2\2\u01b3\u0080\3\2\2\2\u01b4"+
"\u01b5\7(\2\2\u01b5\u01b6\7?\2\2\u01b6\u0082\3\2\2\2\u01b7\u01b8\7~\2"+
"\2\u01b8\u01b9\7?\2\2\u01b9\u0084\3\2\2\2\u01ba\u01bb\7`\2\2\u01bb\u01bc"+
"\7?\2\2\u01bc\u0086\3\2\2\2\u01bd\u01be\7\60\2\2\u01be\u01bf\7d\2\2\u01bf"+
"\u01c0\7{\2\2\u01c0\u01c1\7v\2\2\u01c1\u01c2\7g\2\2\u01c2\u0088\3\2\2"+
"\2\u01c3\u01c4\7%\2\2\u01c4\u008a\3\2\2\2\u01c5\u01c6\7d\2\2\u01c6\u01c7"+
"\7t\2\2\u01c7\u02a4\7m\2\2\u01c8\u01c9\7q\2\2\u01c9\u01ca\7t\2\2\u01ca"+
"\u02a4\7c\2\2\u01cb\u01cc\7m\2\2\u01cc\u01cd\7k\2\2\u01cd\u02a4\7n\2\2"+
"\u01ce\u01cf\7u\2\2\u01cf\u01d0\7n\2\2\u01d0\u02a4\7q\2\2\u01d1\u01d2"+
"\7p\2\2\u01d2\u01d3\7q\2\2\u01d3\u02a4\7r\2\2\u01d4\u01d5\7c\2\2\u01d5"+
"\u01d6\7u\2\2\u01d6\u02a4\7n\2\2\u01d7\u01d8\7r\2\2\u01d8\u01d9\7j\2\2"+
"\u01d9\u02a4\7r\2\2\u01da\u01db\7c\2\2\u01db\u01dc\7p\2\2\u01dc\u02a4"+
"\7e\2\2\u01dd\u01de\7d\2\2\u01de\u01df\7r\2\2\u01df\u02a4\7n\2\2\u01e0"+
"\u01e1\7e\2\2\u01e1\u01e2\7n\2\2\u01e2\u02a4\7e\2\2\u01e3\u01e4\7l\2\2"+
"\u01e4\u01e5\7u\2\2\u01e5\u02a4\7t\2\2\u01e6\u01e7\7c\2\2\u01e7\u01e8"+
"\7p\2\2\u01e8\u02a4\7f\2\2\u01e9\u01ea\7t\2\2\u01ea\u01eb\7n\2\2\u01eb"+
"\u02a4\7c\2\2\u01ec\u01ed\7d\2\2\u01ed\u01ee\7k\2\2\u01ee\u02a4\7v\2\2"+
"\u01ef\u01f0\7t\2\2\u01f0\u01f1\7q\2\2\u01f1\u02a4\7n\2\2\u01f2\u01f3"+
"\7r\2\2\u01f3\u01f4\7n\2\2\u01f4\u02a4\7c\2\2\u01f5\u01f6\7r\2\2\u01f6"+
"\u01f7\7n\2\2\u01f7\u02a4\7r\2\2\u01f8\u01f9\7d\2\2\u01f9\u01fa\7o\2\2"+
"\u01fa\u02a4\7k\2\2\u01fb\u01fc\7u\2\2\u01fc\u01fd\7g\2\2\u01fd\u02a4"+
"\7e\2\2\u01fe\u01ff\7t\2\2\u01ff\u0200\7v\2\2\u0200\u02a4\7k\2\2\u0201"+
"\u0202\7g\2\2\u0202\u0203\7q\2\2\u0203\u02a4\7t\2\2\u0204\u0205\7u\2\2"+
"\u0205\u0206\7t\2\2\u0206\u02a4\7g\2\2\u0207\u0208\7n\2\2\u0208\u0209"+
"\7u\2\2\u0209\u02a4\7t\2\2\u020a\u020b\7r\2\2\u020b\u020c\7j\2\2\u020c"+
"\u02a4\7c\2\2\u020d\u020e\7c\2\2\u020e\u020f\7n\2\2\u020f\u02a4\7t\2\2"+
"\u0210\u0211\7l\2\2\u0211\u0212\7o\2\2\u0212\u02a4\7r\2\2\u0213\u0214"+
"\7d\2\2\u0214\u0215\7x\2\2\u0215\u02a4\7e\2\2\u0216\u0217\7e\2\2\u0217"+
"\u0218\7n\2\2\u0218\u02a4\7k\2\2\u0219\u021a\7t\2\2\u021a\u021b\7v\2\2"+
"\u021b\u02a4\7u\2\2\u021c\u021d\7c\2\2\u021d\u021e\7f\2\2\u021e\u02a4"+
"\7e\2\2\u021f\u0220\7t\2\2\u0220\u0221\7t\2\2\u0221\u02a4\7c\2\2\u0222"+
"\u0223\7d\2\2\u0223\u0224\7x\2\2\u0224\u02a4\7u\2\2\u0225\u0226\7u\2\2"+
"\u0226\u0227\7g\2\2\u0227\u02a4\7k\2\2\u0228\u0229\7u\2\2\u0229\u022a"+
"\7c\2\2\u022a\u02a4\7z\2\2\u022b\u022c\7u\2\2\u022c\u022d\7v\2\2\u022d"+
"\u02a4\7{\2\2\u022e\u022f\7u\2\2\u022f\u0230\7v\2\2\u0230\u02a4\7c\2\2"+
"\u0231\u0232\7u\2\2\u0232\u0233\7v\2\2\u0233\u02a4\7z\2\2\u0234\u0235"+
"\7f\2\2\u0235\u0236\7g\2\2\u0236\u02a4\7{\2\2\u0237\u0238\7v\2\2\u0238"+
"\u0239\7z\2\2\u0239\u02a4\7c\2\2\u023a\u023b\7z\2\2\u023b\u023c\7c\2\2"+
"\u023c\u02a4\7c\2\2\u023d\u023e\7d\2\2\u023e\u023f\7e\2\2\u023f\u02a4"+
"\7e\2\2\u0240\u0241\7c\2\2\u0241\u0242\7j\2\2\u0242\u02a4\7z\2\2\u0243"+
"\u0244\7v\2\2\u0244\u0245\7{\2\2\u0245\u02a4\7c\2\2\u0246\u0247\7v\2\2"+
"\u0247\u0248\7z\2\2\u0248\u02a4\7u\2\2\u0249\u024a\7v\2\2\u024a\u024b"+
"\7c\2\2\u024b\u02a4\7u\2\2\u024c\u024d\7u\2\2\u024d\u024e\7j\2\2\u024e"+
"\u02a4\7{\2\2\u024f\u0250\7u\2\2\u0250\u0251\7j\2\2\u0251\u02a4\7z\2\2"+
"\u0252\u0253\7n\2\2\u0253\u0254\7f\2\2\u0254\u02a4\7{\2\2\u0255\u0256"+
"\7n\2\2\u0256\u0257\7f\2\2\u0257\u02a4\7c\2\2\u0258\u0259\7n\2\2\u0259"+
"\u025a\7f\2\2\u025a\u02a4\7z\2\2\u025b\u025c\7n\2\2\u025c\u025d\7c\2\2"+
"\u025d\u02a4\7z\2\2\u025e\u025f\7v\2\2\u025f\u0260\7c\2\2\u0260\u02a4"+
"\7{\2\2\u0261\u0262\7v\2\2\u0262\u0263\7c\2\2\u0263\u02a4\7z\2\2\u0264"+
"\u0265\7d\2\2\u0265\u0266\7e\2\2\u0266\u02a4\7u\2\2\u0267\u0268\7e\2\2"+
"\u0268\u0269\7n\2\2\u0269\u02a4\7x\2\2\u026a\u026b\7v\2\2\u026b\u026c"+
"\7u\2\2\u026c\u02a4\7z\2\2\u026d\u026e\7n\2\2\u026e\u026f\7c\2\2\u026f"+
"\u02a4\7u\2\2\u0270\u0271\7e\2\2\u0271\u0272\7r\2\2\u0272\u02a4\7{\2\2"+
"\u0273\u0274\7e\2\2\u0274\u0275\7o\2\2\u0275\u02a4\7r\2\2\u0276\u0277"+
"\7e\2\2\u0277\u0278\7r\2\2\u0278\u02a4\7z\2\2\u0279\u027a\7f\2\2\u027a"+
"\u027b\7e\2\2\u027b\u02a4\7r\2\2\u027c\u027d\7f\2\2\u027d\u027e\7g\2\2"+
"\u027e\u02a4\7e\2\2\u027f\u0280\7k\2\2\u0280\u0281\7p\2\2\u0281\u02a4"+
"\7e\2\2\u0282\u0283\7c\2\2\u0283\u0284\7z\2\2\u0284\u02a4\7u\2\2\u0285"+
"\u0286\7d\2\2\u0286\u0287\7p\2\2\u0287\u02a4\7g\2\2\u0288\u0289\7e\2\2"+
"\u0289\u028a\7n\2\2\u028a\u02a4\7f\2\2\u028b\u028c\7u\2\2\u028c\u028d"+
"\7d\2\2\u028d\u02a4\7e\2\2\u028e\u028f\7k\2\2\u028f\u0290\7u\2\2\u0290"+
"\u02a4\7e\2\2\u0291\u0292\7k\2\2\u0292\u0293\7p\2\2\u0293\u02a4\7z\2\2"+
"\u0294\u0295\7d\2\2\u0295\u0296\7g\2\2\u0296\u02a4\7s\2\2\u0297\u0298"+
"\7u\2\2\u0298\u0299\7g\2\2\u0299\u02a4\7f\2\2\u029a\u029b\7f\2\2\u029b"+
"\u029c\7g\2\2\u029c\u02a4\7z\2\2\u029d\u029e\7k\2\2\u029e\u029f\7p\2\2"+
"\u029f\u02a4\7{\2\2\u02a0\u02a1\7t\2\2\u02a1\u02a2\7q\2\2\u02a2\u02a4"+
"\7t\2\2\u02a3\u01c5\3\2\2\2\u02a3\u01c8\3\2\2\2\u02a3\u01cb\3\2\2\2\u02a3"+
"\u01ce\3\2\2\2\u02a3\u01d1\3\2\2\2\u02a3\u01d4\3\2\2\2\u02a3\u01d7\3\2"+
"\2\2\u02a3\u01da\3\2\2\2\u02a3\u01dd\3\2\2\2\u02a3\u01e0\3\2\2\2\u02a3"+
"\u01e3\3\2\2\2\u02a3\u01e6\3\2\2\2\u02a3\u01e9\3\2\2\2\u02a3\u01ec\3\2"+
"\2\2\u02a3\u01ef\3\2\2\2\u02a3\u01f2\3\2\2\2\u02a3\u01f5\3\2\2\2\u02a3"+
"\u01f8\3\2\2\2\u02a3\u01fb\3\2\2\2\u02a3\u01fe\3\2\2\2\u02a3\u0201\3\2"+
"\2\2\u02a3\u0204\3\2\2\2\u02a3\u0207\3\2\2\2\u02a3\u020a\3\2\2\2\u02a3"+
"\u020d\3\2\2\2\u02a3\u0210\3\2\2\2\u02a3\u0213\3\2\2\2\u02a3\u0216\3\2"+
"\2\2\u02a3\u0219\3\2\2\2\u02a3\u021c\3\2\2\2\u02a3\u021f\3\2\2\2\u02a3"+
"\u0222\3\2\2\2\u02a3\u0225\3\2\2\2\u02a3\u0228\3\2\2\2\u02a3\u022b\3\2"+
"\2\2\u02a3\u022e\3\2\2\2\u02a3\u0231\3\2\2\2\u02a3\u0234\3\2\2\2\u02a3"+
"\u0237\3\2\2\2\u02a3\u023a\3\2\2\2\u02a3\u023d\3\2\2\2\u02a3\u0240\3\2"+
"\2\2\u02a3\u0243\3\2\2\2\u02a3\u0246\3\2\2\2\u02a3\u0249\3\2\2\2\u02a3"+
"\u024c\3\2\2\2\u02a3\u024f\3\2\2\2\u02a3\u0252\3\2\2\2\u02a3\u0255\3\2"+
"\2\2\u02a3\u0258\3\2\2\2\u02a3\u025b\3\2\2\2\u02a3\u025e\3\2\2\2\u02a3"+
"\u0261\3\2\2\2\u02a3\u0264\3\2\2\2\u02a3\u0267\3\2\2\2\u02a3\u026a\3\2"+
"\2\2\u02a3\u026d\3\2\2\2\u02a3\u0270\3\2\2\2\u02a3\u0273\3\2\2\2\u02a3"+
"\u0276\3\2\2\2\u02a3\u0279\3\2\2\2\u02a3\u027c\3\2\2\2\u02a3\u027f\3\2"+
"\2\2\u02a3\u0282\3\2\2\2\u02a3\u0285\3\2\2\2\u02a3\u0288\3\2\2\2\u02a3"+
"\u028b\3\2\2\2\u02a3\u028e\3\2\2\2\u02a3\u0291\3\2\2\2\u02a3\u0294\3\2"+
"\2\2\u02a3\u0297\3\2\2\2\u02a3\u029a\3\2\2\2\u02a3\u029d\3\2\2\2\u02a3"+
"\u02a0\3\2\2\2\u02a4\u008c\3\2\2\2\u02a5\u02a6\7}\2\2\u02a6\u02a7\7}\2"+
"\2\u02a7\u02ab\3\2\2\2\u02a8\u02aa\13\2\2\2\u02a9\u02a8\3\2\2\2\u02aa"+
"\u02ad\3\2\2\2\u02ab\u02ac\3\2\2\2\u02ab\u02a9\3\2\2\2\u02ac\u02ae\3\2"+
"\2\2\u02ad\u02ab\3\2\2\2\u02ae\u02af\7\177\2\2\u02af\u02b0\7\177\2\2\u02b0"+
"\u008e\3\2\2\2\u02b1\u02b2\7d\2\2\u02b2\u02b3\7{\2\2\u02b3\u02b4\7v\2"+
"\2\u02b4\u02c7\7g\2\2\u02b5\u02b6\7y\2\2\u02b6\u02b7\7q\2\2\u02b7\u02b8"+
"\7t\2\2\u02b8\u02c7\7f\2\2\u02b9\u02ba\7f\2\2\u02ba\u02bb\7y\2\2\u02bb"+
"\u02bc\7q\2\2\u02bc\u02bd\7t\2\2\u02bd\u02c7\7f\2\2\u02be\u02bf\7d\2\2"+
"\u02bf\u02c0\7q\2\2\u02c0\u02c1\7q\2\2\u02c1\u02c7\7n\2\2\u02c2\u02c3"+
"\7x\2\2\u02c3\u02c4\7q\2\2\u02c4\u02c5\7k\2\2\u02c5\u02c7\7f\2\2\u02c6"+
"\u02b1\3\2\2\2\u02c6\u02b5\3\2\2\2\u02c6\u02b9\3\2\2\2\u02c6\u02be\3\2"+
"\2\2\u02c6\u02c2\3\2\2\2\u02c7\u0090\3\2\2\2\u02c8\u02ce\7$\2\2\u02c9"+
"\u02ca\7^\2\2\u02ca\u02cd\7$\2\2\u02cb\u02cd\n\2\2\2\u02cc\u02c9\3\2\2"+
"\2\u02cc\u02cb\3\2\2\2\u02cd\u02d0\3\2\2\2\u02ce\u02cc\3\2\2\2\u02ce\u02cf"+
"\3\2\2\2\u02cf\u02d1\3\2\2\2\u02d0\u02ce\3\2\2\2\u02d1\u02d2\7$\2\2\u02d2"+
"\u0092\3\2\2\2\u02d3\u02d7\7)\2\2\u02d4\u02d5\7^\2\2\u02d5\u02d8\7)\2"+
"\2\u02d6\u02d8\n\3\2\2\u02d7\u02d4\3\2\2\2\u02d7\u02d6\3\2\2\2\u02d8\u02d9"+
"\3\2\2\2\u02d9\u02da\7)\2\2\u02da\u0094\3\2\2\2\u02db\u02dc\7v\2\2\u02dc"+
"\u02dd\7t\2\2\u02dd\u02de\7w\2\2\u02de\u02e5\7g\2\2\u02df\u02e0\7h\2\2"+
"\u02e0\u02e1\7c\2\2\u02e1\u02e2\7n\2\2\u02e2\u02e3\7u\2\2\u02e3\u02e5"+
"\7g\2\2\u02e4\u02db\3\2\2\2\u02e4\u02df\3\2\2\2\u02e5\u0096\3\2\2\2\u02e6"+
"\u02e9\5\u0099M\2\u02e7\u02e9\5\u00a1Q\2\u02e8\u02e6\3\2\2\2\u02e8\u02e7"+
"\3\2\2\2\u02e9\u0098\3\2\2\2\u02ea\u02ee\5\u009bN\2\u02eb\u02ee\5\u009d"+
"O\2\u02ec\u02ee\5\u009fP\2\u02ed\u02ea\3\2\2\2\u02ed\u02eb\3\2\2\2\u02ed"+
"\u02ec\3\2\2\2\u02ee\u009a\3\2\2\2\u02ef\u02f5\7\'\2\2\u02f0\u02f1\7\62"+
"\2\2\u02f1\u02f5\7d\2\2\u02f2\u02f3\7\62\2\2\u02f3\u02f5\7D\2\2\u02f4"+
"\u02ef\3\2\2\2\u02f4\u02f0\3\2\2\2\u02f4\u02f2\3\2\2\2\u02f5\u02f9\3\2"+
"\2\2\u02f6\u02f8\5\u00a9U\2\u02f7\u02f6\3\2\2\2\u02f8\u02fb\3\2\2\2\u02f9"+
"\u02f7\3\2\2\2\u02f9\u02fa\3\2\2\2\u02fa\u02fc\3\2\2\2\u02fb\u02f9\3\2"+
"\2\2\u02fc\u02fe\7\60\2\2\u02fd\u02ff\5\u00a9U\2\u02fe\u02fd\3\2\2\2\u02ff"+
"\u0300\3\2\2\2\u0300\u02fe\3\2\2\2\u0300\u0301\3\2\2\2\u0301\u009c\3\2"+
"\2\2\u0302\u0304\5\u00abV\2\u0303\u0302\3\2\2\2\u0304\u0307\3\2\2\2\u0305"+
"\u0303\3\2\2\2\u0305\u0306\3\2\2\2\u0306\u0308\3\2\2\2\u0307\u0305\3\2"+
"\2\2\u0308\u030a\7\60\2\2\u0309\u030b\5\u00abV\2\u030a\u0309\3\2\2\2\u030b"+
"\u030c\3\2\2\2\u030c\u030a\3\2\2\2\u030c\u030d\3\2\2\2\u030d\u009e\3\2"+
"\2\2\u030e\u0314\7&\2\2\u030f\u0310\7\62\2\2\u0310\u0314\7z\2\2\u0311"+
"\u0312\7\62\2\2\u0312\u0314\7Z\2\2\u0313\u030e\3\2\2\2\u0313\u030f\3\2"+
"\2\2\u0313\u0311\3\2\2\2\u0314\u0318\3\2\2\2\u0315\u0317\5\u00adW\2\u0316"+
"\u0315\3\2\2\2\u0317\u031a\3\2\2\2\u0318\u0316\3\2\2\2\u0318\u0319\3\2"+
"\2\2\u0319\u031b\3\2\2\2\u031a\u0318\3\2\2\2\u031b\u031d\7\60\2\2\u031c"+
"\u031e\5\u00adW\2\u031d\u031c\3\2\2\2\u031e\u031f\3\2\2\2\u031f\u031d"+
"\3\2\2\2\u031f\u0320\3\2\2\2\u0320\u00a0\3\2\2\2\u0321\u0325\5\u00a5S"+
"\2\u0322\u0325\5\u00a7T\2\u0323\u0325\5\u00a3R\2\u0324\u0321\3\2\2\2\u0324"+
"\u0322\3\2\2\2\u0324\u0323\3\2\2\2\u0325\u00a2\3\2\2\2\u0326\u0327\7\62"+
"\2\2\u0327\u0329\t\4\2\2\u0328\u032a\5\u00a9U\2\u0329\u0328\3\2\2\2\u032a"+
"\u032b\3\2\2\2\u032b\u0329\3\2\2\2\u032b\u032c\3\2\2\2\u032c\u0334\3\2"+
"\2\2\u032d\u032f\7\'\2\2\u032e\u0330\5\u00a9U\2\u032f\u032e\3\2\2\2\u0330"+
"\u0331\3\2\2\2\u0331\u032f\3\2\2\2\u0331\u0332\3\2\2\2\u0332\u0334\3\2"+
"\2\2\u0333\u0326\3\2\2\2\u0333\u032d\3\2\2\2\u0334\u00a4\3\2\2\2\u0335"+
"\u0337\5\u00abV\2\u0336\u0335\3\2\2\2\u0337\u0338\3\2\2\2\u0338\u0336"+
"\3\2\2\2\u0338\u0339\3\2\2\2\u0339\u00a6\3\2\2\2\u033a\u0340\7&\2\2\u033b"+
"\u033c\7\62\2\2\u033c\u0340\7z\2\2\u033d\u033e\7\62\2\2\u033e\u0340\7"+
"Z\2\2\u033f\u033a\3\2\2\2\u033f\u033b\3\2\2\2\u033f\u033d\3\2\2\2\u0340"+
"\u0342\3\2\2\2\u0341\u0343\5\u00adW\2\u0342\u0341\3\2\2\2\u0343\u0344"+
"\3\2\2\2\u0344\u0342\3\2\2\2\u0344\u0345\3\2\2\2\u0345\u00a8\3\2\2\2\u0346"+
"\u0347\t\5\2\2\u0347\u00aa\3\2\2\2\u0348\u0349\t\6\2\2\u0349\u00ac\3\2"+
"\2\2\u034a\u034b\t\7\2\2\u034b\u00ae\3\2\2\2\u034c\u0350\5\u00b1Y\2\u034d"+
"\u034f\5\u00b3Z\2\u034e\u034d\3\2\2\2\u034f\u0352\3\2\2\2\u0350\u034e"+
"\3\2\2\2\u0350\u0351\3\2\2\2\u0351\u00b0\3\2\2\2\u0352\u0350\3\2\2\2\u0353"+
"\u0354\t\b\2\2\u0354\u00b2\3\2\2\2\u0355\u0356\t\t\2\2\u0356\u00b4\3\2"+
"\2\2\u0357\u035b\7#\2\2\u0358\u035a\5\u00b3Z\2\u0359\u0358\3\2\2\2\u035a"+
"\u035d\3\2\2\2\u035b\u0359\3\2\2\2\u035b\u035c\3\2\2\2\u035c\u035f\3\2"+
"\2\2\u035d\u035b\3\2\2\2\u035e\u0360\t\n\2\2\u035f\u035e\3\2\2\2\u0360"+
"\u0361\3\2\2\2\u0361\u035f\3\2\2\2\u0361\u0362\3\2\2\2\u0362\u00b6\3\2"+
"\2\2\u0363\u0365\t\13\2\2\u0364\u0363\3\2\2\2\u0365\u0366\3\2\2\2\u0366"+
"\u0364\3\2\2\2\u0366\u0367\3\2\2\2\u0367\u0368\3\2\2\2\u0368\u0369\b\\"+
"\2\2\u0369\u00b8\3\2\2\2\u036a\u036b\7\61\2\2\u036b\u036c\7\61\2\2\u036c"+
"\u0370\3\2\2\2\u036d\u036f\n\f\2\2\u036e\u036d\3\2\2\2\u036f\u0372\3\2"+
"\2\2\u0370\u036e\3\2\2\2\u0370\u0371\3\2\2\2\u0371\u0373\3\2\2\2\u0372"+
"\u0370\3\2\2\2\u0373\u0374\b]\2\2\u0374\u00ba\3\2\2\2\u0375\u0376\7\61"+
"\2\2\u0376\u0377\7,\2\2\u0377\u037b\3\2\2\2\u0378\u037a\13\2\2\2\u0379"+
"\u0378\3\2\2\2\u037a\u037d\3\2\2\2\u037b\u037c\3\2\2\2\u037b\u0379\3\2"+
"\2\2\u037c\u037e\3\2\2\2\u037d\u037b\3\2\2\2\u037e\u037f\7,\2\2\u037f"+
"\u0380\7\61\2\2\u0380\u0381\3\2\2\2\u0381\u0382\b^\2\2\u0382\u00bc\3\2"+
"\2\2!\2\u02a3\u02ab\u02c6\u02cc\u02ce\u02d7\u02e4\u02e8\u02ed\u02f4\u02f9"+
"\u0300\u0305\u030c\u0313\u0318\u031f\u0324\u032b\u0331\u0333\u0338\u033f"+
"\u0344\u0350\u035b\u0361\u0366\u0370\u037b\3\b\2\2";
public static final ATN _ATN =
new ATNDeserializer().deserialize(_serializedATN.toCharArray());
static {

View File

@ -66,32 +66,26 @@ T__64=65
T__65=66
T__66=67
T__67=68
T__68=69
T__69=70
T__70=71
T__71=72
T__72=73
T__73=74
MNEMONIC=75
KICKASM=76
SIMPLETYPE=77
STRING=78
CHAR=79
BOOLEAN=80
NUMBER=81
NUMFLOAT=82
BINFLOAT=83
DECFLOAT=84
HEXFLOAT=85
NUMINT=86
BININTEGER=87
DECINTEGER=88
HEXINTEGER=89
NAME=90
ASMREL=91
WS=92
COMMENT_LINE=93
COMMENT_BLOCK=94
MNEMONIC=69
KICKASM=70
SIMPLETYPE=71
STRING=72
CHAR=73
BOOLEAN=74
NUMBER=75
NUMFLOAT=76
BINFLOAT=77
DECFLOAT=78
HEXFLOAT=79
NUMINT=80
BININTEGER=81
DECINTEGER=82
HEXINTEGER=83
NAME=84
ASMREL=85
WS=86
COMMENT_LINE=87
COMMENT_BLOCK=88
'import'=1
'='=2
';'=3
@ -115,54 +109,48 @@ COMMENT_BLOCK=94
'register'=21
'volatile'=22
'interrupt'=23
'hardware'=24
'none'=25
'all'=26
'kernel'=27
'min'=28
'std'=29
'if'=30
'else'=31
'while'=32
'do'=33
'for'=34
'return'=35
'asm'=36
'..'=37
'signed'=38
'*'=39
'['=40
']'=41
'--'=42
'++'=43
'+'=44
'-'=45
'!'=46
'&'=47
'~'=48
'>>'=49
'<<'=50
'/'=51
'%'=52
'<'=53
'>'=54
'=='=55
'!='=56
'<='=57
'>='=58
'^'=59
'|'=60
'&&'=61
'||'=62
'+='=63
'-='=64
'*='=65
'/='=66
'%='=67
'<<='=68
'>>='=69
'&='=70
'|='=71
'^='=72
'.byte'=73
'#'=74
'if'=24
'else'=25
'while'=26
'do'=27
'for'=28
'return'=29
'asm'=30
'..'=31
'signed'=32
'*'=33
'['=34
']'=35
'--'=36
'++'=37
'+'=38
'-'=39
'!'=40
'&'=41
'~'=42
'>>'=43
'<<'=44
'/'=45
'%'=46
'<'=47
'>'=48
'=='=49
'!='=50
'<='=51
'>='=52
'^'=53
'|'=54
'&&'=55
'||'=56
'+='=57
'-='=58
'*='=59
'/='=60
'%='=61
'<<='=62
'>>='=63
'&='=64
'|='=65
'^='=66
'.byte'=67
'#'=68

File diff suppressed because it is too large Load Diff

View File

@ -371,25 +371,11 @@ public class Pass0GenerateStatementSequence extends KickCBaseVisitor<Object> {
@Override
public Object visitDirectiveInterrupt(KickCParser.DirectiveInterruptContext ctx) {
String interruptType = "KERNEL";
String interruptType = "KERNEL_MIN";
if(ctx.getChildCount() > 1) {
interruptType = ctx.getChild(2).getText().toUpperCase();
}
String interruptSubType;
if(interruptType.equals("KERNEL")) {
// KERNEL - default is STD
interruptSubType = "STD";
} else {
// HARDWARE - default is ALL
interruptSubType = "ALL";
}
if(ctx.getChildCount() > 3) {
String subTypeText = ctx.getChild(3).getText();
if(!")".equals(subTypeText)) {
interruptSubType = subTypeText.toUpperCase();
}
}
Procedure.InterruptType type = Procedure.InterruptType.valueOf(interruptType + "_" + interruptSubType);
Procedure.InterruptType type = Procedure.InterruptType.valueOf(interruptType);
return new DirectiveInterrupt(type);
}

View File

@ -472,9 +472,11 @@ public class Pass4CodeGeneration {
* @param interruptType The type of interrupt to generate
*/
private void generateInterruptEntry(AsmProgram asm, Procedure.InterruptType interruptType) {
asm.startSegment(null, "interrupt "+interruptType.name());
//asm.getCurrentSegment().setXXX();
if(Procedure.InterruptType.KERNEL_MIN.equals(interruptType)) {
// No entry ASM needed
} else if(Procedure.InterruptType.KERNEL_STD.equals(interruptType)) {
} else if(Procedure.InterruptType.KERNEL_KEYBOARD.equals(interruptType)) {
// No entry ASM needed
} else if(Procedure.InterruptType.HARDWARE_ALL.equals(interruptType)) {
asm.addInstruction("sta", AsmAddressingMode.ABS, "rega+1", false).setDontOptimize(true);
@ -498,7 +500,7 @@ public class Pass4CodeGeneration {
private void generateInterruptExit(AsmProgram asm, Statement statement, Procedure.InterruptType interruptType) {
if(Procedure.InterruptType.KERNEL_MIN.equals(interruptType)) {
asm.addInstruction("jmp", AsmAddressingMode.ABS, "$ea81", false);
} else if(Procedure.InterruptType.KERNEL_STD.equals(interruptType)) {
} else if(Procedure.InterruptType.KERNEL_KEYBOARD.equals(interruptType)) {
asm.addInstruction("jmp", AsmAddressingMode.ABS, "$ea31", false);
} else if(Procedure.InterruptType.HARDWARE_ALL.equals(interruptType)) {
asm.addLabel("rega").setDontOptimize(true);

View File

@ -46,6 +46,11 @@ public class TestPrograms {
AsmFragmentTemplateUsages.logUsages(log, false, false, false, false, false, false);
}
@Test
//public void testIrqHardwareClobber() throws IOException, URISyntaxException {
// compileAndCompare("irq-hardware-clobber");
//}
@Test
public void testIrqHardware() throws IOException, URISyntaxException {
compileAndCompare("irq-hardware");

View File

@ -0,0 +1,58 @@
// A minimal working raster hardware IRQ with clobber-based register savings
const void()** KERNEL_IRQ = $0314;
const void()** HARDWARE_IRQ = $fffe;
const byte* RASTER = $d012;
const byte* VIC_CONTROL = $d011;
const byte* IRQ_STATUS = $d019;
const byte* IRQ_ENABLE = $d01a;
const byte IRQ_RASTER = %00000001;
const byte IRQ_COLLISION_BG = %00000010;
const byte IRQ_COLLISION_SPRITE = %00000100;
const byte IRQ_LIGHTPEN = %00001000;
const byte* BGCOL = $d020;
const byte* FGCOL = $d021;
const byte WHITE = 1;
const byte BLACK = 0;
const byte* CIA1_INTERRUPT = $dc0d;
const byte CIA_INTERRUPT_CLEAR = $7f;
// Processor port data direction register
const byte* 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;
// RAM in $A000, $E000 I/O in $D000
const byte PROCPORT_RAM_IO = %00110101;
// RAM in $A000, $E000 CHAR ROM in $D000
void main() {
asm { sei }
// Disable kernal & basic
*PROCPORT_DDR = PROCPORT_DDR_MEMORY_MASK;
*PROCPORT = PROCPORT_RAM_IO;
// Disable CIA 1 Timer IRQ
*CIA1_INTERRUPT = CIA_INTERRUPT_CLEAR;
// Set raster line to $100
*VIC_CONTROL |=$80;
*RASTER = $00;
// Enable Raster Interrupt
*IRQ_ENABLE = IRQ_RASTER;
// Set the IRQ routine
*HARDWARE_IRQ = &irq;
asm { cli }
while(true) {
(*FGCOL)++;
}
}
// Interrupt Routine
interrupt(hardware_clobber) void irq() {
*BGCOL = WHITE;
*BGCOL = BLACK;
// Acknowledge the IRQ
*IRQ_STATUS = IRQ_RASTER;
}

View File

@ -50,7 +50,7 @@ void main() {
}
// Interrupt Routine
interrupt(hardware all) void irq() {
interrupt(hardware_all) void irq() {
*BGCOL = WHITE;
*BGCOL = BLACK;
// Acknowledge the IRQ

View File

@ -36,7 +36,7 @@ void main() {
}
// Interrupt Routine 1
interrupt void irq_bottom_1() {
interrupt(kernel_min) void irq_bottom_1() {
*FGCOL = WHITE;
// Set screen height to 24 lines - this is done after the border should have started drawing - so it wont start
*VIC_CONTROL &= ($ff^VIC_RSEL);
@ -49,7 +49,7 @@ interrupt void irq_bottom_1() {
}
// Interrupt Routine 2
interrupt void irq_bottom_2() {
interrupt(kernel_keyboard) void irq_bottom_2() {
*FGCOL = WHITE;
// Set screen height back to 25 lines (preparing for the next screen)
*VIC_CONTROL |= VIC_RSEL;

View File

@ -31,7 +31,7 @@ void main() {
}
// Interrupt Routine
interrupt(kernel std) void irq() {
interrupt(kernel_keyboard) void irq() {
*BGCOL = WHITE;
*BGCOL = BLACK;
// Acknowledge the IRQ

View File

@ -9,7 +9,7 @@ void main() {
}
}
interrupt(kernel) void irq() {
interrupt(kernel_min) void irq() {
asm {
lda $dc0d
}

View File

@ -9,7 +9,7 @@ void main() {
}
}
interrupt(kernel) void irq() {
interrupt(kernel_min) void irq() {
(*BGCOL)++;
asm {
lda $dc0d

View File

@ -51,7 +51,7 @@ void main() {
}
// Interrupt Routine
interrupt(hardware all) void irq() {
interrupt(hardware_all) void irq() {
*BGCOL = WHITE;
*BGCOL = BLACK;
// Acknowledge the IRQ
@ -492,22 +492,23 @@ main: {
}
//SEG20 irq
irq: {
//SEG21 interrupt HARDWARE_ALL
sta rega+1
stx regx+1
sty regy+1
//SEG21 [14] *((const byte*) BGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG22 [14] *((const byte*) BGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #WHITE
sta BGCOL
//SEG22 [15] *((const byte*) BGCOL#0) ← (const byte) BLACK#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG23 [15] *((const byte*) BGCOL#0) ← (const byte) BLACK#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #BLACK
sta BGCOL
//SEG23 [16] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG24 [16] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_STATUS
jmp breturn
//SEG24 irq::@return
//SEG25 irq::@return
breturn:
//SEG25 [17] return [ ] ( )
//SEG26 [17] return [ ] ( )
rega:
lda #00
regx:
@ -614,22 +615,23 @@ main: {
}
//SEG20 irq
irq: {
//SEG21 interrupt HARDWARE_ALL
sta rega+1
stx regx+1
sty regy+1
//SEG21 [14] *((const byte*) BGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG22 [14] *((const byte*) BGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #WHITE
sta BGCOL
//SEG22 [15] *((const byte*) BGCOL#0) ← (const byte) BLACK#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG23 [15] *((const byte*) BGCOL#0) ← (const byte) BLACK#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #BLACK
sta BGCOL
//SEG23 [16] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG24 [16] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_STATUS
jmp breturn
//SEG24 irq::@return
//SEG25 irq::@return
breturn:
//SEG25 [17] return [ ] ( )
//SEG26 [17] return [ ] ( )
rega:
lda #00
regx:
@ -766,20 +768,21 @@ main: {
}
//SEG20 irq
irq: {
//SEG21 interrupt HARDWARE_ALL
sta rega+1
stx regx+1
sty regy+1
//SEG21 [14] *((const byte*) BGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG22 [14] *((const byte*) BGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #WHITE
sta BGCOL
//SEG22 [15] *((const byte*) BGCOL#0) ← (const byte) BLACK#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG23 [15] *((const byte*) BGCOL#0) ← (const byte) BLACK#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #BLACK
sta BGCOL
//SEG23 [16] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG24 [16] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_STATUS
//SEG24 irq::@return
//SEG25 [17] return [ ] ( )
//SEG25 irq::@return
//SEG26 [17] return [ ] ( )
rega:
lda #00
regx:

View File

@ -51,7 +51,7 @@ irq_bottom_2: {
sta KERNEL_IRQ+1
lda #RED
sta FGCOL
jmp $ea81
jmp $ea31
}
irq_bottom_1: {
lda #WHITE

View File

@ -14,7 +14,7 @@ main: scope:[main] from @3
[7] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) & (byte/signed byte/word/signed word/dword/signed dword) 127 [ ] ( main:2 [ ] )
[8] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 250 [ ] ( main:2 [ ] )
[9] *((const byte*) IRQ_ENABLE#0) ← (const byte) IRQ_RASTER#0 [ ] ( main:2 [ ] )
[10] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq_bottom_1() [ ] ( main:2 [ ] )
[10] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq_bottom_1() [ ] ( main:2 [ ] )
asm { cli }
to:main::@return
main::@return: scope:[main] from main
@ -25,7 +25,7 @@ irq_bottom_2: scope:[irq_bottom_2] from
[14] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) | (const byte) VIC_RSEL#0 [ ] ( )
[15] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( )
[16] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 250 [ ] ( )
[17] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq_bottom_1() [ ] ( )
[17] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq_bottom_1() [ ] ( )
[18] *((const byte*) FGCOL#0) ← (const byte) RED#0 [ ] ( )
to:irq_bottom_2::@return
irq_bottom_2::@return: scope:[irq_bottom_2] from irq_bottom_2
@ -36,7 +36,7 @@ irq_bottom_1: scope:[irq_bottom_1] from
[21] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) & (byte/word/signed word/dword/signed dword) 255^(const byte) VIC_RSEL#0 [ ] ( )
[22] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( )
[23] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 253 [ ] ( )
[24] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq_bottom_2() [ ] ( )
[24] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_KEYBOARD)(void()) irq_bottom_2() [ ] ( )
[25] *((const byte*) FGCOL#0) ← (const byte) RED#0 [ ] ( )
to:irq_bottom_1::@return
irq_bottom_1::@return: scope:[irq_bottom_1] from irq_bottom_1

View File

@ -37,7 +37,7 @@ void main() {
}
// Interrupt Routine 1
interrupt void irq_bottom_1() {
interrupt(kernel_min) void irq_bottom_1() {
*FGCOL = WHITE;
// Set screen height to 24 lines - this is done after the border should have started drawing - so it wont start
*VIC_CONTROL &= ($ff^VIC_RSEL);
@ -50,7 +50,7 @@ interrupt void irq_bottom_1() {
}
// Interrupt Routine 2
interrupt void irq_bottom_2() {
interrupt(kernel_keyboard) void irq_bottom_2() {
*FGCOL = WHITE;
// Set screen height back to 25 lines (preparing for the next screen)
*VIC_CONTROL |= VIC_RSEL;
@ -61,8 +61,8 @@ interrupt void irq_bottom_2() {
*KERNEL_IRQ = &irq_bottom_1;
*FGCOL = RED;
}
Resolved forward reference irq_bottom_1 to interrupt(KERNEL)(void()) irq_bottom_1()
Resolved forward reference irq_bottom_2 to interrupt(KERNEL)(void()) irq_bottom_2()
Resolved forward reference irq_bottom_1 to interrupt(KERNEL_MIN)(void()) irq_bottom_1()
Resolved forward reference irq_bottom_2 to interrupt(KERNEL_KEYBOARD)(void()) irq_bottom_2()
SYMBOLS
(label) @1
(label) @2
@ -86,11 +86,11 @@ SYMBOLS
(byte*) VIC_CONTROL
(byte) VIC_RSEL
(byte) WHITE
interrupt(KERNEL)(void()) irq_bottom_1()
interrupt(KERNEL_MIN)(void()) irq_bottom_1()
(byte/word/dword~) irq_bottom_1::$0
(void()*~) irq_bottom_1::$1
(label) irq_bottom_1::@return
interrupt(KERNEL)(void()) irq_bottom_2()
interrupt(KERNEL_KEYBOARD)(void()) irq_bottom_2()
(void()*~) irq_bottom_2::$0
(label) irq_bottom_2::@return
(void()) main()
@ -133,7 +133,7 @@ main: scope:[main] from
*((byte*) VIC_CONTROL) ← *((byte*) VIC_CONTROL) & (byte/signed byte/word/signed word/dword/signed dword) 127
*((byte*) RASTER) ← (byte/word/signed word/dword/signed dword) 250
*((byte*) IRQ_ENABLE) ← (byte) IRQ_RASTER
(void()*~) main::$0 ← & interrupt(KERNEL)(void()) irq_bottom_1()
(void()*~) main::$0 ← & interrupt(KERNEL_MIN)(void()) irq_bottom_1()
*((void()**) KERNEL_IRQ) ← (void()*~) main::$0
asm { cli }
to:main::@return
@ -148,7 +148,7 @@ irq_bottom_1: scope:[irq_bottom_1] from
*((byte*) VIC_CONTROL) ← *((byte*) VIC_CONTROL) & (byte/word/dword~) irq_bottom_1::$0
*((byte*) IRQ_STATUS) ← (byte) IRQ_RASTER
*((byte*) RASTER) ← (byte/word/signed word/dword/signed dword) 253
(void()*~) irq_bottom_1::$1 ← & interrupt(KERNEL)(void()) irq_bottom_2()
(void()*~) irq_bottom_1::$1 ← & interrupt(KERNEL_KEYBOARD)(void()) irq_bottom_2()
*((void()**) KERNEL_IRQ) ← (void()*~) irq_bottom_1::$1
*((byte*) FGCOL) ← (byte) RED
to:irq_bottom_1::@return
@ -162,7 +162,7 @@ irq_bottom_2: scope:[irq_bottom_2] from
*((byte*) VIC_CONTROL) ← *((byte*) VIC_CONTROL) | (byte) VIC_RSEL
*((byte*) IRQ_STATUS) ← (byte) IRQ_RASTER
*((byte*) RASTER) ← (byte/word/signed word/dword/signed dword) 250
(void()*~) irq_bottom_2::$0 ← & interrupt(KERNEL)(void()) irq_bottom_1()
(void()*~) irq_bottom_2::$0 ← & interrupt(KERNEL_MIN)(void()) irq_bottom_1()
*((void()**) KERNEL_IRQ) ← (void()*~) irq_bottom_2::$0
*((byte*) FGCOL) ← (byte) RED
to:irq_bottom_2::@return
@ -207,7 +207,7 @@ main: scope:[main] from @3
*((byte*) VIC_CONTROL#0) ← *((byte*) VIC_CONTROL#0) & (byte/signed byte/word/signed word/dword/signed dword) 127
*((byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 250
*((byte*) IRQ_ENABLE#0) ← (byte) IRQ_RASTER#0
(void()*~) main::$0 ← & interrupt(KERNEL)(void()) irq_bottom_1()
(void()*~) main::$0 ← & interrupt(KERNEL_MIN)(void()) irq_bottom_1()
*((void()**) KERNEL_IRQ#0) ← (void()*~) main::$0
asm { cli }
to:main::@return
@ -220,7 +220,7 @@ irq_bottom_1: scope:[irq_bottom_1] from
*((byte*) VIC_CONTROL#0) ← *((byte*) VIC_CONTROL#0) & (byte/word/dword~) irq_bottom_1::$0
*((byte*) IRQ_STATUS#0) ← (byte) IRQ_RASTER#0
*((byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 253
(void()*~) irq_bottom_1::$1 ← & interrupt(KERNEL)(void()) irq_bottom_2()
(void()*~) irq_bottom_1::$1 ← & interrupt(KERNEL_KEYBOARD)(void()) irq_bottom_2()
*((void()**) KERNEL_IRQ#0) ← (void()*~) irq_bottom_1::$1
*((byte*) FGCOL#0) ← (byte) RED#0
to:irq_bottom_1::@return
@ -232,7 +232,7 @@ irq_bottom_2: scope:[irq_bottom_2] from
*((byte*) VIC_CONTROL#0) ← *((byte*) VIC_CONTROL#0) | (byte) VIC_RSEL#0
*((byte*) IRQ_STATUS#0) ← (byte) IRQ_RASTER#0
*((byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 250
(void()*~) irq_bottom_2::$0 ← & interrupt(KERNEL)(void()) irq_bottom_1()
(void()*~) irq_bottom_2::$0 ← & interrupt(KERNEL_MIN)(void()) irq_bottom_1()
*((void()**) KERNEL_IRQ#0) ← (void()*~) irq_bottom_2::$0
*((byte*) FGCOL#0) ← (byte) RED#0
to:irq_bottom_2::@return
@ -277,11 +277,11 @@ SYMBOL TABLE SSA
(byte) VIC_RSEL#0
(byte) WHITE
(byte) WHITE#0
interrupt(KERNEL)(void()) irq_bottom_1()
interrupt(KERNEL_MIN)(void()) irq_bottom_1()
(byte/word/dword~) irq_bottom_1::$0
(void()*~) irq_bottom_1::$1
(label) irq_bottom_1::@return
interrupt(KERNEL)(void()) irq_bottom_2()
interrupt(KERNEL_KEYBOARD)(void()) irq_bottom_2()
(void()*~) irq_bottom_2::$0
(label) irq_bottom_2::@return
(void()) main()
@ -311,10 +311,10 @@ Succesful SSA optimization Pass2ConstantIdentification
Constant (const byte/word/dword) irq_bottom_1::$0 = 255^VIC_RSEL#0
Succesful SSA optimization Pass2ConstantIdentification
OPTIMIZING CONTROL FLOW GRAPH
Constant inlined irq_bottom_2::$0 = &interrupt(KERNEL)(void()) irq_bottom_1()
Constant inlined irq_bottom_2::$0 = &interrupt(KERNEL_MIN)(void()) irq_bottom_1()
Constant inlined irq_bottom_1::$0 = (byte/word/signed word/dword/signed dword) 255^(const byte) VIC_RSEL#0
Constant inlined main::$0 = &interrupt(KERNEL)(void()) irq_bottom_1()
Constant inlined irq_bottom_1::$1 = &interrupt(KERNEL)(void()) irq_bottom_2()
Constant inlined main::$0 = &interrupt(KERNEL_MIN)(void()) irq_bottom_1()
Constant inlined irq_bottom_1::$1 = &interrupt(KERNEL_KEYBOARD)(void()) irq_bottom_2()
Succesful SSA optimization Pass2ConstantInlining
Block Sequence Planned @begin @3 @end main main::@return irq_bottom_2 irq_bottom_2::@return irq_bottom_1 irq_bottom_1::@return
Block Sequence Planned @begin @3 @end main main::@return irq_bottom_2 irq_bottom_2::@return irq_bottom_1 irq_bottom_1::@return
@ -350,7 +350,7 @@ main: scope:[main] from @3
[7] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) & (byte/signed byte/word/signed word/dword/signed dword) 127 [ ] ( main:2 [ ] )
[8] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 250 [ ] ( main:2 [ ] )
[9] *((const byte*) IRQ_ENABLE#0) ← (const byte) IRQ_RASTER#0 [ ] ( main:2 [ ] )
[10] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq_bottom_1() [ ] ( main:2 [ ] )
[10] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq_bottom_1() [ ] ( main:2 [ ] )
asm { cli }
to:main::@return
main::@return: scope:[main] from main
@ -361,7 +361,7 @@ irq_bottom_2: scope:[irq_bottom_2] from
[14] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) | (const byte) VIC_RSEL#0 [ ] ( )
[15] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( )
[16] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 250 [ ] ( )
[17] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq_bottom_1() [ ] ( )
[17] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq_bottom_1() [ ] ( )
[18] *((const byte*) FGCOL#0) ← (const byte) RED#0 [ ] ( )
to:irq_bottom_2::@return
irq_bottom_2::@return: scope:[irq_bottom_2] from irq_bottom_2
@ -372,7 +372,7 @@ irq_bottom_1: scope:[irq_bottom_1] from
[21] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) & (byte/word/signed word/dword/signed dword) 255^(const byte) VIC_RSEL#0 [ ] ( )
[22] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( )
[23] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 253 [ ] ( )
[24] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq_bottom_2() [ ] ( )
[24] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_KEYBOARD)(void()) irq_bottom_2() [ ] ( )
[25] *((const byte*) FGCOL#0) ← (const byte) RED#0 [ ] ( )
to:irq_bottom_1::@return
irq_bottom_1::@return: scope:[irq_bottom_1] from irq_bottom_1
@ -423,8 +423,8 @@ VARIABLE REGISTER WEIGHTS
(byte*) VIC_CONTROL
(byte) VIC_RSEL
(byte) WHITE
interrupt(KERNEL)(void()) irq_bottom_1()
interrupt(KERNEL)(void()) irq_bottom_2()
interrupt(KERNEL_MIN)(void()) irq_bottom_1()
interrupt(KERNEL_KEYBOARD)(void()) irq_bottom_2()
(void()) main()
Initial phi equivalence classes
@ -483,7 +483,7 @@ main: {
//SEG14 [9] *((const byte*) IRQ_ENABLE#0) ← (const byte) IRQ_RASTER#0 [ ] ( main:2 [ ] ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_ENABLE
//SEG15 [10] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq_bottom_1() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
//SEG15 [10] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq_bottom_1() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
lda #<irq_bottom_1
sta KERNEL_IRQ
lda #>irq_bottom_1
@ -498,60 +498,62 @@ main: {
}
//SEG19 irq_bottom_2
irq_bottom_2: {
//SEG20 [13] *((const byte*) FGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG20 interrupt KERNEL_KEYBOARD
//SEG21 [13] *((const byte*) FGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #WHITE
sta FGCOL
//SEG21 [14] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) | (const byte) VIC_RSEL#0 [ ] ( ) -- _deref_pbuc1=_deref_pbuc1_bor_vbuc2
//SEG22 [14] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) | (const byte) VIC_RSEL#0 [ ] ( ) -- _deref_pbuc1=_deref_pbuc1_bor_vbuc2
lda VIC_CONTROL
ora #VIC_RSEL
sta VIC_CONTROL
//SEG22 [15] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG23 [15] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_STATUS
//SEG23 [16] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 250 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG24 [16] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 250 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #$fa
sta RASTER
//SEG24 [17] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq_bottom_1() [ ] ( ) -- _deref_pptc1=pprc2
//SEG25 [17] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq_bottom_1() [ ] ( ) -- _deref_pptc1=pprc2
lda #<irq_bottom_1
sta KERNEL_IRQ
lda #>irq_bottom_1
sta KERNEL_IRQ+1
//SEG25 [18] *((const byte*) FGCOL#0) ← (const byte) RED#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG26 [18] *((const byte*) FGCOL#0) ← (const byte) RED#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #RED
sta FGCOL
jmp breturn
//SEG26 irq_bottom_2::@return
//SEG27 irq_bottom_2::@return
breturn:
//SEG27 [19] return [ ] ( )
jmp $ea81
//SEG28 [19] return [ ] ( )
jmp $ea31
}
//SEG28 irq_bottom_1
//SEG29 irq_bottom_1
irq_bottom_1: {
//SEG29 [20] *((const byte*) FGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG30 interrupt KERNEL_MIN
//SEG31 [20] *((const byte*) FGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #WHITE
sta FGCOL
//SEG30 [21] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) & (byte/word/signed word/dword/signed dword) 255^(const byte) VIC_RSEL#0 [ ] ( ) -- _deref_pbuc1=_deref_pbuc1_band_vbuc2
//SEG32 [21] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) & (byte/word/signed word/dword/signed dword) 255^(const byte) VIC_RSEL#0 [ ] ( ) -- _deref_pbuc1=_deref_pbuc1_band_vbuc2
lda VIC_CONTROL
and #$ff^VIC_RSEL
sta VIC_CONTROL
//SEG31 [22] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG33 [22] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_STATUS
//SEG32 [23] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 253 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG34 [23] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 253 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #$fd
sta RASTER
//SEG33 [24] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq_bottom_2() [ ] ( ) -- _deref_pptc1=pprc2
//SEG35 [24] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_KEYBOARD)(void()) irq_bottom_2() [ ] ( ) -- _deref_pptc1=pprc2
lda #<irq_bottom_2
sta KERNEL_IRQ
lda #>irq_bottom_2
sta KERNEL_IRQ+1
//SEG34 [25] *((const byte*) FGCOL#0) ← (const byte) RED#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG36 [25] *((const byte*) FGCOL#0) ← (const byte) RED#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #RED
sta FGCOL
jmp breturn
//SEG35 irq_bottom_1::@return
//SEG37 irq_bottom_1::@return
breturn:
//SEG36 [26] return [ ] ( )
//SEG38 [26] return [ ] ( )
jmp $ea81
}
@ -561,18 +563,18 @@ Statement [6] *((const byte*) CIA1_INTERRUPT#0) ← (const byte) CIA_INTERRUPT_C
Statement [7] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) & (byte/signed byte/word/signed word/dword/signed dword) 127 [ ] ( main:2 [ ] ) always clobbers reg byte a
Statement [8] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 250 [ ] ( main:2 [ ] ) always clobbers reg byte a
Statement [9] *((const byte*) IRQ_ENABLE#0) ← (const byte) IRQ_RASTER#0 [ ] ( main:2 [ ] ) always clobbers reg byte a
Statement [10] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq_bottom_1() [ ] ( main:2 [ ] ) always clobbers reg byte a
Statement [10] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq_bottom_1() [ ] ( main:2 [ ] ) always clobbers reg byte a
Statement [13] *((const byte*) FGCOL#0) ← (const byte) WHITE#0 [ ] ( ) always clobbers reg byte a
Statement [14] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) | (const byte) VIC_RSEL#0 [ ] ( ) always clobbers reg byte a
Statement [15] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) always clobbers reg byte a
Statement [16] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 250 [ ] ( ) always clobbers reg byte a
Statement [17] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq_bottom_1() [ ] ( ) always clobbers reg byte a
Statement [17] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq_bottom_1() [ ] ( ) always clobbers reg byte a
Statement [18] *((const byte*) FGCOL#0) ← (const byte) RED#0 [ ] ( ) always clobbers reg byte a
Statement [20] *((const byte*) FGCOL#0) ← (const byte) WHITE#0 [ ] ( ) always clobbers reg byte a
Statement [21] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) & (byte/word/signed word/dword/signed dword) 255^(const byte) VIC_RSEL#0 [ ] ( ) always clobbers reg byte a
Statement [22] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) always clobbers reg byte a
Statement [23] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 253 [ ] ( ) always clobbers reg byte a
Statement [24] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq_bottom_2() [ ] ( ) always clobbers reg byte a
Statement [24] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_KEYBOARD)(void()) irq_bottom_2() [ ] ( ) always clobbers reg byte a
Statement [25] *((const byte*) FGCOL#0) ← (const byte) RED#0 [ ] ( ) always clobbers reg byte a
REGISTER UPLIFT SCOPES
@ -639,7 +641,7 @@ main: {
//SEG14 [9] *((const byte*) IRQ_ENABLE#0) ← (const byte) IRQ_RASTER#0 [ ] ( main:2 [ ] ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_ENABLE
//SEG15 [10] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq_bottom_1() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
//SEG15 [10] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq_bottom_1() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
lda #<irq_bottom_1
sta KERNEL_IRQ
lda #>irq_bottom_1
@ -654,60 +656,62 @@ main: {
}
//SEG19 irq_bottom_2
irq_bottom_2: {
//SEG20 [13] *((const byte*) FGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG20 interrupt KERNEL_KEYBOARD
//SEG21 [13] *((const byte*) FGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #WHITE
sta FGCOL
//SEG21 [14] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) | (const byte) VIC_RSEL#0 [ ] ( ) -- _deref_pbuc1=_deref_pbuc1_bor_vbuc2
//SEG22 [14] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) | (const byte) VIC_RSEL#0 [ ] ( ) -- _deref_pbuc1=_deref_pbuc1_bor_vbuc2
lda VIC_CONTROL
ora #VIC_RSEL
sta VIC_CONTROL
//SEG22 [15] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG23 [15] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_STATUS
//SEG23 [16] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 250 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG24 [16] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 250 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #$fa
sta RASTER
//SEG24 [17] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq_bottom_1() [ ] ( ) -- _deref_pptc1=pprc2
//SEG25 [17] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq_bottom_1() [ ] ( ) -- _deref_pptc1=pprc2
lda #<irq_bottom_1
sta KERNEL_IRQ
lda #>irq_bottom_1
sta KERNEL_IRQ+1
//SEG25 [18] *((const byte*) FGCOL#0) ← (const byte) RED#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG26 [18] *((const byte*) FGCOL#0) ← (const byte) RED#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #RED
sta FGCOL
jmp breturn
//SEG26 irq_bottom_2::@return
//SEG27 irq_bottom_2::@return
breturn:
//SEG27 [19] return [ ] ( )
jmp $ea81
//SEG28 [19] return [ ] ( )
jmp $ea31
}
//SEG28 irq_bottom_1
//SEG29 irq_bottom_1
irq_bottom_1: {
//SEG29 [20] *((const byte*) FGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG30 interrupt KERNEL_MIN
//SEG31 [20] *((const byte*) FGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #WHITE
sta FGCOL
//SEG30 [21] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) & (byte/word/signed word/dword/signed dword) 255^(const byte) VIC_RSEL#0 [ ] ( ) -- _deref_pbuc1=_deref_pbuc1_band_vbuc2
//SEG32 [21] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) & (byte/word/signed word/dword/signed dword) 255^(const byte) VIC_RSEL#0 [ ] ( ) -- _deref_pbuc1=_deref_pbuc1_band_vbuc2
lda VIC_CONTROL
and #$ff^VIC_RSEL
sta VIC_CONTROL
//SEG31 [22] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG33 [22] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_STATUS
//SEG32 [23] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 253 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG34 [23] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 253 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #$fd
sta RASTER
//SEG33 [24] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq_bottom_2() [ ] ( ) -- _deref_pptc1=pprc2
//SEG35 [24] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_KEYBOARD)(void()) irq_bottom_2() [ ] ( ) -- _deref_pptc1=pprc2
lda #<irq_bottom_2
sta KERNEL_IRQ
lda #>irq_bottom_2
sta KERNEL_IRQ+1
//SEG34 [25] *((const byte*) FGCOL#0) ← (const byte) RED#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG36 [25] *((const byte*) FGCOL#0) ← (const byte) RED#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #RED
sta FGCOL
jmp breturn
//SEG35 irq_bottom_1::@return
//SEG37 irq_bottom_1::@return
breturn:
//SEG36 [26] return [ ] ( )
//SEG38 [26] return [ ] ( )
jmp $ea81
}
@ -759,9 +763,9 @@ FINAL SYMBOL TABLE
(const byte) VIC_RSEL#0 VIC_RSEL = (byte/signed byte/word/signed word/dword/signed dword) 8
(byte) WHITE
(const byte) WHITE#0 WHITE = (byte/signed byte/word/signed word/dword/signed dword) 1
interrupt(KERNEL)(void()) irq_bottom_1()
interrupt(KERNEL_MIN)(void()) irq_bottom_1()
(label) irq_bottom_1::@return
interrupt(KERNEL)(void()) irq_bottom_2()
interrupt(KERNEL_KEYBOARD)(void()) irq_bottom_2()
(label) irq_bottom_2::@return
(void()) main()
(label) main::@return
@ -816,7 +820,7 @@ main: {
//SEG14 [9] *((const byte*) IRQ_ENABLE#0) ← (const byte) IRQ_RASTER#0 [ ] ( main:2 [ ] ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_ENABLE
//SEG15 [10] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq_bottom_1() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
//SEG15 [10] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq_bottom_1() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
lda #<irq_bottom_1
sta KERNEL_IRQ
lda #>irq_bottom_1
@ -829,56 +833,58 @@ main: {
}
//SEG19 irq_bottom_2
irq_bottom_2: {
//SEG20 [13] *((const byte*) FGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG20 interrupt KERNEL_KEYBOARD
//SEG21 [13] *((const byte*) FGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #WHITE
sta FGCOL
//SEG21 [14] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) | (const byte) VIC_RSEL#0 [ ] ( ) -- _deref_pbuc1=_deref_pbuc1_bor_vbuc2
//SEG22 [14] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) | (const byte) VIC_RSEL#0 [ ] ( ) -- _deref_pbuc1=_deref_pbuc1_bor_vbuc2
lda VIC_CONTROL
ora #VIC_RSEL
sta VIC_CONTROL
//SEG22 [15] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG23 [15] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_STATUS
//SEG23 [16] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 250 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG24 [16] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 250 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #$fa
sta RASTER
//SEG24 [17] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq_bottom_1() [ ] ( ) -- _deref_pptc1=pprc2
//SEG25 [17] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq_bottom_1() [ ] ( ) -- _deref_pptc1=pprc2
lda #<irq_bottom_1
sta KERNEL_IRQ
lda #>irq_bottom_1
sta KERNEL_IRQ+1
//SEG25 [18] *((const byte*) FGCOL#0) ← (const byte) RED#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG26 [18] *((const byte*) FGCOL#0) ← (const byte) RED#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #RED
sta FGCOL
//SEG26 irq_bottom_2::@return
//SEG27 [19] return [ ] ( )
jmp $ea81
//SEG27 irq_bottom_2::@return
//SEG28 [19] return [ ] ( )
jmp $ea31
}
//SEG28 irq_bottom_1
//SEG29 irq_bottom_1
irq_bottom_1: {
//SEG29 [20] *((const byte*) FGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG30 interrupt KERNEL_MIN
//SEG31 [20] *((const byte*) FGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #WHITE
sta FGCOL
//SEG30 [21] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) & (byte/word/signed word/dword/signed dword) 255^(const byte) VIC_RSEL#0 [ ] ( ) -- _deref_pbuc1=_deref_pbuc1_band_vbuc2
//SEG32 [21] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) & (byte/word/signed word/dword/signed dword) 255^(const byte) VIC_RSEL#0 [ ] ( ) -- _deref_pbuc1=_deref_pbuc1_band_vbuc2
lda VIC_CONTROL
and #$ff^VIC_RSEL
sta VIC_CONTROL
//SEG31 [22] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG33 [22] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_STATUS
//SEG32 [23] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 253 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG34 [23] *((const byte*) RASTER#0) ← (byte/word/signed word/dword/signed dword) 253 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #$fd
sta RASTER
//SEG33 [24] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq_bottom_2() [ ] ( ) -- _deref_pptc1=pprc2
//SEG35 [24] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_KEYBOARD)(void()) irq_bottom_2() [ ] ( ) -- _deref_pptc1=pprc2
lda #<irq_bottom_2
sta KERNEL_IRQ
lda #>irq_bottom_2
sta KERNEL_IRQ+1
//SEG34 [25] *((const byte*) FGCOL#0) ← (const byte) RED#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG36 [25] *((const byte*) FGCOL#0) ← (const byte) RED#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #RED
sta FGCOL
//SEG35 irq_bottom_1::@return
//SEG36 [26] return [ ] ( )
//SEG37 irq_bottom_1::@return
//SEG38 [26] return [ ] ( )
jmp $ea81
}

View File

@ -27,9 +27,9 @@
(const byte) VIC_RSEL#0 VIC_RSEL = (byte/signed byte/word/signed word/dword/signed dword) 8
(byte) WHITE
(const byte) WHITE#0 WHITE = (byte/signed byte/word/signed word/dword/signed dword) 1
interrupt(KERNEL)(void()) irq_bottom_1()
interrupt(KERNEL_MIN)(void()) irq_bottom_1()
(label) irq_bottom_1::@return
interrupt(KERNEL)(void()) irq_bottom_2()
interrupt(KERNEL_KEYBOARD)(void()) irq_bottom_2()
(label) irq_bottom_2::@return
(void()) main()
(label) main::@return

View File

@ -13,7 +13,7 @@ main: scope:[main] from @2
[6] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) | (byte/word/signed word/dword/signed dword) 128 [ ] ( main:2 [ ] )
[7] *((const byte*) RASTER#0) ← (byte/signed byte/word/signed word/dword/signed dword) 0 [ ] ( main:2 [ ] )
[8] *((const byte*) IRQ_ENABLE#0) ← (const byte) IRQ_RASTER#0 [ ] ( main:2 [ ] )
[9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_STD)(void()) irq() [ ] ( main:2 [ ] )
[9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_KEYBOARD)(void()) irq() [ ] ( main:2 [ ] )
asm { cli }
to:main::@return
main::@return: scope:[main] from main

View File

@ -32,13 +32,13 @@ void main() {
}
// Interrupt Routine
interrupt(kernel std) void irq() {
interrupt(kernel_keyboard) void irq() {
*BGCOL = WHITE;
*BGCOL = BLACK;
// Acknowledge the IRQ
*IRQ_STATUS = IRQ_RASTER;
}
Resolved forward reference irq to interrupt(KERNEL_STD)(void()) irq()
Resolved forward reference irq to interrupt(KERNEL_KEYBOARD)(void()) irq()
SYMBOLS
(label) @1
(label) @2
@ -58,7 +58,7 @@ SYMBOLS
(byte*) RASTER
(byte*) VIC_CONTROL
(byte) WHITE
interrupt(KERNEL_STD)(void()) irq()
interrupt(KERNEL_KEYBOARD)(void()) irq()
(label) irq::@return
(void()) main()
(void()*~) main::$0
@ -94,7 +94,7 @@ main: scope:[main] from
*((byte*) VIC_CONTROL) ← *((byte*) VIC_CONTROL) | (byte/word/signed word/dword/signed dword) 128
*((byte*) RASTER) ← (byte/signed byte/word/signed word/dword/signed dword) 0
*((byte*) IRQ_ENABLE) ← (byte) IRQ_RASTER
(void()*~) main::$0 ← & interrupt(KERNEL_STD)(void()) irq()
(void()*~) main::$0 ← & interrupt(KERNEL_KEYBOARD)(void()) irq()
*((void()**) KERNEL_IRQ) ← (void()*~) main::$0
asm { cli }
to:main::@return
@ -144,7 +144,7 @@ main: scope:[main] from @2
*((byte*) VIC_CONTROL#0) ← *((byte*) VIC_CONTROL#0) | (byte/word/signed word/dword/signed dword) 128
*((byte*) RASTER#0) ← (byte/signed byte/word/signed word/dword/signed dword) 0
*((byte*) IRQ_ENABLE#0) ← (byte) IRQ_RASTER#0
(void()*~) main::$0 ← & interrupt(KERNEL_STD)(void()) irq()
(void()*~) main::$0 ← & interrupt(KERNEL_KEYBOARD)(void()) irq()
*((void()**) KERNEL_IRQ#0) ← (void()*~) main::$0
asm { cli }
to:main::@return
@ -193,7 +193,7 @@ SYMBOL TABLE SSA
(byte*) VIC_CONTROL#0
(byte) WHITE
(byte) WHITE#0
interrupt(KERNEL_STD)(void()) irq()
interrupt(KERNEL_KEYBOARD)(void()) irq()
(label) irq::@return
(void()) main()
(void()*~) main::$0
@ -216,7 +216,7 @@ Constant (const byte) CIA_INTERRUPT_CLEAR#0 = 127
Constant (const void()*) main::$0 = &irq
Succesful SSA optimization Pass2ConstantIdentification
OPTIMIZING CONTROL FLOW GRAPH
Constant inlined main::$0 = &interrupt(KERNEL_STD)(void()) irq()
Constant inlined main::$0 = &interrupt(KERNEL_KEYBOARD)(void()) irq()
Succesful SSA optimization Pass2ConstantInlining
Block Sequence Planned @begin @2 @end main main::@return irq irq::@return
Block Sequence Planned @begin @2 @end main main::@return irq irq::@return
@ -251,7 +251,7 @@ main: scope:[main] from @2
[6] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) | (byte/word/signed word/dword/signed dword) 128 [ ] ( main:2 [ ] )
[7] *((const byte*) RASTER#0) ← (byte/signed byte/word/signed word/dword/signed dword) 0 [ ] ( main:2 [ ] )
[8] *((const byte*) IRQ_ENABLE#0) ← (const byte) IRQ_RASTER#0 [ ] ( main:2 [ ] )
[9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_STD)(void()) irq() [ ] ( main:2 [ ] )
[9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_KEYBOARD)(void()) irq() [ ] ( main:2 [ ] )
asm { cli }
to:main::@return
main::@return: scope:[main] from main
@ -300,7 +300,7 @@ VARIABLE REGISTER WEIGHTS
(byte*) RASTER
(byte*) VIC_CONTROL
(byte) WHITE
interrupt(KERNEL_STD)(void()) irq()
interrupt(KERNEL_KEYBOARD)(void()) irq()
(void()) main()
Initial phi equivalence classes
@ -354,7 +354,7 @@ main: {
//SEG13 [8] *((const byte*) IRQ_ENABLE#0) ← (const byte) IRQ_RASTER#0 [ ] ( main:2 [ ] ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_ENABLE
//SEG14 [9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_STD)(void()) irq() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
//SEG14 [9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_KEYBOARD)(void()) irq() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
lda #<irq
sta KERNEL_IRQ
lda #>irq
@ -369,19 +369,20 @@ main: {
}
//SEG18 irq
irq: {
//SEG19 [12] *((const byte*) BGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG19 interrupt KERNEL_KEYBOARD
//SEG20 [12] *((const byte*) BGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #WHITE
sta BGCOL
//SEG20 [13] *((const byte*) BGCOL#0) ← (const byte) BLACK#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG21 [13] *((const byte*) BGCOL#0) ← (const byte) BLACK#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #BLACK
sta BGCOL
//SEG21 [14] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG22 [14] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_STATUS
jmp breturn
//SEG22 irq::@return
//SEG23 irq::@return
breturn:
//SEG23 [15] return [ ] ( )
//SEG24 [15] return [ ] ( )
jmp $ea31
}
@ -390,7 +391,7 @@ Statement [5] *((const byte*) CIA1_INTERRUPT#0) ← (const byte) CIA_INTERRUPT_C
Statement [6] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) | (byte/word/signed word/dword/signed dword) 128 [ ] ( main:2 [ ] ) always clobbers reg byte a
Statement [7] *((const byte*) RASTER#0) ← (byte/signed byte/word/signed word/dword/signed dword) 0 [ ] ( main:2 [ ] ) always clobbers reg byte a
Statement [8] *((const byte*) IRQ_ENABLE#0) ← (const byte) IRQ_RASTER#0 [ ] ( main:2 [ ] ) always clobbers reg byte a
Statement [9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_STD)(void()) irq() [ ] ( main:2 [ ] ) always clobbers reg byte a
Statement [9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_KEYBOARD)(void()) irq() [ ] ( main:2 [ ] ) always clobbers reg byte a
Statement [12] *((const byte*) BGCOL#0) ← (const byte) WHITE#0 [ ] ( ) always clobbers reg byte a
Statement [13] *((const byte*) BGCOL#0) ← (const byte) BLACK#0 [ ] ( ) always clobbers reg byte a
Statement [14] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) always clobbers reg byte a
@ -452,7 +453,7 @@ main: {
//SEG13 [8] *((const byte*) IRQ_ENABLE#0) ← (const byte) IRQ_RASTER#0 [ ] ( main:2 [ ] ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_ENABLE
//SEG14 [9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_STD)(void()) irq() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
//SEG14 [9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_KEYBOARD)(void()) irq() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
lda #<irq
sta KERNEL_IRQ
lda #>irq
@ -467,19 +468,20 @@ main: {
}
//SEG18 irq
irq: {
//SEG19 [12] *((const byte*) BGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG19 interrupt KERNEL_KEYBOARD
//SEG20 [12] *((const byte*) BGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #WHITE
sta BGCOL
//SEG20 [13] *((const byte*) BGCOL#0) ← (const byte) BLACK#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG21 [13] *((const byte*) BGCOL#0) ← (const byte) BLACK#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #BLACK
sta BGCOL
//SEG21 [14] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG22 [14] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_STATUS
jmp breturn
//SEG22 irq::@return
//SEG23 irq::@return
breturn:
//SEG23 [15] return [ ] ( )
//SEG24 [15] return [ ] ( )
jmp $ea31
}
@ -525,7 +527,7 @@ FINAL SYMBOL TABLE
(const byte*) VIC_CONTROL#0 VIC_CONTROL = ((byte*))(word/dword/signed dword) 53265
(byte) WHITE
(const byte) WHITE#0 WHITE = (byte/signed byte/word/signed word/dword/signed dword) 1
interrupt(KERNEL_STD)(void()) irq()
interrupt(KERNEL_KEYBOARD)(void()) irq()
(label) irq::@return
(void()) main()
(label) main::@return
@ -575,7 +577,7 @@ main: {
//SEG13 [8] *((const byte*) IRQ_ENABLE#0) ← (const byte) IRQ_RASTER#0 [ ] ( main:2 [ ] ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_ENABLE
//SEG14 [9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_STD)(void()) irq() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
//SEG14 [9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_KEYBOARD)(void()) irq() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
lda #<irq
sta KERNEL_IRQ
lda #>irq
@ -588,17 +590,18 @@ main: {
}
//SEG18 irq
irq: {
//SEG19 [12] *((const byte*) BGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG19 interrupt KERNEL_KEYBOARD
//SEG20 [12] *((const byte*) BGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #WHITE
sta BGCOL
//SEG20 [13] *((const byte*) BGCOL#0) ← (const byte) BLACK#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG21 [13] *((const byte*) BGCOL#0) ← (const byte) BLACK#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #BLACK
sta BGCOL
//SEG21 [14] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG22 [14] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_STATUS
//SEG22 irq::@return
//SEG23 [15] return [ ] ( )
//SEG23 irq::@return
//SEG24 [15] return [ ] ( )
jmp $ea31
}

View File

@ -23,7 +23,7 @@
(const byte*) VIC_CONTROL#0 VIC_CONTROL = ((byte*))(word/dword/signed dword) 53265
(byte) WHITE
(const byte) WHITE#0 WHITE = (byte/signed byte/word/signed word/dword/signed dword) 1
interrupt(KERNEL_STD)(void()) irq()
interrupt(KERNEL_KEYBOARD)(void()) irq()
(label) irq::@return
(void()) main()
(label) main::@return

View File

@ -13,7 +13,7 @@ main: scope:[main] from @2
[6] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) | (byte/word/signed word/dword/signed dword) 128 [ ] ( main:2 [ ] )
[7] *((const byte*) RASTER#0) ← (byte/signed byte/word/signed word/dword/signed dword) 0 [ ] ( main:2 [ ] )
[8] *((const byte*) IRQ_ENABLE#0) ← (const byte) IRQ_RASTER#0 [ ] ( main:2 [ ] )
[9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq() [ ] ( main:2 [ ] )
[9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq() [ ] ( main:2 [ ] )
asm { cli }
to:main::@return
main::@return: scope:[main] from main

View File

@ -38,7 +38,7 @@ interrupt void irq() {
// Acknowledge the IRQ
*IRQ_STATUS = IRQ_RASTER;
}
Resolved forward reference irq to interrupt(KERNEL)(void()) irq()
Resolved forward reference irq to interrupt(KERNEL_MIN)(void()) irq()
SYMBOLS
(label) @1
(label) @2
@ -58,7 +58,7 @@ SYMBOLS
(byte*) RASTER
(byte*) VIC_CONTROL
(byte) WHITE
interrupt(KERNEL)(void()) irq()
interrupt(KERNEL_MIN)(void()) irq()
(label) irq::@return
(void()) main()
(void()*~) main::$0
@ -94,7 +94,7 @@ main: scope:[main] from
*((byte*) VIC_CONTROL) ← *((byte*) VIC_CONTROL) | (byte/word/signed word/dword/signed dword) 128
*((byte*) RASTER) ← (byte/signed byte/word/signed word/dword/signed dword) 0
*((byte*) IRQ_ENABLE) ← (byte) IRQ_RASTER
(void()*~) main::$0 ← & interrupt(KERNEL)(void()) irq()
(void()*~) main::$0 ← & interrupt(KERNEL_MIN)(void()) irq()
*((void()**) KERNEL_IRQ) ← (void()*~) main::$0
asm { cli }
to:main::@return
@ -144,7 +144,7 @@ main: scope:[main] from @2
*((byte*) VIC_CONTROL#0) ← *((byte*) VIC_CONTROL#0) | (byte/word/signed word/dword/signed dword) 128
*((byte*) RASTER#0) ← (byte/signed byte/word/signed word/dword/signed dword) 0
*((byte*) IRQ_ENABLE#0) ← (byte) IRQ_RASTER#0
(void()*~) main::$0 ← & interrupt(KERNEL)(void()) irq()
(void()*~) main::$0 ← & interrupt(KERNEL_MIN)(void()) irq()
*((void()**) KERNEL_IRQ#0) ← (void()*~) main::$0
asm { cli }
to:main::@return
@ -193,7 +193,7 @@ SYMBOL TABLE SSA
(byte*) VIC_CONTROL#0
(byte) WHITE
(byte) WHITE#0
interrupt(KERNEL)(void()) irq()
interrupt(KERNEL_MIN)(void()) irq()
(label) irq::@return
(void()) main()
(void()*~) main::$0
@ -216,7 +216,7 @@ Constant (const byte) CIA_INTERRUPT_CLEAR#0 = 127
Constant (const void()*) main::$0 = &irq
Succesful SSA optimization Pass2ConstantIdentification
OPTIMIZING CONTROL FLOW GRAPH
Constant inlined main::$0 = &interrupt(KERNEL)(void()) irq()
Constant inlined main::$0 = &interrupt(KERNEL_MIN)(void()) irq()
Succesful SSA optimization Pass2ConstantInlining
Block Sequence Planned @begin @2 @end main main::@return irq irq::@return
Block Sequence Planned @begin @2 @end main main::@return irq irq::@return
@ -251,7 +251,7 @@ main: scope:[main] from @2
[6] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) | (byte/word/signed word/dword/signed dword) 128 [ ] ( main:2 [ ] )
[7] *((const byte*) RASTER#0) ← (byte/signed byte/word/signed word/dword/signed dword) 0 [ ] ( main:2 [ ] )
[8] *((const byte*) IRQ_ENABLE#0) ← (const byte) IRQ_RASTER#0 [ ] ( main:2 [ ] )
[9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq() [ ] ( main:2 [ ] )
[9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq() [ ] ( main:2 [ ] )
asm { cli }
to:main::@return
main::@return: scope:[main] from main
@ -300,7 +300,7 @@ VARIABLE REGISTER WEIGHTS
(byte*) RASTER
(byte*) VIC_CONTROL
(byte) WHITE
interrupt(KERNEL)(void()) irq()
interrupt(KERNEL_MIN)(void()) irq()
(void()) main()
Initial phi equivalence classes
@ -354,7 +354,7 @@ main: {
//SEG13 [8] *((const byte*) IRQ_ENABLE#0) ← (const byte) IRQ_RASTER#0 [ ] ( main:2 [ ] ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_ENABLE
//SEG14 [9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
//SEG14 [9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
lda #<irq
sta KERNEL_IRQ
lda #>irq
@ -369,19 +369,20 @@ main: {
}
//SEG18 irq
irq: {
//SEG19 [12] *((const byte*) BGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG19 interrupt KERNEL_MIN
//SEG20 [12] *((const byte*) BGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #WHITE
sta BGCOL
//SEG20 [13] *((const byte*) BGCOL#0) ← (const byte) BLACK#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG21 [13] *((const byte*) BGCOL#0) ← (const byte) BLACK#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #BLACK
sta BGCOL
//SEG21 [14] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG22 [14] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_STATUS
jmp breturn
//SEG22 irq::@return
//SEG23 irq::@return
breturn:
//SEG23 [15] return [ ] ( )
//SEG24 [15] return [ ] ( )
jmp $ea81
}
@ -390,7 +391,7 @@ Statement [5] *((const byte*) CIA1_INTERRUPT#0) ← (const byte) CIA_INTERRUPT_C
Statement [6] *((const byte*) VIC_CONTROL#0) ← *((const byte*) VIC_CONTROL#0) | (byte/word/signed word/dword/signed dword) 128 [ ] ( main:2 [ ] ) always clobbers reg byte a
Statement [7] *((const byte*) RASTER#0) ← (byte/signed byte/word/signed word/dword/signed dword) 0 [ ] ( main:2 [ ] ) always clobbers reg byte a
Statement [8] *((const byte*) IRQ_ENABLE#0) ← (const byte) IRQ_RASTER#0 [ ] ( main:2 [ ] ) always clobbers reg byte a
Statement [9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq() [ ] ( main:2 [ ] ) always clobbers reg byte a
Statement [9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq() [ ] ( main:2 [ ] ) always clobbers reg byte a
Statement [12] *((const byte*) BGCOL#0) ← (const byte) WHITE#0 [ ] ( ) always clobbers reg byte a
Statement [13] *((const byte*) BGCOL#0) ← (const byte) BLACK#0 [ ] ( ) always clobbers reg byte a
Statement [14] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) always clobbers reg byte a
@ -452,7 +453,7 @@ main: {
//SEG13 [8] *((const byte*) IRQ_ENABLE#0) ← (const byte) IRQ_RASTER#0 [ ] ( main:2 [ ] ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_ENABLE
//SEG14 [9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
//SEG14 [9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
lda #<irq
sta KERNEL_IRQ
lda #>irq
@ -467,19 +468,20 @@ main: {
}
//SEG18 irq
irq: {
//SEG19 [12] *((const byte*) BGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG19 interrupt KERNEL_MIN
//SEG20 [12] *((const byte*) BGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #WHITE
sta BGCOL
//SEG20 [13] *((const byte*) BGCOL#0) ← (const byte) BLACK#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG21 [13] *((const byte*) BGCOL#0) ← (const byte) BLACK#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #BLACK
sta BGCOL
//SEG21 [14] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG22 [14] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_STATUS
jmp breturn
//SEG22 irq::@return
//SEG23 irq::@return
breturn:
//SEG23 [15] return [ ] ( )
//SEG24 [15] return [ ] ( )
jmp $ea81
}
@ -525,7 +527,7 @@ FINAL SYMBOL TABLE
(const byte*) VIC_CONTROL#0 VIC_CONTROL = ((byte*))(word/dword/signed dword) 53265
(byte) WHITE
(const byte) WHITE#0 WHITE = (byte/signed byte/word/signed word/dword/signed dword) 1
interrupt(KERNEL)(void()) irq()
interrupt(KERNEL_MIN)(void()) irq()
(label) irq::@return
(void()) main()
(label) main::@return
@ -575,7 +577,7 @@ main: {
//SEG13 [8] *((const byte*) IRQ_ENABLE#0) ← (const byte) IRQ_RASTER#0 [ ] ( main:2 [ ] ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_ENABLE
//SEG14 [9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
//SEG14 [9] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
lda #<irq
sta KERNEL_IRQ
lda #>irq
@ -588,17 +590,18 @@ main: {
}
//SEG18 irq
irq: {
//SEG19 [12] *((const byte*) BGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG19 interrupt KERNEL_MIN
//SEG20 [12] *((const byte*) BGCOL#0) ← (const byte) WHITE#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #WHITE
sta BGCOL
//SEG20 [13] *((const byte*) BGCOL#0) ← (const byte) BLACK#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG21 [13] *((const byte*) BGCOL#0) ← (const byte) BLACK#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #BLACK
sta BGCOL
//SEG21 [14] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
//SEG22 [14] *((const byte*) IRQ_STATUS#0) ← (const byte) IRQ_RASTER#0 [ ] ( ) -- _deref_pbuc1=vbuc2
lda #IRQ_RASTER
sta IRQ_STATUS
//SEG22 irq::@return
//SEG23 [15] return [ ] ( )
//SEG23 irq::@return
//SEG24 [15] return [ ] ( )
jmp $ea81
}

View File

@ -23,7 +23,7 @@
(const byte*) VIC_CONTROL#0 VIC_CONTROL = ((byte*))(word/dword/signed dword) 53265
(byte) WHITE
(const byte) WHITE#0 WHITE = (byte/signed byte/word/signed word/dword/signed dword) 1
interrupt(KERNEL)(void()) irq()
interrupt(KERNEL_MIN)(void()) irq()
(label) irq::@return
(void()) main()
(label) main::@return

View File

@ -8,7 +8,7 @@
@end: scope:[] from @2
[3] phi() [ ] ( )
main: scope:[main] from @2
[4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq() [ col#0 ] ( main:2 [ col#0 ] )
[4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq() [ col#0 ] ( main:2 [ col#0 ] )
to:main::@1
main::@1: scope:[main] from main main::@2
[5] (byte) col#2 ← phi( main/(byte) col#0 main::@2/(byte) col#1 ) [ col#2 ] ( main:2 [ col#2 ] )

View File

@ -10,7 +10,7 @@ void main() {
}
}
interrupt(kernel) void irq() {
interrupt(kernel_min) void irq() {
asm {
lda $dc0d
}
@ -18,7 +18,7 @@ interrupt(kernel) void irq() {
}
Adding pre/post-modifier (byte) col ← ++ (byte) col
Resolved forward reference irq to interrupt(KERNEL)(void()) irq()
Resolved forward reference irq to interrupt(KERNEL_MIN)(void()) irq()
SYMBOLS
(label) @1
(label) @2
@ -27,7 +27,7 @@ SYMBOLS
(byte*) BGCOL
(void()**) KERNEL_IRQ
(byte) col
interrupt(KERNEL)(void()) irq()
interrupt(KERNEL_MIN)(void()) irq()
(label) irq::@return
(void()) main()
(void()*~) main::$0
@ -48,7 +48,7 @@ INITIAL CONTROL FLOW GRAPH
(byte) col ← (byte/signed byte/word/signed word/dword/signed dword) 0
to:@1
main: scope:[main] from
(void()*~) main::$0 ← & interrupt(KERNEL)(void()) irq()
(void()*~) main::$0 ← & interrupt(KERNEL_MIN)(void()) irq()
*((void()**) KERNEL_IRQ) ← (void()*~) main::$0
to:main::@1
main::@1: scope:[main] from main main::@2
@ -102,7 +102,7 @@ CONTROL FLOW GRAPH SSA WITH ASSIGNMENT CALL & RETURN
to:@2
main: scope:[main] from @2
(byte) col#10 ← phi( @2/(byte) col#9 )
(void()*~) main::$0 ← & interrupt(KERNEL)(void()) irq()
(void()*~) main::$0 ← & interrupt(KERNEL_MIN)(void()) irq()
*((void()**) KERNEL_IRQ#0) ← (void()*~) main::$0
to:main::@1
main::@1: scope:[main] from main main::@2
@ -157,7 +157,7 @@ SYMBOL TABLE SSA
(byte) col#7
(byte) col#8
(byte) col#9
interrupt(KERNEL)(void()) irq()
interrupt(KERNEL_MIN)(void()) irq()
(label) irq::@return
(void()) main()
(void()*~) main::$0
@ -193,7 +193,7 @@ Succesful SSA optimization Pass2CullEmptyBlocks
Not aliassing across scopes: col#2 col#0
Not aliassing across scopes: col#2 col#0
OPTIMIZING CONTROL FLOW GRAPH
Constant inlined main::$0 = &interrupt(KERNEL)(void()) irq()
Constant inlined main::$0 = &interrupt(KERNEL_MIN)(void()) irq()
Succesful SSA optimization Pass2ConstantInlining
Block Sequence Planned @begin @2 @end main main::@1 main::@2 irq irq::@return
Block Sequence Planned @begin @2 @end main main::@1 main::@2 irq irq::@return
@ -229,7 +229,7 @@ FINAL CONTROL FLOW GRAPH
@end: scope:[] from @2
[3] phi() [ ] ( )
main: scope:[main] from @2
[4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq() [ col#0 ] ( main:2 [ col#0 ] )
[4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq() [ col#0 ] ( main:2 [ col#0 ] )
to:main::@1
main::@1: scope:[main] from main main::@2
[5] (byte) col#2 ← phi( main/(byte) col#0 main::@2/(byte) col#1 ) [ col#2 ] ( main:2 [ col#2 ] )
@ -280,7 +280,7 @@ VARIABLE REGISTER WEIGHTS
(byte) col#0 3.75
(byte) col#1 22.0
(byte) col#2 24.0
interrupt(KERNEL)(void()) irq()
interrupt(KERNEL_MIN)(void()) irq()
(void()) main()
Initial phi equivalence classes
@ -317,7 +317,7 @@ bend_from_b2:
bend:
//SEG9 main
main: {
//SEG10 [4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq() [ col#0 ] ( main:2 [ col#0 ] ) -- _deref_pptc1=pprc2
//SEG10 [4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq() [ col#0 ] ( main:2 [ col#0 ] ) -- _deref_pptc1=pprc2
lda #<irq
sta KERNEL_IRQ
lda #>irq
@ -338,21 +338,22 @@ main: {
}
//SEG16 irq
irq: {
//SEG17 asm { lda$dc0d }
//SEG17 interrupt KERNEL_MIN
//SEG18 asm { lda$dc0d }
lda $dc0d
//SEG18 [8] *((const byte*) BGCOL#0) ← (byte) col#0 [ ] ( ) -- _deref_pbuc1=vbuz1
//SEG19 [8] *((const byte*) BGCOL#0) ← (byte) col#0 [ ] ( ) -- _deref_pbuc1=vbuz1
lda col
sta BGCOL
jmp breturn
//SEG19 irq::@return
//SEG20 irq::@return
breturn:
//SEG20 [9] return [ ] ( )
//SEG21 [9] return [ ] ( )
jmp $ea81
}
REGISTER UPLIFT POTENTIAL REGISTERS
Statement [0] (byte) col#0 ← (byte/signed byte/word/signed word/dword/signed dword) 0 [ col#0 ] ( ) always clobbers reg byte a
Statement [4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq() [ col#0 ] ( main:2 [ col#0 ] ) always clobbers reg byte a
Statement [4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq() [ col#0 ] ( main:2 [ col#0 ] ) always clobbers reg byte a
Statement asm { lda$dc0d } always clobbers reg byte a
Statement [8] *((const byte*) BGCOL#0) ← (byte) col#0 [ ] ( ) always clobbers reg byte a
Potential registers zp ZP_BYTE:2 [ col#2 col#0 col#1 ] : zp ZP_BYTE:2 ,
@ -396,7 +397,7 @@ bend_from_b2:
bend:
//SEG9 main
main: {
//SEG10 [4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq() [ col#0 ] ( main:2 [ col#0 ] ) -- _deref_pptc1=pprc2
//SEG10 [4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq() [ col#0 ] ( main:2 [ col#0 ] ) -- _deref_pptc1=pprc2
lda #<irq
sta KERNEL_IRQ
lda #>irq
@ -417,15 +418,16 @@ main: {
}
//SEG16 irq
irq: {
//SEG17 asm { lda$dc0d }
//SEG17 interrupt KERNEL_MIN
//SEG18 asm { lda$dc0d }
lda $dc0d
//SEG18 [8] *((const byte*) BGCOL#0) ← (byte) col#0 [ ] ( ) -- _deref_pbuc1=vbuz1
//SEG19 [8] *((const byte*) BGCOL#0) ← (byte) col#0 [ ] ( ) -- _deref_pbuc1=vbuz1
lda col
sta BGCOL
jmp breturn
//SEG19 irq::@return
//SEG20 irq::@return
breturn:
//SEG20 [9] return [ ] ( )
//SEG21 [9] return [ ] ( )
jmp $ea81
}
@ -461,7 +463,7 @@ FINAL SYMBOL TABLE
(byte) col#0 col zp ZP_BYTE:2 3.75
(byte) col#1 col zp ZP_BYTE:2 22.0
(byte) col#2 col zp ZP_BYTE:2 24.0
interrupt(KERNEL)(void()) irq()
interrupt(KERNEL_MIN)(void()) irq()
(label) irq::@return
(void()) main()
(label) main::@1
@ -493,7 +495,7 @@ Score: 216
//SEG8 @end
//SEG9 main
main: {
//SEG10 [4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq() [ col#0 ] ( main:2 [ col#0 ] ) -- _deref_pptc1=pprc2
//SEG10 [4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq() [ col#0 ] ( main:2 [ col#0 ] ) -- _deref_pptc1=pprc2
lda #<irq
sta KERNEL_IRQ
lda #>irq
@ -509,13 +511,14 @@ main: {
}
//SEG16 irq
irq: {
//SEG17 asm { lda$dc0d }
//SEG17 interrupt KERNEL_MIN
//SEG18 asm { lda$dc0d }
lda $dc0d
//SEG18 [8] *((const byte*) BGCOL#0) ← (byte) col#0 [ ] ( ) -- _deref_pbuc1=vbuz1
//SEG19 [8] *((const byte*) BGCOL#0) ← (byte) col#0 [ ] ( ) -- _deref_pbuc1=vbuz1
lda col
sta BGCOL
//SEG19 irq::@return
//SEG20 [9] return [ ] ( )
//SEG20 irq::@return
//SEG21 [9] return [ ] ( )
jmp $ea81
}

View File

@ -9,7 +9,7 @@
(byte) col#0 col zp ZP_BYTE:2 3.75
(byte) col#1 col zp ZP_BYTE:2 22.0
(byte) col#2 col zp ZP_BYTE:2 24.0
interrupt(KERNEL)(void()) irq()
interrupt(KERNEL_MIN)(void()) irq()
(label) irq::@return
(void()) main()
(label) main::@1

View File

@ -8,7 +8,7 @@
@end: scope:[] from @2
[3] phi() [ ] ( )
main: scope:[main] from @2
[4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq() [ ] ( main:2 [ ] )
[4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq() [ ] ( main:2 [ ] )
to:main::@2
main::@2: scope:[main] from main main::@2
[5] *((const byte*) FGCOL#0) ← ++ *((const byte*) FGCOL#0) [ ] ( main:2 [ ] )

View File

@ -10,7 +10,7 @@ void main() {
}
}
interrupt(kernel) void irq() {
interrupt(kernel_min) void irq() {
(*BGCOL)++;
asm {
lda $dc0d
@ -19,7 +19,7 @@ interrupt(kernel) void irq() {
Adding pre/post-modifier *((byte*) FGCOL) ← ++ *((byte*) FGCOL)
Adding pre/post-modifier *((byte*) BGCOL) ← ++ *((byte*) BGCOL)
Resolved forward reference irq to interrupt(KERNEL)(void()) irq()
Resolved forward reference irq to interrupt(KERNEL_MIN)(void()) irq()
SYMBOLS
(label) @1
(label) @2
@ -28,7 +28,7 @@ SYMBOLS
(byte*) BGCOL
(byte*) FGCOL
(void()**) KERNEL_IRQ
interrupt(KERNEL)(void()) irq()
interrupt(KERNEL_MIN)(void()) irq()
(label) irq::@return
(void()) main()
(void()*~) main::$0
@ -50,7 +50,7 @@ INITIAL CONTROL FLOW GRAPH
(byte*) FGCOL ← ((byte*)) (word/dword/signed dword) 53281
to:@1
main: scope:[main] from
(void()*~) main::$0 ← & interrupt(KERNEL)(void()) irq()
(void()*~) main::$0 ← & interrupt(KERNEL_MIN)(void()) irq()
*((void()**) KERNEL_IRQ) ← (void()*~) main::$0
to:main::@1
main::@1: scope:[main] from main main::@2
@ -100,7 +100,7 @@ CONTROL FLOW GRAPH SSA WITH ASSIGNMENT CALL & RETURN
(byte*) FGCOL#0 ← ((byte*)) (word/dword/signed dword) 53281
to:@2
main: scope:[main] from @2
(void()*~) main::$0 ← & interrupt(KERNEL)(void()) irq()
(void()*~) main::$0 ← & interrupt(KERNEL_MIN)(void()) irq()
*((void()**) KERNEL_IRQ#0) ← (void()*~) main::$0
to:main::@1
main::@1: scope:[main] from main main::@2
@ -137,7 +137,7 @@ SYMBOL TABLE SSA
(byte*) FGCOL#0
(void()**) KERNEL_IRQ
(void()**) KERNEL_IRQ#0
interrupt(KERNEL)(void()) irq()
interrupt(KERNEL_MIN)(void()) irq()
(label) irq::@return
(void()) main()
(void()*~) main::$0
@ -160,7 +160,7 @@ Succesful SSA optimization Pass2EliminateUnusedBlocks
Culled Empty Block (label) main::@1
Succesful SSA optimization Pass2CullEmptyBlocks
OPTIMIZING CONTROL FLOW GRAPH
Constant inlined main::$0 = &interrupt(KERNEL)(void()) irq()
Constant inlined main::$0 = &interrupt(KERNEL_MIN)(void()) irq()
Succesful SSA optimization Pass2ConstantInlining
Block Sequence Planned @begin @2 @end main main::@2 irq irq::@return
Block Sequence Planned @begin @2 @end main main::@2 irq irq::@return
@ -190,7 +190,7 @@ FINAL CONTROL FLOW GRAPH
@end: scope:[] from @2
[3] phi() [ ] ( )
main: scope:[main] from @2
[4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq() [ ] ( main:2 [ ] )
[4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq() [ ] ( main:2 [ ] )
to:main::@2
main::@2: scope:[main] from main main::@2
[5] *((const byte*) FGCOL#0) ← ++ *((const byte*) FGCOL#0) [ ] ( main:2 [ ] )
@ -234,7 +234,7 @@ VARIABLE REGISTER WEIGHTS
(byte*) BGCOL
(byte*) FGCOL
(void()**) KERNEL_IRQ
interrupt(KERNEL)(void()) irq()
interrupt(KERNEL_MIN)(void()) irq()
(void()) main()
Initial phi equivalence classes
@ -265,7 +265,7 @@ bend_from_b2:
bend:
//SEG8 main
main: {
//SEG9 [4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
//SEG9 [4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
lda #<irq
sta KERNEL_IRQ
lda #>irq
@ -279,19 +279,20 @@ main: {
}
//SEG12 irq
irq: {
//SEG13 [6] *((const byte*) BGCOL#0) ← ++ *((const byte*) BGCOL#0) [ ] ( ) -- _deref_pbuc1=_inc__deref_pbuc1
//SEG13 interrupt KERNEL_MIN
//SEG14 [6] *((const byte*) BGCOL#0) ← ++ *((const byte*) BGCOL#0) [ ] ( ) -- _deref_pbuc1=_inc__deref_pbuc1
inc BGCOL
//SEG14 asm { lda$dc0d }
//SEG15 asm { lda$dc0d }
lda $dc0d
jmp breturn
//SEG15 irq::@return
//SEG16 irq::@return
breturn:
//SEG16 [8] return [ ] ( )
//SEG17 [8] return [ ] ( )
jmp $ea81
}
REGISTER UPLIFT POTENTIAL REGISTERS
Statement [4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq() [ ] ( main:2 [ ] ) always clobbers reg byte a
Statement [4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq() [ ] ( main:2 [ ] ) always clobbers reg byte a
Statement asm { lda$dc0d } always clobbers reg byte a
REGISTER UPLIFT SCOPES
@ -328,7 +329,7 @@ bend_from_b2:
bend:
//SEG8 main
main: {
//SEG9 [4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
//SEG9 [4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
lda #<irq
sta KERNEL_IRQ
lda #>irq
@ -342,14 +343,15 @@ main: {
}
//SEG12 irq
irq: {
//SEG13 [6] *((const byte*) BGCOL#0) ← ++ *((const byte*) BGCOL#0) [ ] ( ) -- _deref_pbuc1=_inc__deref_pbuc1
//SEG13 interrupt KERNEL_MIN
//SEG14 [6] *((const byte*) BGCOL#0) ← ++ *((const byte*) BGCOL#0) [ ] ( ) -- _deref_pbuc1=_inc__deref_pbuc1
inc BGCOL
//SEG14 asm { lda$dc0d }
//SEG15 asm { lda$dc0d }
lda $dc0d
jmp breturn
//SEG15 irq::@return
//SEG16 irq::@return
breturn:
//SEG16 [8] return [ ] ( )
//SEG17 [8] return [ ] ( )
jmp $ea81
}
@ -378,7 +380,7 @@ FINAL SYMBOL TABLE
(const byte*) FGCOL#0 FGCOL = ((byte*))(word/dword/signed dword) 53281
(void()**) KERNEL_IRQ
(const void()**) KERNEL_IRQ#0 KERNEL_IRQ = ((void()**))(word/signed word/dword/signed dword) 788
interrupt(KERNEL)(void()) irq()
interrupt(KERNEL_MIN)(void()) irq()
(label) irq::@return
(void()) main()
(label) main::@2
@ -405,7 +407,7 @@ Score: 211
//SEG7 @end
//SEG8 main
main: {
//SEG9 [4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL)(void()) irq() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
//SEG9 [4] *((const void()**) KERNEL_IRQ#0) ← &interrupt(KERNEL_MIN)(void()) irq() [ ] ( main:2 [ ] ) -- _deref_pptc1=pprc2
lda #<irq
sta KERNEL_IRQ
lda #>irq
@ -418,12 +420,13 @@ main: {
}
//SEG12 irq
irq: {
//SEG13 [6] *((const byte*) BGCOL#0) ← ++ *((const byte*) BGCOL#0) [ ] ( ) -- _deref_pbuc1=_inc__deref_pbuc1
//SEG13 interrupt KERNEL_MIN
//SEG14 [6] *((const byte*) BGCOL#0) ← ++ *((const byte*) BGCOL#0) [ ] ( ) -- _deref_pbuc1=_inc__deref_pbuc1
inc BGCOL
//SEG14 asm { lda$dc0d }
//SEG15 asm { lda$dc0d }
lda $dc0d
//SEG15 irq::@return
//SEG16 [8] return [ ] ( )
//SEG16 irq::@return
//SEG17 [8] return [ ] ( )
jmp $ea81
}

View File

@ -7,7 +7,7 @@
(const byte*) FGCOL#0 FGCOL = ((byte*))(word/dword/signed dword) 53281
(void()**) KERNEL_IRQ
(const void()**) KERNEL_IRQ#0 KERNEL_IRQ = ((void()**))(word/signed word/dword/signed dword) 788
interrupt(KERNEL)(void()) irq()
interrupt(KERNEL_MIN)(void()) irq()
(label) irq::@return
(void()) main()
(label) main::@2