- fixed memory leaks found with valgrind when trying to start a second

simulation with wxBochs:
  * cpu: delete pageWriteStampTable array
  * devices: simplified setup of initial default i/o handlers
  * ne2k: delete ethernet module in destructor
This commit is contained in:
Volker Ruppert 2006-09-20 20:52:23 +00:00
parent 72283f6760
commit 1f5d311ca1
3 changed files with 15 additions and 16 deletions

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: icache.h,v 1.17 2006-05-19 20:04:33 sshwarts Exp $ // $Id: icache.h,v 1.18 2006-09-20 20:52:23 vruppert Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2001 MandrakeSoft S.A. // Copyright (C) 2001 MandrakeSoft S.A.
@ -55,6 +55,9 @@ public:
BX_CPP_INLINE void alloc(Bit32u memSize) BX_CPP_INLINE void alloc(Bit32u memSize)
{ {
if (memSizeInBytes > 0) {
delete [] pageWriteStampTable;
}
memSizeInBytes = memSize; memSizeInBytes = memSize;
pageWriteStampTable = new Bit32u [memSizeInBytes>>12]; pageWriteStampTable = new Bit32u [memSizeInBytes>>12];
resetWriteStamps(); resetWriteStamps();

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: devices.cc,v 1.110 2006-09-20 18:24:17 vruppert Exp $ // $Id: devices.cc,v 1.111 2006-09-20 20:52:23 vruppert Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2002 MandrakeSoft S.A. // Copyright (C) 2002 MandrakeSoft S.A.
@ -119,27 +119,19 @@ void bx_devices_c::init(BX_MEM_C *newmem)
unsigned i; unsigned i;
const char def_name[] = "Default"; const char def_name[] = "Default";
BX_DEBUG(("Init $Id: devices.cc,v 1.110 2006-09-20 18:24:17 vruppert Exp $")); BX_DEBUG(("Init $Id: devices.cc,v 1.111 2006-09-20 20:52:23 vruppert Exp $"));
mem = newmem; mem = newmem;
/* set no-default handlers, will be overwritten by the real default handler */ /* set no-default handlers, will be overwritten by the real default handler */
register_default_io_read_handler(NULL, &default_read_handler, def_name, 7);
io_read_handlers.next = &io_read_handlers; io_read_handlers.next = &io_read_handlers;
io_read_handlers.prev = &io_read_handlers; io_read_handlers.prev = &io_read_handlers;
io_read_handlers.handler_name = new char[strlen(def_name)+1];
strcpy(io_read_handlers.handler_name, def_name);
io_read_handlers.funct = (void *)&default_read_handler;
io_read_handlers.this_ptr = NULL;
io_read_handlers.usage_count = 0; // not used with the default handler io_read_handlers.usage_count = 0; // not used with the default handler
io_read_handlers.mask = 7;
register_default_io_write_handler(NULL, &default_write_handler, def_name, 7);
io_write_handlers.next = &io_write_handlers; io_write_handlers.next = &io_write_handlers;
io_write_handlers.prev = &io_write_handlers; io_write_handlers.prev = &io_write_handlers;
io_write_handlers.handler_name = new char[strlen(def_name)+1];
strcpy(io_write_handlers.handler_name, def_name);
io_write_handlers.funct = (void *)&default_write_handler;
io_write_handlers.this_ptr = NULL;
io_write_handlers.usage_count = 0; // not used with the default handler io_write_handlers.usage_count = 0; // not used with the default handler
io_write_handlers.mask = 7;
if (read_port_to_handler) if (read_port_to_handler)
delete [] read_port_to_handler; delete [] read_port_to_handler;

View File

@ -1,5 +1,5 @@
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// $Id: ne2k.cc,v 1.89 2006-09-10 17:18:44 vruppert Exp $ // $Id: ne2k.cc,v 1.90 2006-09-20 20:52:23 vruppert Exp $
///////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////
// //
// Copyright (C) 2002 MandrakeSoft S.A. // Copyright (C) 2002 MandrakeSoft S.A.
@ -66,11 +66,15 @@ bx_ne2k_c::bx_ne2k_c()
put("NE2K"); put("NE2K");
settype(NE2KLOG); settype(NE2KLOG);
s.tx_timer_index = BX_NULL_TIMER_HANDLE; s.tx_timer_index = BX_NULL_TIMER_HANDLE;
ethdev = NULL;
} }
bx_ne2k_c::~bx_ne2k_c() bx_ne2k_c::~bx_ne2k_c()
{ {
if (ethdev != NULL) {
delete ethdev;
}
BX_DEBUG(("Exit")); BX_DEBUG(("Exit"));
} }
@ -1404,7 +1408,7 @@ void bx_ne2k_c::init(void)
char devname[16]; char devname[16];
bx_list_c *base; bx_list_c *base;
BX_DEBUG(("Init $Id: ne2k.cc,v 1.89 2006-09-10 17:18:44 vruppert Exp $")); BX_DEBUG(("Init $Id: ne2k.cc,v 1.90 2006-09-20 20:52:23 vruppert Exp $"));
// Read in values from config interface // Read in values from config interface
base = (bx_list_c*) SIM->get_param(BXPN_NE2K); base = (bx_list_c*) SIM->get_param(BXPN_NE2K);