dynamic plugin in c++

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



hi,

i am writing a dynamic plugin,


however, sometimes it run succesfully and sometimes it give following error:

/home/avantika/Downloads/gcc/gccpackage/install/bin/g++ -o result -flto -fplugin=./plugin.so test1.o -O3 -fdump-ipa-all
In function ‘main’:
lto1: internal compiler error: in rebuild_frequencies, at predict.c:2396
Please submit a full bug report,
with preprocessed source if appropriate.
See <http://gcc.gnu.org/bugs.html> for instructions.
lto-wrapper: /home/avantika/Downloads/gcc/gccpackage/install/bin/g++ returned 1 exit status
/usr/bin/ld: lto-wrapper failed
collect2: error: ld returned 1 exit status
make: *** [test] Error 1


code : following are the name of files constraint.cpp, dataflow.cpp , constraint.hpp, dataflow.hpp;

the main file named pointo-callstring.c includes both the hpp files, and is defining some object and class map.

i have attached the files.
#include "constraint.hpp"

using namespace std;
	
namespace con{
// ============constraint=============

	constraint::constraint(int a, type b)
	{
	var=a;
	t=b;
	}

	constraint::constraint(constraint const &ob)
	{
	var=ob.var;
	t=ob.t;
	}

	int constraint::get_var()
	{
	return var;
	}

	type constraint::get_type()
	{
	return t;
	}

	bool operator<(constraint const &ob1, constraint const &ob2)
	{
	if(ob1.var < ob2.var) return true;
	if(ob1.t < ob2.t) return true;
	return false;
	}	
	
	
// ==============constraint_pair===========================

		
			
	constraint_pair::constraint_pair(constraint * a, constraint * b, bool is)
	{
	lhs=a;
	rhs=b;
	is_alias=is;
	livevar=-1;
	}
	
	constraint_pair::constraint_pair(int a, bool is)
	{
	livevar=a;
	is_alias=is;
	lhs=NULL;
	rhs=NULL;
	}
	
	constraint_pair::constraint_pair(constraint_pair const & ob)
	{
	livevar=ob.livevar;
	is_alias=ob.is_alias;
	lhs=ob.lhs;
	rhs=ob.rhs;	
	}
	
	constraint * constraint_pair::get_lhs()
	{
	return lhs;	
	}
	
	constraint * constraint_pair::get_rhs()
	{
	return rhs;	
	}
	
	bool constraint_pair::alias()
	{
	return is_alias;	
	}
	 
	int constraint_pair::get_livevar()
	{
	return livevar;	
	}
	
	int constraint_pair::lhs_var()
	{
	return lhs->var;	
	}
	
	int constraint_pair::rhs_var()
	{
	return rhs->var;	
	}
	
	type constraint_pair::lhs_type()
	{
	return lhs->t;	
	}
	
	type constraint_pair::rhs_type()
	{
	return rhs->t;	
	}
	
	bool operator<(constraint_pair const & ob1, constraint_pair const & ob2)
	{
	if(*(ob1.lhs)<*(ob2.lhs)) return true;
	if(*(ob1.rhs)<*(ob2.rhs)) return true;
	if(ob1.is_alias<ob2.is_alias) return true;
	if(ob1.livevar<ob2.livevar) return true;
	return false;
	}


// ================constraint_list============
	
	bool constraint_list::empty()
		{
		return my.empty();
		}
		
	void constraint_list::push(constraint_pair * a)
		{
		my.push_back(a);
		}
		
	constraint_pair * constraint_list::front()
		{
		return my.front();	
		}
	
	constraint_pair * constraint_list::back()
		{
		return my.back();	
		}
	
	it constraint_list::begin()
		{
		present = my.begin();
		return my.begin();
		}
		
	it constraint_list::end()
		{
		present = my.end();
		return my.end();
		}
	
}

/*int main()
{

con::constraint c(2,con::DEREF);
con::constraint d(3,con::SCALAR);
cout<<c.get_var();
map<con::constraint,con::constraint *> my;
my[c]= &c;
cout<<endl<<my.at(c)->get_var()<<endl;
con::constraint_pair s(&c,&d,1);
cout<<s.lhs_var();
}*/
#ifndef CONSTRAINT_H
#define	CONSTRAINT_H

#include<map>
#include<iostream>
#include<cstring>
#include<list>

using namespace std;

namespace con {

	typedef enum type{	
		SCALAR,DEREF,ADDOF,
		}type;

// =============constraint=================

	class constraint {
		
		int var;
		type t;
		
		public:

			constraint(int a, type b);
			constraint(constraint const &);
			int get_var();
			type get_type();
			void set_var(int a){var =a;}
			friend bool operator<(constraint const &, constraint const &);

			friend class constraint_pair;
			friend class constraint_list;

		};

// ===============constraint pair========================

	class constraint_pair {
		
		constraint *lhs;
		constraint *rhs;
		bool is_alias;
		int livevar;

		public:
			constraint_pair(constraint *, constraint *, bool);
			constraint_pair(int,bool);
			constraint_pair(constraint_pair const &);
			constraint * get_lhs();
			constraint * get_rhs();
			bool alias();
			int get_livevar();
			int lhs_var();
			int rhs_var();
			type lhs_type();
			type rhs_type();
			friend bool operator<(constraint const & , constraint const &);
			friend bool operator<(constraint_pair const &, constraint_pair const &);
			
		friend class constraint_list;
	};
	
	
	typedef list<constraint_pair *>::iterator it;
	
// ================constraint_list============
	
	class constraint_list{
	
		list<constraint_pair *> my;
		list<constraint_pair *>::iterator present;
	
			public:
				constraint_list() {}
				bool empty();
				void push(constraint_pair *);
				constraint_pair * front();
				constraint_pair * back();	
				it begin();
				it end();
	};
	
}

#endif
#ifndef DATAFLOW_H
#define DATAFLOW_H

#include<map>
#include<utility>
#include<iostream>

using namespace std;

namespace data{
	
//=======liveness============
	
	class liveness{
	
	string *live;
	
	public:
		liveness(int);
		string get_live();
		friend bool operator<(liveness const &, liveness const &);
		bool is_live(int);
		void make_live(int); 
		void kill_live(int); 
		
	};
	
//=======pointsto============

	/*typedef enum pointinfo {
		NOTPOINTS=0,POINTS=1,UNDEF=2,NOINFO=3
	}type;*/
	
	class pointsto{
		
		int lhs;
		int size;
		string *rhs;
		
		public:
			pointsto(int,int);
			int get_lhs();
			string get_rhs();
			bool is_must();
			bool is_may();
			bool is_noinfo();
			bool is_undef();
			void set(int);
			void unset(int);
			void set_undef();
			void set_noinfo();
			bool is_pointsto(int); // if this integer in pointsto set of lhs
			friend bool operator<(pointsto const &, pointsto const &);
			
			
	};

	
}

#endif

#include"dataflow.hpp"

using namespace std;

namespace data{
	
//=======liveness============

	liveness::liveness(int s)
	{
	live= new string(s,'0');
	}
	
	string  liveness::get_live()
	{
	return *live;	
	}
	
	bool operator<(liveness const & ob1, liveness const & ob2)
	{
	 if(((*(ob1.live)).compare(*(ob2.live)))<0) return true;		
	return false;
	}
	
	bool liveness::is_live(int a)
	{
	if(((*live)[a])=='0') return false;
	return true;
	}
	
	void liveness::make_live(int a)
	{
	(*live)[a]='1';	
	}
	
	void liveness::kill_live(int a)
	{
	(*live)[a]='0';	
	}
		
		
//=======pointsto============

	pointsto::pointsto(int l,int s)
	{
	lhs=l;
	size=s;
	rhs = new string(s,'3');
	}
	
	int pointsto::get_lhs()
	{
	return lhs;
	}
	
	string  pointsto::get_rhs()
	{
	return *rhs;
	}
	
	bool pointsto::is_must()
	{
	if(!is_noinfo() && !is_undef())
		{
		if(!is_may()) return true;
		}
	return false;
	}
	
	bool pointsto::is_may()
	{
	if(!is_noinfo() && !is_undef())
		{
		int count=0;
		for(int i=0;i<size;i++)
			{
			if((*rhs)[i] == '1') count++;
			if(count>1) return true;
			}
		}
		return false;
	}
	
	bool pointsto::is_noinfo()
	{
	string n(size,'3');
	if((*rhs).compare(n)==0) return true;
	return false;  //compare returns 0 when equal
	}
	
	bool pointsto::is_undef()
	{
	string n(size,'2');
	if((*rhs).compare(n)==0) return true;
	return false;	
	}
	
	void pointsto::set(int a)
	{
	(*rhs)[a]='1';
	}
	
	void pointsto::unset(int a)
	{
	(*rhs)[a]='0';	
	}
	
	void pointsto::set_undef()
	{
	rhs= new string(size,'2');
	}
	
	void pointsto::set_noinfo()
	{
	rhs= new string(size,'3');	
	}
	
	bool pointsto::is_pointsto(int a)
	{
	return ((*rhs)[a]==1);	
	}
	
	bool operator<(pointsto const & ob1, pointsto const & ob2)
	{
	if(ob1.lhs < ob2.lhs) return true;
	if(ob1.size < ob2.size) return true;
	if(((*(ob1.rhs)).compare(*(ob2.rhs)))<0) return true;
	return false;
	}
	
}

int main()
{
data::liveness l(4);
cout<<(l.get_live())<<endl;
l.make_live(2);
cout<<(l.get_live());
cout<<l.is_live(2);
map<data::liveness,data::liveness *> my;
my[l]=&l;
}
#include "gcc-plugin.h"
#include "config.h"
#include "system.h"
#include "cgraph.h"
#include "coretypes.h"
#include "tm.h"
#include "tree.h"
#include "tree-flow.h"
#include "diagnostic.h"
#include "tree-pass.h"
#include "timevar.h"
#include "alloc-pool.h"
#include "params.h"
#include "ggc.h"
#include "vec.h"
#include "gimple-pretty-print.h"

#include"constraint.hpp"
#include"dataflow.hpp"

//#define alloc_mem ggc_alloc_cleared_atomic 
using namespace std;
/*-----------------------------------------------------------------------------
 *  Each plugin MUST define this global int to assert compatibility with GPL; 
 *  else the compiler throws a fatal error 
 *-----------------------------------------------------------------------------*/
int plugin_is_GPL_compatible;  
//using namespace std;

/* -----------------------------------------
   Return: true if we should execute IPA PTA.
   ----------------------------------------*/
/*static bool
gate_ipacs (void)
{
   return (flag_ipacs && !(errorcount || sorrycount));
}*/

/* -------------------------------
   The callstrings pointsto pass. 
   ------------------------------*/

static unsigned int
execute_ipacs (void)
{
con::constraint c(2,con::DEREF);
cout<<c.get_var();
map<con::constraint, con::constraint *> my;
my[c]= &c;
fprintf(dump_file,"\njhgiocsud==========\n");
//struct cgraph_node *cnode;
}

struct simple_ipa_opt_pass pass_ipacs =
{
  {
    SIMPLE_IPA_PASS,
    "lfcpa",                                /* name */
    NULL,	                            /* gate */
    execute_ipacs,		            /* execute */
    NULL,                                   /* sub */
    NULL,                                   /* next */
    0,                                      /* static_pass_number */
    TV_INTEGRATION,                         /* tv_id */
    0,                                      /* properties_required */
    0,                                      /* properties_provided */
    0,                                      /* properties_destroyed */
    0,                                      /* todo_flags_start */
    0                                       /* todo_flags_finish */
  }
};
struct register_pass_info pass_info = 
{
	&(pass_ipacs.pass),
	"pta",
	0,
	PASS_POS_INSERT_AFTER
};
int plugin_init(struct plugin_name_args *plugin_info, struct plugin_gcc_version *version)
{
	register_callback(
		plugin_info->base_name,
		PLUGIN_PASS_MANAGER_SETUP,
		NULL,
		&pass_info);
	return 0;
}

#------ MAKE CHANGES TO BASE_DIR : Please put the path to base directory of your pristine gcc-4.7.2 build -----------#
BASE_DIR = /home/avantika/Downloads/gcc/gccpackage

INSTALL = $(BASE_DIR)/install
CC = $(INSTALL)/bin/g++
NEW_PATH = $(BASE_DIR)/gcc-4.7.2/gcc

#----- MAKE CHANGES TO OBJS : Add the name of your test file with extension .o (say test as test.o) --------#
#------------------------------- Multiple dependent files maybe also be added ------------------------------#
OBJS = test1.o

GCCPLUGINS_DIR:= $(shell $(CC) -print-file-name=plugin)
INCLUDE= -I$(GCCPLUGINS_DIR)/include -I$(NEW_PATH)

FLAGS= -fPIC -O0 -flto -flto-partition=none


%.o : %.c
	$(CC) $(FLAGS) $(INCLUDE) -c $< 

%.o : %.cpp
	$(CC) $(FLAGS) $(INCLUDE) -c $< 

plugin.so: pointsto-callstrings.o constraint.o dataflow.o
	$(CC) $(INCLUDE) $(FLAGS) -shared $^ -o $@

test:  $(OBJS) plugin.so
	$(CC) -o result -flto  -fplugin=./plugin.so $(OBJS) -O3 -fdump-ipa-all 
#test:   plugin.so
#	$(CC) -c -flto -flto-partition=none -fplugin=./plugin.so function-pointer.c -O0 -fdump-ipa-all 

clean:
	\rm -f plugin.so *~ *.o a.out result* *.cpp.*



[Index of Archives]     [Linux C Programming]     [Linux Kernel]     [eCos]     [Fedora Development]     [Fedora Announce]     [Autoconf]     [The DWARVES Debugging Tools]     [Yosemite Campsites]     [Yosemite News]     [Linux GCC]

  Powered by Linux