summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTor Lillqvist <tlillqvist@suse.com>2011-11-21 01:38:11 +0200
committerTor Lillqvist <tlillqvist@suse.com>2011-11-21 01:51:19 +0200
commit0e867a88602fc5bb8e318edcb82b9c940ade41c4 (patch)
tree43a847245d3cdf63463eb082b966015e4a1baf7c
parent190ddfcdb2ffe445be00285a10df6af22a99d6a4 (diff)
Fix crash in the "memory" FileHandle_Impl
-rw-r--r--sal/osl/unx/file.cxx21
1 files changed, 12 insertions, 9 deletions
diff --git a/sal/osl/unx/file.cxx b/sal/osl/unx/file.cxx
index b6b4600ae8b7..62d6aa02bc25 100644
--- a/sal/osl/unx/file.cxx
+++ b/sal/osl/unx/file.cxx
@@ -106,7 +106,7 @@ struct FileHandle_Impl
size_t m_bufsiz;
sal_uInt8 * m_buffer;
- explicit FileHandle_Impl (int fd, char const * path = "<anon>");
+ explicit FileHandle_Impl (int fd, Kind kind = KIND_FD, char const * path = "<anon>");
~FileHandle_Impl();
static void* operator new (size_t n);
@@ -245,10 +245,10 @@ FileHandle_Impl::Guard::~Guard()
(void) pthread_mutex_unlock (m_mutex);
}
-FileHandle_Impl::FileHandle_Impl (int fd, char const * path)
+FileHandle_Impl::FileHandle_Impl (int fd, enum Kind kind, char const * path)
: m_strFilePath (0),
m_fd (fd),
- m_kind (KIND_FD),
+ m_kind (kind),
m_state (STATE_SEEKABLE | STATE_READABLE),
m_size (0),
m_offset (0),
@@ -260,13 +260,16 @@ FileHandle_Impl::FileHandle_Impl (int fd, char const * path)
{
(void) pthread_mutex_init(&m_mutex, 0);
rtl_string_newFromStr (&m_strFilePath, path);
- Allocator::get().allocate (&m_buffer, &m_bufsiz);
- if (0 != m_buffer)
- memset (m_buffer, 0, m_bufsiz);
+ if (m_kind == KIND_FD) {
+ Allocator::get().allocate (&m_buffer, &m_bufsiz);
+ if (0 != m_buffer)
+ memset (m_buffer, 0, m_bufsiz);
+ }
}
FileHandle_Impl::~FileHandle_Impl()
{
- Allocator::get().deallocate (m_buffer), m_buffer = 0;
+ if (m_kind == KIND_FD)
+ Allocator::get().deallocate (m_buffer), m_buffer = 0;
rtl_string_release (m_strFilePath), m_strFilePath = 0;
(void) pthread_mutex_destroy(&m_mutex); // ignoring EBUSY ...
}
@@ -856,7 +859,7 @@ static oslFileError
SAL_CALL osl_openMemoryAsFile( void *address, size_t size, oslFileHandle *pHandle )
{
oslFileError eRet;
- FileHandle_Impl * pImpl = new FileHandle_Impl (-1, "");
+ FileHandle_Impl * pImpl = new FileHandle_Impl (-1, FileHandle_Impl::KIND_MEM);
if (!pImpl)
{
eRet = oslTranslateFileError (OSL_FET_ERROR, ENOMEM);
@@ -1017,7 +1020,7 @@ SAL_CALL osl_openFile( rtl_uString* ustrFileURL, oslFileHandle* pHandle, sal_uIn
}
/* allocate memory for impl structure */
- FileHandle_Impl * pImpl = new FileHandle_Impl (fd, buffer);
+ FileHandle_Impl * pImpl = new FileHandle_Impl (fd, FileHandle_Impl::KIND_FD, buffer);
if (!pImpl)
{
eRet = oslTranslateFileError (OSL_FET_ERROR, ENOMEM);