GNU bug report logs -
#19890
[PATCH] Use after free in dld_link on error path
Previous Next
Reported by: Tobias Stoeckmann <tobias <at> stoeckmann.org>
Date: Tue, 17 Feb 2015 21:44:02 UTC
Severity: normal
Tags: patch
Fixed in version 2.4.6.25
Done: Pavel Raiskup <praiskup <at> redhat.com>
Bug is archived. No further changes may be made.
To add a comment to this bug, you must first unarchive it, by sending
a message to control AT debbugs.gnu.org, with unarchive 19890 in the body.
You can then email your comments to 19890 AT debbugs.gnu.org in the normal way.
Toggle the display of automated, internal messages from the tracker.
Report forwarded
to
bug-libtool <at> gnu.org
:
bug#19890
; Package
libtool
.
(Tue, 17 Feb 2015 21:44:02 GMT)
Full text and
rfc822 format available.
Acknowledgement sent
to
Tobias Stoeckmann <tobias <at> stoeckmann.org>
:
New bug report received and forwarded. Copy sent to
bug-libtool <at> gnu.org
.
(Tue, 17 Feb 2015 21:44:02 GMT)
Full text and
rfc822 format available.
Message #5 received at submit <at> debbugs.gnu.org (full text, mbox):
When dld_link fails, the allocated memory for module (strdup) is
freed, but still returned by vm_open. vm_open is called in
ltdr.c line 444, which checks the error flag only if result is NULL.
Therefore, the error condition of vm_open is ignored and the memory
pointed to by module is used later on.
While fixing this, also set error condition and return NULL if
strdup is unable to allocate memory.
---
libltdl/loaders/dld_link.c | 8 ++++++--
1 file changed, 6 insertions(+), 2 deletions(-)
diff --git a/libltdl/loaders/dld_link.c b/libltdl/loaders/dld_link.c
index a73880f..e95d5e4 100644
--- a/libltdl/loaders/dld_link.c
+++ b/libltdl/loaders/dld_link.c
@@ -111,11 +111,15 @@ vm_open (lt_user_data loader_data LT__UNUSED, const char *filename,
lt_dladvise advise LT__UNUSED)
{
lt_module module = lt__strdup (filename);
-
- if (dld_link (filename) != 0)
+ if (module == NULL)
+ {
+ LT__SETERROR (NO_MEMORY);
+ }
+ else if (dld_link (filename) != 0)
{
LT__SETERROR (CANNOT_OPEN);
FREE (module);
+ module = NULL;
}
return module;
--
2.3.0
Information forwarded
to
bug-libtool <at> gnu.org
:
bug#19890
; Package
libtool
.
(Tue, 17 Feb 2015 22:01:01 GMT)
Full text and
rfc822 format available.
Message #8 received at 19890 <at> debbugs.gnu.org (full text, mbox):
In contrast to previous mail, only check for strdup NULL value.
The FREE macro properly sets module to NULL, therefore this one is
the only issue left.
---
Sorry for the previous noise.
---
libltdl/loaders/dld_link.c | 6 +++++-
1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/libltdl/loaders/dld_link.c b/libltdl/loaders/dld_link.c
index a73880f..54053ee 100644
--- a/libltdl/loaders/dld_link.c
+++ b/libltdl/loaders/dld_link.c
@@ -112,7 +112,11 @@ vm_open (lt_user_data loader_data LT__UNUSED, const char *filename,
{
lt_module module = lt__strdup (filename);
- if (dld_link (filename) != 0)
+ if (module == NULL)
+ {
+ LT__SETERROR (NO_MEMORY);
+ }
+ else if (dld_link (filename) != 0)
{
LT__SETERROR (CANNOT_OPEN);
FREE (module);
--
2.3.0
Information forwarded
to
bug-libtool <at> gnu.org
:
bug#19890
; Package
libtool
.
(Fri, 12 Feb 2016 15:14:01 GMT)
Full text and
rfc822 format available.
Message #11 received at submit <at> debbugs.gnu.org (full text, mbox):
Thanks for the report, Tobias.
On Tuesday 17 of February 2015 22:59:55 Tobias Stoeckmann wrote:
> - if (dld_link (filename) != 0)
> + if (module == NULL)
> + {
> + LT__SETERROR (NO_MEMORY);
> + }
There is 'lt__alloc_die = lt__alloc_die_callback;' in ltdl.c (properly
setting the lasterror). Can you verify that this patch is good enough?
| libltdl: handle ENOMEM sooner
|
| * libltdl/loaders/dld_link.c (vm_open): Do not even try dld_link()
| in case of ENOMEM.
|
| diff --git a/libltdl/loaders/dld_link.c b/libltdl/loaders/dld_link.c
| index a73880f..0edf0df 100644
| --- a/libltdl/loaders/dld_link.c
| +++ b/libltdl/loaders/dld_link.c
| @@ -112,7 +112,7 @@ vm_open (lt_user_data loader_data LT__UNUSED, const char *filename,
| {
| lt_module module = lt__strdup (filename);
|
| - if (dld_link (filename) != 0)
| + if (module && dld_link (filename) != 0)
| {
| LT__SETERROR (CANNOT_OPEN);
| FREE (module);
Pavel
Information forwarded
to
bug-libtool <at> gnu.org
:
bug#19890
; Package
libtool
.
(Fri, 12 Feb 2016 15:14:02 GMT)
Full text and
rfc822 format available.
Information forwarded
to
bug-libtool <at> gnu.org
:
bug#19890
; Package
libtool
.
(Fri, 12 Feb 2016 20:01:02 GMT)
Full text and
rfc822 format available.
Message #17 received at submit <at> debbugs.gnu.org (full text, mbox):
On Fri, Feb 12, 2016 at 04:12:57PM +0100, Pavel Raiskup wrote:
> There is 'lt__alloc_die = lt__alloc_die_callback;' in ltdl.c (properly
> setting the lasterror). Can you verify that this patch is good enough?
Yes, that looks reasonable to me. Thanks for pointing that out!
Tobias
Information forwarded
to
bug-libtool <at> gnu.org
:
bug#19890
; Package
libtool
.
(Fri, 12 Feb 2016 20:01:03 GMT)
Full text and
rfc822 format available.
Information forwarded
to
bug-libtool <at> gnu.org
:
bug#19890
; Package
libtool
.
(Mon, 15 Feb 2016 14:31:02 GMT)
Full text and
rfc822 format available.
Message #23 received at submit <at> debbugs.gnu.org (full text, mbox):
close 19890 libtool-2.4.6.25
thanks
On Friday 12 of February 2016 21:00:18 Tobias Stoeckmann wrote:
> On Fri, Feb 12, 2016 at 04:12:57PM +0100, Pavel Raiskup wrote:
> > There is 'lt__alloc_die = lt__alloc_die_callback;' in ltdl.c (properly
> > setting the lasterror). Can you verify that this patch is good enough?
>
> Yes, that looks reasonable to me. Thanks for pointing that out!
Pushed as b5d44b844703.
Pavel
Information forwarded
to
bug-libtool <at> gnu.org
:
bug#19890
; Package
libtool
.
(Mon, 15 Feb 2016 14:31:02 GMT)
Full text and
rfc822 format available.
bug marked as fixed in version 2.4.6.25, send any further explanations to
19890 <at> debbugs.gnu.org and Tobias Stoeckmann <tobias <at> stoeckmann.org>
Request was from
Pavel Raiskup <praiskup <at> redhat.com>
to
control <at> debbugs.gnu.org
.
(Mon, 15 Feb 2016 14:34:02 GMT)
Full text and
rfc822 format available.
bug archived.
Request was from
Debbugs Internal Request <help-debbugs <at> gnu.org>
to
internal_control <at> debbugs.gnu.org
.
(Tue, 15 Mar 2016 11:24:04 GMT)
Full text and
rfc822 format available.
This bug report was last modified 9 years and 99 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.