gem5  v20.1.0.0
sc_lv_base.cc
Go to the documentation of this file.
1 /*****************************************************************************
2 
3  Licensed to Accellera Systems Initiative Inc. (Accellera) under one or
4  more contributor license agreements. See the NOTICE file distributed
5  with this work for additional information regarding copyright ownership.
6  Accellera licenses this file to you under the Apache License, Version 2.0
7  (the "License"); you may not use this file except in compliance with the
8  License. You may obtain a copy of the License at
9 
10  http://www.apache.org/licenses/LICENSE-2.0
11 
12  Unless required by applicable law or agreed to in writing, software
13  distributed under the License is distributed on an "AS IS" BASIS,
14  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
15  implied. See the License for the specific language governing
16  permissions and limitations under the License.
17 
18  *****************************************************************************/
19 
20 /*****************************************************************************
21 
22  sc_lv_base.cpp -- Arbitrary size logic vector class.
23 
24  Original Author: Gene Bushuyev, Synopsys, Inc.
25 
26  *****************************************************************************/
27 
28 /*****************************************************************************
29 
30  MODIFICATION LOG - modifiers, enter your name, affiliation, date and
31  changes you are making here.
32 
33  Name, Affiliation, Date:
34  Description of Modification:
35 
36  *****************************************************************************/
37 
38 
39 // $Log: sc_lv_base.cpp,v $
40 // Revision 1.2 2011/08/24 22:05:40 acg
41 // Torsten Maehne: initialization changes to remove warnings.
42 //
43 // Revision 1.1.1.1 2006/12/15 20:20:04 acg
44 // SystemC 2.3
45 //
46 // Revision 1.3 2006/01/13 18:53:53 acg
47 // Andy Goodrich: added $Log command so that CVS comments are reproduced in
48 // the source.
49 //
50 
51 #include <sstream>
52 
56 
57 namespace sc_dt
58 {
59 
60 // explicit template instantiations
61 template class sc_proxy<sc_lv_base>;
62 template class sc_proxy<sc_bv_base>;
63 
64 void
65 sc_proxy_out_of_bounds(const char *msg, int64 val)
66 {
67  std::stringstream ss;
68  if (msg != NULL)
69  ss << msg;
70  if (val != 0)
71  ss << val;
73 }
74 
75 // ----------------------------------------------------------------------------
76 // CLASS : sc_lv_base
77 //
78 // Arbitrary size logic vector base class.
79 // ----------------------------------------------------------------------------
80 
81 static const sc_digit data_array[] = {
83 };
84 
85 static const sc_digit ctrl_array[] = {
87 };
88 
89 void
90 sc_lv_base::init(int length_, const sc_logic& init_value)
91 {
92  // check the length
93  if (length_ <= 0) {
95  sc_core::sc_abort(); // can't recover from here
96  }
97  // allocate memory for the data and control words
98  m_len = length_;
99  m_size = (m_len - 1) / SC_DIGIT_SIZE + 1;
100  m_data = new sc_digit[m_size * 2];
101  m_ctrl = m_data + m_size;
102  // initialize the bits to 'init_value'
103  sc_digit dw = data_array[init_value.value()];
104  sc_digit cw = ctrl_array[init_value.value()];
105  int sz = m_size;
106  for (int i = 0; i < sz; ++i) {
107  m_data[i] = dw;
108  m_ctrl[i] = cw;
109  }
110  clean_tail();
111 }
112 
113 void
114 sc_lv_base::assign_from_string(const std::string &s)
115 {
116  // s must have been converted to bin
117  int len = m_len;
118  int s_len = s.length() - 1;
119  int min_len = sc_min(len, s_len);
120  int i = 0;
121  for (; i < min_len; ++i) {
122  char c = s[s_len - i - 1];
124  }
125  // if formatted, fill the rest with sign(s), otherwise fill with zeros
126  sc_logic_value_t fill = (s[s_len] == 'F' ? sc_logic_value_t(s[0] - '0')
127  : sc_logic_value_t(0));
128  for (; i < len; ++i) {
129  set_bit(i, fill);
130  }
131 }
132 
133 // constructors
134 sc_lv_base::sc_lv_base(const char *a) :
135  m_len(0), m_size(0), m_data(0), m_ctrl(0)
136 {
137  std::string s = convert_to_bin(a);
138  init(s.length() - 1);
140 }
141 
142 sc_lv_base::sc_lv_base(const char *a, int length_) :
143  m_len(0), m_size(0), m_data(0), m_ctrl(0)
144 {
145  init(length_);
147 }
148 
150  sc_proxy<sc_lv_base>(), m_len(a.m_len), m_size(a.m_size),
151  m_data(new sc_digit[m_size * 2]), m_ctrl(m_data + m_size)
152 {
153  // copy the bits
154  int sz = m_size;
155  for (int i = 0; i < sz; ++i) {
156  m_data[i] = a.m_data[i];
157  m_ctrl[i] = a.m_ctrl[i];
158  }
159 }
160 
161 // assignment operators
162 sc_lv_base &
163 sc_lv_base::operator = (const char *a)
164 {
166  return *this;
167 }
168 
169 // returns true if logic vector contains only 0's and 1's
170 bool
171 sc_lv_base::is_01() const
172 {
173  int sz = m_size;
174  for (int i = 0; i < sz; ++i) {
175  if (m_ctrl[i] != 0) {
176  return false;
177  }
178  }
179  return true;
180 }
181 
182 } // namespace sc_dt
sc_dt::sc_lv_base::assign_from_string
void assign_from_string(const std::string &)
Definition: sc_lv_base.cc:145
messages.hh
sc_dt::SC_DIGIT_ZERO
const sc_digit SC_DIGIT_ZERO
Definition: sc_proxy.hh:139
sc_core::SC_ID_ZERO_LENGTH_
const char SC_ID_ZERO_LENGTH_[]
Definition: messages.cc:40
sc_dt::sc_lv_base::init
void init(int length_, const sc_logic &init_value=SC_LOGIC_X)
Definition: sc_lv_base.cc:121
sc_dt
Definition: sc_bit.cc:67
ArmISA::i
Bitfield< 7 > i
Definition: miscregs_types.hh:63
sc_dt::sc_lv_base::clean_tail
void clean_tail()
Definition: sc_lv_base.hh:326
sc_dt::sc_lv_base::operator=
sc_lv_base & operator=(const sc_proxy< X > &a)
Definition: sc_lv_base.hh:163
sc_dt::sc_digit
unsigned int sc_digit
Definition: sc_nbdefs.hh:197
sc_dt::sc_lv_base::m_len
int m_len
Definition: sc_lv_base.hh:296
sc_dt::sc_lv_base::sc_lv_base
sc_lv_base(int length_=sc_length_param().len())
Definition: sc_lv_base.hh:131
sc_dt::sc_lv_base::is_01
bool is_01() const
Definition: sc_lv_base.cc:202
sc_dt::sc_logic_value_t
sc_logic_value_t
Definition: sc_logic.hh:116
sc_dt::sc_logic::char_to_logic
static const sc_logic_value_t char_to_logic[128]
Definition: sc_logic.hh:178
ArmISA::ss
Bitfield< 21 > ss
Definition: miscregs_types.hh:56
ArmISA::a
Bitfield< 8 > a
Definition: miscregs_types.hh:62
SC_REPORT_ERROR
#define SC_REPORT_ERROR(msg_type, msg)
Definition: sc_report_handler.hh:127
messages.hh
sc_dt::sc_lv_base::m_ctrl
sc_digit * m_ctrl
Definition: sc_lv_base.hh:299
sc_dt::sc_proxy
Definition: sc_proxy.hh:119
sc_dt::int64
int64_t int64
Definition: sc_nbdefs.hh:205
sc_dt::sc_lv_base::m_data
sc_digit * m_data
Definition: sc_lv_base.hh:298
X86ISA::val
Bitfield< 63 > val
Definition: misc.hh:769
sc_dt::sc_min
const T sc_min(const T &a, const T &b)
Definition: functions.hh:59
sc_dt::sc_lv_base::set_bit
void set_bit(int i, value_type value)
Definition: sc_lv_base.hh:314
MipsISA::fill
fill
Definition: pra_constants.hh:54
sc_dt::ctrl_array
static const sc_digit ctrl_array[]
Definition: sc_lv_base.cc:116
sc_dt::sc_lv_base
Definition: sc_lv_base.hh:118
sc_dt::convert_to_bin
const std::string convert_to_bin(const char *s)
Definition: sc_bv_base.cc:190
ArmISA::len
Bitfield< 18, 16 > len
Definition: miscregs_types.hh:439
sc_dt::sc_lv_base::m_size
int m_size
Definition: sc_lv_base.hh:297
sc_core::sc_abort
void sc_abort()
Definition: sc_report.cc:178
sc_dt::SC_DIGIT_SIZE
const int SC_DIGIT_SIZE
Definition: sc_proxy.hh:137
ArmISA::c
Bitfield< 29 > c
Definition: miscregs_types.hh:50
sc_core::SC_ID_OUT_OF_BOUNDS_
const char SC_ID_OUT_OF_BOUNDS_[]
Definition: messages.cc:40
ArmISA::s
Bitfield< 4 > s
Definition: miscregs_types.hh:556
sc_lv_base.hh
sc_dt::data_array
static const sc_digit data_array[]
Definition: sc_lv_base.cc:112
sc_dt::sc_proxy_out_of_bounds
void sc_proxy_out_of_bounds(const char *msg, int64 val)
Definition: sc_lv_base.cc:96

Generated on Wed Sep 30 2020 14:02:14 for gem5 by doxygen 1.8.17