mirror of
https://github.com/darlinghq/darling-gdb.git
synced 2025-02-26 12:25:31 +00:00
Zero supplied stat buffers in functions that pretend to stat
GDB has five places where it pretends to stat for bfd_openr_iovec. Four of these only set the incoming buffer's st_size, leaving the other fields unchanged, which is to say very likely populated with random values from the stack. remote_bfd_iovec_stat was fixed in 0a93529c56714b1da3d7106d3e0300764f8bb81c; this commit fixes the other four. gdb/ChangeLog: * jit.c (mem_bfd_iovec_stat): Zero supplied buffer. * minidebug.c (lzma_stat): Likewise. * solib-spu.c (spu_bfd_iovec_stat): Likewise. * spu-linux-nat.c (spu_bfd_iovec_stat): Likewise.
This commit is contained in:
parent
889c2a6796
commit
326a5c7e36
@ -1,3 +1,10 @@
|
||||
2015-04-14 Gary Benson <gbenson@redhat.com>
|
||||
|
||||
* jit.c (mem_bfd_iovec_stat): Zero supplied buffer.
|
||||
* minidebug.c (lzma_stat): Likewise.
|
||||
* solib-spu.c (spu_bfd_iovec_stat): Likewise.
|
||||
* spu-linux-nat.c (spu_bfd_iovec_stat): Likewise.
|
||||
|
||||
2015-04-13 Stan Shebs <stanshebs@google.com>
|
||||
|
||||
* MAINTAINERS: Update my email address.
|
||||
|
@ -126,6 +126,7 @@ mem_bfd_iovec_stat (struct bfd *abfd, void *stream, struct stat *sb)
|
||||
{
|
||||
struct target_buffer *buffer = (struct target_buffer*) stream;
|
||||
|
||||
memset (sb, 0, sizeof (struct stat));
|
||||
sb->st_size = buffer->size;
|
||||
return 0;
|
||||
}
|
||||
|
@ -241,6 +241,7 @@ lzma_stat (struct bfd *abfd,
|
||||
{
|
||||
struct gdb_lzma_stream *lstream = stream;
|
||||
|
||||
memset (sb, 0, sizeof (struct stat));
|
||||
sb->st_size = lzma_index_uncompressed_size (lstream->index);
|
||||
return 0;
|
||||
}
|
||||
|
@ -313,6 +313,7 @@ spu_bfd_iovec_stat (bfd *abfd, void *stream, struct stat *sb)
|
||||
table to find the extent of the last section but that seems
|
||||
pointless when the size is needed only for checks of other
|
||||
parsed values in dbxread.c. */
|
||||
memset (sb, 0, sizeof (struct stat));
|
||||
sb->st_size = INT_MAX;
|
||||
return 0;
|
||||
}
|
||||
|
@ -313,6 +313,7 @@ spu_bfd_iovec_stat (struct bfd *abfd, void *stream, struct stat *sb)
|
||||
table to find the extent of the last section but that seems
|
||||
pointless when the size is needed only for checks of other
|
||||
parsed values in dbxread.c. */
|
||||
memset (sb, 0, sizeof (struct stat));
|
||||
sb->st_size = INT_MAX;
|
||||
return 0;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user