mars/mars_client.h

57 lines
1.0 KiB
C
Raw Normal View History

2011-02-23 20:48:06 +00:00
// (c) 2010 Thomas Schoebel-Theuer / 1&1 Internet AG
#ifndef MARS_CLIENT_H
#define MARS_CLIENT_H
#include "mars_net.h"
2011-03-30 12:02:50 +00:00
#define CLIENT_HASH_MAX 256
2011-02-23 20:48:06 +00:00
struct client_mref_aspect {
GENERIC_ASPECT(mref);
struct list_head io_head;
2011-03-30 12:02:50 +00:00
struct list_head hash_head;
2011-02-23 20:48:06 +00:00
bool do_dealloc;
};
struct client_brick {
MARS_BRICK(client);
2011-03-29 14:40:40 +00:00
// tunables
int max_flying; // limit on parallelism
2011-02-23 20:48:06 +00:00
};
struct client_input {
MARS_INPUT(client);
};
struct client_threadinfo {
struct task_struct *thread;
2011-03-03 18:23:34 +00:00
wait_queue_head_t run_event;
2011-05-26 14:32:32 +00:00
int restart_count;
2011-03-03 18:23:34 +00:00
bool terminated;
2011-02-23 20:48:06 +00:00
};
struct client_output {
MARS_OUTPUT(client);
2011-03-29 14:40:40 +00:00
atomic_t fly_count;
2011-02-23 20:48:06 +00:00
spinlock_t lock;
struct list_head mref_list;
struct list_head wait_list;
wait_queue_head_t event;
int last_id;
2011-08-31 11:42:04 +00:00
struct mars_socket *socket;
2011-02-23 20:48:06 +00:00
char *host;
char *path;
struct client_threadinfo sender;
struct client_threadinfo receiver;
struct mars_info info;
wait_queue_head_t info_event;
2011-03-07 05:55:10 +00:00
bool get_info;
2011-02-23 20:48:06 +00:00
bool got_info;
2011-03-30 12:02:50 +00:00
spinlock_t hash_lock[CLIENT_HASH_MAX];
struct list_head hash_table[CLIENT_HASH_MAX];
2011-02-23 20:48:06 +00:00
};
MARS_TYPES(client);
#endif