summaryrefslogtreecommitdiffstats
path: root/views
diff options
context:
space:
mode:
Diffstat (limited to 'views')
-rw-r--r--views/CMakeLists.txt4
-rw-r--r--views/enum.c2
-rw-r--r--views/register.c65
-rw-r--r--views/register.h19
4 files changed, 87 insertions, 3 deletions
diff --git a/views/CMakeLists.txt b/views/CMakeLists.txt
index 646a982..0e0c20b 100644
--- a/views/CMakeLists.txt
+++ b/views/CMakeLists.txt
@@ -8,6 +8,6 @@ include_directories(
${UTHASH_INCLUDE_DIRS}
)
-set(HEADERS ${HEADERS} enum.h transform.h)
+set(HEADERS ${HEADERS} enum.h transform.h register.h)
-add_library(views STATIC enum.c transform.c)
+add_library(views STATIC enum.c transform.c register.c)
diff --git a/views/enum.c b/views/enum.c
index d712c71..e049c43 100644
--- a/views/enum.c
+++ b/views/enum.c
@@ -34,7 +34,7 @@ static int pcilib_enum_view_read(pcilib_t *ctx, pcilib_view_context_t *view_ctx,
return pcilib_set_value_from_static_string(ctx, val, v->names[i].name);
}
- return pcilib_set_value_from_int(ctx, val, regval);
+ return pcilib_set_value_from_register_value(ctx, val, regval);
}
static int pcilib_enum_view_write(pcilib_t *ctx, pcilib_view_context_t *view_ctx, pcilib_register_value_t *regval, const pcilib_value_t *val) {
diff --git a/views/register.c b/views/register.c
new file mode 100644
index 0000000..8256a4a
--- /dev/null
+++ b/views/register.c
@@ -0,0 +1,65 @@
+#define _PCILIB_VIEW_ENUM_C
+
+#include <stdio.h>
+#include <unistd.h>
+#include <stdlib.h>
+#include <string.h>
+#include <strings.h>
+
+#include <uthash.h>
+
+#include "error.h"
+#include "version.h"
+#include "model.h"
+#include "enum.h"
+#include "view.h"
+#include "value.h"
+#include "register.h"
+
+
+static void pcilib_register_view_free(pcilib_t *ctx, pcilib_view_description_t *view) {
+ if (view->name)
+ free((void*)view->name);
+ free(view);
+}
+
+static int pcilib_register_view_read(pcilib_t *ctx, pcilib_view_context_t *view_ctx, pcilib_register_value_t dummy, pcilib_value_t *val) {
+ int err;
+
+ const pcilib_model_description_t *model_info = pcilib_get_model_description(ctx);
+ pcilib_register_view_description_t *v = (pcilib_register_view_description_t*)(model_info->views[view_ctx->view]);
+
+ if (v->view) {
+ return pcilib_read_register_view(ctx, v->bank, v->reg, v->view, val);
+ } else {
+ pcilib_register_value_t regval;
+
+ err = pcilib_read_register(ctx, v->bank, v->reg, &regval);
+ if (err) return err;
+
+ return pcilib_set_value_from_register_value(ctx, val, regval);
+ }
+}
+
+static int pcilib_register_view_write(pcilib_t *ctx, pcilib_view_context_t *view_ctx, pcilib_register_value_t *dummy, const pcilib_value_t *val) {
+ int err;
+
+ const pcilib_model_description_t *model_info = pcilib_get_model_description(ctx);
+ pcilib_register_view_description_t *v = (pcilib_register_view_description_t*)(model_info->views[view_ctx->view]);
+
+ if (v->view) {
+ return pcilib_write_register_view(ctx, v->bank, v->reg, v->view, val);
+ } else {
+ pcilib_register_value_t regval;
+
+ regval = pcilib_get_value_as_register_value(ctx, val, &err);
+ if (err) return err;
+
+ return pcilib_write_register(ctx, v->bank, v->reg, regval);
+ }
+
+ return err;
+}
+
+const pcilib_view_api_description_t pcilib_register_view_api =
+ { PCILIB_VERSION, sizeof(pcilib_register_view_description_t), NULL, NULL, pcilib_register_view_free, pcilib_register_view_read, pcilib_register_view_write };
diff --git a/views/register.h b/views/register.h
new file mode 100644
index 0000000..e527846
--- /dev/null
+++ b/views/register.h
@@ -0,0 +1,19 @@
+#ifndef _PCILIB_VIEW_REGISTER_H
+#define _PCILIB_VIEW_REGISTER_H
+
+#include <pcilib.h>
+#include <pcilib/view.h>
+
+typedef struct {
+ pcilib_view_description_t base;
+ const char *view;
+ const char *reg;
+ const char *bank;
+} pcilib_register_view_description_t;
+
+
+#ifndef _PCILIB_VIEW_REGISTER_C
+extern const pcilib_view_api_description_t pcilib_register_view_api;
+#endif /* _PCILIB_VIEW_REGISTER_C */
+
+#endif /* _PCILIB_VIEW_REGISTER_H */