Move protocol-specific interface state into iface_t

This commit is contained in:
Matthias Schiffer 2013-07-29 02:11:08 +02:00
parent 37c2167874
commit b15c16f12c
7 changed files with 22 additions and 15 deletions

View file

@ -37,6 +37,7 @@
typedef struct gmrf gmrf_t;
typedef struct gmrf_context gmrf_context_t;
typedef struct gmrf_iface gmrf_iface_t;
typedef struct gmrf_iface_state gmrf_iface_state_t;
#define GMRF_ADDR_LEN 8
@ -68,7 +69,7 @@ size_t gmrf_iface_get_mtu(gmrf_t *gmrf, gmrf_iface_t *iface);
bool gmrf_iface_send(gmrf_t *gmrf, gmrf_iface_t *iface, const void *data, size_t len, const gmrf_addr_t *dest);
bool gmrf_iface_send_bc(gmrf_t *gmrf, gmrf_iface_t *iface, const void *data, size_t len);
typedef void (*gmrf_scheduled_func)(gmrf_t *gmrf, gmrf_context_t *ctx, void *arg);
typedef void (*gmrf_scheduled_func)(gmrf_context_t *ctx, void *arg);
void gmrf_schedule(gmrf_t *gmrf, gmrf_scheduled_func f, void *arg, unsigned delay);
@ -77,7 +78,7 @@ extern const char *gmrf_protocol_name;
extern const char *gmrf_protocol_version;
gmrf_context_t* gmrf_protocol_init(gmrf_t *gmrf);
void gmrf_protocol_add_iface(gmrf_t *gmrf, gmrf_context_t *ctx, gmrf_iface_t *iface);
void gmrf_protocol_handle_packet(gmrf_t *gmrf, gmrf_context_t *ctx, gmrf_iface_t *iface, const gmrf_addr_t *source, const void *data, size_t len);
gmrf_iface_state_t* gmrf_protocol_add_iface(gmrf_context_t *ctx, gmrf_iface_t *iface);
void gmrf_protocol_handle_packet(gmrf_context_t *ctx, gmrf_iface_state_t *iface, const gmrf_addr_t *source, const void *data, size_t len);
#endif /* _GMRF_GMRF_H_ */

View file

@ -35,8 +35,8 @@ typedef struct mmss_protocol {
const char* (*get_version)(void);
gmrf_context_t* (*init)(gmrf_t *gmrf);
void (*add_iface)(gmrf_t *gmrf, gmrf_context_t *ctx, gmrf_iface_t *iface);
void (*handle_packet)(gmrf_t *gmrf, gmrf_context_t *ctx, gmrf_iface_t *iface, const gmrf_addr_t *source, const void *data, size_t len);
gmrf_iface_state_t* (*add_iface)(gmrf_context_t *ctx, gmrf_iface_t *iface);
void (*handle_packet)(gmrf_context_t *ctx, gmrf_iface_state_t *iface, const gmrf_addr_t *source, const void *data, size_t len);
} mmss_protocol_t;
#endif /* _GMRF_MMSS_PROTOCOL_H_ */

View file

@ -105,7 +105,7 @@ void context_t::run(int argc, char *argv[]) {
int timeout = event_queue.timeout();
if (timeout < 0) {
fprintf(stderr, "nothing queued, deadlock occured.\n");
logf(LOG_ERR, "nothing queued, deadlock occured");
break;
}

View file

@ -38,7 +38,7 @@ std::shared_ptr<iface_t> iface_t::add(const std::shared_ptr<node_t> &node, const
std::shared_ptr<iface_t> iface = std::shared_ptr<iface_t>(new iface_t(node.get(), net.get(), name, address));
net->add_iface(iface);
node->add_iface(iface);
iface->state = node->add_iface(iface);
return iface;
}

View file

@ -42,6 +42,8 @@ private:
std::string name;
gmrf_addr_t address;
gmrf_iface_state *state;
void enqueue(context_t *mmss, const std::shared_ptr<iface_t> &dest, const void *data, size_t len);
iface_t(node_t *node0, network_t *net0, const std::string &name0, const gmrf_addr_t *address0)
@ -64,6 +66,10 @@ public:
return &address;
}
gmrf_iface_state* get_state() const {
return state;
}
void send(const void *data, size_t len, const gmrf_addr_t *dest) {
net->send(data, len, this, dest);
}

View file

@ -62,9 +62,9 @@ public:
return node;
}
void add_iface(const std::shared_ptr<iface_t> &iface) {
gmrf_iface_state_t* add_iface(const std::shared_ptr<iface_t> &iface) {
interfaces.insert(iface);
proto->add_iface(this, gmrf_ctx, iface.get());
return proto->add_iface(gmrf_ctx, iface.get());
}
context_t* get_context() const {
@ -80,11 +80,11 @@ public:
}
void handle_packet(const std::shared_ptr<iface_t> &iface, const gmrf_addr_t *source, const void *data, size_t len) {
proto->handle_packet(this, gmrf_ctx, iface.get(), source, data, len);
proto->handle_packet(gmrf_ctx, iface->get_state(), source, data, len);
}
void handle_scheduled(gmrf_scheduled_func f, void *arg) {
f(this, gmrf_ctx, arg);
f(gmrf_ctx, arg);
}
};

View file

@ -61,12 +61,12 @@ public:
return proto->init(gmrf);
}
void add_iface(gmrf_t *gmrf, gmrf_context_t *ctx, gmrf_iface_t *iface) const {
return proto->add_iface(gmrf, ctx, iface);
gmrf_iface_state_t* add_iface(gmrf_context_t *ctx, gmrf_iface_t *iface) const {
return proto->add_iface(ctx, iface);
}
void handle_packet(gmrf_t *gmrf, gmrf_context_t *ctx, gmrf_iface_t *iface, const gmrf_addr_t *source, const void *data, size_t len) const {
return proto->handle_packet(gmrf, ctx, iface, source, data, len);
void handle_packet(gmrf_context_t *ctx, gmrf_iface_state_t *iface, const gmrf_addr_t *source, const void *data, size_t len) const {
proto->handle_packet(ctx, iface, source, data, len);
}
static std::shared_ptr<const protocol_t> load(context_t *mmss, const std::string &module);