summaryrefslogtreecommitdiff
path: root/quellcode/versuch5/Server.cpp
blob: 94afb5c7b1927bf6725d2de8ed9f1e5f83ebea06 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
#include <iostream>

#include "bench_i.h"

#include "orbsvcs/CosNamingC.h"
#include <tao/RTCORBA/RTCORBA.h>
#include "tao/RTCORBA/Network_Priority_Mapping_Manager.h"
#include "tao/RTCORBA/Network_Priority_Mapping.h"
#include "Custom_Network_Priority_Mapping.h"

RTCORBA::Priority corbaPriority = RTCORBA::minPriority;

int main(int argc, char* argv[]){

	struct sched_param schedparam; 
	schedparam.sched_priority = 99;

	if (sched_setscheduler(0, SCHED_FIFO, &schedparam) != 0) { 
	  fprintf(stderr, "%s: PID %d: sched_setscheduler() failed errno = %d\n", __FUNCTION__, getpid(), errno); 
	}

    try{
    // initialize ORB
	CORBA::ORB_var orb = CORBA::ORB_init(argc, argv, "ServerORB");
	std::cout<<"ORB initialized"<<std::endl;

	// Network priority mapping
	CORBA::Object_var netmapper = orb->resolve_initial_references("NetworkPriorityMappingManager");
	RTCORBA::NetworkPriorityMappingManager_var mappingManager = RTCORBA::NetworkPriorityMappingManager::_narrow( netmapper.in() );

    Custom_Network_Priority_Mapping *cnpm;
	cnpm = new Custom_Network_Priority_Mapping();

    cnpm->corba_priority(corbaPriority);
    mappingManager->mapping(cnpm);
	
	// access RT Extensions
	CORBA::Object_var rtorb = orb->resolve_initial_references("RTORB");
	RTCORBA::RTORB_var rtORB = RTCORBA::RTORB::_narrow(rtorb);
	std::cout<<"RT Extensions OK"<<std::endl;
	
    // Set transport protocol properties
    RTCORBA::TCPProtocolProperties_var tcpProperties = rtORB->create_tcp_protocol_properties (ACE_DEFAULT_MAX_SOCKET_BUFSIZ, ACE_DEFAULT_MAX_SOCKET_BUFSIZ, 1, 0, 1, 1 /*enable netw. priority*/);

    RTCORBA::ProtocolList protocols;
    protocols.length (1);
    protocols[0].protocol_type = 0;
    protocols[0].transport_protocol_properties = RTCORBA::ProtocolProperties::_duplicate (tcpProperties.in ());
    protocols[0].orb_protocol_properties = RTCORBA::ProtocolProperties::_nil ();

	// obtain rootPOA
	CORBA::Object_var poa = orb->resolve_initial_references("RootPOA");
	PortableServer::POA_var rootPOA = PortableServer::POA::_narrow(poa.in());

	// NameService
	CORBA::Object_var  namingObject = orb->resolve_initial_references("NameService");
	CosNaming::NamingContext_var namingContext = CosNaming::NamingContext::_narrow(namingObject.in());

	// activate POA Manager
	PortableServer::POAManager_var poaManager = rootPOA->the_POAManager();
	poaManager->activate();
	std::cout<<"rootPOA OK"<<std::endl;

	// create 2 lanes (message and port)
	CORBA::ULong TOTAL_LANES = 2;
	RTCORBA::ThreadpoolLanes lanes(TOTAL_LANES);
	lanes.length(TOTAL_LANES);

	// message lane
	lanes[0].static_threads = 1;
	lanes[0].dynamic_threads = 1;
	lanes[0].lane_priority = 0;

	// port lane
	lanes[1].static_threads = 1;
	lanes[1].dynamic_threads = 1;
	lanes[1].lane_priority = RTCORBA::maxPriority;

	// create threadpool
	RTCORBA::ThreadpoolId threadpool_id = rtORB->create_threadpool_with_lanes(0 /*Stacksize*/, lanes, 0 /*borrowing*/, 0 /*buffering*/, 0 /*maxBuf*/, 0 /*maxBufSize*/);

	// create Policy
	CORBA::PolicyList benchPolicy(3);
	benchPolicy.length(3);
	benchPolicy[0] = rtORB->create_priority_model_policy(RTCORBA::CLIENT_PROPAGATED, 0 /*default priority*/);
	benchPolicy[1] = rtORB->create_threadpool_policy(threadpool_id);
	benchPolicy[2] = rtORB->create_server_protocol_policy (protocols);

	// create ObjectAdapters, assign Policy
	PortableServer::POA_var msgAndPort1POA = rootPOA->create_POA("msgAndPort1POA", poaManager.in(), benchPolicy);
	PortableServer::POA_var msgAndPort2POA = rootPOA->create_POA("msgAndPort2POA", poaManager.in(), benchPolicy);
	PortableServer::POA_var msgOnlyPOA = rootPOA->create_POA("msgOnlyPOA", poaManager.in(), benchPolicy);

	// benchPolicy[0] = rtORB->create_priority_model_policy(RTCORBA::CLIENT_PROPAGATED, 0 /*default priority*/);

	PortableServer::POA_var portOnlyPOA = rootPOA->create_POA("portOnlyPOA", poaManager.in(), benchPolicy);
	std::cout<<"POAs created, Policies assigned"<<std::endl;

	// create the servants
	benchmark_msgAndPort1_i msgAndPort1_i(orb);
	benchmark_msgAndPort2_i msgAndPort2_i(orb);
	benchmark_msgOnly_i msgOnly_i(orb);
	benchmark_setPortsOnly_i portOnly_i(orb);

	// activate servants
	CosNaming::Name name(1);
	name.length(1);

	PortableServer::ObjectId_var objectID = msgAndPort1POA->activate_object(&msgAndPort1_i);
	CORBA::Object_var benchObj = msgAndPort1POA->id_to_reference(objectID.in());
	name[0].id = CORBA::string_dup("msgAndPort1");
	namingContext->bind(name, benchObj.in());

	objectID = msgAndPort2POA->activate_object(&msgAndPort2_i);
	benchObj = msgAndPort2POA->id_to_reference(objectID.in());
	name[0].id = CORBA::string_dup("msgAndPort2");
	namingContext->bind(name, benchObj.in());

	objectID = msgOnlyPOA->activate_object(&msgOnly_i);
	benchObj = msgOnlyPOA->id_to_reference(objectID.in());
	name[0].id = CORBA::string_dup("msgOnly");
	namingContext->bind(name, benchObj.in());

	objectID = portOnlyPOA->activate_object(&portOnly_i);
	benchObj = portOnlyPOA->id_to_reference(objectID.in());
	name[0].id = CORBA::string_dup("portOnly");
	namingContext->bind(name, benchObj.in());

	std::cout<<"Servants activated"<<std::endl;

	// start ORB
	orb->run();
	std::cout<<"ORB ready"<<std::endl;

	//destroy
	rootPOA->destroy(1,1);
	orb->destroy();
    }catch(CORBA::Exception &any){
    	std::cout<<"Exception: "<<any<<std::endl;
    }
    return 0;
}