mars/mars_dummy.c
Thomas Schoebel-Theuer cf17986f8b import mars-10.tgz
2013-01-08 15:53:49 +01:00

156 lines
3.9 KiB
C

// (c) 2010 Thomas Schoebel-Theuer / 1&1 Internet AG
// Dummy brick (just for demonstration)
#include <linux/kernel.h>
#include <linux/module.h>
#include <linux/string.h>
#include "mars.h"
///////////////////////// own type definitions ////////////////////////
#include "mars_dummy.h"
////////////////// own brick / input / output operations //////////////////
static int dummy_io(struct dummy_output *output, struct mars_io_object *mio)
{
struct dummy_input *input = output->brick->inputs[0];
struct dummy_output *other;
if (unlikely(!input))
return -ENOSYS;
other = input->connect;
if (unlikely(!other || !other->ops || !other->ops->mars_io))
return -ENOSYS;
return other->ops->mars_io(other, mio);
}
static loff_t dummy_get_size(struct dummy_output *output)
{
struct dummy_input *input = output->brick->inputs[0];
struct dummy_output *other;
if (unlikely(!input))
return -ENOSYS;
other = input->connect;
if (unlikely(!other || !other->ops || !other->ops->mars_get_size))
return -ENOSYS;
return other->ops->mars_get_size(other);
}
//////////////// object / aspect constructors / destructors ///////////////
static int dummy_aspect_init_fn(struct mars_io_aspect *_ini, void *_init_data)
{
struct dummy_mars_io_aspect *ini = (void*)_ini;
ini->my_own = 0;
return 0;
}
static int dummy_make_object_layout(struct dummy_output *output, struct generic_object_layout *object_layout)
{
const struct generic_object_type *object_type = object_layout->type;
int res;
struct dummy_brick *brick = output->brick;
int i;
if (object_type != &mars_io_type)
return 0;
res = mars_io_add_aspect(object_layout, sizeof(struct dummy_mars_io_aspect), dummy_aspect_init_fn, output);
if (res < 0)
return res;
output->aspect_slot = res;
for (i = 0; i < brick->type->max_inputs; i++) {
struct dummy_input *input = brick->inputs[i];
if (input && input->connect) {
int subres = input->connect->ops->make_object_layout(input->connect, object_layout);
if (subres < 0)
return subres;
res += subres;
}
}
return res + sizeof(struct dummy_mars_io_aspect);
}
////////////////////// brick constructors / destructors ////////////////////
static int dummy_brick_construct(struct dummy_brick *brick)
{
brick->my_own = 0;
return 0;
}
static int dummy_output_construct(struct dummy_output *output)
{
output->my_own = 0;
return 0;
}
///////////////////////// static structs ////////////////////////
static struct dummy_brick_ops dummy_brick_ops = {
};
static struct dummy_output_ops dummy_output_ops = {
.make_object_layout = dummy_make_object_layout,
.mars_io = dummy_io,
.mars_get_size = dummy_get_size,
};
static struct dummy_input_type dummy_input_type = {
.type_name = "dummy_input",
.input_size = sizeof(struct dummy_input),
};
static struct dummy_input_type *dummy_input_types[] = {
&dummy_input_type,
};
static struct dummy_output_type dummy_output_type = {
.type_name = "dummy_output",
.output_size = sizeof(struct dummy_output),
.master_ops = &dummy_output_ops,
.output_construct = &dummy_output_construct,
};
static struct dummy_output_type *dummy_output_types[] = {
&dummy_output_type,
};
struct dummy_brick_type dummy_brick_type = {
.type_name = "dummy_brick",
.brick_size = sizeof(struct dummy_brick),
.max_inputs = 1,
.max_outputs = 1,
.master_ops = &dummy_brick_ops,
.default_input_types = dummy_input_types,
.default_output_types = dummy_output_types,
.brick_construct = &dummy_brick_construct,
};
EXPORT_SYMBOL_GPL(dummy_brick_type);
////////////////// module init stuff /////////////////////////
static int __init init_dummy(void)
{
printk(MARS_INFO "init_dummy()\n");
return dummy_register_brick_type();
}
static void __exit exit_dummy(void)
{
printk(MARS_INFO "exit_dummy()\n");
dummy_unregister_brick_type();
}
MODULE_DESCRIPTION("MARS dummy brick");
MODULE_AUTHOR("Thomas Schoebel-Theuer <tst@1und1.de>");
MODULE_LICENSE("GPL");
module_init(init_dummy);
module_exit(exit_dummy);