4 #include <libfirm/firm_types.h>
5 #include <libfirm/dbginfo.h>
8 rts_debugbreak, /**< the name of the __debugbreak() intrinsic */
9 rts_abort, /**< the name of the abort() function */
10 rts_abs, /**< the name of the abs() function */
11 rts_labs, /**< the name of the labs() function */
12 rts_llabs, /**< the name of the llabs() function */
13 rts_imaxabs, /**< the name of the imaxabs() function */
15 /* double -> double functions */
16 rts_fabs, /**< the name of the fabs() function */
17 rts_sqrt, /**< the name of the sqrt() function */
18 rts_cbrt, /**< the name of the cbrt() function */
19 rts_pow, /**< the name of the pow() function */
20 rts_exp, /**< the name of the exp() function */
21 rts_exp2, /**< the name of the exp2() function */
22 rts_exp10, /**< the name of the exp10() function */
23 rts_log, /**< the name of the log() function */
24 rts_log2, /**< the name of the log2() function */
25 rts_log10, /**< the name of the log10() function */
26 rts_sin, /**< the name of the sin() function */
27 rts_cos, /**< the name of the cos() function */
28 rts_tan, /**< the name of the tan() function */
29 rts_asin, /**< the name of the asin() function */
30 rts_acos, /**< the name of the acos() function */
31 rts_atan, /**< the name of the atan() function */
32 rts_sinh, /**< the name of the sinh() function */
33 rts_cosh, /**< the name of the cosh() function */
34 rts_tanh, /**< the name of the tanh() function */
36 /* float -> float functions */
37 rts_fabsf, /**< the name of the fabsf() function */
38 rts_sqrtf, /**< the name of the sqrtf() function */
39 rts_cbrtf, /**< the name of the cbrtf() function */
40 rts_powf, /**< the name of the powf() function */
41 rts_expf, /**< the name of the expf() function */
42 rts_exp2f, /**< the name of the exp2f() function */
43 rts_exp10f, /**< the name of the exp10f() function */
44 rts_logf, /**< the name of the logf() function */
45 rts_log2f, /**< the name of the log2f() function */
46 rts_log10f, /**< the name of the log10f() function */
47 rts_sinf, /**< the name of the sinf() function */
48 rts_cosf, /**< the name of the cosf() function */
49 rts_tanf, /**< the name of the tanf() function */
50 rts_asinf, /**< the name of the asinf() function */
51 rts_acosf, /**< the name of the acosf() function */
52 rts_atanf, /**< the name of the atanf() function */
53 rts_sinhf, /**< the name of the sinhf() function */
54 rts_coshf, /**< the name of the coshf() function */
55 rts_tanhf, /**< the name of the tanhf() function */
57 /* long double -> long double functions */
58 rts_fabsl, /**< the name of the fabsl() function */
59 rts_sqrtl, /**< the name of the sqrtl() function */
60 rts_cbrtl, /**< the name of the cbrtl() function */
61 rts_powl, /**< the name of the powl() function */
62 rts_expl, /**< the name of the expl() function */
63 rts_exp2l, /**< the name of the exp2l() function */
64 rts_exp10l, /**< the name of the exp10l() function */
65 rts_logl, /**< the name of the log() function */
66 rts_log2l, /**< the name of the log2() function */
67 rts_log10l, /**< the name of the log10() function */
68 rts_sinl, /**< the name of the sinl() function */
69 rts_cosl, /**< the name of the cosl() function */
70 rts_tanl, /**< the name of the tanl() function */
71 rts_asinl, /**< the name of the asinl() function */
72 rts_acosl, /**< the name of the acosl() function */
73 rts_atanl, /**< the name of the atanl() function */
74 rts_sinhl, /**< the name of the sinhl() function */
75 rts_coshl, /**< the name of the coshl() function */
76 rts_tanhl, /**< the name of the tanhl() function */
78 /* string functions */
79 rts_memcpy, /**< the name of the memcpy() function */
80 rts_memset, /**< the name of the memset() function */
81 rts_strcmp, /**< the name of the strcmp() function */
82 rts_strncmp, /**< the name of the strncmp() function */
83 rts_strlen, /**< the name of the strlen() function */
88 extern ir_entity_ptr rts_entities[rts_max];
90 /* This function is called, whenever a local variable is used before definition. */
91 extern ir_node *uninitialized_local_var(ir_graph *irg, ir_mode *mode, int pos);
93 /* Debug printf implementation. */
94 extern void dbg_printf(const char *fmt, ...);
96 /* Convert the debug info into human readable form. */
97 extern unsigned dbg_snprint(char *buf, unsigned len, const dbg_info *dbg);
99 /* Convert the debug info back. */
100 extern const char *dbg_retrieve(const dbg_info *dbg, unsigned *line);
102 /* Do the necessary lowering for compound parameters. */
103 extern void lower_compound_params(void);
105 /* Initialize for the Firm-generating back end. */
106 void gen_firm_init(void);
108 /* called, after the Firm generation is completed. */
109 void gen_firm_finish(FILE *out, const char *input_filename, int c_mode, int firm_const_exists);
111 void gen_Firm_assembler(const char *input_filename);
113 /* early initialization. */
114 void firm_early_init(void);
116 #endif /* FIRM_OPT_H */