2001-03-16 02:44:34 +01:00
|
|
|
/*
|
|
|
|
|
* Copyright (c) 2001 Stephen Williams (steve@icarus.com)
|
|
|
|
|
*
|
|
|
|
|
* This source code is free software; you can redistribute it
|
|
|
|
|
* and/or modify it in source code form under the terms of the GNU
|
|
|
|
|
* General Public License as published by the Free Software
|
|
|
|
|
* Foundation; either version 2 of the License, or (at your option)
|
|
|
|
|
* any later version.
|
|
|
|
|
*
|
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
|
*
|
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
|
|
|
|
|
*/
|
|
|
|
|
#if !defined(WINNT)
|
2001-06-12 05:53:10 +02:00
|
|
|
#ident "$Id: vpi_modules.cc,v 1.5 2001/06/12 03:53:11 steve Exp $"
|
2001-03-16 02:44:34 +01:00
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
# include "config.h"
|
|
|
|
|
# include "vpi_priv.h"
|
|
|
|
|
# include "ivl_dlfcn.h"
|
|
|
|
|
# include <stdio.h>
|
2001-06-12 05:53:10 +02:00
|
|
|
# include "vpithunk.h"
|
2001-03-16 02:44:34 +01:00
|
|
|
|
|
|
|
|
typedef void (*vlog_startup_routines_t)(void);
|
2001-06-12 05:53:10 +02:00
|
|
|
typedef int (*vpi_register_sim_t)(p_vpi_thunk tp);
|
2001-03-16 02:44:34 +01:00
|
|
|
|
2001-03-23 03:40:22 +01:00
|
|
|
void vpip_load_module(const char*name, const char*path)
|
2001-03-16 02:44:34 +01:00
|
|
|
{
|
2001-03-23 03:40:22 +01:00
|
|
|
char buf[4096];
|
2001-05-22 04:14:47 +02:00
|
|
|
#ifdef __MINGW32__
|
|
|
|
|
char sep = '\\';
|
|
|
|
|
#else
|
|
|
|
|
char sep = '/';
|
|
|
|
|
#endif
|
|
|
|
|
sprintf(buf, "%s%c%s.vpi", path, sep, name);
|
2001-03-23 03:40:22 +01:00
|
|
|
//printf("Load %s...\n", buf);
|
2001-03-16 02:44:34 +01:00
|
|
|
|
2001-03-23 03:40:22 +01:00
|
|
|
ivl_dll_t dll = ivl_dlopen(buf);
|
|
|
|
|
if (dll == 0) {
|
|
|
|
|
fprintf(stderr, "%s: %s\n", name, dlerror());
|
|
|
|
|
return;
|
|
|
|
|
}
|
2001-03-16 02:44:34 +01:00
|
|
|
|
2001-06-12 05:53:10 +02:00
|
|
|
void *regsub = ivl_dlsym(dll, LU "vpi_register_sim" TU);
|
|
|
|
|
vpi_register_sim_t simreg = (vpi_register_sim_t)regsub;
|
|
|
|
|
if (regsub == 0) {
|
|
|
|
|
fprintf(stderr, "%s: Unable to locate vpi_register_sim", name);
|
|
|
|
|
ivl_dlclose(dll);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
extern vpi_thunk vvpt;
|
|
|
|
|
if (((simreg)(&vvpt)) == 0) {
|
|
|
|
|
fprintf(stderr, "%s: : vpi_register_sim returned zero", name);
|
|
|
|
|
ivl_dlclose(dll);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2001-03-23 03:40:22 +01:00
|
|
|
void*table = ivl_dlsym(dll, LU "vlog_startup_routines" TU);
|
|
|
|
|
if (table == 0) {
|
|
|
|
|
fprintf(stderr, "%s: no vlog_startup_routines\n", name);
|
|
|
|
|
ivl_dlclose(dll);
|
|
|
|
|
return;
|
|
|
|
|
}
|
2001-03-16 02:44:34 +01:00
|
|
|
|
2001-03-23 03:40:22 +01:00
|
|
|
vlog_startup_routines_t*routines = (vlog_startup_routines_t*)table;
|
|
|
|
|
for (unsigned tmp = 0 ; routines[tmp] ; tmp += 1)
|
|
|
|
|
(routines[tmp])();
|
2001-03-16 02:44:34 +01:00
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
* $Log: vpi_modules.cc,v $
|
2001-06-12 05:53:10 +02:00
|
|
|
* Revision 1.5 2001/06/12 03:53:11 steve
|
|
|
|
|
* Change the VPI call process so that loaded .vpi modules
|
|
|
|
|
* use a function table instead of implicit binding.
|
|
|
|
|
*
|
2001-05-22 04:14:47 +02:00
|
|
|
* Revision 1.4 2001/05/22 02:14:47 steve
|
|
|
|
|
* Update the mingw build to not require cygwin files.
|
|
|
|
|
*
|
2001-03-23 03:40:22 +01:00
|
|
|
* Revision 1.3 2001/03/23 02:40:22 steve
|
|
|
|
|
* Add the :module header statement.
|
|
|
|
|
*
|
2001-03-22 06:39:34 +01:00
|
|
|
* Revision 1.2 2001/03/22 05:39:34 steve
|
|
|
|
|
* Test print that interferes with output.
|
|
|
|
|
*
|
2001-03-16 02:44:34 +01:00
|
|
|
* Revision 1.1 2001/03/16 01:44:34 steve
|
|
|
|
|
* Add structures for VPI support, and all the %vpi_call
|
|
|
|
|
* instruction. Get linking of VPI modules to work.
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|