forked from accellera-official/systemc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathRELEASENOTES
955 lines (620 loc) · 34.2 KB
/
RELEASENOTES
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
Release Notes for SystemC 2.3.4
===============================
Philipp A. Hartmann, Intel Corporation
Andrew C. Goodrich
CONTENTS
========
1) IMPORTANT
2) What's new in this release?
3) Bug fixes and enhancements
4) New features
5) Incompatibitilies with previous releases
6) Initial support for C++11/14
7) Experimental features
8) Known problems
9) Fixed-point library
10) TLM Release Notes
IMPORTANT
---------
This is a public review release of the SystemC 2.3.4 Class Library.
This release includes TLM 2.0.6 (Transaction Level Modeling) code,
as described in the IEEE 1666-2011 Language Reference Manual.
-------------------------------------------------------------------------------
1. This is a public review release of SystemC. This release contains bug fixes
for SystemC 2.3.3 (and earlier).
2. This release is supported on the following platform combinations for
which it has been tested:
* 64-bit Linux (x86_64)
(RedHat Enterprise 6; SuSE Enterprise Linux 11; Debian 9)
- GNU C++ compiler versions gcc-4.2.2 through gcc-7.2.0
- Clang C++ compiler versions clang-3.4 through clang-5.0
- Intel C++ Compiler (ICC 15.0.0)
* 64-bit Linux (x86_64) with 32-bit compiler (--host=i686-linux-gnu)
(SuSE Enterprise Linux 11)
- GNU C++ compiler versions gcc-4.2.2 through gcc-7.2.0
- Intel C++ Compiler (ICC 15.0.0)
* 64-bit Linux (aarch64)
(Ubuntu 16.04)
- GNU C++ compiler version gcc-4.5.0
* 64-bit Mac OS X (x86_64)
(10.12 Sierra)
- Apple LLVM version 8.0 (clang-800.0.42.1)
- GNU C++ compiler (MacPorts) versions gcc-4.9.0, gcc-5.4.0, gcc-6.3.0
* Microsoft Windows
(Windows Server 2008, Windows 10 Enterprise)
- Microsoft Visual Studio 2010 (10.0) (Win32 and x64)
- Microsoft Visual Studio 2013 (12.0) (Win32 and x64)
- Microsoft Visual Studio 2015 (14.0) (Win32 and x64)
- Microsoft Visual Studio 2017 (14.1) (Win32 and x64)
Warning: The fixed-point datatypes are not working as defined on
MSVC 2015/2017 (x64) in Release mode. See RELEASENOTES.
* Windows Server 2008 (WoW64), Msys 1.0.17(0.48/3/2)
- MinGW-w64 GNU C++ compiler version 4.9.2 (x86_64)
This release has not yet been tested or is known not to work as expected
on the following formerly supported platforms:
* GNU C++ compiler versions prior to 4.2.x (all platforms)
* FreeBSD 9.0 or later (x86, x86_64) with GNU C++ compiler
* HP-UX 11.00 or later with GNU C++ or HP C++ compiler
* Sun/Oracle Solaris, with GNU C++ or Sun/Solaris Studio compiler
* Mac OS X prior to 10.12 (Sierra) and/or on the x86, PowerPC architectures
* Microsoft Visual C++ versions prior to 10.0 (2010)
* Cygwin 1.7 or later (x86, x86_64) with GNU C++ compiler
* Msys/MinGW32 GNU C++ compiler
3. (In)compatibility note
While it is possible to build SystemC as a shared library (both on
ELF-based systems and well as a DLL on Windows), there is no explicitly
defined binary interface across different
- SystemC implementations (e.g. from multiple vendors)
- SystemC library versions
- Compilers or compiler versions
- Operating systems or OS versions
Some differences might be caught at link time, while other incompatibilities
could just sliently lead to undefined behavior during simulation. Please
carefully ensure a consistent build configuration, when integrating binary
SystemC models built from separate sources.
-------------------------------------------------------------------------------
2) What's new in this release?
==============================
This version of SystemC contains the "Proof of Concept" simulator
for the IEEE 1666-2011 SystemC standard. Please consult the IEEE Std
1666-2011 SystemC Language Reference Manual for details about the
current SystemC standard.
TLM-2.0 is merged into the main SystemC release since 2.3.0.
Please see section 10) below for more details related to TLM.
Compared to the 2.3.0 release, this release has the following new items:
- New features, partially beyond the current IEEE 1666-2011 standard,
see section 4.
- Experimental features (some disabled by default), see section 5.
Testing and feedback welcome via the Accellera SystemC forums
at http://forums.accellera.org/forum/9-systemc/.
- Bug fixes, see section 3.
- Updated platform support, see the README.md.
3) Bug fixes and enhancements
=============================
For bug fixes added in 2.3.1 (or before) already, please refer to the previous
RELEASENOTES.
- For fixes and enhancements of the embedded TLM-2.0 implementation,
please see section 10.
- Additional changes and cleanups leading to incompatibilities with
earlier versions of SystemC are described in section 4.
Following is the list of bug fixes and enhancements for the 2.3.4 release:
- sc_thread_process: remove dynamic sensitivity before dying
- sc_cor_qt::stack_protect: don't try to add PROC_EXEC
- Mark QuickThreads stack non-executable on supported platforms
- tracing: fix buffer overflow for big datatypes
Following is the list of bug fixes and enhancements for the 2.3.3 release:
- sc_fxval: consider carry bit during addition/subtraction
- sc_trace: fix overflow check for tracing signed C integer types
- sc_trace: fix division by zero when closing an empty trace file
- sc_trace_file::set_time_unit: report error for invalid timescale units
- sc_elab_and_sim: guard against modification of argv from sc_main
- sc_event: remove dynamic sensitivity of processes in destructor
- Report error when calling wait/next_trigger on empty event lists
- sc_vector_iter: avoid using std::iterator (deprecated in C++17)
- Use proper bit in sc_signed_bitref::concat_set
- Fix immediate triggering of reset during wait(n)
- Detect calling wait(n) with n <= 0 in (clocked) threads
- Fix memory corruption during simulation teardown when processes were
spawned during end_of_elaboration/start_of_simulation
- AArch64: fix stack corruption with optimizations disabled
- sc_fifo_in/out: delete event finder objects
- sc_port_base: free bind info in destructor
- sc_host_mutex/semaphore: use C++11, if available
- sc_start(): detect delta event notifications as activity
Following is the list of bug fixes and enhancements for the 2.3.2 release:
- Adding support for modern compilers and related cleanups
(MSVC 2015, recent GCC/Clang versions)
- Remove conflict with external Boost library on Intel compiler
- Fix bitvector element comparisons with char literals
In 2.3.1, a new boolean conversion for sc_bitref_r had been
added, breaking comparisons like bv[0] == '0'. This extension
has been reverted in 2.3.2 and replaced by an "explicit" boolean
conversion instead (requires C++11, see section 5).
- Improve sc_name_gen memory footprint
- Add support for binding an sc_export during the
before_end_of_elaboration() phase.
- Detect instantiation of an sc_export outside of an sc_module
- Detect invalid immediate notification of events during elaboration
(report an error, instead of causing a crash in some cases)
- Guard against self-assignment of sc_(and|or)_event_list objects
- Fix incomplete time advance under the SC_RUN_TO_TIME starvation policy,
causing incorrect sc_signal::event() values in some corner cases
- Fix memory corruption when starting processes in asynchronous
reset state (async_reset_signal_is asserted at startup)
- Avoid accessing invalid memory in the sc_signal writer check
in case conflicting writer processes have already terminated.
- Correctly detect all conflicting signal writes under the
SC_MANY_WRITERS writer policy.
- Improved error checking in sc_fifo implementation
- Minor enhancements of sc_vector-related classes
- enable initialization from outside the current SystemC hierarchy
- add stricter check of custom Creator compatibility
- sc_vector_iter: enable comparison of compatible iterators
- Avoid deleting the main fiber on Windows in some cases
- Improve robustness of non-standard SC_WAIT macros to avoid
giving wrong information when mixed with non-macro wait() calls
- Fix timestamps when enabling tracing of delta cycles,
improved tracing implementation
- Catch unexpected calls to sc_start (e.g. from within a SystemC process)
- Properly clean up (terminated) processes, releasing their resources
once no longer referenced through a process handle
- Add check for matching C++ standard selection (see section 5)
- When using pthreads for SystemC thread processes, create them in
the "detached" state to reduce resource pressure
- In the default report handler, close the current and open a new logfile
when calling sc_report_handler::set_log_file_name during simulation
- Fix non-standard sc_simcontext::reset
- properly handle sc_reset::reconcile_resets
- delete elements in reverse order of creation
- Cleanup systemc.h
- Drop inclusion of 'cstring', 'sstream' by default (see section 4)
- Avoid referencing deprecated 'std::gets' on C++11
4) New features
===============
Here is an overview of changes in 2.3.x compared to 2.3.0.
Note: These features partly add functionality beyond the current
IEEE Std. 1666-2011.
- [2.3.3] SC_NAMED, a convenience macro for named entities
The new macro SC_NAMED(var,args...) can be used to construct a variable
with a SystemC matching name. It passes the identifier converted to a
string literal as (first) constructor parameter. Additional arguments
are passed unmodified. Example:
SC_MODULE(module)
{
SC_CTOR(module)
: SC_NAMED(port_i) // works in C++03
, SC_NAMED(sig, true) // supports multiple parameters
{}
sc_in<bool> port_i;
sc_out<bool> SC_NAMED(port_o); // in-class member init., requires C++11
sc_signal<bool> sig;
};
- [2.3.3] Add sc_process_handle::basename() function
- [2.3.2] Extend hierarchical name registry
In addition to `sc_hierarchical_name_exists`, four new functions
have been added to register a name with the SystemC name hierarchy:
bool sc_register_hierarchical_name(const char* hierarchical_name);
bool sc_register_hierarchical_name(const sc_object* parent, const char* name);
bool sc_unregister_hierarchical_name(const char* hierarchical_name);
bool sc_unregister_hierarchical_name(const sc_object* parent, const char* name);
These functions enable (un)registering an external hierarchical name with
the SystemC name hierarchy, e.g. used by the CCI configuration standard.
Additionally, two new functions enable obtaining the persistent name pointers
stored in the name registry, if they exist:
const char* sc_get_hierarchical_name(const char* hierarchical_name);
const char* sc_get_hierarchical_name(const sc_object* parent, const char* name);
- [2.3.2] Add new RTTI queries and helper class
A new class `sc_type_index` (with C++11 just a typedef to `std::type_index`)
is introduced, which helps writing RTTI-related code.
This new type is used by two new inspection functions added to sc_port_base,
and sc_export_base, respectively (implemented in their corresponding template
classes) to query the RTTI information of the interface types:
virtual sc_type_index sc_port_base::get_interface_type() const = 0;
virtual sc_type_index sc_export_base::get_interface_type() const = 0;
- [2.3.2] Add never-notified event: const sc_event sc_event::none
wait( sc_event::none ); // never triggered
- [2.3.2] Add new `sc_time::from_string` functions, `sc_time_tuple` class
With sc_time::from_string, it is now possible to conveniently create
time objects from string repesentations (e.g. configuration files):
sc_time( double v, const char* unit );
static sc_time from_string(const char* v);
To simplify the reverse direction, a new class `sc_time_tuple` is
introduced, providing separate access to the value and the unit of
the time object:
class sc_time_tuple
{
// ...
value_type value() const; // normalized value (wrt. unit)
sc_time_unit unit() const; // normalized unit
const char * unit_symbol() const;
};
sc_time tuple tt = sc_time(10000, SC_NS);
tt.value() == 10
tt.unit() == SC_US
- [2.3.1] Improved conversion between the underlying integral time
representation and sc_time objects:
- Add a nested typedef "value_type" to sc_time to enable an
implementation-independent use of the underlying integral
time representation (see IEEE 1666-2011, 5.11.1).
- Adding an inverse to the 'sc_time::value()' function to
convert a plain value back to an sc_time object:
static sc_time sc_time::from_value( value_type t );
- Adding modulus operators (%, %=) to compute time offsets from
clock or quantum boundaries:
sc_time operator%(const sc_time& lhs, const sc_time& rhs);
sc_time& sc_time::operator%=();
Note: These operators are missing from IEEE 1666-2011, which
make e.g. the tlm_global_quantum implementation nearly
impossible within the limits of the SystemC standard.
- [2.3.1] Add function to determine the current object hierarchy:
sc_object* sc_core::sc_get_current_object()
Returns a pointer to the sc_object instance (or NULL) that would
currently become the parent object of a newly created sc_object
instance (i.e. the current module during elaboration, and the
currently active process during simulation).
- [2.3.1] Add an sc_signal initialization which does not create an
event via newly provided constructors to the signal classes:
sc_signal<T>::sc_signal( const char* name
, const T& initial_value );
(similarly for sc_buffer and sc_signal_resolved)
Compared to calling the "write()" function on a signal during
the elaboration, these constructors will set the initial value
of the signal without triggering an event at the beginning of the
simulation (and therefore may avoid triggering sensitive processes).
- [2.3.2] Add common signal base class `sc_signal_channel`
The new base class for all signal channels reduces the code duplication
in the template-based signal implementations.
- [2.3.2] Add support for SC_SIGNAL_WRITE_CHECK=CONFLICT
Instead of disabling all runtime signal write checks via the
environment setting SC_SIGNAL_WRITE_CHECK=DISABLE, setting the
variable to SC_SIGNAL_WRITE_CHECK=CONFLICT allows detecting
conflicting writes to a signal within a single evaluation phase
(see INSTALL).
- [2.3.2] Promote SC_DEFAULT_*_ACTIONS to enum constants
Previously, the SC_DEFAULT_(INFO,WARNING,ERROR,FATAL)_ACTIONS were
defined as macros. In this release, they are moved into the actions
enumeration as constants.
- [2.3.2] Call report handler for exceptions caught outside of sc_main:
With two new functions added to the sc_report_handler:
static sc_actions get_catch_actions();
static sc_actions set_catch_actions(sc_actions);
and the new
SC_DEFAULT_CATCH_ACTIONS = SC_DISPLAY
it is now possible to externally influence the handling of
exceptions caught outside of sc_main.
- [2.3.1] Add a static function to sc_report_handler to query the
current report handler function:
static sc_report_handler_proc sc_report_handler::get_handler();
Additionally, sc_report_handler::set_handler() now returns the
previously set handler (c.f. sc_report_handler::set_actions).
- [2.3.2] Improved conversion from bitvector element references to bool
Elements of a sc_bv can now be used in an boolean context
(requires C++11, see section 5). This enables the following
coding style:
sc_bv<8> mybits;
// ...
if( mybits[0] ) // no longer a compiler error here!
/* do something */ ;
Note: For logic vectors, the bit-references still need to be
converted to bool explicitly (e.g. via the "to_bool()"
function.
- [2.3.2] Support for scoped names in VCD trace files
In VCD trace files, traced variables are now automatically
grouped in hierarchical scopes (according to the '.'
separators in the trace names).
This feature can be disabled at compile-time or runtime.
See INSTALL.
- [2.3.2] Add VCD tracing support for sc_time and sc_event
The VCD format supports tracing of "time" and "event"
variables by default. Added new overloads to sc_trace
and a corresponding implementation for VCD:
void sc_trace( sc_trace_file* tf, const sc_time&, const std::string& );
void sc_trace( sc_trace_file* tf, const sc_event&, const std::string& );
- [2.3.1] Enhanced Autoconf/Automake build system
- better control of the installation directories
- improved libtool library dependency detection, especially
in cross-compilation scenarios (--host=...)
- support for pkg-config for SystemC and TLM
(see http://www.freedesktop.org/wiki/Software/pkg-config/)
- accept arbitrary GCC-compatible compilers
(e.g. Clang, Intel compiler, compiler-wrappers like scan-build)
- avoid deprecation warnings, cleanup implementation
- less recursive build, silent rules by default
- improved "make check" test handling
- [2.3.2] Add support for AArch64 architecture (on Linux)
- [2.3.2] Updated MS Visual C++ project and solution files to include
support for Visual Studio 2010 and later
- support for 32-bit and 64-bit builds
- support for building SystemC dynamic link library (DLL) (see INSTALL)
- switch to DLL-based runtime by default (/MD[d])
- [2.3.2] New CMake-based build system (experimental)
- unified configuration of the SystemC on different platforms
- see cmake/INSTALL_USING_CMAKE
5) Incompatibilities with previous releases
===========================================
Here is a list of known incompatibilities between this release and 2.3.1
(and earlier):
- MSVC project files have been upgraded to MSVC 2010. Building SystemC
for earlier versions of MSVC might still be possible with the new
CMake build system (see cmake/INSTALL_USING_CMAKE).
- Switch to MSVC DLL-based Runtime Library (/MD[d]) instead of using
the no longer recommended static variants.
- The non-standard functions `interface_count` and `if_typename` in
sc_port_base have been marked as private.
- The non-standard, 32-bit implementation of sc_(u)int has been removed.
- The non-standard macros WAIT, WAITN and WAIT_UNTIL have been
renamed to SC_WAIT, SC_WAITN, SC_WAIT_UNTIL.
- The non-standard macros SCAST, CCAST, RCAST have been removed.
- The implicit inclusions of the system-headers "cstring" and "sstream"
have been removed. See INSTALL.
Here is a list of known incompatibilities between this release and 2.3.0
(and earlier):
- The non-standard sc_time constructors
- sc_time( uint64, bool scale )
- sc_time( double, bool scale )
have been deprecated and issue a warning when being used.
Use the new 'sc_time::from_value' function instead (see section 3).
- The non-standard function 'sc_object::get_parent()' has been
deprecated, use 'sc_object::get_parent_object()' instead.
- The non-standard function 'sc_signal::get_new_value()' has been
deprecated (as required by IEEE 1666-2011).
- The 'sc_string_old' class is no longer available by default.
Define 'SC_USE_SC_STRING_OLD' before including "systemc.h",
see INSTALL.
- The implicit inclusions of the system-headers "windows.h" (on Windows),
"cstring", "sstream" and (deprecated) "strstream" have been removed.
See INSTALL.
Here is a list of known incompatibilities between this release and 2.2.0:
- The order that processes (SC_METHODs and SC_THREADs) are dispatched
for execution may be different than the order with SystemC 2.2.0 for
some SystemC programs. This is related to the new starvation policy
support for the sc_start() function introduced with IEEE 1666_2011.
6) Initial support for C++11/14
===============================
This package includes an initial implementation of the C++11/14 proposal,
presented at DVCon Europe 2016 ("Moving SystemC to a new C++ Standard").
This includes the addition of two new preprocessor symbols:
- IEEE_1666_CPLUSPLUS (read-only)
This symbol indicates the availability of certain SystemC features
which depend on a particular version of the ISO C++ standard (see below).
- SC_CPLUSPLUS (overridable)
By default, the most recent supported version of the C++ standard for the
current platform/compiler is automatically detected and reflected by the
SC_CPLUSPLUS macro.
Users can override (i.e. usually downgrade) the assumed C++ standard to an
earlier version for compatiblity. The value of this macro has to be set
consistently across the SystemC library build and all linked models
(see INSTALL).
The values of these macros follow the values defined by the C++ standards.
Currently supported versions are:
- 199711L (C++03, ISO/IEC 14882:1998, 14882:2003)
- 201103L (C++11, ISO/IEC 14882:2011)
- 201402L (C++14, ISO/IEC 14882:2014)
- 201703L (C++17, ISO/IEC 14882:2017)
The following features currently require a dedicated C++ standard version
beyond ISO/IEC 14882:2003 (aka C++03):
- C++11 (IEEE_1666_CPLUSPLUS==201103L)
o explicit sc_bitref_r<>::operator bool() const
Restricts direct boolean conversion of bitvector element references
to explicit boolean contexts (e.g. `if` expressions).
Use the `to_bool()` function on earlier setups.
o On C++11-enabled platforms, the embedded Boost implementation is
superseded by using standard C++11 features.
o Convert sc_bind/sc_(c)ref macros to functions
With the support of perfect forwarding since C++11, the dynamic process
support macros sc_bind/sc(c)ref have been propagated to real functions
in the namespace sc_core.
For backwards compatibility, these functions are still made visible
in the global namespace, unless the macro SC_BIND_IN_GLOBAL_NAMESPACE
is explicitly defined to 0.
o On C++11-enabled platforms, SC_NAMED uses uniform initialization
syntax (regular () form on C++03)
In the future, further language features depending on modern C++ language
constructs may be added.
7) Experimental features
========================
In this section the experimental features of this release are listed.
Note: Some of these features are not enabled in the default library
configuration and need to be explicitly activated during at
library build time. See INSTALL file.
- Extended Simulation Phase Callbacks
This release adds an optional mechanism to register callbacks
to several simulation phases. This can be used to integrate
custom introspection techniques in a non-invasive manner.
New phases are added to the sc_status enumeration:
SC_END_OF_INITIALIZATION,
SC_END_OF_UPDATE,
SC_BEFORE_TIMESTEP
to enable a more fine-grained view to the SystemC simulation phases.
When the phase callback mechanism is activated (see the INSTALL file),
any sc_object can subscribe to a (set of) elaboration/simulation phases
for dynamic callbacks explicitly:
// trigger current object before updating the simulation time
this->register_simulation_phase_callback( SC_BEFORE_TIMESTEP );
// trigger current object before returning to "sc_start"
this->register_simulation_phase_callback( SC_PAUSED | SC_STOPPED );
Unsubscribing from any simulation phase is possible via the corresponding
unregister_simulation_phase_callback( phase_cb_mask )
function.
Both functions return the effective mask after the requested callback mask
update. Therefore, querying the currently active mask can be achieved by
calling the (un)registration functions with an empty mask:
sc_object::phase_cb_mask current_cb_mask =
this->register_simulation_phase_callback( 0u );
To enable the external (un)registration of callbacks for a user-defined
sc_object class, the (un)registration functions can be made public by
adding the following using directives to a 'public:' section of the
class definition:
using sc_core::sc_object::register_simulation_phase_callback;
using sc_core::sc_object::unregister_simulation_phase_callback;
When the simulation passes a phase where dynamic callbacks are registered,
the subscribed objects are triggered via the function:
virtual void sc_object::simulation_phase_callback();
which should then be implemented by the subscribing object's class.
Within a simulation callback, the triggering phase can be determined
via the IEEE 1666-2011 'sc_get_status()' function:
void simulation_phase_callback() {
std::cout << sc_core::sc_get_status() << std::endl;
}
A related feature is the triggering of sc_trace updates via these
simulation phase callbacks instead of the hard-coded calls in various
places of the simulation loop. This feature has to be enabled separately,
see INSTALL file.
- Allow creation of sc_max_time() objects before fixing the sc_time
resolution
Currently. IEEE 1666-2011 requires that any call to
sc_core::sc_set_time_resolution( double, sc_time_unit )
happens before the construction of the first non-SC_ZERO_TIME
sc_time object.
This can be inconvenient in cases, where an "uninitialized sc_time value"
is needed, which needs to be separate from SC_ZERO_TIME in some cases.
A relaxation of the strict sc_time construction rules wrt. to
the simulation time resolution can be optionally enabled via the
preprocessor switch SC_ENABLE_EARLY_MAXTIME_CREATION (see INSTALL).
When this option is enabled, the creation of time objects with the
values SC_ZERO_TIME and 'sc_max_time()' are allowed before fixing the
time resolution. The resolution is still fixed once the actual
relationship between the internal time representation and the physical
time units (SC_FS, SC_PS, ...) is used or observed by the application.
- Allow suspending simulation to receive asynchronous updates
When using asynchronous channels (updated from outside the simulation
via async_request_update), the simulation can run into event starvation
prematurely.
Two new functions are added to the sc_prim_channel base class
bool async_attach_suspending();
bool async_detach_suspending();
If any channel has attached itself to request suspension, instead
of ending the simulation when running out of internal events, the
simulation loop suspends until any external async_request_update()
call is received.
An example demonstrating the usage of this feature is provided in
examples/sysc/2.3/simple_async (requires C++11).
8) Known Problems
=================
- When building SystemC on Cygwin for the x86_64 platform with
QuickThreads support, thread processes are not starting properly.
Build with pthreads on this platform instead:
../configure --enable-pthreads ...
- IEEE 1666-2011 does not explicitly define the behaviour in the corner
cases of attempting to create sc_time objects smaller than the time
resolution or bigger than sc_max_time(). This implementation currently
truncates "small" sc_time objects to SC_ZERO_TIME, while "too big"
objects wrap-around sc_max_time() and lead to a value modulo the
maximum time. In both cases, no warning is generated.
- The sign-extension of mixed-signedness logic expressions (&,|)
involving one sc_bigint<> operand and C++ builtin integral types
(int, short, etc.) is inconsistent between 32-bit and 64-bit
platforms in some cases. Convert both operands to sc_bigint<> first.
- The definition of sc_dt::(u)int64 differs from std::(u)int64_t types
on some platforms. This may lead to problems with function overloads
and/or format-string placeholders. As a workaround, convert these
values explicitly to the correct type before passing them to functions
expecting one of these types. For sc_time, use the new nested type
sc_time::value_type to hold values of the underlying representation.
- Bit/logic-vector reductions (or_reduce, and_reduce, etc.) return an
'sc_logic_value_t' enum value, instead of a bool or sc_logic (as required
by IEEE 1666-2011). Using the return value of these functions in a
boolean context, e.g.
if( lv.or_reduce() ) { /* ... */ }
might lead to wrong results in case of 'X' or 'Z' bits in the vector.
Avoid this by converting the result to an 'sc_logic' first and perform
a safe conversion to bool:
if( sc_logic( lv.or_reduce() ).to_bool() ) { /* ... */ }
- The current implementation of bit-wise operations on sc_bv and other
bit types implicitly uses the left-hand argument as the size of the result
rather than the size of the larger operand, as required by the IEEE 1666
standard.
- The fixed-point implementation is not working correctly on MSVC 2015 (64-bit)
or later, when built with optimization enabled (Release mode). On this
compiler/platform, optimization needs to be disabled when using the
fixed-point library (for all SystemC versions before and including 2.3.2).
- Some paths in this release are longer than the historical 99 character
limit of tar archives, and several Windows archivers (e.g. WinZip)
have been reported to trip over this. The open source archiver 7-zip
(http://7-zip.org) is known to work.
9) Fixed-point library
======================
SystemC contains a fixed-point datatypes package.
Changes compared to SystemC 2.0.1
- support for explicit construction from "float" values
- removing a conversion ambiguity by marking some constructors of
sc_fxval[_fast] classes as 'explicit'
- sc_fxnum::to_{integer} fully defined and accurate
- read-only fixed-point bitrefs/subrefs returned from const values
Compile-time macro SC_INCLUDE_FX must be defined in order to build
applications that use fixed point types. You can specify a compiler
flag, e.g., g++ -DSC_INCLUDE_FX ... or use a define statement before
you include systemc.h, e.g.:
#define SC_INCLUDE_FX
#include "systemc.h"
Due to the large size of the fixed-point datatypes header files,
compilation can take considerably more time.
If you want to use the fixed-point data types only (i.e., not data-
types sc_int, sc_uint, sc_bigint, sc_biguint), compilation time can be
reduced by defining compile-time macro SC_FX_EXCLUDE_OTHER (in addition
to SC_INCLUDE_FX).
10) TLM Release Notes
====================
CONTENTS
========
1) Supported SystemC versions
2) What's changed in this kit?
3) Known issues
10.1) Supported SystemC versions
===============================
Starting with the current release, only the bundled SystemC version is supported.
Parts of the TLM implementation are now linked into the kernel library.
10.2) What's changed in this kit?
================================
Compared to the TLM 2.0.3 kit (part of SystemC 2.3.1), the following has changed:
- [2.0.6] tlm_fifo_get_if: resolve nb_peek ambiguity
- [2.0.6] tlm_base_*_socket: implement get_protocol_types()
- [2.0.6] tlm_base_socket_if: match existing functions in tlm_base_*_socket_b
- [2.0.5] Fixed a regression introduced in 2.0.4, now allowing hierarchical
binding of multi_passthrough_target_sockets again.
- [2.0.5] tlm_req_rsp_channel: remove erroneous private inheritance
- [2.0.4] A new base interface `tlm_socket_base_if` has been added to the TLM
socket classes, providing a non-templated access to some socket information:
o querying of protocol types (returning an `sc_type_index`, see above)
o querying of socket category
(TLM_INITIATOR_SOCKET, TLM_TARGET_SOCKET, TLM_MULTI_*_SOCKET)
o querying port/export base (`get_base_port`/`get_base_export`)
o querying bus width
- [2.0.4] Move parts of TLM-2.0 library into prebuilt SystemC (shared) library
By moving the TLM extension and phase registries and the global quantum
handling into the prebuilt SystemC library, the global variables in these
parts of TLM are more deterministically handled in case of dynamically
linked models.
Note: With this change, the TLM-2.0 headers from this package can only
be used in conjunction with the matching SystemC kernel sources.
- [2.0.4] Improved error handling in convenience sockets
All error checking on the convenience sockets now consistently report
the affected socket name (and kind) to help tracking down their origin.
- [2.0.4] tlm_utils::simple_target_socket: only spawn b2nb_thread, if needed
The blocking-to-nonblocking conversion thread is only spawned in
case there is no b_transport callback but only an nb_transport callback
registered.
Note: With this change, classes inheriting from simple_target_socket
need to call the base class' start_of_simulation() callback
in case it is overridden in the derived class.
- [2.0.4] Fix regression introduced in 2.0.3 to allow using the optional
sc_port_policy SC_ZERO_OR_MORE_BOUND for
tlm_utils::multi_passthrough_target_socket again.
- [2.0.4] Fix memory corruption in tlm::circular_buffer<T>::clear.
- [2.0.4] Prefer using `sc_assert' over plain `assert'.
- [2.0.4] Hide warnings on some compilers about hidden overloads of virtual
bind functions in TLM target socket.
- [2.0.4] Minor cleanups and improved compiler support.
10.3) Known issues
=================
a. The tlm_simple_target_socket in tlm_utils does not obey the END_REQ rule
when only an nb_ call is registered, an b_ call is being handled in the
socket and there is an nb_ call coming in at the same time. In this case
the incoming nb_ call will be forwarded to the registered nb_ call without
checking whether the earlier b_ call has passed the END_REQ timing point.
b. The implementation of the PEQ 'peq_with_get' in tlm_utils does not properly
distinguish between immediate notifications and delta notifications. In the
case that a immediate and delta notification happen at the same simulation
time both types of notifications emerge from the PEQ in the same evaluation
phase. This is wrong immediate notifications should overtake delta
notifications.