Cygwin: fhandler_base: Fix double free caused when open() fails.
- When open fails, archetype stored in archetypes[] is not cleared. This causes double free when next open fail. This patch fixes the issue. Addresses: https://cygwin.com/pipermail/cygwin/2022-January/250518.html
This commit is contained in:
parent
0cae2b802b
commit
ff539cc0f9
|
@ -440,8 +440,8 @@ fhandler_base::open_with_arch (int flags, mode_t mode)
|
||||||
if (!(res = (archetype && archetype->io_handle)
|
if (!(res = (archetype && archetype->io_handle)
|
||||||
|| open (flags, mode & 07777)))
|
|| open (flags, mode & 07777)))
|
||||||
{
|
{
|
||||||
if (archetype)
|
if (archetype && archetype->usecount == 0)
|
||||||
delete archetype;
|
cygheap->fdtab.delete_archetype (archetype);
|
||||||
}
|
}
|
||||||
else if (archetype)
|
else if (archetype)
|
||||||
{
|
{
|
||||||
|
|
|
@ -30,3 +30,6 @@ Bug Fixes
|
||||||
- Fix a problem creating a dir "foo", if a file (but not a Cygwin symlink)
|
- Fix a problem creating a dir "foo", if a file (but not a Cygwin symlink)
|
||||||
"foo.lnk" already exists.
|
"foo.lnk" already exists.
|
||||||
Addresses: https://github.com/msys2/msys2-runtime/issues/81
|
Addresses: https://github.com/msys2/msys2-runtime/issues/81
|
||||||
|
|
||||||
|
- Fix double free for archetype, which is caused when open() fails.
|
||||||
|
Addresses: https://cygwin.com/pipermail/cygwin/2022-January/250518.html
|
||||||
|
|
Loading…
Reference in New Issue