diff options
| author | Xavier ASUS <xavi92psx@gmail.com> | 2019-10-18 00:31:54 +0200 |
|---|---|---|
| committer | Xavier ASUS <xavi92psx@gmail.com> | 2019-10-18 00:31:54 +0200 |
| commit | 268a53de823a6750d6256ee1fb1e7707b4b45740 (patch) | |
| tree | 42c1799a9a82b2f7d9790ee9fe181d72a7274751 /src/pdk/ralloc.h | |
| download | sdcc-gas-268a53de823a6750d6256ee1fb1e7707b4b45740.tar.gz | |
sdcc-3.9.0 fork implementing GNU assembler syntax
This fork aims to provide better support for stm8-binutils
Diffstat (limited to 'src/pdk/ralloc.h')
| -rw-r--r-- | src/pdk/ralloc.h | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/src/pdk/ralloc.h b/src/pdk/ralloc.h new file mode 100644 index 0000000..bef02fa --- /dev/null +++ b/src/pdk/ralloc.h @@ -0,0 +1,64 @@ +/*------------------------------------------------------------------------- + + ralloc.h - header file register allocation + + Written By - Philipp Krause . pkk@spth.de (2018) + + This program is free software; you can redistribute it and/or modify it + under the terms of the GNU General Public License as published by the + Free Software Foundation; either version 2, or (at your option) any + later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + + In other words, you are welcome to use, share and improve this program. + You are forbidden to forbid anyone else to use, share and improve + what you give them. Help stamp out software-hoarding! +-------------------------------------------------------------------------*/ + +#ifndef SDCCRALLOC_H +#define SDCCRALLOC_H 1 + +#include "common.h" + +enum +{ + A_IDX = 0, // The accumulator + P_IDX, // A memory location used as pseudoregister + C_IDX, // Implicit condition operand. + SP_IDX // SP - for use with debug info. +}; + +enum +{ + REG_GPR = 2, + REG_CND = 4, +}; + +/* definition for the registers */ +typedef struct reg_info +{ + short type; /* can have value + REG_GPR, REG_PTR or REG_CND */ + short rIdx; /* index into register table */ + char *name; /* name */ +} reg_info; + +extern reg_info pdk_regs[]; + +void pdk_assignRegisters (ebbIndex *); + +void pdkSpillThis (symbol *sym); +iCode *pdk_ralloc2_cc(ebbIndex *ebbi); + +void pdkRegFix (eBBlock **ebbs, int count); + +#endif + |
