Project

General

Profile

Actions

Bug #3197

closed

Found an UAF bug in /src/chunk.c

Added by shangzhi_xu almost 2 years ago. Updated almost 2 years ago.

Status:
Fixed
Priority:
Normal
Category:
core
Target version:
ASK QUESTIONS IN Forums:
No

Description

File: /src/chunk.c
Function: chunkqueue_chunk_file_viewadj

Description:

munmap(cfv->mptr, (size_t)cfv->mlen); 

is called in this function [Line 1715]
Then in line 1719
c->file.view = chunk_file_view_failed(cfv);

is called, in this function, it called chunk_file_view_release(cfv)
but in function chunk_file_view_release
munmap(cfv->mptr, (size_t)cfv->mlen);

is called again as cfv->mptr != MAP_FAILED;

Suggestion:
I found that /*cfv->mptr= MAP_FAILED;*//*(assigned below)*/ was commented out at [Line 1716], which lead to this bug, maybe we should delete the comment mark on this statement.

Actions #1

Updated by gstrauss almost 2 years ago

  • Category set to core
  • Status changed from New to Patch Pending
  • Target version changed from 1.4.xx to 1.4.70

Configuring lighttpd to use mmap is not the default in the build and must be enabled in the build with ./configure --enable-mmap

If you found this with a static analyzer, please provide details.

Actions #2

Updated by shangzhi_xu almost 2 years ago

gstrauss wrote in #note-1:

Configuring lighttpd to use mmap is not the default in the build and must be enabled in the build with ./configure --enable-mmap

If you found this with a static analyzer, please provide details.

Thanks for your reply! Yes, I found it with static analysis with Goshawk https://github.com/Yunlongs/Goshawk. The details are just like I mentioned above. I think the trace in chunk.c [Line 1715]->[ line 1719]->[Line 156] might lead to a bug. So if you need any further information or details, please tell me~ I'll provide them as soon as possible.

Actions #3

Updated by gstrauss almost 2 years ago

The chunk is generally opened prior to this function being called, and this feature is intended to be enabled in the lighttpd build on systems where the filesystem is trusted. Still, to fix this potential issue, I'll move the call to chunk_open_file_chunk() to the top of the func. Thank you for reporting the issue.

Actions #4

Updated by shangzhi_xu almost 2 years ago

You are welcome. Thanks for your cooperation! Wish you have a good day~

Actions #5

Updated by gstrauss almost 2 years ago

  • Status changed from Patch Pending to Fixed
Actions

Also available in: Atom