fix data overflow with init_putv
The simplest code to reproduce this bug seems to be
int a[][] = {{1,1,1,1,1,1,1}};
This commit is contained in:
4
tcc.c
4
tcc.c
@ -8808,6 +8808,10 @@ static void init_putv(CType *type, Section *sec, unsigned long c,
|
|||||||
/* XXX: generate error if incorrect relocation */
|
/* XXX: generate error if incorrect relocation */
|
||||||
gen_assign_cast(&dtype);
|
gen_assign_cast(&dtype);
|
||||||
bt = type->t & VT_BTYPE;
|
bt = type->t & VT_BTYPE;
|
||||||
|
/* we'll write at most 12 bytes */
|
||||||
|
if (c + 12 > sec->data_allocated) {
|
||||||
|
section_realloc(sec, c + 12);
|
||||||
|
}
|
||||||
ptr = sec->data + c;
|
ptr = sec->data + c;
|
||||||
/* XXX: make code faster ? */
|
/* XXX: make code faster ? */
|
||||||
if (!(type->t & VT_BITFIELD)) {
|
if (!(type->t & VT_BITFIELD)) {
|
||||||
|
|||||||
Reference in New Issue
Block a user