ref: da8e1d6c8cd2711d7a8566bf658399fbe3531b39
parent: 63284fa474d0474e85fd63a0b2fb00878f7efeee
author: Roberto E. Vargas Caballero <k0ga@shike2.com>
date: Mon Jul 20 18:07:23 EDT 2015
Deal size_t like any other type The important point in the types in the current implementation is the value of the fields, so two types can be represented by different pointers, with different values that if they have the same values then they will be the same type. For this reason is better keep size_t like a common type.
--- a/cc1/cc1.h
+++ b/cc1/cc1.h
@@ -343,7 +343,7 @@
extern Type *voidtype, *pvoidtype, *booltype,
*uchartype, *chartype,
- *uinttype, *inttype, *sizetp,
+ *uinttype, *inttype, *sizettype,
*ushortype, *shortype,
*longtype, *ulongtype,
*ullongtype, *llongtype,
--- a/cc1/code.c
+++ b/cc1/code.c
@@ -345,7 +345,7 @@
Symbol *sym;
sym = newsym(NS_IDEN);
- sym->type = sizetp;
+ sym->type = sizettype;
sym->u.i = tp->size;
return constnode(sym);
}
--- a/cc1/types.c
+++ b/cc1/types.c
@@ -147,6 +147,14 @@
.size = 16,
.align = 1,
.n.rank = RANK_LDOUBLE
+ },
+ { /* 17 = sizettype */
+ .op = INT,
+ .letter = L_UINT,
+ .defined = 1,
+ .size = 2,
+ .align = 1,
+ .n.rank = RANK_UINT
}
};
@@ -158,9 +166,7 @@
*longtype = &types[10], *ulongtype = &types[11],
*ullongtype = &types[12], *llongtype = &types[13],
*floattype = &types[14], *doubletype = &types[15],
- *ldoubletype = &types[16];
-
-Type *sizetp = &types[8]; /* TODO: This depend of the target */
+ *ldoubletype = &types[16], *sizettype = &types[17];
static Symbol dummy0 = {.u.i = 0, .type = &types[9]},
dummy1 = {.u.i = 1, .type = &types[9]};