Initialize ngspice only once
This commit is contained in:
parent
ad3c2ac4ea
commit
cac571c056
|
@ -45,9 +45,7 @@ NGSPICE::~NGSPICE()
|
||||||
|
|
||||||
void NGSPICE::Init()
|
void NGSPICE::Init()
|
||||||
{
|
{
|
||||||
if( m_error )
|
|
||||||
init();
|
init();
|
||||||
|
|
||||||
Command( "reset" );
|
Command( "reset" );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -270,13 +268,16 @@ string NGSPICE::GetXAxis( SIM_TYPE aType ) const
|
||||||
|
|
||||||
void NGSPICE::init()
|
void NGSPICE::init()
|
||||||
{
|
{
|
||||||
m_error = false;
|
if( m_initialized )
|
||||||
|
return;
|
||||||
|
|
||||||
LOCALE_IO c_locale; // ngspice works correctly only with C locale
|
LOCALE_IO c_locale; // ngspice works correctly only with C locale
|
||||||
ngSpice_Init( &cbSendChar, &cbSendStat, &cbControlledExit, NULL, NULL, &cbBGThreadRunning, this );
|
ngSpice_Init( &cbSendChar, &cbSendStat, &cbControlledExit, NULL, NULL, &cbBGThreadRunning, this );
|
||||||
|
|
||||||
// Workaround to avoid hang ups on certain errors
|
// Workaround to avoid hang ups on certain errors
|
||||||
Command( "unset interactive" );
|
Command( "unset interactive" );
|
||||||
|
|
||||||
|
m_initialized = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -323,9 +324,12 @@ int NGSPICE::cbBGThreadRunning( bool is_running, int id, void* user )
|
||||||
int NGSPICE::cbControlledExit( int status, bool immediate, bool exit_upon_quit, int id, void* user )
|
int NGSPICE::cbControlledExit( int status, bool immediate, bool exit_upon_quit, int id, void* user )
|
||||||
{
|
{
|
||||||
// Something went wrong, reload the dll
|
// Something went wrong, reload the dll
|
||||||
NGSPICE* sim = reinterpret_cast<NGSPICE*>( user );
|
//NGSPICE* sim = reinterpret_cast<NGSPICE*>( user );
|
||||||
sim->m_error = true;
|
//sim->m_initialized = false;
|
||||||
//printf("stat %d immed %d quit %d\n", status, !!immediate, !!exit_upon_quit);
|
//printf("stat %d immed %d quit %d\n", status, !!immediate, !!exit_upon_quit);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool NGSPICE::m_initialized = false;
|
||||||
|
|
|
@ -74,8 +74,6 @@ public:
|
||||||
std::vector<double> GetPhasePlot( const std::string& aName, int aMaxLen = -1 ) override;
|
std::vector<double> GetPhasePlot( const std::string& aName, int aMaxLen = -1 ) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
bool m_error;
|
|
||||||
|
|
||||||
void init();
|
void init();
|
||||||
|
|
||||||
// Callback functions
|
// Callback functions
|
||||||
|
@ -85,6 +83,9 @@ private:
|
||||||
static int cbControlledExit( int status, bool immediate, bool exit_upon_quit, int id, void* user );
|
static int cbControlledExit( int status, bool immediate, bool exit_upon_quit, int id, void* user );
|
||||||
|
|
||||||
void dump();
|
void dump();
|
||||||
|
|
||||||
|
///> NGspice should be initialized only once
|
||||||
|
static bool m_initialized;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* NGSPICE_H */
|
#endif /* NGSPICE_H */
|
||||||
|
|
Loading…
Reference in New Issue