author | Tero Marttila <terom@fixme.fi> |
Sat, 07 Jun 2008 05:05:18 +0300 | |
changeset 13 | ee426f453cf5 |
parent 9 | fb6632e6c1bb |
child 26 | 6d615203d963 |
permissions | -rw-r--r-- |
9
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
1 |
#ifndef REMOTE_NODE_H |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
2 |
#define REMOTE_NODE_H |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
3 |
|
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
4 |
#include <sys/socket.h> |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
5 |
|
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
6 |
/* |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
7 |
* Information about a single remote render node. |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
8 |
*/ |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
9 |
|
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
10 |
struct remote_node { |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
11 |
int valid; |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
12 |
|
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
13 |
/* |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
14 |
* Static information |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
15 |
*/ |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
16 |
|
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
17 |
// the remote address, note how this can both AF_INET and AF_LOCAL |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
18 |
struct sockaddr_storage addr; |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
19 |
|
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
20 |
// how many render requests this node can process concurrently |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
21 |
int parallel_renders; |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
22 |
|
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
23 |
/* |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
24 |
* Dynamic information |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
25 |
*/ |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
26 |
|
13
ee426f453cf5
* fix some (of the) stupid things in Makefile
Tero Marttila <terom@fixme.fi>
parents:
9
diff
changeset
|
27 |
// an estimate of how many render requests this node is currently processing |
9
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
28 |
int current_load; |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
29 |
}; |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
30 |
|
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
31 |
/* |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
32 |
* Initialize the given remote_node struct to work with the render node at the given host/port. |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
33 |
* |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
34 |
* Portname may also be NULL, in which case the default port is used. |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
35 |
* |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
36 |
* Note that this is a blocking function, and should only be called at startup. |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
37 |
* |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
38 |
* returns nonzero on error, zero on success. |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
39 |
*/ |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
40 |
int remote_node_init (struct remote_node *node_info, const char *hostname, const char *portname); |
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
41 |
|
fb6632e6c1bb
two new modules, remote_node and remote_pool
Tero Marttila <terom@fixme.fi>
parents:
diff
changeset
|
42 |
#endif /* REMOTE_NODE_H */ |