mirror of
https://github.com/cc65/cc65.git
synced 2025-01-13 09:31:53 +00:00
Merge branch 'cc65:master' into bootstrap-fix
This commit is contained in:
commit
fdd4d35887
@ -2283,7 +2283,7 @@ See: <tt><ref id=".ASCIIZ" name=".ASCIIZ"></tt>,<tt><ref id=".CHARMAP" name=".CH
|
|||||||
Switch on or off case sensitivity on identifiers. The default is off
|
Switch on or off case sensitivity on identifiers. The default is off
|
||||||
(that is, identifiers are case sensitive), but may be changed by the
|
(that is, identifiers are case sensitive), but may be changed by the
|
||||||
-i switch on the command line.
|
-i switch on the command line.
|
||||||
The command must be followed by a '+' or '-' character to switch the
|
The command can be followed by a '+' or '-' character to switch the
|
||||||
option on or off respectively.
|
option on or off respectively.
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
@ -2432,7 +2432,7 @@ See: <tt><ref id=".ASCIIZ" name=".ASCIIZ"></tt>,<tt><ref id=".CHARMAP" name=".CH
|
|||||||
Switch on or off debug info generation. The default is off (that is,
|
Switch on or off debug info generation. The default is off (that is,
|
||||||
the object file will not contain debug infos), but may be changed by the
|
the object file will not contain debug infos), but may be changed by the
|
||||||
-g switch on the command line.
|
-g switch on the command line.
|
||||||
The command must be followed by a '+' or '-' character to switch the
|
The command can be followed by a '+' or '-' character to switch the
|
||||||
option on or off respectively.
|
option on or off respectively.
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
@ -3380,7 +3380,7 @@ See: <tt><ref id=".ASCIIZ" name=".ASCIIZ"></tt>,<tt><ref id=".CHARMAP" name=".CH
|
|||||||
Note: Line continuations do not work in a comment. A backslash at the
|
Note: Line continuations do not work in a comment. A backslash at the
|
||||||
end of a comment is treated as part of the comment and does not trigger
|
end of a comment is treated as part of the comment and does not trigger
|
||||||
line continuation.
|
line continuation.
|
||||||
The command must be followed by a '+' or '-' character to switch the
|
The command can be followed by a '+' or '-' character to switch the
|
||||||
option on or off respectively.
|
option on or off respectively.
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
@ -3395,7 +3395,7 @@ See: <tt><ref id=".ASCIIZ" name=".ASCIIZ"></tt>,<tt><ref id=".CHARMAP" name=".CH
|
|||||||
|
|
||||||
<sect1><tt>.LIST</tt><label id=".LIST"><p>
|
<sect1><tt>.LIST</tt><label id=".LIST"><p>
|
||||||
|
|
||||||
Enable output to the listing. The command must be followed by a boolean
|
Enable output to the listing. The command can be followed by a boolean
|
||||||
switch ("on", "off", "+" or "-") and will enable or disable listing
|
switch ("on", "off", "+" or "-") and will enable or disable listing
|
||||||
output.
|
output.
|
||||||
The option has no effect if the listing is not enabled by the command line
|
The option has no effect if the listing is not enabled by the command line
|
||||||
@ -4040,7 +4040,7 @@ See: <tt><ref id=".ASCIIZ" name=".ASCIIZ"></tt>,<tt><ref id=".BYTE" name=".BYTE"
|
|||||||
|
|
||||||
<sect1><tt>.SMART</tt><label id=".SMART"><p>
|
<sect1><tt>.SMART</tt><label id=".SMART"><p>
|
||||||
|
|
||||||
Switch on or off smart mode. The command must be followed by a '+' or '-'
|
Switch on or off smart mode. The command can be followed by a '+' or '-'
|
||||||
character to switch the option on or off respectively. The default is off
|
character to switch the option on or off respectively. The default is off
|
||||||
(that is, the assembler doesn't try to be smart), but this default may be
|
(that is, the assembler doesn't try to be smart), but this default may be
|
||||||
changed by the -s switch on the command line.
|
changed by the -s switch on the command line.
|
||||||
@ -4262,8 +4262,13 @@ macro actually takes in the definition. You may also leave intermediate
|
|||||||
parameters empty. Empty parameters are replaced by empty space (that is,
|
parameters empty. Empty parameters are replaced by empty space (that is,
|
||||||
they are removed when the macro is expanded). If you have a look at our
|
they are removed when the macro is expanded). If you have a look at our
|
||||||
macro definition above, you will see, that replacing the "addr" parameter
|
macro definition above, you will see, that replacing the "addr" parameter
|
||||||
by nothing will lead to wrong code in most lines. To help you, writing
|
by nothing will lead to wrong code in most lines.
|
||||||
macros with a variable parameter list, there are some control commands:
|
|
||||||
|
The names "a", "x" and "y" should be avoided for macro parameters, as these
|
||||||
|
will usually conflict with the 6502 registers.
|
||||||
|
|
||||||
|
For writing macros with a variable parameter list, control commands are
|
||||||
|
available:
|
||||||
|
|
||||||
<tt><ref id=".IFBLANK" name=".IFBLANK"></tt> tests the rest of the line and
|
<tt><ref id=".IFBLANK" name=".IFBLANK"></tt> tests the rest of the line and
|
||||||
returns true, if there are any tokens on the remainder of the line. Since
|
returns true, if there are any tokens on the remainder of the line. Since
|
||||||
@ -4274,15 +4279,15 @@ opposite.
|
|||||||
Look at this example:
|
Look at this example:
|
||||||
|
|
||||||
<tscreen><verb>
|
<tscreen><verb>
|
||||||
.macro ldaxy a, x, y
|
.macro ldaxy i, j, k
|
||||||
.ifnblank a
|
.ifnblank i
|
||||||
lda #a
|
lda #i
|
||||||
.endif
|
.endif
|
||||||
.ifnblank x
|
.ifnblank j
|
||||||
ldx #x
|
ldx #j
|
||||||
.endif
|
.endif
|
||||||
.ifnblank y
|
.ifnblank k
|
||||||
ldy #y
|
ldy #k
|
||||||
.endif
|
.endif
|
||||||
.endmacro
|
.endmacro
|
||||||
</verb></tscreen>
|
</verb></tscreen>
|
||||||
|
@ -43,6 +43,10 @@
|
|||||||
/*****************************************************************************/
|
/*****************************************************************************/
|
||||||
|
|
||||||
|
|
||||||
|
/* EffAddr Flags */
|
||||||
|
#define EFFADDR_OVERRIDE_ZP 0x00000001UL
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* GetEA result struct */
|
/* GetEA result struct */
|
||||||
typedef struct EffAddr EffAddr;
|
typedef struct EffAddr EffAddr;
|
||||||
@ -51,6 +55,7 @@ struct EffAddr {
|
|||||||
unsigned long AddrModeSet; /* Possible addressing modes */
|
unsigned long AddrModeSet; /* Possible addressing modes */
|
||||||
struct ExprNode* Expr; /* Expression if any (NULL otherwise) */
|
struct ExprNode* Expr; /* Expression if any (NULL otherwise) */
|
||||||
unsigned Reg; /* Register number in sweet16 mode */
|
unsigned Reg; /* Register number in sweet16 mode */
|
||||||
|
unsigned long Flags; /* Other properties */
|
||||||
|
|
||||||
/* The following fields are used inside instr.c */
|
/* The following fields are used inside instr.c */
|
||||||
unsigned AddrMode; /* Actual addressing mode used */
|
unsigned AddrMode; /* Actual addressing mode used */
|
||||||
|
@ -72,11 +72,13 @@ void GetEA (EffAddr* A)
|
|||||||
/* Clear the output struct */
|
/* Clear the output struct */
|
||||||
A->AddrModeSet = 0;
|
A->AddrModeSet = 0;
|
||||||
A->Expr = 0;
|
A->Expr = 0;
|
||||||
|
A->Flags = 0;
|
||||||
|
|
||||||
/* Handle an addressing size override */
|
/* Handle an addressing size override */
|
||||||
switch (CurTok.Tok) {
|
switch (CurTok.Tok) {
|
||||||
case TOK_OVERRIDE_ZP:
|
case TOK_OVERRIDE_ZP:
|
||||||
Restrictions = AM65_DIR | AM65_DIR_X | AM65_DIR_Y;
|
Restrictions = AM65_DIR | AM65_DIR_X | AM65_DIR_Y;
|
||||||
|
A->Flags |= EFFADDR_OVERRIDE_ZP;
|
||||||
NextTok ();
|
NextTok ();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -1269,7 +1269,8 @@ static int EvalEA (const InsDesc* Ins, EffAddr* A)
|
|||||||
ExprNode* Left = A->Expr->Left;
|
ExprNode* Left = A->Expr->Left;
|
||||||
if ((A->Expr->Op == EXPR_BYTE0 || A->Expr->Op == EXPR_BYTE1) &&
|
if ((A->Expr->Op == EXPR_BYTE0 || A->Expr->Op == EXPR_BYTE1) &&
|
||||||
Left->Op == EXPR_SYMBOL &&
|
Left->Op == EXPR_SYMBOL &&
|
||||||
GetSymAddrSize (Left->V.Sym) != ADDR_SIZE_ZP) {
|
GetSymAddrSize (Left->V.Sym) != ADDR_SIZE_ZP &&
|
||||||
|
!(A->Flags & EFFADDR_OVERRIDE_ZP)) {
|
||||||
|
|
||||||
/* Output a warning */
|
/* Output a warning */
|
||||||
Warning (1, "Suspicious address expression");
|
Warning (1, "Suspicious address expression");
|
||||||
@ -1617,11 +1618,12 @@ static void PutJMP (const InsDesc* Ins)
|
|||||||
if (EvalEA (Ins, &A)) {
|
if (EvalEA (Ins, &A)) {
|
||||||
|
|
||||||
/* Check for indirect addressing */
|
/* Check for indirect addressing */
|
||||||
if (A.AddrModeBit & AM65_ABS_IND) {
|
if ((A.AddrModeBit & AM65_ABS_IND) && (CPU < CPU_65SC02)) {
|
||||||
|
|
||||||
/* Compare the low byte of the expression to 0xFF to check for
|
/* Compare the low byte of the expression to 0xFF to check for
|
||||||
** a page cross. Be sure to use a copy of the expression otherwise
|
** a page cross. Be sure to use a copy of the expression otherwise
|
||||||
** things will go weird later.
|
** things will go weird later. This only affects the 6502 CPU,
|
||||||
|
** and was corrected in 65C02 and later CPUs in this family.
|
||||||
*/
|
*/
|
||||||
ExprNode* E = GenNE (GenByteExpr (CloneExpr (A.Expr)), 0xFF);
|
ExprNode* E = GenNE (GenByteExpr (CloneExpr (A.Expr)), 0xFF);
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@ unsigned int uia, uib;
|
|||||||
unsigned long ula, ulb;
|
unsigned long ula, ulb;
|
||||||
|
|
||||||
#define OPTCMP8TEST_SINGLE(num,cmpop,asmprefix,vara,varb,b0,b1,a0,a1,typename,name) \
|
#define OPTCMP8TEST_SINGLE(num,cmpop,asmprefix,vara,varb,b0,b1,a0,a1,typename,name) \
|
||||||
typename name ## _ ## num ## (void) { \
|
typename name ## _ ## num(void) { \
|
||||||
varb = b0; \
|
varb = b0; \
|
||||||
asm( asmprefix ); \
|
asm( asmprefix ); \
|
||||||
vara = a0; \
|
vara = a0; \
|
||||||
@ -30,7 +30,7 @@ unsigned long ula, ulb;
|
|||||||
}
|
}
|
||||||
|
|
||||||
#define OPTCMP8TEST_VERIFY(num,b,desc,printterm,name) \
|
#define OPTCMP8TEST_VERIFY(num,b,desc,printterm,name) \
|
||||||
ASSERT_AreEqual(name ## _ ## num ##(),b,printterm,"Incorrect optimization of const comparison (" #name "_" #num ": " desc ").");
|
ASSERT_AreEqual(name ## _ ## num(),b,printterm,"Incorrect optimization of const comparison (" #name "_" #num ": " desc ").");
|
||||||
|
|
||||||
/* Generates a set of comparison tests for one type and set of test values.
|
/* Generates a set of comparison tests for one type and set of test values.
|
||||||
** name = a name for this test (no spaces)
|
** name = a name for this test (no spaces)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user