From: Alexandre Oliva Date: Mon, 18 Nov 2002 20:45:48 +0000 (+0000) Subject: * config/tc-mips.c (s_change_section): Make sure input buffer X-Git-Tag: cagney-unwind-20030108-branchpoint~725 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=a816d1ed6a3d5f6d82f77b4e391f32332c1b1817;p=platform%2Fupstream%2Fbinutils.git * config/tc-mips.c (s_change_section): Make sure input buffer is not accessed past the end. Don't hand obj_elf_change_section a pointer into the input buffer. --- diff --git a/gas/ChangeLog b/gas/ChangeLog index 2b74b6b..4a5b671 100644 --- a/gas/ChangeLog +++ b/gas/ChangeLog @@ -1,3 +1,9 @@ +2002-11-18 Alexandre Oliva + + * config/tc-mips.c (s_change_section): Make sure input buffer + is not accessed past the end. Don't hand + obj_elf_change_section a pointer into the input buffer. + 2002-11-18 Alexandre Oliva , Chris Demetriou * config/tc-mips.c (tc_gen_reloc): Fix typo in handling of diff --git a/gas/config/tc-mips.c b/gas/config/tc-mips.c index 611e775..02e9e9f 100644 --- a/gas/config/tc-mips.c +++ b/gas/config/tc-mips.c @@ -11657,7 +11657,8 @@ s_change_section (ignore) section_name = input_line_pointer; c = get_symbol_end (); - next_c = *(input_line_pointer + 1); + if (c) + next_c = *(input_line_pointer + 1); /* Do we have .section Name<,"flags">? */ if (c != ',' || (c == ',' && next_c == '"')) @@ -11688,8 +11689,13 @@ s_change_section (ignore) else section_alignment = 0; + section_name = xstrdup (section_name); + obj_elf_change_section (section_name, section_type, section_flag, section_entry_size, 0, 0, 0); + + if (now_seg->name != section_name) + free (section_name); #endif /* OBJ_ELF */ }