{"id":444371,"date":"2024-10-20T08:37:22","date_gmt":"2024-10-20T08:37:22","guid":{"rendered":"https:\/\/pdfstandards.shop\/product\/uncategorized\/ieee-1666-2023-3\/"},"modified":"2024-10-26T16:04:11","modified_gmt":"2024-10-26T16:04:11","slug":"ieee-1666-2023-3","status":"publish","type":"product","link":"https:\/\/pdfstandards.shop\/product\/publishers\/ieee\/ieee-1666-2023-3\/","title":{"rendered":"IEEE 1666-2023"},"content":{"rendered":"

Revision Standard – Active. SystemC\u00ae is defined in this standard. SystemC is an ISO standard C++ class library for system and hardware design for use by designers and architects who need to address complex systems that are a hybrid between hardware and software. This standard provides a precise and complete definition of the SystemC class library so that a SystemC implementation can be developed with reference to this standard alone. The primary audiences for this standard are the implementors of the SystemC class library, the implementors of tools supporting the class library, and the users of the class library. (Thanks to our sponsor, the PDF of this standard is available at no charge through the IEEE GET Program https:\/\/ieeexplore.ieee.org\/browse\/standards\/get-program\/page\/series?id=80)<\/p>\n

PDF Catalog<\/h4>\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n
PDF Pages<\/th>\nPDF Title<\/th>\n<\/tr>\n
1<\/td>\nFront cover <\/td>\n<\/tr>\n
2<\/td>\nTitle page <\/td>\n<\/tr>\n
4<\/td>\nImportant Notices and Disclaimers Concerning IEEE Standards Documents <\/td>\n<\/tr>\n
7<\/td>\nIntroduction
Acknowledgments <\/td>\n<\/tr>\n
8<\/td>\nParticipants <\/td>\n<\/tr>\n
10<\/td>\nContents <\/td>\n<\/tr>\n
24<\/td>\n1. Overview
1.1 Scope
1.2 Purpose
1.3 Word usage <\/td>\n<\/tr>\n
25<\/td>\n1.4 Subsets
1.5 Relationship with C++ standard
1.6 Guidance for readers <\/td>\n<\/tr>\n
27<\/td>\n2. Normative references <\/td>\n<\/tr>\n
28<\/td>\n3. Terminology and conventions used in this standard
3.1 Terminology
3.1.1 Shall, should, may, can
3.1.2 Implementation, application
3.1.3 Call, called from, derived from
3.1.4 Specific technical terms <\/td>\n<\/tr>\n
30<\/td>\n3.2 Syntactical conventions
3.2.1 Implementation-defined
3.2.2 Disabled
3.2.3 Ellipsis (…)
3.2.4 Class names <\/td>\n<\/tr>\n
31<\/td>\n3.2.5 Embolded text
3.3 Semantic conventions
3.3.1 Class definitions and the inheritance hierarchy
3.3.2 Function definitions and side-effects
3.3.3 Functions that use const char* as parameter <\/td>\n<\/tr>\n
32<\/td>\n3.3.4 Functions whose return type is a reference or a pointer
3.3.4.1 Overview
3.3.4.2 Functions that return *this or an actual argument
3.3.4.3 Functions that return const char*
3.3.4.4 Functions that return a reference or pointer to an object in the module hierarchy
3.3.4.5 Functions that return a reference or pointer to a transient object <\/td>\n<\/tr>\n
33<\/td>\n3.3.4.6 sc_time_stamp and sc_signal::read <\/td>\n<\/tr>\n
34<\/td>\n3.3.5 Namespaces and internal naming
3.3.6 Non-compliant applications and errors
3.4 Notes and examples <\/td>\n<\/tr>\n
35<\/td>\n4. Elaboration and simulation semantics
4.1 Overview
4.2 Elaboration
4.2.1 Overview <\/td>\n<\/tr>\n
36<\/td>\n4.2.2 Instantiation <\/td>\n<\/tr>\n
37<\/td>\n4.2.3 Process macros
4.2.4 Port binding and export binding <\/td>\n<\/tr>\n
38<\/td>\n4.2.5 Setting the time resolution <\/td>\n<\/tr>\n
39<\/td>\n4.3 Simulation
4.3.1 Overview
4.3.2 The scheduling algorithm
4.3.2.1 Overview <\/td>\n<\/tr>\n
40<\/td>\n4.3.2.2 Initialization phase
4.3.2.3 Evaluation phase <\/td>\n<\/tr>\n
41<\/td>\n4.3.2.4 Update phase
4.3.2.5 Delta notification phase <\/td>\n<\/tr>\n
42<\/td>\n4.3.2.6 Timed notification phase
4.3.3 Initialization, cycles, pauses,and suspension in the scheduling algorithm <\/td>\n<\/tr>\n
43<\/td>\n4.4 Running elaboration and simulation
4.4.1 Overview
4.4.2 Function declarations <\/td>\n<\/tr>\n
44<\/td>\n4.4.3 sc_elab_and_sim
4.4.4 sc_argc and sc_argv <\/td>\n<\/tr>\n
45<\/td>\n4.4.5 Running under application control using functions sc_main and sc_start
4.4.5.1 Overview
4.4.5.2 sc_main
4.4.5.3 sc_start <\/td>\n<\/tr>\n
47<\/td>\n4.4.6 Running under control of the kernel
4.5 Elaboration and simulation callbacks
4.5.1 Overview <\/td>\n<\/tr>\n
48<\/td>\n4.5.2 before_end_of_elaboration <\/td>\n<\/tr>\n
49<\/td>\n4.5.3 end_of_elaboration <\/td>\n<\/tr>\n
50<\/td>\n4.5.4 start_of_simulation <\/td>\n<\/tr>\n
51<\/td>\n4.5.5 end_of_simulation
4.6 Other functions related to the scheduler
4.6.1 Function declarations <\/td>\n<\/tr>\n
53<\/td>\n4.6.2 sc_pause <\/td>\n<\/tr>\n
54<\/td>\n4.6.3 sc_suspend_all, sc_unsuspend_all, sc_unsuspendable, and sc_suspendable
4.6.4 sc_stop, sc_set_stop_mode, and sc_get_stop_mode <\/td>\n<\/tr>\n
55<\/td>\n4.6.5 sc_time_stamp <\/td>\n<\/tr>\n
56<\/td>\n4.6.6 sc_delta_count and sc_delta_count_at_current_time
4.6.7 sc_is_running <\/td>\n<\/tr>\n
57<\/td>\n4.6.8 Functions to detect pending activity <\/td>\n<\/tr>\n
58<\/td>\n4.6.9 sc_get_status <\/td>\n<\/tr>\n
59<\/td>\n4.6.10 sc_stage_callback_if
4.6.10.1 Description
4.6.10.2 Class definition
4.6.10.3 stage_callback <\/td>\n<\/tr>\n
61<\/td>\n4.6.11 sc_register_stage_callback
4.6.12 sc_unregister_stage_callback
4.6.13 Callbacks execution <\/td>\n<\/tr>\n
62<\/td>\n5. Core language class definitions
5.1 Class header files
5.1.1 Overview
5.1.2 #include “systemc”
5.1.3 #include “systemc.h” <\/td>\n<\/tr>\n
63<\/td>\n5.2 sc_module
5.2.1 Description
5.2.2 Class definition <\/td>\n<\/tr>\n
66<\/td>\n5.2.3 Constraints on usage
5.2.4 kind
5.2.5 SC_MODULE <\/td>\n<\/tr>\n
67<\/td>\n5.2.6 Constructors
5.2.7 SC_CTOR <\/td>\n<\/tr>\n
68<\/td>\n5.2.8 SC_METHOD, SC_THREAD, SC_CTHREAD <\/td>\n<\/tr>\n
69<\/td>\n5.2.9 SC_NAMED
5.2.10 Method process <\/td>\n<\/tr>\n
70<\/td>\n5.2.11 Thread and clocked thread processes <\/td>\n<\/tr>\n
71<\/td>\n5.2.12 Clocked thread processes <\/td>\n<\/tr>\n
73<\/td>\n5.2.13 reset_signal_is and async_reset_signal_is <\/td>\n<\/tr>\n
74<\/td>\n5.2.14 sensitive <\/td>\n<\/tr>\n
75<\/td>\n5.2.15 dont_initialize <\/td>\n<\/tr>\n
76<\/td>\n5.2.16 set_stack_size
5.2.17 next_trigger <\/td>\n<\/tr>\n
78<\/td>\n5.2.18 wait <\/td>\n<\/tr>\n
79<\/td>\n5.2.19 Positional port binding <\/td>\n<\/tr>\n
81<\/td>\n5.2.20 before_end_of_elaboration, end_of_elaboration, start_of_simulation, end_of_simulation
5.2.21 get_child_objects and get_child_events <\/td>\n<\/tr>\n
82<\/td>\n5.2.22 sc_gen_unique_name
5.2.23 sc_behavior and sc_channel <\/td>\n<\/tr>\n
83<\/td>\n5.3 sc_module_name
5.3.1 Description
5.3.2 Class definition <\/td>\n<\/tr>\n
84<\/td>\n5.3.3 Constraints on usage
5.3.4 Module hierarchy <\/td>\n<\/tr>\n
85<\/td>\n5.3.5 Member functions <\/td>\n<\/tr>\n
86<\/td>\n5.4 sc_sensitive\u2020
5.4.1 Description
5.4.2 Class definition
5.4.3 Constraints on usage
5.4.4 operator<< <\/td>\n<\/tr>\n
87<\/td>\n5.5 sc_spawn_options and sc_spawn
5.5.1 Description
5.5.2 Class definition <\/td>\n<\/tr>\n
89<\/td>\n5.5.3 Constraints on usage
5.5.4 Constructors
5.5.5 Member functions <\/td>\n<\/tr>\n
90<\/td>\n5.5.6 sc_spawn <\/td>\n<\/tr>\n
93<\/td>\n5.5.7 SC_FORK and SC_JOIN <\/td>\n<\/tr>\n
94<\/td>\n5.6 sc_process_handle
5.6.1 Description
5.6.2 Class definition <\/td>\n<\/tr>\n
96<\/td>\n5.6.3 Constraints on usage
5.6.4 Constructors
5.6.5 Member functions <\/td>\n<\/tr>\n
99<\/td>\n5.6.6 Member functions for process control
5.6.6.1 Overview <\/td>\n<\/tr>\n
104<\/td>\n5.6.6.2 suspend and resume <\/td>\n<\/tr>\n
106<\/td>\n5.6.6.3 disable and enable <\/td>\n<\/tr>\n
107<\/td>\n5.6.6.4 Member functions to reset processes
5.6.6.5 kill <\/td>\n<\/tr>\n
108<\/td>\n5.6.6.6 reset <\/td>\n<\/tr>\n
109<\/td>\n5.6.6.7 sc_unwind_exception <\/td>\n<\/tr>\n
110<\/td>\n5.6.6.8 is_unwinding
5.6.6.9 reset_event
5.6.6.10 sync_reset_on and sync_reset_off <\/td>\n<\/tr>\n
112<\/td>\n5.6.6.11 throw_it <\/td>\n<\/tr>\n
113<\/td>\n5.6.6.12 Interactions between member functions for process control <\/td>\n<\/tr>\n
115<\/td>\n5.6.7 sc_get_current_process_handle <\/td>\n<\/tr>\n
116<\/td>\n5.6.8 sc_is_unwinding <\/td>\n<\/tr>\n
117<\/td>\n5.7 sc_event_finder and sc_event_finder_t
5.7.1 Description
5.7.2 Class definition
5.7.3 Constraints on usage <\/td>\n<\/tr>\n
119<\/td>\n5.8 sc_event_and_list and sc_event_or_list
5.8.1 Description
5.8.2 Class definition <\/td>\n<\/tr>\n
120<\/td>\n5.8.3 Constraints and usage
5.8.4 Constructors, destructor, assignment
5.8.5 Member functions and operators <\/td>\n<\/tr>\n
122<\/td>\n5.9 sc_event_and_expr\u2020 and sc_event_or_expr\u2020
5.9.1 Description
5.9.2 Class definition <\/td>\n<\/tr>\n
123<\/td>\n5.9.3 Constraints on usage
5.9.4 Operators <\/td>\n<\/tr>\n
124<\/td>\n5.10 sc_event
5.10.1 Description
5.10.2 Class definition <\/td>\n<\/tr>\n
125<\/td>\n5.10.3 Constraints on usage
5.10.4 Constructors, destructor, and event naming <\/td>\n<\/tr>\n
126<\/td>\n5.10.5 Functions for naming and hierarchy traversal <\/td>\n<\/tr>\n
127<\/td>\n5.10.6 notify and cancel <\/td>\n<\/tr>\n
128<\/td>\n5.10.7 Event lists
5.10.8 None event
5.10.9 Multiple event notifications <\/td>\n<\/tr>\n
129<\/td>\n5.11 sc_time
5.11.1 Description
5.11.2 Class definition <\/td>\n<\/tr>\n
130<\/td>\n5.11.3 Constructors <\/td>\n<\/tr>\n
131<\/td>\n5.11.4 Functions and operators
5.11.5 Time resolution <\/td>\n<\/tr>\n
132<\/td>\n5.11.6 sc_max_time
5.11.7 SC_ZERO_TIME
5.12 sc_port
5.12.1 Description
5.12.2 Class definition <\/td>\n<\/tr>\n
134<\/td>\n5.12.3 Template parameters <\/td>\n<\/tr>\n
135<\/td>\n5.12.4 Constraints on usage <\/td>\n<\/tr>\n
136<\/td>\n5.12.5 Constructors
5.12.6 kind
5.12.7 Named port binding <\/td>\n<\/tr>\n
137<\/td>\n5.12.8 Member functions for bound ports and port-to-port binding
5.12.8.1 Overview <\/td>\n<\/tr>\n
138<\/td>\n5.12.8.2 size
5.12.8.3 operator-> <\/td>\n<\/tr>\n
139<\/td>\n5.12.8.4 operator[] <\/td>\n<\/tr>\n
140<\/td>\n5.12.8.5 get_interface <\/td>\n<\/tr>\n
141<\/td>\n5.12.8.6 get_interface_type
5.12.9 before_end_of_elaboration, end_of_elaboration, start_of_simulation, end_of_simulation
5.13 sc_export
5.13.1 Description
5.13.2 Class definition <\/td>\n<\/tr>\n
142<\/td>\n5.13.3 Template parameters
5.13.4 Constraints on usage <\/td>\n<\/tr>\n
143<\/td>\n5.13.5 Constructors
5.13.6 kind
5.13.7 Export binding <\/td>\n<\/tr>\n
144<\/td>\n5.13.8 Member functions for bound exports and export-to-export binding
5.13.8.1 Overview <\/td>\n<\/tr>\n
145<\/td>\n5.13.8.2 operator-> and operator IF&
5.13.8.3 get_interface
5.13.8.4 get_interface_type
5.13.9 before_end_of_elaboration, end_of_elaboration, start_of_simulation, end_of_simulation
5.14 sc_interface
5.14.1 Description <\/td>\n<\/tr>\n
146<\/td>\n5.14.2 Class definition
5.14.3 Constraints on usage
5.14.4 register_port <\/td>\n<\/tr>\n
147<\/td>\n5.14.5 default_event <\/td>\n<\/tr>\n
148<\/td>\n5.15 sc_prim_channel
5.15.1 Description
5.15.2 Class definition <\/td>\n<\/tr>\n
149<\/td>\n5.15.3 Constraints on usage
5.15.4 Constructors, destructor, and hierarchical names <\/td>\n<\/tr>\n
150<\/td>\n5.15.5 kind
5.15.6 request_update and update <\/td>\n<\/tr>\n
151<\/td>\n5.15.7 async_attach_suspending and async_detach_suspending
5.15.8 next_trigger and wait <\/td>\n<\/tr>\n
152<\/td>\n5.15.9 before_end_of_elaboration, end_of_elaboration, start_of_simulation, end_of_simulation <\/td>\n<\/tr>\n
153<\/td>\n5.16 sc_object
5.16.1 Description
5.16.2 Class definition <\/td>\n<\/tr>\n
154<\/td>\n5.16.3 Constraints on usage
5.16.4 Constructors and destructor <\/td>\n<\/tr>\n
155<\/td>\n5.16.5 name, basename, and kind <\/td>\n<\/tr>\n
156<\/td>\n5.16.6 print and dump
5.16.7 Functions for object hierarchy traversal <\/td>\n<\/tr>\n
158<\/td>\n5.16.8 Member functions for attributes <\/td>\n<\/tr>\n
159<\/td>\n5.16.9 get_hierarchy_scope
5.17 Hierarchical naming of objects and events
5.17.1 Overview <\/td>\n<\/tr>\n
160<\/td>\n5.17.2 sc_hierarchical_name_exists
5.17.3 sc_register_hierarchical_name, sc_unregister_hierarchical_name <\/td>\n<\/tr>\n
161<\/td>\n5.18 sc_attr_base
5.18.1 Description
5.18.2 Class definition
5.18.3 Member functions <\/td>\n<\/tr>\n
162<\/td>\n5.19 sc_attribute
5.19.1 Description
5.19.2 Class definition
5.19.3 Template parameters
5.19.4 Member functions and data members
5.20 sc_attr_cltn
5.20.1 Description
5.20.2 Class definition <\/td>\n<\/tr>\n
163<\/td>\n5.20.3 Constraints on usage
5.20.4 Iterators <\/td>\n<\/tr>\n
164<\/td>\n5.21 sc_hierarchy_scope
5.21.1 Description
5.21.2 Class definition
5.21.3 Constraints on usage
5.21.4 Constructor
5.21.5 get_root <\/td>\n<\/tr>\n
166<\/td>\n6. Predefined channel class definitions
6.1 sc_signal_in_if
6.1.1 Description
6.1.2 Class definition
6.1.3 Member functions <\/td>\n<\/tr>\n
167<\/td>\n6.2 sc_signal_in_if and sc_signal_in_if
6.2.1 Description
6.2.2 Class definition <\/td>\n<\/tr>\n
168<\/td>\n6.2.3 Member functions
6.3 sc_signal_inout_if
6.3.1 Description
6.3.2 Class definition <\/td>\n<\/tr>\n
169<\/td>\n6.3.3 Member functions
6.4 sc_signal
6.4.1 Description <\/td>\n<\/tr>\n
170<\/td>\n6.4.2 Class definition
6.4.3 Template parameter T <\/td>\n<\/tr>\n
171<\/td>\n6.4.4 Reading and writing signals <\/td>\n<\/tr>\n
172<\/td>\n6.4.5 Constructors
6.4.6 register_port <\/td>\n<\/tr>\n
173<\/td>\n6.4.7 Member functions for reading
6.4.8 Member functions for writing
6.4.9 Member functions for events <\/td>\n<\/tr>\n
174<\/td>\n6.4.10 Diagnostic member functions
6.4.11 operator<< <\/td>\n<\/tr>\n
175<\/td>\n6.5 sc_signal and sc_signal
6.5.1 Description
6.5.2 Class definition <\/td>\n<\/tr>\n
177<\/td>\n6.5.3 Member functions <\/td>\n<\/tr>\n
178<\/td>\n6.6 sc_buffer
6.6.1 Description
6.6.2 Class definition
6.6.3 Constructors <\/td>\n<\/tr>\n
179<\/td>\n6.6.4 Member functions <\/td>\n<\/tr>\n
180<\/td>\n6.7 sc_clock
6.7.1 Description
6.7.2 Class definition <\/td>\n<\/tr>\n
181<\/td>\n6.7.3 Characteristic properties
6.7.4 Constructors
6.7.5 write <\/td>\n<\/tr>\n
182<\/td>\n6.7.6 Diagnostic member functions
6.7.7 before_end_of_elaboration
6.7.8 sc_in_clk
6.8 sc_in
6.8.1 Description
6.8.2 Class definition <\/td>\n<\/tr>\n
183<\/td>\n6.8.3 Member functions <\/td>\n<\/tr>\n
184<\/td>\n6.8.4 sc_trace
6.8.5 end_of_elaboration
6.9 sc_in and sc_in
6.9.1 Description
6.9.2 Class definition <\/td>\n<\/tr>\n
186<\/td>\n6.9.3 Member functions <\/td>\n<\/tr>\n
187<\/td>\n6.10 sc_inout
6.10.1 Description
6.10.2 Class definition <\/td>\n<\/tr>\n
188<\/td>\n6.10.3 Member functions
6.10.4 initialize
6.10.5 sc_trace <\/td>\n<\/tr>\n
189<\/td>\n6.10.6 end_of_elaboration
6.10.7 Binding
6.11 sc_inout and sc_inout
6.11.1 Description
6.11.2 Class definition <\/td>\n<\/tr>\n
191<\/td>\n6.11.3 Member functions
6.12 sc_out
6.12.1 Description
6.12.2 Class definition <\/td>\n<\/tr>\n
192<\/td>\n6.12.3 Member functions
6.13 sc_signal_resolved
6.13.1 Description
6.13.2 Class definition <\/td>\n<\/tr>\n
193<\/td>\n6.13.3 Constructors
6.13.4 Resolution semantics <\/td>\n<\/tr>\n
194<\/td>\n6.13.5 Member functions <\/td>\n<\/tr>\n
195<\/td>\n6.14 sc_in_resolved
6.14.1 Description
6.14.2 Class definition <\/td>\n<\/tr>\n
196<\/td>\n6.14.3 Member functions
6.15 sc_inout_resolved
6.15.1 Description
6.15.2 Class definition <\/td>\n<\/tr>\n
197<\/td>\n6.15.3 Member functions
6.16 sc_out_resolved
6.16.1 Description
6.16.2 Class definition <\/td>\n<\/tr>\n
198<\/td>\n6.16.3 Member functions
6.17 sc_signal_rv
6.17.1 Description
6.17.2 Class definition <\/td>\n<\/tr>\n
199<\/td>\n6.17.3 Semantics and member functions
6.18 sc_in_rv
6.18.1 Description
6.18.2 Class definition <\/td>\n<\/tr>\n
200<\/td>\n6.18.3 Member functions
6.19 sc_inout_rv
6.19.1 Description
6.19.2 Class definition <\/td>\n<\/tr>\n
201<\/td>\n6.19.3 Member functions
6.20 sc_out_rv
6.20.1 Description
6.20.2 Class definition <\/td>\n<\/tr>\n
202<\/td>\n6.20.3 Member functions
6.21 sc_fifo_in_if
6.21.1 Description
6.21.2 Class definition <\/td>\n<\/tr>\n
203<\/td>\n6.21.3 Member functions
6.22 sc_fifo_out_if
6.22.1 Description
6.22.2 Class definition <\/td>\n<\/tr>\n
204<\/td>\n6.22.3 Member functions <\/td>\n<\/tr>\n
205<\/td>\n6.23 sc_fifo
6.23.1 Description
6.23.2 Class definition <\/td>\n<\/tr>\n
206<\/td>\n6.23.3 Template parameter T
6.23.4 Constructors
6.23.5 register_port <\/td>\n<\/tr>\n
207<\/td>\n6.23.6 Member functions for reading
6.23.7 Member functions for writing <\/td>\n<\/tr>\n
208<\/td>\n6.23.8 The update phase
6.23.9 Member functions for events
6.23.10 Member functions for available values and free slots
6.23.11 Diagnostic member functions <\/td>\n<\/tr>\n
209<\/td>\n6.23.12 operator<<
6.24 sc_fifo_in
6.24.1 Description <\/td>\n<\/tr>\n
210<\/td>\n6.24.2 Class definition
6.24.3 Member functions
6.25 sc_fifo_out
6.25.1 Description <\/td>\n<\/tr>\n
211<\/td>\n6.25.2 Class definition
6.25.3 Member functions <\/td>\n<\/tr>\n
213<\/td>\n6.26 sc_mutex_if
6.26.1 Description
6.26.2 Class definition
6.26.3 Member functions
6.27 sc_mutex
6.27.1 Description <\/td>\n<\/tr>\n
214<\/td>\n6.27.2 Class definition
6.27.3 Constructors
6.27.4 Member functions <\/td>\n<\/tr>\n
215<\/td>\n6.28 sc_semaphore_if
6.28.1 Description
6.28.2 Class definition <\/td>\n<\/tr>\n
216<\/td>\n6.28.3 Member functions
6.29 sc_semaphore
6.29.1 Description
6.29.2 Class definition
6.29.3 Constructors <\/td>\n<\/tr>\n
217<\/td>\n6.29.4 Member functions
6.30 sc_event_queue
6.30.1 Description <\/td>\n<\/tr>\n
218<\/td>\n6.30.2 Class definition
6.30.3 Constraints on usage
6.30.4 Constructors
6.30.5 kind <\/td>\n<\/tr>\n
219<\/td>\n6.30.6 Member functions <\/td>\n<\/tr>\n
220<\/td>\n6.31 sc_stub, sc_unbound, sc_tie <\/td>\n<\/tr>\n
221<\/td>\n7. SystemC data types
7.1 Introduction <\/td>\n<\/tr>\n
223<\/td>\n7.2 Common characteristics
7.2.1 Overview <\/td>\n<\/tr>\n
224<\/td>\n7.2.2 Initialization and assignment operators
7.2.3 Precision of arithmetic expressions <\/td>\n<\/tr>\n
225<\/td>\n7.2.4 Base class default word length <\/td>\n<\/tr>\n
226<\/td>\n7.2.5 Word length
7.2.6 Bit-select <\/td>\n<\/tr>\n
227<\/td>\n7.2.7 Part-select <\/td>\n<\/tr>\n
228<\/td>\n7.2.8 Concatenation <\/td>\n<\/tr>\n
229<\/td>\n7.2.9 Reduction operators
7.2.10 Integer conversion <\/td>\n<\/tr>\n
230<\/td>\n7.2.11 String input and output
7.2.12 Conversion of application-defined types in integer expressions <\/td>\n<\/tr>\n
231<\/td>\n7.3 String literals <\/td>\n<\/tr>\n
233<\/td>\n7.4 sc_value_base\u2020
7.4.1 Description
7.4.2 Class definition
7.4.3 Constraints on usage
7.4.4 Member functions <\/td>\n<\/tr>\n
234<\/td>\n7.5 Limited-precision integer types
7.5.1 Type definitions <\/td>\n<\/tr>\n
235<\/td>\n7.5.2 sc_int_base
7.5.2.1 Description
7.5.2.2 Class definition <\/td>\n<\/tr>\n
237<\/td>\n7.5.2.3 Constraints on usage
7.5.2.4 Constructors
7.5.2.5 Assignment operators
7.5.2.6 Implicit type conversion <\/td>\n<\/tr>\n
238<\/td>\n7.5.2.7 Explicit type conversion
7.5.2.8 Arithmetic, bitwise, and comparison operators <\/td>\n<\/tr>\n
239<\/td>\n7.5.2.9 Other member functions
7.5.3 sc_uint_base
7.5.3.1 Description
7.5.3.2 Class definition <\/td>\n<\/tr>\n
241<\/td>\n7.5.3.3 Constraints on usage
7.5.3.4 Constructors <\/td>\n<\/tr>\n
242<\/td>\n7.5.3.5 Assignment operators
7.5.3.6 Implicit type conversion
7.5.3.7 Explicit type conversion
7.5.3.8 Arithmetic, bitwise, and comparison operators <\/td>\n<\/tr>\n
243<\/td>\n7.5.3.9 Other member functions
7.5.4 sc_int
7.5.4.1 Description <\/td>\n<\/tr>\n
244<\/td>\n7.5.4.2 Class definition <\/td>\n<\/tr>\n
245<\/td>\n7.5.4.3 Constraints on usage
7.5.4.4 Constructors
7.5.4.5 Assignment operators
7.5.4.6 Arithmetic and bitwise operators <\/td>\n<\/tr>\n
246<\/td>\n7.5.5 sc_uint
7.5.5.1 Description
7.5.5.2 Class definition <\/td>\n<\/tr>\n
247<\/td>\n7.5.5.3 Constraints on usage
7.5.5.4 Constructors <\/td>\n<\/tr>\n
248<\/td>\n7.5.5.5 Assignment operators
7.5.5.6 Arithmetic and bitwise operators <\/td>\n<\/tr>\n
249<\/td>\n7.5.6 Bit-selects
7.5.6.1 Description
7.5.6.2 Class definition <\/td>\n<\/tr>\n
251<\/td>\n7.5.6.3 Constraints on usage <\/td>\n<\/tr>\n
252<\/td>\n7.5.6.4 Assignment operators
7.5.6.5 Implicit type conversion
7.5.6.6 Other member functions
7.5.7 Part-selects
7.5.7.1 Description
7.5.7.2 Class definition <\/td>\n<\/tr>\n
256<\/td>\n7.5.7.3 Constraints on usage
7.5.7.4 Assignment operators
7.5.7.5 Implicit type conversion <\/td>\n<\/tr>\n
257<\/td>\n7.5.7.6 Explicit type conversion
7.5.7.7 Other member functions
7.6 Finite-precision integer types
7.6.1 Type definitions
7.6.2 Constraints on usage <\/td>\n<\/tr>\n
258<\/td>\n7.6.3 sc_signed
7.6.3.1 Description
7.6.3.2 Class definition <\/td>\n<\/tr>\n
260<\/td>\n7.6.3.3 Constraints on usage
7.6.3.4 Constructors
7.6.3.5 Assignment operators <\/td>\n<\/tr>\n
261<\/td>\n7.6.3.6 Explicit type conversion
7.6.3.7 Arithmetic, bitwise, and comparison operators <\/td>\n<\/tr>\n
264<\/td>\n7.6.3.8 Other member functions
7.6.4 sc_unsigned
7.6.4.1 Description
7.6.4.2 Class definition <\/td>\n<\/tr>\n
266<\/td>\n7.6.4.3 Constraints on usage
7.6.4.4 Constructors
7.6.4.5 Assignment operators <\/td>\n<\/tr>\n
267<\/td>\n7.6.4.6 Explicit type conversion
7.6.4.7 Arithmetic, bitwise, and comparison operators <\/td>\n<\/tr>\n
270<\/td>\n7.6.4.8 Other member functions
7.6.5 sc_bigint
7.6.5.1 Description
7.6.5.2 Class definition <\/td>\n<\/tr>\n
271<\/td>\n7.6.5.3 Constraints on usage <\/td>\n<\/tr>\n
272<\/td>\n7.6.5.4 Constructors
7.6.5.5 Assignment operators
7.6.6 sc_biguint
7.6.6.1 Description
7.6.6.2 Class definition <\/td>\n<\/tr>\n
274<\/td>\n7.6.6.3 Constraints on usage
7.6.6.4 Constructors
7.6.6.5 Assignment operators
7.6.7 Bit-selects
7.6.7.1 Description
7.6.7.2 Class definition <\/td>\n<\/tr>\n
277<\/td>\n7.6.7.3 Constraints on usage
7.6.7.4 Assignment operators
7.6.7.5 Implicit type conversion <\/td>\n<\/tr>\n
278<\/td>\n7.6.7.6 Other member functions
7.6.8 Part-selects
7.6.8.1 Description
7.6.8.2 Class definition <\/td>\n<\/tr>\n
282<\/td>\n7.6.8.3 Constraints on usage
7.6.8.4 Assignment operators
7.6.8.5 Implicit type conversion
7.6.8.6 Explicit type conversion <\/td>\n<\/tr>\n
283<\/td>\n7.6.8.7 Other member functions
7.7 Integer concatenations
7.7.1 Description
7.7.2 Class definition <\/td>\n<\/tr>\n
284<\/td>\n7.7.3 Constraints on usage <\/td>\n<\/tr>\n
285<\/td>\n7.7.4 Assignment operators
7.7.5 Implicit type conversion
7.7.6 Explicit type conversion
7.7.7 Other member functions <\/td>\n<\/tr>\n
286<\/td>\n7.8 Generic base proxy class
7.8.1 Description
7.8.2 Class definition
7.8.3 Constraints on usage <\/td>\n<\/tr>\n
287<\/td>\n7.9 Logic and vector types
7.9.1 Type definitions
7.9.2 sc_logic
7.9.2.1 Description <\/td>\n<\/tr>\n
288<\/td>\n7.9.2.2 Class definition <\/td>\n<\/tr>\n
289<\/td>\n7.9.2.3 Constraints on usage
7.9.2.4 Constructors
7.9.2.5 Explicit type conversion <\/td>\n<\/tr>\n
290<\/td>\n7.9.2.6 Bitwise and comparison operators
7.9.2.7 Other member functions <\/td>\n<\/tr>\n
291<\/td>\n7.9.2.8 sc_logic constant definitions
7.9.3 sc_bv_base
7.9.3.1 Description
7.9.3.2 Class definition <\/td>\n<\/tr>\n
293<\/td>\n7.9.3.3 Constraints on usage
7.9.3.4 Constructors <\/td>\n<\/tr>\n
294<\/td>\n7.9.3.5 Assignment operators
7.9.3.6 Explicit type conversion
7.9.3.7 Bitwise and comparison operators <\/td>\n<\/tr>\n
296<\/td>\n7.9.3.8 Other member functions
7.9.4 sc_lv_base
7.9.4.1 Description
7.9.4.2 Class definition <\/td>\n<\/tr>\n
298<\/td>\n7.9.4.3 Constraints on usage
7.9.4.4 Constructors <\/td>\n<\/tr>\n
299<\/td>\n7.9.4.5 Assignment operators
7.9.4.6 Explicit type conversion <\/td>\n<\/tr>\n
300<\/td>\n7.9.4.7 Bitwise and comparison operators <\/td>\n<\/tr>\n
301<\/td>\n7.9.4.8 Other member functions <\/td>\n<\/tr>\n
302<\/td>\n7.9.5 sc_bv
7.9.5.1 Description
7.9.5.2 Class definition <\/td>\n<\/tr>\n
303<\/td>\n7.9.5.3 Constraints on usage
7.9.5.4 Constructors
7.9.5.5 Assignment operators <\/td>\n<\/tr>\n
304<\/td>\n7.9.6 sc_lv
7.9.6.1 Description
7.9.6.2 Class definition <\/td>\n<\/tr>\n
305<\/td>\n7.9.6.3 Constraints on usage
7.9.6.4 Constructors
7.9.6.5 Assignment operators
7.9.7 Bit-selects
7.9.7.1 Description <\/td>\n<\/tr>\n
306<\/td>\n7.9.7.2 Class definition <\/td>\n<\/tr>\n
307<\/td>\n7.9.7.3 Constraints on usage <\/td>\n<\/tr>\n
308<\/td>\n7.9.7.4 Assignment operators
7.9.7.5 Implicit type conversion
7.9.7.6 Explicit type conversion
7.9.7.7 Bitwise and comparison operators <\/td>\n<\/tr>\n
309<\/td>\n7.9.7.8 Other member functions
7.9.8 Part-selects
7.9.8.1 Description
7.9.8.2 Class definition <\/td>\n<\/tr>\n
311<\/td>\n7.9.8.3 Constraints on usage <\/td>\n<\/tr>\n
312<\/td>\n7.9.8.4 Assignment operators
7.9.8.5 Explicit type conversion <\/td>\n<\/tr>\n
313<\/td>\n7.9.8.6 Bitwise and comparison operators <\/td>\n<\/tr>\n
315<\/td>\n7.9.8.7 Other member functions
7.9.9 Concatenations
7.9.9.1 Description
7.9.9.2 Class definition <\/td>\n<\/tr>\n
318<\/td>\n7.9.9.3 Constraints on usage
7.9.9.4 Assignment operators
7.9.9.5 Explicit type conversion <\/td>\n<\/tr>\n
319<\/td>\n7.9.9.6 Bitwise and comparison operators <\/td>\n<\/tr>\n
321<\/td>\n7.9.9.7 Other member functions
7.9.9.8 concat and operator, <\/td>\n<\/tr>\n
322<\/td>\n7.10 Fixed-point types
7.10.1 Overview
7.10.2 Fixed-point representation <\/td>\n<\/tr>\n
323<\/td>\n7.10.3 Fixed-point type conversion <\/td>\n<\/tr>\n
324<\/td>\n7.10.4 Fixed-point data types
7.10.4.1 Overview
7.10.4.2 Finite-precision fixed-point types
7.10.4.3 Limited-precision fixed-point types <\/td>\n<\/tr>\n
325<\/td>\n7.10.5 Fixed-point expressions and operations <\/td>\n<\/tr>\n
328<\/td>\n7.10.6 Bit and part selection
7.10.7 Variable-precision fixed-point value limits <\/td>\n<\/tr>\n
329<\/td>\n7.10.8 Fixed-point word length and mode
7.10.8.1 Overview <\/td>\n<\/tr>\n
330<\/td>\n7.10.8.2 Reading parameter settings <\/td>\n<\/tr>\n
331<\/td>\n7.10.8.3 Value attributes
7.10.9 Conversions to character string
7.10.9.1 Overview <\/td>\n<\/tr>\n
332<\/td>\n7.10.9.2 String shortcut member functions
7.10.9.3 Bit-pattern string conversion
7.10.10 Finite word-length effects
7.10.10.1 Overview <\/td>\n<\/tr>\n
333<\/td>\n7.10.10.2 Overflow modes
7.10.10.3 Overflow for signed fixed-point numbers <\/td>\n<\/tr>\n
335<\/td>\n7.10.10.4 Overflow for unsigned fixed-point numbers <\/td>\n<\/tr>\n
336<\/td>\n7.10.10.5 SC_SAT <\/td>\n<\/tr>\n
337<\/td>\n7.10.10.6 SC_SAT_ZERO <\/td>\n<\/tr>\n
338<\/td>\n7.10.10.7 SC_SAT_SYM <\/td>\n<\/tr>\n
339<\/td>\n7.10.10.8 SC_WRAP <\/td>\n<\/tr>\n
341<\/td>\n7.10.10.9 SC_WRAP_SM <\/td>\n<\/tr>\n
345<\/td>\n7.10.10.10 Quantization modes <\/td>\n<\/tr>\n
346<\/td>\n7.10.10.11 Quantization for signed fixed-point numbers <\/td>\n<\/tr>\n
347<\/td>\n7.10.10.12 Quantization for unsigned fixed-point numbers <\/td>\n<\/tr>\n
349<\/td>\n7.10.10.13 SC_RND <\/td>\n<\/tr>\n
350<\/td>\n7.10.10.14 SC_RND_ZERO <\/td>\n<\/tr>\n
351<\/td>\n7.10.10.15 SC_RND_MIN_INF <\/td>\n<\/tr>\n
352<\/td>\n7.10.10.16 SC_RND_INF <\/td>\n<\/tr>\n
353<\/td>\n7.10.10.17 SC_RND_CONV <\/td>\n<\/tr>\n
354<\/td>\n7.10.10.18 SC_TRN <\/td>\n<\/tr>\n
355<\/td>\n7.10.10.19 SC_TRN_ZERO <\/td>\n<\/tr>\n
356<\/td>\n7.10.11 sc_fxnum
7.10.11.1 Description
7.10.11.2 Class definition <\/td>\n<\/tr>\n
359<\/td>\n7.10.11.3 Constraints on usage <\/td>\n<\/tr>\n
360<\/td>\n7.10.11.4 Assignment operators
7.10.11.5 Implicit type conversion
7.10.11.6 Explicit type conversion
7.10.12 sc_fxnum_fast
7.10.12.1 Description
7.10.12.2 Class definition <\/td>\n<\/tr>\n
364<\/td>\n7.10.12.3 Constraints on usage
7.10.12.4 Assignment operators
7.10.12.5 Implicit type conversion
7.10.12.6 Explicit type conversion <\/td>\n<\/tr>\n
365<\/td>\n7.10.13 sc_fxval
7.10.13.1 Description
7.10.13.2 Class definition <\/td>\n<\/tr>\n
368<\/td>\n7.10.13.3 Constraints on usage
7.10.13.4 Public constructors <\/td>\n<\/tr>\n
369<\/td>\n7.10.13.5 Operators
7.10.13.6 Implicit type conversion
7.10.13.7 Explicit type conversion <\/td>\n<\/tr>\n
370<\/td>\n7.10.14 sc_fxval_fast
7.10.14.1 Description
7.10.14.2 Class definition <\/td>\n<\/tr>\n
373<\/td>\n7.10.14.3 Constraints on usage
7.10.14.4 Public constructors
7.10.14.5 Operators
7.10.14.6 Implicit type conversion
7.10.14.7 Explicit type conversion <\/td>\n<\/tr>\n
374<\/td>\n7.10.15 sc_fix
7.10.15.1 Description
7.10.15.2 Class definition <\/td>\n<\/tr>\n
376<\/td>\n7.10.15.3 Constraints on usage <\/td>\n<\/tr>\n
377<\/td>\n7.10.15.4 Public constructors
7.10.15.5 Assignment operators
7.10.15.6 Bitwise operators
7.10.16 sc_ufix
7.10.16.1 Description
7.10.16.2 Class definition <\/td>\n<\/tr>\n
380<\/td>\n7.10.16.3 Constraints on usage
7.10.16.4 Public constructors
7.10.16.5 Assignment operators
7.10.16.6 Bitwise operators
7.10.17 sc_fix_fast
7.10.17.1 Description
7.10.17.2 Class definition <\/td>\n<\/tr>\n
382<\/td>\n7.10.17.3 Constraints on usage
7.10.17.4 Public constructors <\/td>\n<\/tr>\n
383<\/td>\n7.10.17.5 Assignment operators
7.10.17.6 Bitwise operators
7.10.18 sc_ufix_fast
7.10.18.1 Description
7.10.18.2 Class definition <\/td>\n<\/tr>\n
385<\/td>\n7.10.18.3 Constraints on usage
7.10.18.4 Public constructors <\/td>\n<\/tr>\n
386<\/td>\n7.10.18.5 Assignment operators
7.10.18.6 Bitwise operators
7.10.19 sc_fixed
7.10.19.1 Description
7.10.19.2 Class definition <\/td>\n<\/tr>\n
388<\/td>\n7.10.19.3 Constraints on usage
7.10.19.4 Public constructors
7.10.19.5 Assignment operators
7.10.20 sc_ufixed
7.10.20.1 Description
7.10.20.2 Class definition <\/td>\n<\/tr>\n
390<\/td>\n7.10.20.3 Constraints on usage
7.10.20.4 Public constructors
7.10.20.5 Assignment operators
7.10.21 sc_fixed_fast
7.10.21.1 Description
7.10.21.2 Class definition <\/td>\n<\/tr>\n
392<\/td>\n7.10.21.3 Constraints on usage
7.10.21.4 Public constructors
7.10.21.5 Assignment operators
7.10.22 sc_ufixed_fast
7.10.22.1 Description <\/td>\n<\/tr>\n
393<\/td>\n7.10.22.2 Class definition <\/td>\n<\/tr>\n
394<\/td>\n7.10.22.3 Constraints on usage <\/td>\n<\/tr>\n
395<\/td>\n7.10.22.4 Public constructors
7.10.22.5 Assignment operators
7.10.23 Bit-selects
7.10.23.1 Description
7.10.23.2 Class definition <\/td>\n<\/tr>\n
397<\/td>\n7.10.23.3 Constraints on usage
7.10.23.4 Assignment operators
7.10.23.5 Implicit type conversion <\/td>\n<\/tr>\n
398<\/td>\n7.10.24 Part-selects
7.10.24.1 Description
7.10.24.2 Class definition <\/td>\n<\/tr>\n
403<\/td>\n7.10.24.3 Constraints on usage
7.10.24.4 Assignment operators
7.10.24.5 Bitwise operators
7.10.24.6 Implicit type conversion <\/td>\n<\/tr>\n
404<\/td>\n7.10.24.7 Explicit type conversion
7.11 Contexts
7.11.1 Overview
7.11.2 sc_length_param
7.11.2.1 Description
7.11.2.2 Class definition <\/td>\n<\/tr>\n
405<\/td>\n7.11.2.3 Constraints on usage
7.11.2.4 Public constructors
7.11.2.5 Public member functions
7.11.2.6 Public operators
7.11.3 sc_length_context
7.11.3.1 Description
7.11.3.2 Class definition <\/td>\n<\/tr>\n
406<\/td>\n7.11.3.3 Public constructor
7.11.3.4 Public member functions
7.11.4 sc_fxtype_params
7.11.4.1 Description
7.11.4.2 Class definition <\/td>\n<\/tr>\n
407<\/td>\n7.11.4.3 Constraints on usage
7.11.4.4 Public constructors <\/td>\n<\/tr>\n
408<\/td>\n7.11.4.5 Public member functions
7.11.4.6 Operators <\/td>\n<\/tr>\n
409<\/td>\n7.11.5 sc_fxtype_context
7.11.5.1 Description
7.11.5.2 Class definition
7.11.5.3 Public constructor
7.11.5.4 Public member functions <\/td>\n<\/tr>\n
410<\/td>\n7.11.6 sc_fxcast_switch
7.11.6.1 Description
7.11.6.2 Class definition
7.11.6.3 Public constructors
7.11.6.4 Public member functions
7.11.6.5 Explicit conversion
7.11.6.6 Operators <\/td>\n<\/tr>\n
411<\/td>\n7.11.7 sc_fxcast_context
7.11.7.1 Description
7.11.7.2 Class definition
7.11.7.3 Public constructor
7.11.7.4 Public member functions <\/td>\n<\/tr>\n
412<\/td>\n7.12 Control of string representation
7.12.1 Description
7.12.2 Class definition
7.12.3 Functions <\/td>\n<\/tr>\n
413<\/td>\n8. SystemC utilities
8.1 Trace files
8.1.1 Overview
8.1.2 Class definition and function declarations
8.1.3 sc_trace_file <\/td>\n<\/tr>\n
414<\/td>\n8.1.4 sc_create_vcd_trace_file
8.1.5 sc_close_vcd_trace_file
8.1.6 sc_write_comment
8.1.7 sc_trace <\/td>\n<\/tr>\n
416<\/td>\n8.2 sc_report
8.2.1 Description
8.2.2 Class definition <\/td>\n<\/tr>\n
417<\/td>\n8.2.3 Constraints on usage
8.2.4 sc_verbosity <\/td>\n<\/tr>\n
418<\/td>\n8.2.5 sc_severity
8.2.6 Copy constructor and assignment
8.2.7 Member functions <\/td>\n<\/tr>\n
419<\/td>\n8.3 sc_report_handler
8.3.1 Description
8.3.2 Class definition <\/td>\n<\/tr>\n
421<\/td>\n8.3.3 Constraints on usage
8.3.4 sc_actions <\/td>\n<\/tr>\n
422<\/td>\n8.3.5 report
8.3.6 set_actions <\/td>\n<\/tr>\n
423<\/td>\n8.3.7 stop_after <\/td>\n<\/tr>\n
424<\/td>\n8.3.8 get_count
8.3.9 Verbosity level <\/td>\n<\/tr>\n
425<\/td>\n8.3.10 suppress and force
8.3.11 set_handler <\/td>\n<\/tr>\n
426<\/td>\n8.3.12 get_new_action_id
8.3.13 sc_interrupt_here and sc_stop_here
8.3.14 get_cached_report and clear_cached_report <\/td>\n<\/tr>\n
427<\/td>\n8.3.15 set_log_file_name and get_log_file_name
8.4 sc_exception
8.4.1 Description
8.4.2 Class definition <\/td>\n<\/tr>\n
428<\/td>\n8.5 sc_vector
8.5.1 Description
8.5.2 Class definition <\/td>\n<\/tr>\n
431<\/td>\n8.5.3 Constraints on usage
8.5.4 Constructors and destructors <\/td>\n<\/tr>\n
432<\/td>\n8.5.5 init and create_element <\/td>\n<\/tr>\n
434<\/td>\n8.5.6 Incremental additions to sc_vector during elaboration phase
8.5.7 kind, size, get_elements
8.5.8 operator[] and at <\/td>\n<\/tr>\n
435<\/td>\n8.5.9 Iterators
8.5.10 bind <\/td>\n<\/tr>\n
437<\/td>\n8.5.11 sc_assemble_vector <\/td>\n<\/tr>\n
439<\/td>\n8.6 Utility functions
8.6.1 Function declarations
8.6.2 sc_abs <\/td>\n<\/tr>\n
440<\/td>\n8.6.3 sc_max
8.6.4 sc_min
8.6.5 Version and copyright <\/td>\n<\/tr>\n
442<\/td>\n9. Overview of TLM-2.0 and compliance with TLM-2.0 standard
9.1 Overview <\/td>\n<\/tr>\n
443<\/td>\n9.2 Compliance with the TLM-2.0 standard <\/td>\n<\/tr>\n
444<\/td>\n10. Introduction to TLM-2.0
10.1 Background
10.2 Transaction-level modeling, use cases, and abstraction <\/td>\n<\/tr>\n
445<\/td>\n10.3 Coding styles
10.3.1 Overview
10.3.2 Untimed coding style <\/td>\n<\/tr>\n
446<\/td>\n10.3.3 Loosely-timed coding style and temporal decoupling <\/td>\n<\/tr>\n
447<\/td>\n10.3.4 Synchronization in loosely-timed models
10.3.5 Approximately-timed coding style <\/td>\n<\/tr>\n
448<\/td>\n10.3.6 Characterization of loosely-timed and approximately-timed coding styles
10.3.7 Switching between loosely-timed and approximately-timed modeling
10.3.8 Cycle-accurate modeling
10.3.9 Blocking versus non-blocking transport interfaces <\/td>\n<\/tr>\n
449<\/td>\n10.3.10 Use cases and coding styles
10.4 Initiators, targets, sockets, and transaction bridges <\/td>\n<\/tr>\n
451<\/td>\n10.5 DMI and debug transport interfaces
10.6 Combined interfaces and sockets <\/td>\n<\/tr>\n
452<\/td>\n10.7 Namespaces
10.8 Header files and version numbers
10.8.1 Overview
10.8.2 Software version information
10.8.3 Definitions <\/td>\n<\/tr>\n
453<\/td>\n10.8.4 Rules <\/td>\n<\/tr>\n
454<\/td>\n11. TLM-2.0 core interfaces
11.1 Overview
11.2 Transport interfaces
11.2.1 Overview
11.2.2 Blocking transport interface
11.2.2.1 Introduction <\/td>\n<\/tr>\n
455<\/td>\n11.2.2.2 Class definition
11.2.2.3 The TRANS template argument
11.2.2.4 Rules <\/td>\n<\/tr>\n
456<\/td>\n11.2.2.5 Message sequence chart\u2014blocking transport <\/td>\n<\/tr>\n
457<\/td>\n11.2.2.6 Message sequence chart\u2014temporal decoupling <\/td>\n<\/tr>\n
458<\/td>\n11.2.2.7 Message sequence chart\u2014the time quantum <\/td>\n<\/tr>\n
459<\/td>\n11.2.3 Non-blocking transport interface
11.2.3.1 Introduction
11.2.3.2 Class definition <\/td>\n<\/tr>\n
460<\/td>\n11.2.3.3 The TRANS and PHASE template arguments
11.2.3.4 The nb_transport_fw and nb_transport_bw calls
11.2.3.5 The trans argument <\/td>\n<\/tr>\n
461<\/td>\n11.2.3.6 The phase argument
11.2.3.7 The tlm_sync_enum return value <\/td>\n<\/tr>\n
462<\/td>\n11.2.3.8 tlm_sync_enum summary <\/td>\n<\/tr>\n
463<\/td>\n11.2.3.9 Message sequence chart\u2014using the backward path <\/td>\n<\/tr>\n
464<\/td>\n11.2.3.10 Message sequence chart\u2014using the return path <\/td>\n<\/tr>\n
465<\/td>\n11.2.3.11 Message sequence chart\u2014early completion <\/td>\n<\/tr>\n
466<\/td>\n11.2.3.12 Message sequence chart\u2014timing annotation <\/td>\n<\/tr>\n
467<\/td>\n11.2.4 Timing annotation with the transport interfaces
11.2.4.1 Overview
11.2.4.2 The sc_time argument <\/td>\n<\/tr>\n
470<\/td>\n11.2.5 Migration path from TLM-1
11.3 Direct memory interface
11.3.1 Introduction <\/td>\n<\/tr>\n
471<\/td>\n11.3.2 Class definition <\/td>\n<\/tr>\n
472<\/td>\n11.3.3 get_direct_mem_ptr <\/td>\n<\/tr>\n
473<\/td>\n11.3.4 template argument and tlm_generic_payload class <\/td>\n<\/tr>\n
474<\/td>\n11.3.5 tlm_dmi class <\/td>\n<\/tr>\n
477<\/td>\n11.3.6 invalidate_direct_mem_ptr
11.3.7 DMI versus transport <\/td>\n<\/tr>\n
478<\/td>\n11.3.8 DMI and temporal decoupling
11.3.9 Optimization using a DMI hint
11.4 Debug transport interface
11.4.1 Introduction <\/td>\n<\/tr>\n
479<\/td>\n11.4.2 Class definition
11.4.3 TRANS template argument and tlm_generic_payload class
11.4.4 Rules <\/td>\n<\/tr>\n
482<\/td>\n12. TLM-2.0 global quantum
12.1 Introduction
12.2 Header file
12.3 Class definition <\/td>\n<\/tr>\n
483<\/td>\n12.4 tlm_global_quantum <\/td>\n<\/tr>\n
484<\/td>\n13. Combined TLM-2.0 interfaces and sockets
13.1 Combined interfaces
13.1.1 Introduction
13.1.2 Class definition <\/td>\n<\/tr>\n
485<\/td>\n13.2 Initiator and target sockets
13.2.1 Introduction
13.2.2 Class definition <\/td>\n<\/tr>\n
489<\/td>\n13.2.3 tlm_base_socket_if
13.2.4 tlm_base_initiator_socket_b and tlm_base_target_socket_b <\/td>\n<\/tr>\n
490<\/td>\n13.2.5 tlm_base_initiator_socket and tlm_base_target_socket <\/td>\n<\/tr>\n
492<\/td>\n13.2.6 tlm_initiator_socket and tlm_target_socket <\/td>\n<\/tr>\n
495<\/td>\n14. TLM-2.0 generic payload
14.1 Introduction
14.2 Extensions and interoperability
14.2.1 Overview <\/td>\n<\/tr>\n
496<\/td>\n14.2.2 Use the generic payload directly, with ignorable extensions <\/td>\n<\/tr>\n
497<\/td>\n14.2.3 Define a new protocol traits class containing a typedef for tlm_generic_payload
14.2.4 Define a new protocol traits class and a new transaction type <\/td>\n<\/tr>\n
498<\/td>\n14.3 Generic payload attributes and member functions
14.4 Class definition <\/td>\n<\/tr>\n
500<\/td>\n14.5 Generic payload memory management <\/td>\n<\/tr>\n
504<\/td>\n14.6 Constructors, assignment, and destructor
14.7 Default values and modifiability of attributes <\/td>\n<\/tr>\n
506<\/td>\n14.8 Option attribute <\/td>\n<\/tr>\n
508<\/td>\n14.9 Command attribute <\/td>\n<\/tr>\n
509<\/td>\n14.10 Address attribute
14.11 Data pointer attribute <\/td>\n<\/tr>\n
510<\/td>\n14.12 Data length attribute
14.13 Byte enable pointer attribute <\/td>\n<\/tr>\n
511<\/td>\n14.14 Byte enable length attribute <\/td>\n<\/tr>\n
512<\/td>\n14.15 Streaming width attribute <\/td>\n<\/tr>\n
513<\/td>\n14.16 DMI allowed attribute
14.17 Response status attribute
14.17.1 Overview <\/td>\n<\/tr>\n
514<\/td>\n14.17.2 The standard error response <\/td>\n<\/tr>\n
517<\/td>\n14.18 Endianness
14.18.1 Introduction <\/td>\n<\/tr>\n
518<\/td>\n14.18.2 Rules <\/td>\n<\/tr>\n
521<\/td>\n14.19 Helper functions to determine host endianness
14.19.1 Introduction
14.19.2 Definition
14.19.3 Rules
14.20 Helper functions for endianness conversion
14.20.1 Introduction <\/td>\n<\/tr>\n
522<\/td>\n14.20.2 Definition <\/td>\n<\/tr>\n
523<\/td>\n14.20.3 Rules <\/td>\n<\/tr>\n
524<\/td>\n14.21 Generic payload extensions
14.21.1 Introduction
14.21.1.1 Overview
14.21.1.2 Ignorable extensions
14.21.1.3 Non-ignorable and mandatory extensions
14.21.2 Rationale <\/td>\n<\/tr>\n
525<\/td>\n14.21.3 Extension pointers, objects and transaction bridges
14.21.4 Rules <\/td>\n<\/tr>\n
531<\/td>\n15. TLM-2.0 base protocol and phases
15.1 Phases
15.1.1 Introduction
15.1.2 Class definition <\/td>\n<\/tr>\n
532<\/td>\n15.1.3 Rules <\/td>\n<\/tr>\n
533<\/td>\n15.2 Base protocol
15.2.1 Introduction <\/td>\n<\/tr>\n
534<\/td>\n15.2.2 Class definition
15.2.3 Base protocol phase sequences <\/td>\n<\/tr>\n
536<\/td>\n15.2.4 Permitted phase transitions <\/td>\n<\/tr>\n
539<\/td>\n15.2.5 Ignorable phases <\/td>\n<\/tr>\n
541<\/td>\n15.2.6 Base protocol timing parameters and flow control <\/td>\n<\/tr>\n
545<\/td>\n15.2.7 Base protocol rules concerning timing annotation <\/td>\n<\/tr>\n
546<\/td>\n15.2.8 Base protocol rules concerning b_transport
15.2.9 Base protocol rules concerning request and response ordering <\/td>\n<\/tr>\n
547<\/td>\n15.2.10 Base protocol rules for switching between b_transport and nb_transport <\/td>\n<\/tr>\n
548<\/td>\n15.2.11 Other base protocol rules
15.2.12 Summary of base protocol transaction ordering rules <\/td>\n<\/tr>\n
549<\/td>\n15.2.13 Guidelines for creating base-protocol-compliant components
15.2.13.1 Overview
15.2.13.2 Guidelines for creating a base protocol initiator <\/td>\n<\/tr>\n
550<\/td>\n15.2.13.3 Guidelines for creating an initiator that calls nb_transport
15.2.13.4 Guidelines for creating a base protocol target
15.2.13.5 Guidelines for creating a target that calls nb_transport <\/td>\n<\/tr>\n
551<\/td>\n15.2.13.6 Guidelines for creating a base protocol interconnect component <\/td>\n<\/tr>\n
552<\/td>\n16. TLM-2.0 utilities
16.1 Overview
16.2 Convenience sockets
16.2.1 Introduction
16.2.1.1 Overview
16.2.1.2 Summary of standard and convenience socket types <\/td>\n<\/tr>\n
553<\/td>\n16.2.1.3 Permitted socket bindings
16.2.2 Simple sockets
16.2.2.1 Introduction <\/td>\n<\/tr>\n
554<\/td>\n16.2.2.2 Class definition <\/td>\n<\/tr>\n
555<\/td>\n16.2.2.3 Header file <\/td>\n<\/tr>\n
556<\/td>\n16.2.2.4 Rules
16.2.2.5 Simple target socket b\/nb conversion <\/td>\n<\/tr>\n
559<\/td>\n16.2.3 Tagged simple sockets
16.2.3.1 Introduction <\/td>\n<\/tr>\n
560<\/td>\n16.2.3.2 Header file
16.2.3.3 Class definition <\/td>\n<\/tr>\n
562<\/td>\n16.2.3.4 Rules
16.2.4 Multi-sockets
16.2.4.1 Introduction <\/td>\n<\/tr>\n
563<\/td>\n16.2.4.2 Header file
16.2.4.3 Class definition <\/td>\n<\/tr>\n
565<\/td>\n16.2.4.4 Rules <\/td>\n<\/tr>\n
568<\/td>\n16.3 Quantum keeper
16.3.1 Introduction <\/td>\n<\/tr>\n
569<\/td>\n16.3.2 Header file
16.3.3 Class definition
16.3.4 General guidelines for processes using temporal decoupling <\/td>\n<\/tr>\n
570<\/td>\n16.3.5 tlm_quantumkeeper <\/td>\n<\/tr>\n
572<\/td>\n16.4 Payload event queue
16.4.1 Introduction <\/td>\n<\/tr>\n
573<\/td>\n16.4.2 Header file
16.4.3 Class definition
16.4.4 Rules <\/td>\n<\/tr>\n
574<\/td>\n16.5 Instance-specific extensions
16.5.1 Introduction <\/td>\n<\/tr>\n
575<\/td>\n16.5.2 Header file
16.5.3 Class definition <\/td>\n<\/tr>\n
577<\/td>\n17. TLM-1 message passing interface and analysis ports
17.1 Overview
17.2 Put, get, peek, and transport interfaces
17.2.1 Description
17.2.2 Class definition <\/td>\n<\/tr>\n
579<\/td>\n17.2.3 Blocking versus non-blocking interfaces <\/td>\n<\/tr>\n
580<\/td>\n17.2.4 Blocking interface methods
17.2.5 Non-blocking interface methods <\/td>\n<\/tr>\n
581<\/td>\n17.2.6 Argument passing and transaction lifetime <\/td>\n<\/tr>\n
582<\/td>\n17.2.7 Constraints on the transaction data type
17.3 TLM-1 fifo interfaces
17.3.1 Description
17.3.2 Class definition <\/td>\n<\/tr>\n
583<\/td>\n17.3.3 Member functions <\/td>\n<\/tr>\n
584<\/td>\n17.4 tlm_fifo
17.4.1 Description
17.4.2 Class definition <\/td>\n<\/tr>\n
585<\/td>\n17.4.3 Template parameter T
17.4.4 Constructors and destructor <\/td>\n<\/tr>\n
586<\/td>\n17.4.5 Member functions <\/td>\n<\/tr>\n
587<\/td>\n17.4.6 Delta cycle semantics <\/td>\n<\/tr>\n
589<\/td>\n17.5 Analysis interface and analysis ports
17.5.1 Overview
17.5.2 Class definition <\/td>\n<\/tr>\n
590<\/td>\n17.5.3 Rules <\/td>\n<\/tr>\n
592<\/td>\nAnnex A (informative) Glossary <\/td>\n<\/tr>\n
609<\/td>\nAnnex B (informative) Introduction to SystemC <\/td>\n<\/tr>\n
613<\/td>\nAnnex C (informative) Deprecated features <\/td>\n<\/tr>\n
615<\/td>\nAnnex D (informative) Changes between IEEE Std 1666-2011 and IEEE Std 1666-2023 <\/td>\n<\/tr>\n
618<\/td>\nBack cover <\/td>\n<\/tr>\n<\/table>\n","protected":false},"excerpt":{"rendered":"

IEEE Standard for Standard SystemC\u00ae Language Reference Manual (Published)<\/b><\/p>\n\n\n\n\n
Published By<\/td>\nPublication Date<\/td>\nNumber of Pages<\/td>\n<\/tr>\n
IEEE<\/b><\/a><\/td>\n2023<\/td>\n618<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n","protected":false},"featured_media":444378,"template":"","meta":{"rank_math_lock_modified_date":false,"ep_exclude_from_search":false},"product_cat":[2644],"product_tag":[],"class_list":{"0":"post-444371","1":"product","2":"type-product","3":"status-publish","4":"has-post-thumbnail","6":"product_cat-ieee","8":"first","9":"instock","10":"sold-individually","11":"shipping-taxable","12":"purchasable","13":"product-type-simple"},"_links":{"self":[{"href":"https:\/\/pdfstandards.shop\/wp-json\/wp\/v2\/product\/444371","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/pdfstandards.shop\/wp-json\/wp\/v2\/product"}],"about":[{"href":"https:\/\/pdfstandards.shop\/wp-json\/wp\/v2\/types\/product"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/pdfstandards.shop\/wp-json\/wp\/v2\/media\/444378"}],"wp:attachment":[{"href":"https:\/\/pdfstandards.shop\/wp-json\/wp\/v2\/media?parent=444371"}],"wp:term":[{"taxonomy":"product_cat","embeddable":true,"href":"https:\/\/pdfstandards.shop\/wp-json\/wp\/v2\/product_cat?post=444371"},{"taxonomy":"product_tag","embeddable":true,"href":"https:\/\/pdfstandards.shop\/wp-json\/wp\/v2\/product_tag?post=444371"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}