Commit Graph

216 Commits

Author SHA1 Message Date
Jim Monte 8d903d8e30 Merge branch 'pre-master' of ssh://git.code.sf.net/p/ngspice/ngspice into beta_jdm 2020-03-03 09:59:30 -05:00
Holger Vogt 4e1fd88466 some tiny updates to the plot commands 2020-02-28 18:08:44 +01:00
dwarning cfbae5c297 specific ngbehavior by .spiceinit 2020-02-25 15:31:00 +01:00
dwarning 26730ba102 change vdmos flag to thermal, not to confuse with b4soi 2020-02-24 18:49:19 +01:00
Jim Monte b945fb3733 Merging with pre-master 2020-02-24 02:48:13 -05:00
Holger Vogt 99cfe7bc81 MOS output characteristics with and witout drain series resistance 2020-02-23 14:28:29 +01:00
Holger Vogt b7b77a9561 When plotting arrays of curves, plot lines only in the direction
of (in absolute terms) growing x values.
Example: MOS output characteristics.
In the rare case of plotting versus varying x directions
(e.g. example memristor.sp), one has to add the flag
'retraceplot' to the plot command.
2020-02-23 14:27:14 +01:00
Holger Vogt 106207098a thicken grid and graph separately 2020-02-23 14:10:31 +01:00
Holger Vogt 07a203a7ce more precise warning of potential failure 2020-02-23 14:09:39 +01:00
Holger Vogt b26c054f51 replace variable 'gridwidth' by 'xgridwidth' 2020-02-22 15:50:19 +01:00
Holger Vogt f5fa14b390 some more examples, use $oscompiled 2020-02-22 09:55:27 +01:00
Holger Vogt 0d4fe21269 examples for the recent plot enhancements 2020-02-22 09:55:01 +01:00
Holger Vogt 10a4c231c6 examle file for color and font selection 2020-02-22 09:54:40 +01:00
Holger Vogt 9f73552d29 new variable nolegend: with 'set nolegend' plotting of
the legend is suppressed.
2020-02-22 09:54:18 +01:00
Holger Vogt 001c1060cc use a more pleasant color for ps background 2020-02-22 09:53:14 +01:00
Holger Vogt 1539887006 color input for text/grids (color1), background (color0)
and graphs (color2-22) on Windows via
set color2=red
set color2=rgb:ff/0/0
set color2=rgbd:255,0,0
several examples given in the example files
2020-02-22 09:52:59 +01:00
Holger Vogt c1aa6d7142 enable using setting colors by colornn with 0<=nn<=22
The name list of colors is given by
https://www.codeproject.com/Articles/1276/Naming-Common-Colors
2020-02-22 09:52:09 +01:00
Holger Vogt f8c3c7c417 add shell plotter selection as function of oscompiled 2020-02-22 09:51:43 +01:00
Holger Vogt a709512a86 add color selection to WinGui plots 2020-02-22 09:51:21 +01:00
Holger Vogt 901ce79509 use variable 'oscompiled' to specialize for various OSs 2020-02-22 09:50:50 +01:00
Holger Vogt 076037a34c generate variable oscompiled
test for variable
2020-02-22 09:50:30 +01:00
Holger Vogt 9b7766f867 remove typo 2020-02-22 09:50:21 +01:00
Holger Vogt 2ce891b66f some updates on fonts etc. 2020-02-22 09:48:46 +01:00
Holger Vogt 68f95d4407 command hardcopy changes font, check is necessary 2020-02-22 09:45:17 +01:00
Holger Vogt cb4eeb44ee re-organize PS color selection
Improve settings for PS image
Improve error messages
2020-02-22 09:43:59 +01:00
Holger Vogt 67b84f3d2d add local linewidth change for plot and gnuplot commands 2020-02-22 09:43:42 +01:00
Holger Vogt 6a7e9db1e1 add some plots 2020-02-22 09:42:45 +01:00
Holger Vogt 55c92d63fe setcf -> setcs
comments added
2020-02-22 09:42:32 +01:00
h_vogt de7bd1ac7c some utf-8 examples
please apologize for the nonsense texts
2020-02-22 09:38:33 +01:00
Jim Monte 69c6fd72da Resolution of merge conflicts with pre-master. 2020-02-22 01:04:18 -05:00
Holger Vogt f09d1d451e increase max. number of threads for BSIM4 to 8 2020-02-02 17:51:07 +01:00
Jim Monte d33b31b3a9 Minor merge issues 2020-01-29 01:42:37 -05:00
Jim Monte da9bcc050f Merge branch 'pre-master' of ssh://git.code.sf.net/p/ngspice/ngspice into beta_jdm
Fixed some uses of const

Changed dstring to use allocations that are serialized by mutex when
needed
but can fail without terminating the program. Also changed calls to free()
to
use a replacement (txfree()) that will serialize when necessary.

Removed flag fields from Model_Info_t and Node_Info_t since they were no
longer required.

Reverted OK back to 0 in cmpp. There were issues with OK conflicting with
another macro definition of OK due to a header inclusion.

Added functions for writing new code model and UDN information.

Added function output_paths_from_lst_file() to extract paths in more
general
lst format.

Used new function fbget() in cmpp to get data from lst file.

Made reomval of trailing slash in cmpp an inline function for modularity.

Removed restrictions on line length and related items in cmpp by
dynamically
resizizng as required.

Reduced the number of allocation calls when storing model info and
user-defined type information in cmpp while reading lst files by doubling
the
size when resizing rather than increasing the size by 1. Also added checks
for
failure that were not present. These things were also done for
user-defined
types, which are processed in a similar way.

Fixed potential buffer overrun in cmpp function read_model_names() while
building the path. Also the path name is built more efficiently by
maintining
the current location in the output string instead of repeatedly finding it
via
strcat(). These things were also done for the corresponding function for
user-defined nodes.

To support versioning, a group of "filebuf" functions were written to get
the
path names and version numbers from a .lst file having a more flexible
format.

Added checks for failure in cmpp function read_model_names() while setting
the
name of the model and the function.

Developed a more modular and efficient method of testing for duplicate
SPICE
models, etc. in cmpp. Instead of nested for loops, the items are compared
in a
sorted order, so that a single pass needs to be done. This method also
avoids
the need of several flag variables that are used to check if a duplicate
is
being found multiple times. A related functions test_for_duplicates() was
written to perform a generic test of any of the uniquness conditions
checked,
along with a sort function and functions to report errors.

In cmpp, function fopen_cmpp was changed into a function that generates
the
file name but does not open the file (gen_filename()) followed by a
standard
fopen. This change prevented error messages from fopen_cmpp() from causing
an
access violation of the name of the file was not allocated properly. It
also
separtes the input file name from the output file name, so it is clearer
what
is being freed when the output file name is freed at the end of the
function.

Added checks for failure of fclose() in several places. Often a small file
is
not written at all on disk until fclose is called.

Added a function to write version 2 code model info into cminfo2.h. A
similar
function was written for udninfo.h.

Wrote functions to free Model_Info_t and Node_Info_t structures.

Added checks to all output file operations to ensure that the files that
are
generated are correct. This change involved adding tests to the individual
functions outputting data and adding return codes and checks of them in
functions doing output.

Combined several small file outputs into larger ones while adjusting the
format of the text being ouptut to keep the clarity of what is being
written
while reducing the number of function calls.

In functions like cmpp function dta_type_to_str(), strings were returned
directly instead of making a copy that was not necessary. This change
eliminated the copy, made the functions thread safe, and eliminated
allocations. The allocations were not checked for failure, so the change
also
prevented problems associated with failures of these allocations.

In value_to_string(), the elimination of the allocation and copy were not
possible due to retain the value of the string, but the allocation was
checked
for failure where it was not and the resize was also checked.

In integer_to_str(), a buffer size was used that was a function of the
size of
the data to fill it rather than an unrelated size that was most likely too
large. Also due to the reduced size, a stack-based buffer was used.

Fixed a bug in table-generator-b4-2d.sp where the plot names are incorrect
if
the script is called from a running instance of ngspice that has already
created some plot names that would cause conflicts. Also commented this
issue.

Added functions to the structure communicating between ngspice and code
models
to support required memory functions so that the code models, which are
running in the same address space, will have serialized allocations when
that
is required.

Reorganized memory allocations to allow for "raw" allocations that are
serialized when required. Essentially the allocation functions were
decomposed
into part that does not require serialization and part that does. Aside
from
exposing the "raw" allocations, this change made the functions clearer and
fixed an issue where free was being called without mutex protection when
it
would be required. Also, tstrdup() and tstrdup_raw() were written so that
serialization would be available in strdup(). If the other allocation
functions require serialization, then strdup() does also. There were some
issues fixed with the "garbage collect" versions of the allocation
functions.

moved src/misc/alloc.h to src/include/ngspice/alloc.h. This change was
done
because one of the builds (only MinGW) was having problems finding it in
one
case. The others were searching the include path while MinGW was using the
path of the including file as its base. While that issue may have been
corrected, this change was beneficial because there were many files
including
alloc.h through a long path of ../.. from include. As part of this change,
those includes were fixed also.

Loading code models and user-defined types was enhanced to handle
versioning.
Additionally, the copying of error messages along with a potential buffer
overrun was completely eliminated by using the string directly. Following
the
use, a macro FEEE_DLERR_MSG(msg) was added to free the string in Windows.
In
other OS where dlerror() does not require its string to be freed, the
macro
expands to nothing.

In cm_analog_alloc() the number of doubles required was corrected.

Fixed Maiefile.am to include new files.

Fixed the macro definition of strdup in Windows so that it will not
confilct
with the definition provided when CRT memory debugging is used.

Updated usage message for cmpp to provide information about the -p flag.

Added diagnostic messages when running cmpp if the macro DEBUG_CMPP is
enabled. These were entirely removed from the mainline code flow except
for a
single macro PRINT_CMPP_INFO(argc, argv)

Changed free functions in rm_ifs_table from txfree() to a regular free()
since
cmpp does not ever require mutex serialization. Also, its allocations are
done
using standard malloc(), calloc(), and realloc(), so free() is more
appropriate.

Modified change_extension() so that it will append a dot plus the new
extension
in the case where the original file does not have an extension. This case
is
not used in cmpp, but it seems more correct since the new extension being
supplied does not come with a leading dot.

Added check in call to change_extension() for failure.

Added function vprint_error() to cmpp/util.c and defined print_eror in
terms
of vprint_error(). The intent was to be able to call vprint_error()
directly.
Subsequent changes to the code removed the call to vprint_error(), but the
function was left since it is a useful utility function.

Modified src/xspice/icm/GNUmakefile.in to use cmpp -p to obtain a path
list.

Converted all code models supplied with ngspice to
1) Use the "talloc" functions so that their allocations will be serialized
    when necesary
    2) Check for allocation failure in all cases
    3) Free resources on exit
    4) Supply version information in the corresponding .lst file

    Modified icm/dlmain.c to include version 2 information.

    visualc/make-install-vngspiced.bat was changed in two ways. First sime
    actions
    were preceeded by checks to avoid error messages if they were
    unconditionally
    performed. Seond, code models were copied to a second location besides
    the
    destination used by a "production" ngspice. This second location along
    with an
    spinit file to use them allows debugging of multiple versions of
    ngspice
    concurrently.

    visualc/xspice/aux-cfunc.bat was modified to print additional
    diagnostic
    messages during a build, much like the compiler outputs file names.
    Also, cmpp
    -p was made the method to get the list of directories. Finally, the
    actions of
    visualc/xspice/aux-udnfunc.bat were added to aux-cfunc.bat since that
    file was
    already doing two of the three actions, and calling aux-udnfunc.bat
    alone or
    in the wrong order would cause an error. aux-udnfunc.bat was commented
    out and
    probably should be removed at some later time.
2020-01-28 23:56:07 -05:00
dwarning f610089c19 correct thermal parameter 2020-01-26 10:09:28 +01:00
dwarning 0eddbe5b5e avoiding temporary setplot problem 2020-01-26 08:42:11 +01:00
dwarning 37a43ed745 update vdmos examples to the new model interface 2020-01-25 16:18:33 +01:00
Holger Vogt 0217efb290 option not needed for convergence 2020-01-24 21:40:14 +01:00
Holger Vogt 07e680bcfd out-of-interval examples added 2020-01-18 16:56:54 +01:00
Holger Vogt 6b476e99af update to the .measure and meas error messages:
remove crash uipon buggy inputs
add buggy example input file
unify fcn returns: 0 is OK, 1 is bad
Improve on error message for bad syntax
2020-01-18 16:49:04 +01:00
Holger Vogt 12bc3a55b6 example for ~(~v(9)&v(8)) 2020-01-11 13:08:39 +01:00
Holger Vogt 82aad9d5b7 make simulation faster, allow batch mode 2020-01-05 15:29:36 +01:00
Holger Vogt eb5327edf0 Add ac simulation 2019-10-26 16:22:04 +02:00
Holger Vogt 4f22475018 add simulation time info 2019-10-01 23:42:18 +02:00
Holger Vogt 9f5ea51aab use ; instead of $ as end-of-line delimiter 2019-10-01 23:41:32 +02:00
dwarning 435520afbe better title line 2019-09-14 11:26:34 +02:00
dwarning 4ee09fe5c6 vbic model example files 2019-09-14 11:26:21 +02:00
AsamMich 9b28a951d2 Patch #83
Improve and complete command 'compose'
2019-08-13 23:34:48 +02:00
Holger Vogt 6af98bf90b remove warnings 2019-08-13 23:16:12 +02:00
h_vogt a0d87048e6 command.c, inpcom.c, add command 'setcs': like command 'set',
but case sensitive, and thus keeping upper or lower case
of subsequently following variable name and other letters.
2019-08-13 22:51:36 +02:00
Holger Vogt 9dec5f5f1e An example for non-convergence of the pll if the stepszelimit is removed.
Adding a somewhat relaxed limit by TMAX in the tran command will speed
up the simulation by a factor of 1.5 without compromising the result.
2019-03-21 20:26:24 +01:00