tcc: fix weak attribute handling

This commit is contained in:
Joe Soroka 2011-03-02 13:31:09 -08:00
parent 684723488d
commit 823f832630
2 changed files with 10 additions and 6 deletions

View File

@ -2927,9 +2927,6 @@ static int parse_btype(CType *type, AttributeDef *ad)
case TOK_ATTRIBUTE1:
case TOK_ATTRIBUTE2:
parse_attribute(ad);
if (ad->weak) {
t |= VT_WEAK;
}
if (ad->mode) {
u = ad->mode -1;
t = (t & ~VT_BTYPE) | u;
@ -3189,9 +3186,6 @@ static void type_decl(CType *type, AttributeDef *ad, int *v, int td)
if (tok == TOK_ATTRIBUTE1 || tok == TOK_ATTRIBUTE2)
parse_attribute(ad);
if (ad->weak)
type->t |= VT_WEAK;
if (!type1.t)
return;
/* append type at the end of type1 */
@ -5445,6 +5439,8 @@ ST_FUNC void decl(int l)
func_decl_list(sym);
}
if (ad.weak)
type.t |= VT_WEAK;
#ifdef TCC_TARGET_PE
if (ad.func_import)
type.t |= VT_IMPORT;

View File

@ -2354,6 +2354,10 @@ extern int __attribute__((weak)) weak_v1;
extern int __attribute__((weak)) weak_v2;
extern int weak_v3;
extern int (*weak_fpa)() __attribute__((weak));
extern int __attribute__((weak)) (*weak_fpb)();
extern __attribute__((weak)) int (*weak_fpc)();
void __attribute__((weak)) weak_test(void)
{
printf("weak_f1=%d\n", weak_f1 ? weak_f1() : 123);
@ -2362,6 +2366,10 @@ void __attribute__((weak)) weak_test(void)
printf("weak_v1=%d\n",&weak_v1 ? weak_v1 : 123);
printf("weak_v2=%d\n",&weak_v2 ? weak_v2 : 123);
printf("weak_v3=%d\n",&weak_v3 ? weak_v3 : 123);
printf("weak_fpa=%d\n",&weak_fpa ? weak_fpa() : 123);
printf("weak_fpb=%d\n",&weak_fpb ? weak_fpb() : 123);
printf("weak_fpc=%d\n",&weak_fpc ? weak_fpc() : 123);
}
int __attribute__((weak)) weak_f2() { return 222; }