8 gasinit(enum Asm asmmode
)
24 gasemitlnk(char *n
, Lnk
*l
, char *s
, FILE *f
)
29 fprintf(f
, ".section %s", l
->sec
);
31 fprintf(f
, ", %s", l
->secf
);
37 fprintf(f
, ".balign %d\n", l
->align
);
38 p
= n
[0] == '"' ? "" : gassym
;
40 fprintf(f
, ".globl %s%s\n", p
, n
);
41 fprintf(f
, "%s%s:\n", p
, n
);
45 gasemitfntail(char *fn
, FILE *f
)
47 if (gasasm
== Gaself
) {
48 fprintf(f
, ".type %s, @function\n", fn
);
49 fprintf(f
, ".size %s, .-%s\n", fn
, fn
);
54 gasemitdat(Dat
*d
, FILE *f
)
56 static char *dtoa
[] = {
71 gasemitlnk(d
->name
, d
->lnk
, ".bss", f
);
72 fprintf(f
, "\t.fill %"PRId64
",1,0\n", zero
);
79 fprintf(f
, "\t.fill %"PRId64
",1,0\n", d
->u
.num
);
83 gasemitlnk(d
->name
, d
->lnk
, ".data", f
);
85 fprintf(f
, "\t.fill %"PRId64
",1,0\n", zero
);
90 err("strings only supported for 'b' currently");
91 fprintf(f
, "\t.ascii %s\n", d
->u
.str
);
94 p
= d
->u
.ref
.name
[0] == '"' ? "" : gassym
;
95 fprintf(f
, "%s %s%s%+"PRId64
"\n",
96 dtoa
[d
->type
], p
, d
->u
.ref
.name
,
100 fprintf(f
, "%s %"PRId64
"\n",
101 dtoa
[d
->type
], d
->u
.num
);
107 typedef struct Asmbits Asmbits
;
115 static Asmbits
*stash
;
118 gasstash(void *bits
, int size
)
123 assert(size
== 4 || size
== 8 || size
== 16);
124 for (pb
=&stash
, i
=0; (b
=*pb
); pb
=&b
->link
, i
++)
126 if (memcmp(bits
, b
->bits
, size
) == 0)
128 b
= emalloc(sizeof *b
);
129 memcpy(b
->bits
, bits
, size
);
144 if (gasasm
== Gaself
)
145 fprintf(f
, ".section .note.GNU-stack,\"\",@progbits\n\n");
148 fprintf(f
, "/* floating point constants */\n.data\n");
149 for (sz
=16; sz
>=4; sz
/=2)
150 for (b
=stash
, i
=0; b
; b
=b
->link
, i
++) {
157 for (p
=b
->bits
; p
<&b
->bits
[sz
]; p
+=4)
158 fprintf(f
, "\n\t.int %"PRId32
,
162 d
= *(float *)b
->bits
;
164 d
= *(double *)b
->bits
;
165 fprintf(f
, " /* %f */\n", d
);