mirror of
https://github.com/cc65/cc65.git
synced 2025-04-05 13:37:17 +00:00
Moved CPU definition into common/
git-svn-id: svn://svn.cc65.org/cc65/trunk@2111 b7a2c559-68d2-44c3-8de9-860c34a00d81
This commit is contained in:
parent
8fb90af8ff
commit
986e3779ce
@ -6,10 +6,10 @@
|
||||
/* */
|
||||
/* */
|
||||
/* */
|
||||
/* (C) 1998-2000 Ullrich von Bassewitz */
|
||||
/* Wacholderweg 14 */
|
||||
/* D-70597 Stuttgart */
|
||||
/* EMail: uz@musoftware.de */
|
||||
/* (C) 1998-2003 Ullrich von Bassewitz */
|
||||
/* Römerstrasse 52 */
|
||||
/* D-70794 Filderstadt */
|
||||
/* EMail: uz@cc65.org */
|
||||
/* */
|
||||
/* */
|
||||
/* This software is provided 'as-is', without any expressed or implied */
|
||||
@ -331,8 +331,7 @@ static const struct {
|
||||
|
||||
|
||||
|
||||
/* The current CPU and an array with instruction tables */
|
||||
static enum CPUType CPU = CPU_6502;
|
||||
/* An array with instruction tables */
|
||||
static const InsTable* InsTabs[CPU_COUNT] = {
|
||||
(const InsTable*) &InsTab6502,
|
||||
(const InsTable*) &InsTab65SC02,
|
||||
@ -676,7 +675,7 @@ static int CmpName (const void* Key, const void* Instr)
|
||||
|
||||
|
||||
|
||||
void SetCPU (enum CPUType NewCPU)
|
||||
void SetCPU (cpu_t NewCPU)
|
||||
/* Set a new CPU */
|
||||
{
|
||||
/* Make sure the parameter is correct */
|
||||
@ -693,7 +692,7 @@ void SetCPU (enum CPUType NewCPU)
|
||||
|
||||
|
||||
|
||||
enum CPUType GetCPU (void)
|
||||
cpu_t GetCPU (void)
|
||||
/* Return the current CPU */
|
||||
{
|
||||
return CPU;
|
||||
|
@ -1,15 +1,15 @@
|
||||
/*****************************************************************************/
|
||||
/* */
|
||||
/* instr.h */
|
||||
/* instr.h */
|
||||
/* */
|
||||
/* Instruction encoding for the ca65 macroassembler */
|
||||
/* */
|
||||
/* */
|
||||
/* */
|
||||
/* (C) 1998-2000 Ullrich von Bassewitz */
|
||||
/* Wacholderweg 14 */
|
||||
/* D-70597 Stuttgart */
|
||||
/* EMail: uz@musoftware.de */
|
||||
/* (C) 1998-2003 Ullrich von Bassewitz */
|
||||
/* Römerstrasse 52 */
|
||||
/* D-70794 Filderstadt */
|
||||
/* EMail: uz@cc65.org */
|
||||
/* */
|
||||
/* */
|
||||
/* This software is provided 'as-is', without any expressed or implied */
|
||||
@ -38,21 +38,17 @@
|
||||
|
||||
|
||||
|
||||
/* common */
|
||||
#include "cpu.h"
|
||||
|
||||
|
||||
|
||||
/*****************************************************************************/
|
||||
/* Data */
|
||||
/* Data */
|
||||
/*****************************************************************************/
|
||||
|
||||
|
||||
|
||||
/* Supported CPUs */
|
||||
enum CPUType {
|
||||
CPU_6502,
|
||||
CPU_65C02,
|
||||
CPU_65816,
|
||||
CPU_SUNPLUS, /* Not in the freeware version - sorry */
|
||||
CPU_COUNT /* Count of different CPUs */
|
||||
};
|
||||
|
||||
/* Constants for the addressing mode. If an opcode is available in zero page
|
||||
* and absolut adressing mode, both bits are set. When checking for valid
|
||||
* modes, the zeropage bit is checked first. Similar, the implicit bit is set
|
||||
@ -134,10 +130,10 @@ extern unsigned char ExtBytes [AMI_COUNT];
|
||||
|
||||
|
||||
|
||||
void SetCPU (enum CPUType NewCPU);
|
||||
void SetCPU (cpu_t NewCPU);
|
||||
/* Set a new CPU */
|
||||
|
||||
enum CPUType GetCPU (void);
|
||||
cpu_t GetCPU (void);
|
||||
/* Return the current CPU */
|
||||
|
||||
int FindInstruction (const char* Ident);
|
||||
|
@ -609,6 +609,15 @@ int main (int argc, char* argv [])
|
||||
exit (EXIT_FAILURE);
|
||||
}
|
||||
|
||||
/* If no CPU given, use the default CPU for the target */
|
||||
if (GetCPU () == CPU_UNKNOWN) {
|
||||
if (Target != TGT_UNKNOWN) {
|
||||
SetCPU (DefaultCPU[Target]);
|
||||
} else {
|
||||
SetCPU (CPU_6502);
|
||||
}
|
||||
}
|
||||
|
||||
/* Intialize the target translation tables */
|
||||
TgtTranslateInit ();
|
||||
|
||||
|
@ -39,6 +39,7 @@
|
||||
|
||||
/* common */
|
||||
#include "check.h"
|
||||
#include "cpu.h"
|
||||
#include "strbuf.h"
|
||||
#include "version.h"
|
||||
#include "xmalloc.h"
|
||||
@ -49,7 +50,6 @@
|
||||
#include "asmlabel.h"
|
||||
#include "casenode.h"
|
||||
#include "codeseg.h"
|
||||
#include "cpu.h"
|
||||
#include "dataseg.h"
|
||||
#include "error.h"
|
||||
#include "global.h"
|
||||
@ -189,7 +189,7 @@ void g_preamble (void)
|
||||
|
||||
void g_fileinfo (const char* Name, unsigned long Size, unsigned long MTime)
|
||||
/* If debug info is enabled, place a file info into the source */
|
||||
{
|
||||
{
|
||||
if (DebugInfo) {
|
||||
/* We have to place this into the global text segment, so it will
|
||||
* appear before all .dbg line statements.
|
||||
|
@ -39,6 +39,7 @@
|
||||
/* common */
|
||||
#include "abend.h"
|
||||
#include "chartype.h"
|
||||
#include "cpu.h"
|
||||
#include "print.h"
|
||||
#include "xmalloc.h"
|
||||
#include "xsprintf.h"
|
||||
@ -58,7 +59,6 @@
|
||||
#include "coptstore.h"
|
||||
#include "coptsub.h"
|
||||
#include "copttest.h"
|
||||
#include "cpu.h"
|
||||
#include "error.h"
|
||||
#include "global.h"
|
||||
#include "codeopt.h"
|
||||
|
@ -33,11 +33,13 @@
|
||||
|
||||
|
||||
|
||||
/* common */
|
||||
#include "cpu.h"
|
||||
|
||||
/* cc65 */
|
||||
#include "codeent.h"
|
||||
#include "codeinfo.h"
|
||||
#include "codeopt.h"
|
||||
#include "cpu.h"
|
||||
#include "error.h"
|
||||
#include "coptind.h"
|
||||
|
||||
|
@ -35,10 +35,12 @@
|
||||
|
||||
#include <stdlib.h>
|
||||
|
||||
/* common */
|
||||
#include "cpu.h"
|
||||
|
||||
/* cc65 */
|
||||
#include "codeent.h"
|
||||
#include "codeinfo.h"
|
||||
#include "cpu.h"
|
||||
#include "coptsize.h"
|
||||
|
||||
|
||||
|
@ -42,6 +42,7 @@
|
||||
#include "abend.h"
|
||||
#include "chartype.h"
|
||||
#include "cmdline.h"
|
||||
#include "cpu.h"
|
||||
#include "debugflag.h"
|
||||
#include "fname.h"
|
||||
#include "print.h"
|
||||
@ -55,7 +56,6 @@
|
||||
#include "asmcode.h"
|
||||
#include "compile.h"
|
||||
#include "codeopt.h"
|
||||
#include "cpu.h"
|
||||
#include "error.h"
|
||||
#include "global.h"
|
||||
#include "incpath.h"
|
||||
@ -378,11 +378,8 @@ static void OptCreateDep (const char* Opt attribute ((unused)),
|
||||
static void OptCPU (const char* Opt, const char* Arg)
|
||||
/* Handle the --cpu option */
|
||||
{
|
||||
if (strcmp (Arg, "6502") == 0) {
|
||||
CPU = CPU_6502;
|
||||
} else if (strcmp (Arg, "65C02") == 0) {
|
||||
CPU = CPU_65C02;
|
||||
} else {
|
||||
CPU = FindCPU (Arg);
|
||||
if (CPU != CPU_6502 && CPU != CPU_65C02) {
|
||||
AbEnd ("Invalid argument for %s: `%s'", Opt, Arg);
|
||||
}
|
||||
}
|
||||
@ -795,23 +792,23 @@ int main (int argc, char* argv[])
|
||||
OutputFile = MakeFilename (InputFile, ".s");
|
||||
}
|
||||
|
||||
/* If no CPU given, use the default CPU for the target */
|
||||
if (CPU == CPU_UNKNOWN) {
|
||||
if (Target != TGT_UNKNOWN) {
|
||||
CPU = DefaultCPU[Target];
|
||||
} else {
|
||||
CPU = CPU_6502;
|
||||
}
|
||||
}
|
||||
|
||||
/* Go! */
|
||||
Compile (InputFile);
|
||||
|
||||
/* Create the output file if we didn't had any errors */
|
||||
if (ErrorCount == 0 || Debug) {
|
||||
|
||||
FILE* F;
|
||||
|
||||
#if 0
|
||||
/* Optimize the output if requested */
|
||||
if (Optimize) {
|
||||
OptDoOpt ();
|
||||
}
|
||||
#endif
|
||||
|
||||
/* Open the file */
|
||||
F = fopen (OutputFile, "w");
|
||||
FILE* F = fopen (OutputFile, "w");
|
||||
if (F == 0) {
|
||||
Fatal ("Cannot open output file `%s': %s", OutputFile, strerror (errno));
|
||||
}
|
||||
|
@ -46,7 +46,6 @@ OBJS = anonname.o \
|
||||
coptstore.o \
|
||||
coptsub.o \
|
||||
copttest.o \
|
||||
cpu.o \
|
||||
dataseg.o \
|
||||
datatype.o \
|
||||
declare.o \
|
||||
|
@ -67,7 +67,6 @@ OBJS = anonname.obj \
|
||||
coptstore.obj \
|
||||
coptsub.obj \
|
||||
copttest.obj \
|
||||
cpu.obj \
|
||||
dataseg.obj \
|
||||
datatype.obj \
|
||||
declare.obj \
|
||||
|
@ -39,10 +39,10 @@
|
||||
|
||||
/* common */
|
||||
#include "check.h"
|
||||
#include "cpu.h"
|
||||
|
||||
/* cc65 */
|
||||
#include "codeinfo.h"
|
||||
#include "cpu.h"
|
||||
#include "error.h"
|
||||
#include "opcodes.h"
|
||||
|
||||
|
@ -1,15 +1,15 @@
|
||||
/*****************************************************************************/
|
||||
/* */
|
||||
/* cpu.c */
|
||||
/* cpu.c */
|
||||
/* */
|
||||
/* CPU type definitions */
|
||||
/* CPU specifications */
|
||||
/* */
|
||||
/* */
|
||||
/* */
|
||||
/* (C) 2000 Ullrich von Bassewitz */
|
||||
/* Wacholderweg 14 */
|
||||
/* D-70597 Stuttgart */
|
||||
/* EMail: uz@musoftware.de */
|
||||
/* (C) 2003 Ullrich von Bassewitz */
|
||||
/* Römerstrasse 52 */
|
||||
/* D-70794 Filderstadt */
|
||||
/* EMail: uz@cc65.org */
|
||||
/* */
|
||||
/* */
|
||||
/* This software is provided 'as-is', without any expressed or implied */
|
||||
@ -33,18 +33,55 @@
|
||||
|
||||
|
||||
|
||||
#include <string.h>
|
||||
|
||||
/* common */
|
||||
#include "cpu.h"
|
||||
|
||||
|
||||
|
||||
/*****************************************************************************/
|
||||
/* Data */
|
||||
/* Data */
|
||||
/*****************************************************************************/
|
||||
|
||||
|
||||
|
||||
/* Current CPU */
|
||||
CPUType CPU = CPU_6502;
|
||||
/* CPU used */
|
||||
cpu_t CPU = CPU_UNKNOWN;
|
||||
|
||||
/* Table with target names */
|
||||
const char* CPUNames [CPU_COUNT] = {
|
||||
"6502"
|
||||
"65C02",
|
||||
"65816",
|
||||
"sunplus",
|
||||
};
|
||||
|
||||
|
||||
|
||||
/*****************************************************************************/
|
||||
/* Code */
|
||||
/*****************************************************************************/
|
||||
|
||||
|
||||
|
||||
cpu_t FindCPU (const char* Name)
|
||||
/* Find a CPU by name and return the target id. CPU_UNKNOWN is returned if
|
||||
* the given name is no valid target.
|
||||
*/
|
||||
{
|
||||
unsigned I;
|
||||
|
||||
/* Check all CPU names */
|
||||
for (I = 0; I < CPU_COUNT; ++I) {
|
||||
if (strcmp (CPUNames [I], Name) == 0) {
|
||||
return (cpu_t)I;
|
||||
}
|
||||
}
|
||||
|
||||
/* Not found */
|
||||
return CPU_UNKNOWN;
|
||||
}
|
||||
|
||||
|
||||
|
@ -1,15 +1,15 @@
|
||||
/*****************************************************************************/
|
||||
/* */
|
||||
/* cpu.h */
|
||||
/* cpu.h */
|
||||
/* */
|
||||
/* CPU type definitions */
|
||||
/* CPU specifications */
|
||||
/* */
|
||||
/* */
|
||||
/* */
|
||||
/* (C) 2000 Ullrich von Bassewitz */
|
||||
/* Wacholderweg 14 */
|
||||
/* D-70597 Stuttgart */
|
||||
/* EMail: uz@musoftware.de */
|
||||
/* (C) 2003 Ullrich von Bassewitz */
|
||||
/* Römerstrasse 52 */
|
||||
/* D-70794 Filderstadt */
|
||||
/* EMail: uz@cc65.org */
|
||||
/* */
|
||||
/* */
|
||||
/* This software is provided 'as-is', without any expressed or implied */
|
||||
@ -39,19 +39,39 @@
|
||||
|
||||
|
||||
/*****************************************************************************/
|
||||
/* Data */
|
||||
/* Data */
|
||||
/*****************************************************************************/
|
||||
|
||||
|
||||
|
||||
/* Supported CPUs */
|
||||
typedef enum CPUType {
|
||||
/* CPUs */
|
||||
typedef enum {
|
||||
CPU_UNKNOWN = -1, /* Not specified or invalid target */
|
||||
CPU_6502,
|
||||
CPU_65C02
|
||||
} CPUType;
|
||||
CPU_65C02,
|
||||
CPU_65816,
|
||||
CPU_SUNPLUS, /* Not in the freeware version - sorry */
|
||||
CPU_COUNT /* Number of different CPUs */
|
||||
} cpu_t;
|
||||
|
||||
/* Current CPU */
|
||||
extern CPUType CPU;
|
||||
/* CPU used */
|
||||
extern cpu_t CPU;
|
||||
|
||||
/* Table with target names */
|
||||
extern const char* CPUNames [CPU_COUNT];
|
||||
|
||||
|
||||
|
||||
/*****************************************************************************/
|
||||
/* Code */
|
||||
/*****************************************************************************/
|
||||
|
||||
|
||||
|
||||
cpu_t FindCPU (const char* Name);
|
||||
/* Find a CPU by name and return the target id. CPU_UNKNOWN is returned if
|
||||
* the given name is no valid target.
|
||||
*/
|
||||
|
||||
|
||||
|
@ -15,6 +15,7 @@ OBJS = abend.o \
|
||||
check.o \
|
||||
cmdline.o \
|
||||
coll.o \
|
||||
cpu.o \
|
||||
debugflag.o \
|
||||
exprdefs.o \
|
||||
filepos.o \
|
||||
|
@ -47,6 +47,7 @@ OBJS = abend.obj \
|
||||
check.obj \
|
||||
cmdline.obj \
|
||||
coll.obj \
|
||||
cpu.obj \
|
||||
debugflag.obj \
|
||||
exprdefs.obj \
|
||||
filepos.obj \
|
||||
|
@ -6,10 +6,10 @@
|
||||
/* */
|
||||
/* */
|
||||
/* */
|
||||
/* (C) 2000-2002 Ullrich von Bassewitz */
|
||||
/* Wacholderweg 14 */
|
||||
/* D-70597 Stuttgart */
|
||||
/* EMail: uz@musoftware.de */
|
||||
/* (C) 2000-2003 Ullrich von Bassewitz */
|
||||
/* Römerstrasse 52 */
|
||||
/* D-70794 Filderstadt */
|
||||
/* EMail: uz@cc65.org */
|
||||
/* */
|
||||
/* */
|
||||
/* This software is provided 'as-is', without any expressed or implied */
|
||||
@ -69,7 +69,30 @@ const char* TargetNames [TGT_COUNT] = {
|
||||
"geos",
|
||||
"lunix",
|
||||
"atmos"
|
||||
};
|
||||
};
|
||||
|
||||
|
||||
|
||||
/* Table with default CPUs per target */
|
||||
const cpu_t DefaultCPU[TGT_COUNT] = {
|
||||
CPU_6502, /* none */
|
||||
CPU_6502, /* module */
|
||||
CPU_6502, /* atari */
|
||||
CPU_6502, /* vic20 */
|
||||
CPU_6502, /* c16 */
|
||||
CPU_6502, /* c64 */
|
||||
CPU_6502, /* c128 */
|
||||
CPU_6502, /* ace */
|
||||
CPU_6502, /* plus4 */
|
||||
CPU_6502, /* cbm510 */
|
||||
CPU_6502, /* cbm610 */
|
||||
CPU_6502, /* pet */
|
||||
CPU_6502, /* bbc */
|
||||
CPU_6502, /* apple2 */
|
||||
CPU_6502, /* geos */
|
||||
CPU_6502, /* lunix */
|
||||
CPU_6502, /* atmos */
|
||||
};
|
||||
|
||||
|
||||
|
||||
|
@ -6,10 +6,10 @@
|
||||
/* */
|
||||
/* */
|
||||
/* */
|
||||
/* (C) 2000-2002 Ullrich von Bassewitz */
|
||||
/* Wacholderweg 14 */
|
||||
/* D-70597 Stuttgart */
|
||||
/* EMail: uz@musoftware.de */
|
||||
/* (C) 2000-2003 Ullrich von Bassewitz */
|
||||
/* Römerstrasse 52 */
|
||||
/* D-70794 Filderstadt */
|
||||
/* EMail: uz@cc65.org */
|
||||
/* */
|
||||
/* */
|
||||
/* This software is provided 'as-is', without any expressed or implied */
|
||||
@ -38,6 +38,11 @@
|
||||
|
||||
|
||||
|
||||
/* common */
|
||||
#include "cpu.h"
|
||||
|
||||
|
||||
|
||||
/*****************************************************************************/
|
||||
/* Data */
|
||||
/*****************************************************************************/
|
||||
@ -71,7 +76,10 @@ typedef enum {
|
||||
extern target_t Target;
|
||||
|
||||
/* Table with target names */
|
||||
extern const char* TargetNames [TGT_COUNT];
|
||||
extern const char* TargetNames[TGT_COUNT];
|
||||
|
||||
/* Table with default CPUs per target */
|
||||
extern const cpu_t DefaultCPU[TGT_COUNT];
|
||||
|
||||
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user