tinycc/riscv64-gen.c
2019-08-14 18:18:46 +02:00

194 lines
3.7 KiB
C

#ifdef TARGET_DEFS_ONLY
// Number of registers available to allocator:
#define NB_REGS 16 // x10-x17 aka a0-a7, f10-f17 aka fa0-fa7
#define TREG_R(x) (x) // x = 0..7
#define TREG_F(x) (x + 10) // x = 0..7
// Register classes sorted from more general to more precise:
#define RC_INT (1 << 0)
#define RC_FLOAT (1 << 1)
#define RC_R(x) (1 << (2 + (x))) // x = 0..7
#define RC_F(x) (1 << (10 + (x))) // x = 0..7
#define RC_IRET (RC_R(0)) // int return register class
#define RC_FRET (RC_F(0)) // float return register class
#define REG_IRET (TREG_R(0)) // int return register number
#define REG_FRET (TREG_F(0)) // float return register number
#define PTR_SIZE 8
#define LDOUBLE_SIZE 16
#define LDOUBLE_ALIGN 16
#define MAX_ALIGN 16
#define CHAR_IS_UNSIGNED
#else
#include "tcc.h"
ST_DATA const int reg_classes[NB_REGS] = {
RC_INT | RC_R(0),
RC_INT | RC_R(1),
RC_INT | RC_R(2),
RC_INT | RC_R(3),
RC_INT | RC_R(4),
RC_INT | RC_R(5),
RC_INT | RC_R(6),
RC_INT | RC_R(7),
RC_FLOAT | RC_F(0),
RC_FLOAT | RC_F(1),
RC_FLOAT | RC_F(2),
RC_FLOAT | RC_F(3),
RC_FLOAT | RC_F(4),
RC_FLOAT | RC_F(5),
RC_FLOAT | RC_F(6),
RC_FLOAT | RC_F(7)
};
// Patch all branches in list pointed to by t to branch to a:
ST_FUNC void gsym_addr(int t_, int a_)
{
uint32_t t = t_;
uint32_t a = a_;
tcc_error("implement me");
while (t) {
unsigned char *ptr = cur_text_section->data + t;
uint32_t next = read32le(ptr);
if (a - t + 0x8000000 >= 0x10000000)
tcc_error("branch out of range");
write32le(ptr, (a - t == 4 ? 0xd503201f : // nop
0x14000000 | ((a - t) >> 2 & 0x3ffffff))); // b
t = next;
}
}
ST_FUNC void load(int r, SValue *sv)
{
tcc_error("implement me");
}
ST_FUNC void store(int r, SValue *sv)
{
tcc_error("implement me");
}
ST_FUNC void gfunc_call(int nb_args)
{
tcc_error("implement me");
}
ST_FUNC void gfunc_prolog(CType *func_type)
{
tcc_error("implement me");
}
ST_FUNC void gen_va_start(void)
{
tcc_error("implement me");
}
ST_FUNC void gen_va_arg(CType *t)
{
tcc_error("implement me");
}
ST_FUNC int gfunc_sret(CType *vt, int variadic, CType *ret,
int *align, int *regsize)
{
tcc_error("implement me");
}
ST_FUNC void gfunc_return(CType *func_type)
{
tcc_error("implement me");
}
ST_FUNC void gfunc_epilog(void)
{
tcc_error("implement me");
}
ST_FUNC void gen_fill_nops(int bytes)
{
tcc_error("implement me");
if ((bytes & 3))
tcc_error("alignment of code section not multiple of 4");
}
// Generate forward branch to label:
ST_FUNC int gjmp(int t)
{
tcc_error("implement me");
}
// Generate branch to known address:
ST_FUNC void gjmp_addr(int a)
{
tcc_error("implement me");
}
ST_FUNC int gjmp_cond(int op, int t)
{
tcc_error("implement me");
}
ST_FUNC int gjmp_append(int n, int t)
{
tcc_error("implement me");
}
ST_FUNC int gtst(int inv, int t)
{
tcc_error("implement me");
}
ST_FUNC void gen_opi(int op)
{
tcc_error("implement me");
}
ST_FUNC void gen_opl(int op)
{
tcc_error("implement me");
}
ST_FUNC void gen_opf(int op)
{
tcc_error("implement me");
}
ST_FUNC void gen_cvt_sxtw(void)
{
tcc_error("implement me");
}
ST_FUNC void gen_cvt_itof(int t)
{
tcc_error("implement me");
}
ST_FUNC void gen_cvt_ftoi(int t)
{
tcc_error("implement me");
}
ST_FUNC void gen_cvt_ftof(int t)
{
tcc_error("implement me");
}
ST_FUNC void ggoto(void)
{
tcc_error("implement me");
}
ST_FUNC void gen_vla_sp_save(int addr)
{
tcc_error("implement me");
}
ST_FUNC void gen_vla_sp_restore(int addr)
{
tcc_error("implement me");
}
ST_FUNC void gen_vla_alloc(CType *type, int align)
{
tcc_error("implement me");
}
#endif