PandA-2024.02
Public Member Functions | Protected Member Functions | Protected Attributes
HDLVarDeclFix Class Reference

Pre-analysis step. More...

#include <hdl_var_decl_fix.hpp>

Inheritance diagram for HDLVarDeclFix:
Inheritance graph
[legend]
Collaboration diagram for HDLVarDeclFix:
Collaboration graph
[legend]

Public Member Functions

 HDLVarDeclFix (const application_managerRef AppM, unsigned int _function_id, const DesignFlowManagerConstRef design_flow_manager, const ParameterConstRef parameters)
 Constructor. More...
 
 ~HDLVarDeclFix () override
 Destructor. More...
 
DesignFlowStep_Status InternalExec () override
 Fixes the var_decl duplication. More...
 
- Public Member Functions inherited from VarDeclFix
 VarDeclFix (const application_managerRef AppM, unsigned int _function_id, const DesignFlowManagerConstRef design_flow_manager, const ParameterConstRef parameters, const FrontendFlowStepType frontend_flow_step_type=VAR_DECL_FIX)
 Constructor. More...
 
 ~VarDeclFix () override
 Destructor. More...
 
DesignFlowStep_Status InternalExec () override
 Fixes the var_decl duplication. More...
 
- Public Member Functions inherited from FunctionFrontendFlowStep
 FunctionFrontendFlowStep (const application_managerRef AppM, const unsigned int function_id, const FrontendFlowStepType frontend_flow_step_type, const DesignFlowManagerConstRef design_flow_manager, const ParameterConstRef parameters)
 Constructor. More...
 
 ~FunctionFrontendFlowStep () override
 Destructor. More...
 
void ComputeRelationships (DesignFlowStepSet &relationship, const DesignFlowStep::RelationshipType relationship_type) override
 Compute the relationships of a step with other steps. More...
 
std::string GetSignature () const override
 Return the signature of this step. More...
 
std::string GetName () const override
 Return the name of this design step. More...
 
DesignFlowStep_Status Exec () final
 Execute the step. More...
 
bool HasToBeExecuted () const override
 Check if this step has actually to be executed. More...
 
unsigned int CGetBBVersion () const
 
unsigned int GetBitValueVersion () const
 
void PrintInitialIR () const override
 Dump the initial intermediate representation. More...
 
void PrintFinalIR () const override
 Dump the final intermediate representation. More...
 
- Public Member Functions inherited from FrontendFlowStep
 FrontendFlowStep (const application_managerRef AppM, const FrontendFlowStepType frontend_flow_step_type, const DesignFlowManagerConstRef design_flow_manager, const ParameterConstRef parameters)
 Constructor. More...
 
 ~FrontendFlowStep () override
 Destructor. More...
 
virtual std::string GetKindText () const
 Return the name of the type of this frontend flow step. More...
 
DesignFlowStepFactoryConstRef CGetDesignFlowStepFactory () const override
 Return the factory to create this type of steps. More...
 
void PrintTreeManager (const bool before) const
 Dump the tree manager. More...
 
- Public Member Functions inherited from DesignFlowStep
 DesignFlowStep (const DesignFlowManagerConstRef design_flow_manager, const ParameterConstRef parameters)
 Constructor. More...
 
virtual ~DesignFlowStep ()
 Destructor. More...
 
virtual void Initialize ()
 Initialize the step (i.e., like a constructor, but executed just before exec. More...
 
DesignFlowStep_Status GetStatus () const
 Return the status of this design step. More...
 
virtual void WriteDot (std::ostream &out) const
 Write the label for a dot graph. More...
 
bool IsComposed () const
 Returns if this step is composed. More...
 
int CGetDebugLevel () const
 Return the debug level of the step. More...
 

Protected Member Functions

const std::string Normalize (const std::string &identifier) const override
 Return the normalized identifier; in this class it is the identifier itself. More...
 
- Protected Member Functions inherited from VarDeclFix
void recursive_examinate (const tree_nodeRef &tn, CustomUnorderedSet< unsigned int > &already_examinated_decls, CustomUnorderedSet< std::string > &already_examinated_names, CustomUnorderedSet< std::string > &already_examinated_type_names, CustomUnorderedSet< unsigned int > &already_visited_ae)
 Recursive examinate tree node. More...
 
const CustomUnorderedSet< std::pair< FrontendFlowStepType, FunctionRelationship > > ComputeFrontendRelationships (const DesignFlowStep::RelationshipType relationship_type) const override
 Return the set of analyses in relationship with this design step. More...
 
- Protected Member Functions inherited from FunctionFrontendFlowStep
void WriteBBGraphDot (const std::string &filename) const
 Write the current version of statement list in dot format. More...
 

Protected Attributes

const HDLWriter_Language hdl_writer_type
 The hdl language. More...
 
- Protected Attributes inherited from VarDeclFix
bool modified
 
- Protected Attributes inherited from FunctionFrontendFlowStep
const FunctionBehaviorRef function_behavior
 The function behavior of the function to be analyzed. More...
 
const unsigned int function_id
 The index of the function to be analyzed. More...
 
unsigned int bb_version
 The version of the basic block intermediate representation on which this step has been applied. More...
 
unsigned int bitvalue_version
 The version of the bitvalue information on which this step has been applied. More...
 
- Protected Attributes inherited from FrontendFlowStep
const application_managerRef AppM
 The application manager. More...
 
const FrontendFlowStepType frontend_flow_step_type
 The type of this step. More...
 
unsigned int print_counter
 Print counter. More...
 
- Protected Attributes inherited from DesignFlowStep
bool composed
 True if this step represents a composition of design flow steps (e.g., a flow); must be set by specialized constructors. More...
 
const Wrefcount< const DesignFlowManagerdesign_flow_manager
 The design flow manager. More...
 
const ParameterConstRef parameters
 Set of input parameters. More...
 
int debug_level
 The debug level. More...
 
const int output_level
 The output level. More...
 

Additional Inherited Members

- Public Types inherited from FrontendFlowStep
using FunctionRelationship = enum { ALL_FUNCTIONS, CALLED_FUNCTIONS, CALLING_FUNCTIONS, SAME_FUNCTION, WHOLE_APPLICATION }
 The different relationship type between function analysis. More...
 
- Public Types inherited from DesignFlowStep
enum  RelationshipType { DEPENDENCE_RELATIONSHIP, INVALIDATION_RELATIONSHIP, PRECEDENCE_RELATIONSHIP }
 The relationship type. More...
 
- Static Public Member Functions inherited from FunctionFrontendFlowStep
static const std::string ComputeSignature (const FrontendFlowStepType frontend_flow_step_type, const unsigned int function_id)
 Compute the signature of a function frontend flow step. More...
 
- Static Public Member Functions inherited from FrontendFlowStep
static void CreateSteps (const DesignFlowManagerConstRef design_flow_manager, const CustomUnorderedSet< std::pair< FrontendFlowStepType, FunctionRelationship >> &frontend_relationships, const application_managerConstRef application_manager, DesignFlowStepSet &relationships)
 Create the relationship steps of a step with other steps starting from already specified dependencies between frontend flow steps. More...
 
static const std::string EnumToKindText (const FrontendFlowStepType frontend_flow_step_type)
 Given a frontend flow step type, return the name of the type. More...
 

Detailed Description

Pre-analysis step.

It transforms the raw intermediate representation removing decl duplication (two decl_node with the same name in the same function) and hdl name conflicts (variable or parameters with same name of auxiliary signals

Definition at line 53 of file hdl_var_decl_fix.hpp.

Constructor & Destructor Documentation

◆ HDLVarDeclFix()

HDLVarDeclFix::HDLVarDeclFix ( const application_managerRef  AppM,
unsigned int  _function_id,
const DesignFlowManagerConstRef  design_flow_manager,
const ParameterConstRef  parameters 
)

Constructor.

Parameters
AppMis the application manager
fun_idis the function index
design_flow_manageris the design flow manager
parametersis the set of input parameters

Definition at line 57 of file hdl_var_decl_fix.cpp.

References DesignFlowStep::debug_level, DEBUG_LEVEL_NONE, GET_CLASS, DesignFlowStep::parameters, and ~HDLVarDeclFix().

Here is the call graph for this function:

◆ ~HDLVarDeclFix()

HDLVarDeclFix::~HDLVarDeclFix ( )
overridedefault

Destructor.

Referenced by HDLVarDeclFix().

Here is the caller graph for this function:

Member Function Documentation

◆ InternalExec()

DesignFlowStep_Status HDLVarDeclFix::InternalExec ( )
overridevirtual

Fixes the var_decl duplication.

Returns
the exit status of this step

Already considered decl_node

Already found variable and parameter names

Already found type names

Already visited address expression (used to avoid infinite recursion)

Preload backend names

a parameter cannot be named "this"

Add function name

Fixing names of parameters

Implements FunctionFrontendFlowStep.

Definition at line 67 of file hdl_var_decl_fix.cpp.

References FrontendFlowStep::AppM, test_panda::arg, language_writer::create_writer(), FunctionFrontendFlowStep::function_behavior, FunctionFrontendFlowStep::function_id, GET_NODE, tree_helper::GetMangledFunctionName(), tree_manager::GetTreeNode(), hdl_writer_type, VarDeclFix::InternalExec(), Normalize(), DesignFlowStep::parameters, VarDeclFix::recursive_examinate(), and THROW_ASSERT.

Here is the call graph for this function:

◆ Normalize()

const std::string HDLVarDeclFix::Normalize ( const std::string &  identifier) const
overrideprotectedvirtual

Return the normalized identifier; in this class it is the identifier itself.

Subclasses can specialize it

Parameters
identifieris the identifier to be normalized
Returns
the normalized identifier

Reimplemented from VarDeclFix.

Definition at line 142 of file hdl_var_decl_fix.cpp.

References hdl_writer_type, and VHDL.

Referenced by InternalExec().

Here is the caller graph for this function:

Field Documentation

◆ hdl_writer_type

const HDLWriter_Language HDLVarDeclFix::hdl_writer_type
protected

The hdl language.

Definition at line 57 of file hdl_var_decl_fix.hpp.

Referenced by InternalExec(), and Normalize().


The documentation for this class was generated from the following files:

Generated on Mon Feb 12 2024 13:03:54 for PandA-2024.02 by doxygen 1.8.13