7 gasemitdat(Dat
*d
, FILE *f
)
10 static char *dtoa
[] = {
23 fprintf(f
, ".section %s\n", d
->u
.str
);
25 fprintf(f
, ".data\n");
32 fprintf(f
, ".balign 8\n");
33 p
= d
->u
.str
[0] == '"' ? "" : gassym
;
35 fprintf(f
, ".globl %s%s\n", p
, d
->u
.str
);
36 fprintf(f
, "%s%s:\n", p
, d
->u
.str
);
39 fprintf(f
, "\t.fill %"PRId64
",1,0\n", d
->u
.num
);
42 if (d
->type
== DAlign
)
47 err("strings only supported for 'b' currently");
48 fprintf(f
, "\t.ascii %s\n", d
->u
.str
);
51 p
= d
->u
.ref
.nam
[0] == '"' ? "" : gassym
;
52 fprintf(f
, "%s %s%s%+"PRId64
"\n",
53 dtoa
[d
->type
], p
, d
->u
.ref
.nam
,
57 fprintf(f
, "%s %"PRId64
"\n",
58 dtoa
[d
->type
], d
->u
.num
);
64 typedef struct Asmbits Asmbits
;
72 static Asmbits
*stash
;
75 gasstash(void *bits
, int size
)
80 assert(size
== 4 || size
== 8 || size
== 16);
81 for (pb
=&stash
, i
=0; (b
=*pb
); pb
=&b
->link
, i
++)
83 if (memcmp(bits
, b
->bits
, size
) == 0)
85 b
= emalloc(sizeof *b
);
86 memcpy(b
->bits
, bits
, size
);
103 fprintf(f
, "/* floating point constants */\n.data\n");
104 for (sz
=16; sz
>=4; sz
/=2)
105 for (b
=stash
, i
=0; b
; b
=b
->link
, i
++) {
112 for (p
=b
->bits
; p
<&b
->bits
[sz
]; p
+=4)
113 fprintf(f
, "\n\t.int %"PRId32
,
117 d
= *(float *)b
->bits
;
119 d
= *(double *)b
->bits
;
120 fprintf(f
, " /* %f */\n", d
);
129 fprintf(f
, ".section .note.GNU-stack,\"\",@progbits\n");