X-Git-Url: http://shamusworld.gotdns.org/cgi-bin/gitweb.cgi?p=rmac;a=blobdiff_plain;f=sect.h;h=8759eda1dcbd9c41a996f1a5be7fae3847d1c08b;hp=d86056d33372df357fa664a770f9b8e22d0cc174;hb=062214e62031c26d372edc2e68473ebb64f6a506;hpb=bcd800a128cf43be03cf6a7ea54b4fc404b3ed8d diff --git a/sect.h b/sect.h index d86056d..8759eda 100644 --- a/sect.h +++ b/sect.h @@ -64,14 +64,15 @@ #define FU_PCREL 020 // Subtract PC first #define FU_EXPR 040 // Expression (not symbol) follows +#define FUMASKRISC 0x0F00 // Mask for RISC fixup cases #define FU_MOVEI 0x0100 #define FU_JR 0x0200 -//#define FU_MJR 0x0300 #define FU_REGONE 0x0400 #define FU_NUM15 0x0500 #define FU_NUM31 0x0600 #define FU_NUM32 0x0700 #define FU_REGTWO 0x0800 + #define FU_SUB32 0x1000 #define FU_ISBRA 0x2000 // Word forward fixup is a BRA or DBRA #define FU_LBRA 0x4000 // Long branch, for short branch detect @@ -120,10 +121,6 @@ MCHUNK { #define MCHEND 0x2000 // Indicates end of mark chunk #define MPCREL 0x1000 // Mark is PC-relative -//#define MAXFWDJUMPS 1024 // Maximum forward jumps to check -//extern unsigned fwdjump[MAXFWDJUMPS]; -//extern unsigned fwindex; - // Globals, external etc extern LONG sloc; extern WORD scattr; @@ -136,11 +133,11 @@ extern CHUNK * scode; // Prototypes void InitSection(void); -void switchsect(int); -void savsect(void); +void SwitchSection(int); +void SaveSection(void); int fixtest(int, LONG); int chcheck(LONG); -int fixup(WORD, LONG, TOKEN *); +int AddFixup(WORD, LONG, TOKEN *); int ResolveAllFixups(void); #endif // __SECT_H__