From a816d1ed6a3d5f6d82f77b4e391f32332c1b1817 Mon Sep 17 00:00:00 2001 From: Alexandre Oliva Date: Mon, 18 Nov 2002 20:45:48 +0000 Subject: * 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. --- gas/config/tc-mips.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) (limited to 'gas/config/tc-mips.c') 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 */ } -- cgit v1.1