URL
https://opencores.org/ocsvn/c16/c16/trunk
Subversion Repositories c16
[/] [c16/] [trunk/] [compiler/] [Backend.hh] - Rev 26
Compare with Previous | Blame | View Log
#include <stdio.h>#include <assert.h>#include "Node.hh"enum Size{SIZE_CHAR = 1,SIZE_SHORT = 2,SIZE_LONG = 4,SIZE_INT = SIZE_SHORT,SIZE_POINTER = SIZE_INT};extern FILE * out;class Backend{public:static int check_size(int size, const char * function);static int check_size(SUW suw, const char * function);static void file_header();static void file_footer();static void load_rr_string(int snum, int offset);static void load_ll_string(int snum, int offset);static void load_rr_constant(int constant);static void load_ll_constant(int constant);static void load_rr_var(const char * name, SUW suw);static void load_ll_var(const char * name, SUW suw);static void load_rr_var(const char * name, int sp_offset, SUW suw);static void load_ll_var(const char * name, int sp_offset, SUW suw);static void store_rr_var(const char * name, SUW suw);static void store_rr_var(const char * name, int sp_offset, SUW suw);static void load_address(const char * name);static void add_address(const char * name);static void load_address(const char * name, int sp_offset);static void assign(int size);static void call(const char * name);static void call_ptr();static void ret();static void push_rr(SUW suw);static void pop_rr (SUW suw);static void pop_ll (SUW suw);static void pop(int pushed);static void pop_jump(int diff);static void pop_return(int ret_bytes);static int push_return(int ret_bytes);static void push_zero(int bytes);static void move_rr_to_ll();static void compute_unary(int what, const char * pretty);static void compute_binary(int what, bool uns, const char * pretty);static void compute_binary(int what, bool uns, const char * pretty,int value);static void mult_shift(int value, bool negative);static void div_shift(int value, bool negative, bool uns);static void mod_and(int value, bool negative, bool uns);static void compute_binary(int what, bool uns, int value,const char * pretty);static void content(SUW suw);static void scale_rr(int size);static void unscale_rr(int size, bool uns);static void asmbl(const char * asm_string);static void asm_adjust(const char * asm_line);static void label(int lab);static void label(const char * name);static void label(const char * name, int loop);static void label(const char * name, int loop, int value);static void branch(int lab);static void branch(const char * name, int loop);static void branch(const char * name);static void branch_true(const char * name, int loop, int size);static void branch_false(const char * name, int lab, int size);static void branch_case(const char * name, int loop, int size, int value);static int GetSP() { return stack_pointer; };static int get_label() { return label_num++; };static int new_function(const char * fname);private:static int stack_pointer;static int label_num;static int function_num;};
