*** empty log message ***
[charm.git] / src / conv-com / convcomlibmanager.C
1 /* Converse ComlibManager 
2    Enables communication library strategies to be called from converse code.
3    Also called by the Charm Comlibmanager.
4    
5    Stores a strategy table. Strategies can be inserted and accessed
6    from this table.
7
8    Sameer Kumar 28/03/04
9 */
10
11 #include "convcomlibmanager.h"
12 #include "routerstrategy.h"
13
14 int comm_debug;
15
16 CkpvDeclare(ConvComlibManager *, conv_comm_ptr);
17 CkpvDeclare(int, RecvdummyHandle);
18 CkpvExtern(int, RecvmsgHandle);
19 CkpvExtern(int, RecvCombinedShortMsgHdlrIdx);
20
21
22 ConvComlibManager::ConvComlibManager(): strategyTable(10){
23     nstrats = 0;
24 }
25
26 void ConvComlibManager::insertStrategy(Strategy *s) {
27     StrategyTableEntry &st = strategyTable[nstrats];
28     st.strategy = s;
29
30     s->setInstance(nstrats);
31     nstrats ++;
32 }
33
34
35 void ConvComlibManager::insertStrategy(Strategy *s, int loc) {
36
37     //For now allow insertion of any location    
38     StrategyTableEntry &st = strategyTable[loc];
39
40     st.strategy = s;
41 }
42
43 //handler for dummy messages
44 void recv_dummy(void *msg){
45     ComlibPrintf("Received Dummy %d\n", CmiMyPe());    
46     CmiFree(msg);
47 }
48
49
50 //An initialization routine which does prelimnary initialization of the 
51 //Converse commlib manager. Currently also initialized krishnans code
52 void initComlibManager(){ 
53     ConvComlibManager *conv_com = new ConvComlibManager();
54     
55     CkpvInitialize(ConvComlibManager *, conv_comm_ptr);
56     CkpvAccess(conv_comm_ptr) = conv_com;
57
58     //comm_debug = 1;
59     ComlibPrintf("Init Call\n");
60
61     CkpvInitialize(int, RecvmsgHandle);
62     CkpvInitialize(int, RecvCombinedShortMsgHdlrIdx);
63     
64     CkpvInitialize(int, RecvdummyHandle);
65     CkpvAccess(RecvdummyHandle) = CkRegisterHandler((CmiHandler)recv_dummy);
66
67     PUPable_reg(Strategy);
68     PUPable_reg(RouterStrategy);
69     PUPable_reg(MessageHolder);
70 }
71  
72 Strategy *ConvComlibGetStrategy(int loc) {
73     //Calling converse strategy lets Charm++ strategies one strategy
74     //table entry but multiple layers of strategies (Charm on top of Converse).
75     return (CkpvAccess(conv_comm_ptr))->getStrategy(loc)->getConverseStrategy();
76 }
77
78 void ConvComlibRegisterStrategy(Strategy *s) {
79     (CkpvAccess(conv_comm_ptr))->insertStrategy(s);    
80 }