blob: 7ee8c297f2e5994b1a377a1dedbbedf136395e7c (
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
|
// -*- C++ -*-
#ifndef BIG_TWOWAYS_SESSION_H
#define BIG_TWOWAYS_SESSION_H
#include /**/ "ace/pre.h"
#include "TestS.h"
#include "Session_Task.h"
#if defined(ACE_HAS_THREADS)
# include "ace/Barrier.h"
#else
# include "ace/Null_Barrier.h"
#endif /* ACE_HAS_THREADS */
/// Implement the Test::Session interface
class Session
: public virtual POA_Test::Session
{
public:
/// Constructor
Session (Test::Session_Control_ptr control,
CORBA::ULong payload_size,
CORBA::ULong thread_count,
CORBA::ULong message_count,
CORBA::ULong peer_count);
/// Run one of the experiment threads
int svc (void);
// = The skeleton methods
virtual void start (const Test::Session_List &other_sessions);
virtual Test::Payload* echo_payload (const Test::Payload &the_payload);
virtual void destroy (void);
protected:
/// Protected destructor, call _remove_ref() to delete
virtual ~Session (void);
private:
/// Helper function used to report any problems and destroy local
/// resources
void terminate (CORBA::Boolean success);
/// Return 1 if all the work in this session has been completed
int more_work () const;
/// Validate all the connections
void validate_connections (void);
private:
/// Synchronize the internal state
TAO_SYNCH_MUTEX mutex_;
/// Keep a reference to the Session_Control, this is used to report
/// when the test finishes.
Test::Session_Control_var control_;
/// Keep track of wether the test is running.
int running_;
/// The other session objects participating in the test
Test::Session_List other_sessions_;
/// Size of each message
CORBA::ULong payload_size_;
/// Number of threads
CORBA::ULong thread_count_;
/// Number of messages to send
CORBA::ULong message_count_;
/// The number of threads currently running, when this reaches 0 the
/// session destroys itself.
CORBA::ULong active_thread_count_;
/// Number of messages expected
CORBA::ULong expected_messages_;
/// Helper class to run svc() in a separate thread
Session_Task task_;
/// Barrier to start all threads simultaenously
#if defined(ACE_HAS_THREADS)
typedef ACE_Thread_Barrier Barrier;
#else
typedef ACE_Null_Barrier Barrier;
#endif /* ACE_HAS_THREADS */
Barrier barrier_;
};
#include /**/ "ace/post.h"
#endif /* BIG_TWOWAYS_SESSION_H */
|