Class: HDLRuby::High::Binary
- Inherits:
-
Low::Binary
- Object
- Low::Expression
- Low::Operation
- Low::Binary
- HDLRuby::High::Binary
- Includes:
- HExpression
- Defined in:
- lib/HDLRuby/hruby_high.rb,
lib/HDLRuby/hruby_rsim.rb,
lib/HDLRuby/hruby_rcsim.rb
Overview
Describes an binary operation.
Constant Summary
Constants included from Low::Low2Symbol
Low::Low2Symbol::Low2SymbolPrefix, Low::Low2Symbol::Low2SymbolTable, Low::Low2Symbol::Symbol2LowTable
Instance Attribute Summary
Attributes included from HExpression
Attributes inherited from Low::Binary
Attributes inherited from Low::Operation
Attributes inherited from Low::Expression
Attributes included from Low::Hparent
Instance Method Summary collapse
-
#execute(mode) ⇒ Object
Execute the expression.
-
#init_sim(systemT) ⇒ Object
Initialize the simulation for system +systemT+.
-
#to_expr ⇒ Object
Converts to a new expression.
-
#to_low ⇒ Object
Converts the binary expression to HDLRuby::Low.
-
#to_rcsim ⇒ Object
Generate the C description of the binary operation.
Methods included from HExpression
#<=>, #[], #as, #coerce, #constant?, #inout, #input, #ljust, #lr, #ls, #match_type, #mux, orig_operator, #orig_operator, #output, #rjust, #rr, #rs, #sdownto, #seach, #sext, #stimes, #supto, #to_bit, #to_signed, #to_unsigned, #to_value, #to_value?, #zext
Methods inherited from Low::Binary
#boolean?, #boolean_in_assign2select, #casts_without_expression!, #clone, #each_deep, #each_node, #each_node_deep, #each_ref_deep, #eql?, #explicit_types, #hash, #immutable?, #initialize, #map_nodes!, #replace_expressions!, #set_left!, #set_right!, #to_c, #to_change, #to_hdr, #to_high, #to_verilog, #to_vhdl, #use_name?
Methods inherited from Low::Operation
#eql?, #explicit_types, #hash, #initialize, #set_operator!, #to_c, #to_hdr, #to_vhdl, #to_viz_node
Methods inherited from Low::Expression
#boolean?, #break_types!, #clone, #each_node, #each_node_deep, #each_ref_deep, #eql?, #explicit_types, #extract_selects_to!, #fix_scope_refnames!, #hash, #immutable?, #initialize, #leftvalue?, #map_nodes!, #replace_expressions!, #replace_names!, #rightvalue?, #set_type!, #signal2subs!, #statement, #to_c, #to_c_expr, #to_hdr, #to_high, #to_vhdl, #to_viz_names, #use_name?
Methods included from Low::Low2Symbol
Methods included from Low::Hparent
#absolute_ref, #hierarchy, #no_parent!, #scope
Constructor Details
This class inherits a constructor from HDLRuby::Low::Binary
Instance Method Details
#execute(mode) ⇒ Object
Execute the expression.
1124 1125 1126 1127 1128 1129 1130 |
# File 'lib/HDLRuby/hruby_rsim.rb', line 1124 def execute(mode) # Recurse on the children. tmpl = self.left.execute(mode) tmpr = self.right.execute(mode) # Apply the operator. return tmpl.send(self.operator,tmpr) end |
#init_sim(systemT) ⇒ Object
Initialize the simulation for system +systemT+.
1117 1118 1119 1120 1121 |
# File 'lib/HDLRuby/hruby_rsim.rb', line 1117 def init_sim(systemT) # Recurse on the children. self.left.init_sim(systemT) self.right.init_sim(systemT) end |
#to_expr ⇒ Object
Converts to a new expression.
3333 3334 3335 3336 |
# File 'lib/HDLRuby/hruby_high.rb', line 3333 def to_expr return Binary.new(self.type, self.operator, self.left.to_expr, self.right.to_expr) end |
#to_low ⇒ Object
Converts the binary expression to HDLRuby::Low.
3339 3340 3341 3342 3343 3344 3345 3346 3347 3348 |
# File 'lib/HDLRuby/hruby_high.rb', line 3339 def to_low # return HDLRuby::Low::Binary.new(self.type.to_low, self.operator, # self.left.to_low, self.right.to_low) binaryL = HDLRuby::Low::Binary.new(self.type.to_low, self.operator, self.left.to_low, self.right.to_low) # # For debugging: set the source high object # binaryL.properties[:low2high] = self.hdr_id # self.properties[:high2low] = binaryL return binaryL end |
#to_rcsim ⇒ Object
Generate the C description of the binary operation.
982 983 984 985 986 987 |
# File 'lib/HDLRuby/hruby_rcsim.rb', line 982 def to_rcsim # Create the binary C object. return RCSim.rcsim_make_binary(self.type.to_rcsim,self.operator, self.left.to_rcsim, self.right.to_rcsim) end |